FIX: distinguish between scroll and drag for sidebar (#22794)
Change to drag move event handling. When position of mouse changed, we can assume it is not drag and drop, and we should keep default behaviour. Otherwise, we stop propagation of the event to handle drag and drop correctly. s
This commit is contained in:
parent
44a104dff8
commit
6e3da7c07d
|
@ -82,10 +82,24 @@ export default class SectionLink {
|
||||||
|
|
||||||
@bind
|
@bind
|
||||||
dragMove(event) {
|
dragMove(event) {
|
||||||
this.startMouseY = this.#calcMouseY(event);
|
const moveMouseY = this.#calcMouseY(event);
|
||||||
|
|
||||||
event.stopPropagation();
|
if (this.willDrag && moveMouseY !== this.startMouseY && !this.drag) {
|
||||||
event.preventDefault();
|
/**
|
||||||
|
* If mouse position is different, it means that it is a scroll and not drag and drop action.
|
||||||
|
* In that case, we want to do nothing and keep original behaviour.
|
||||||
|
*/
|
||||||
|
this.willDrag = false;
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
/**
|
||||||
|
* Otherwise, event propagation should be stopped as we have our own handler for drag and drop.
|
||||||
|
*/
|
||||||
|
event.stopPropagation();
|
||||||
|
event.preventDefault();
|
||||||
|
}
|
||||||
|
|
||||||
|
this.startMouseY = moveMouseY;
|
||||||
|
|
||||||
if (!this.drag) {
|
if (!this.drag) {
|
||||||
return;
|
return;
|
||||||
|
|
Loading…
Reference in New Issue