Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Moving elements beyond the border of a pool is possible when moving it outside the viewport #2210

Open
StefanLerch opened this issue Jul 31, 2024 · 7 comments
Labels
backlog Queued in backlog bug Something isn't working good first issue Good for newcomers pr welcome We rely on a community contribution to improve this. spring cleaning Could be cleaned up one day

Comments

@StefanLerch
Copy link

Describe the Bug

Restricting the movement of an element inside the "RulesProvider" module can be bypassed by moving an element outside the viewport. With this, it is for example possible to stack pools on top of each other, see GIF.

Steps to Reproduce

  1. Create a new model with two pools
  2. Moving the pools on top of each other does not work
  3. Move the viewport so that one pool is barely visible
  4. Now move the second pool beyond the viewport, on top of the other pool
  5. The pool can be dropped, even though it is normally not possible

Result: The pools can be stacked on top of each other.

Or:

  1. Create a new model with a pool
  2. Create a Startevent inside of it
  3. Try to move the element outside the pool's border
  4. Now move the element beyond the viewport

chrome_SU1NUSx2UP

Result: The element is moved to the position. Even though the pool increases its size afterward to contain the element, I would still argue that this is not intended behavior because moving the element beyond the border of the pool is otherwise restricted.

Expected Behavior

The current viewport should be considered when moving elements. Locally, I could fix this by preventing any movement beyond it. In the case provided above, I would expect, that I am unable to move the element beyond the viewport. The pool should only increase in size if I drop the element close to the edge of the pool, but not far beyond its borders.

Environment

  • Browser: Chrome v127.0.6533.73
  • OS: Windows 11 Enterprise
  • Library version: 17.6.4, als [e.g. 2.0.0] demo.bpmn.io
@StefanLerch StefanLerch added the bug Something isn't working label Jul 31, 2024
@barmac
Copy link
Member

barmac commented Aug 2, 2024

Thanks for reporting this.

I've tested a similar interaction in Excalidraw and Miro, and both of them allow to move the element past the viewport if one
is fast enough.

The problem of extending the participant by far via this trick looks like a bug to me as well. I wouldn't deem it critical though.

@barmac barmac added good first issue Good for newcomers pr welcome We rely on a community contribution to improve this. backlog Queued in backlog spring cleaning Could be cleaned up one day labels Aug 2, 2024
@Adam-Thometz
Copy link

I could pick this one up

@Adam-Thometz
Copy link

I already came up with a fix I just need permission to push my branch

@nikku
Copy link
Member

nikku commented Oct 6, 2024

Please propose your changes through a pull request.

@Adam-Thometz
Copy link

I tried doing that but I have to push my branch and I get a 403 when I try to do that

@barmac
Copy link
Member

barmac commented Oct 7, 2024

You will need to fork the repository, and create a PR from your fork: https://docs.github.com/en/get-started/exploring-projects-on-github/contributing-to-a-project

@Adam-Thometz
Copy link

Just made a PR. Thanks guys, I'm new to open source

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
backlog Queued in backlog bug Something isn't working good first issue Good for newcomers pr welcome We rely on a community contribution to improve this. spring cleaning Could be cleaned up one day
Projects
None yet
Development

No branches or pull requests

4 participants