mirror of
https://github.com/konvajs/konva.git
synced 2025-04-05 20:48:28 +08:00
stop triggering click and tap on short drag&drop. fix #784
This commit is contained in:
parent
680ea026d8
commit
67d5e362e8
4
konva.min.js
vendored
4
konva.min.js
vendored
File diff suppressed because one or more lines are too long
@ -109,7 +109,8 @@ export const DD = {
|
||||
return;
|
||||
}
|
||||
|
||||
if (elem.dragStatus === 'dragging') {
|
||||
if (elem.dragStatus === 'dragging' || elem.dragStatus === 'stopped') {
|
||||
// if a node is stopped manully we still need to reset events:
|
||||
DD.justDragged = true;
|
||||
Konva.listenClickTap = false;
|
||||
elem.dragStatus = 'stopped';
|
||||
|
@ -546,6 +546,7 @@ export class Stage extends Container<BaseLayer> {
|
||||
var pointerId = Util._getFirstPointerId(evt);
|
||||
var shape = this.getIntersection(this.getPointerPosition());
|
||||
|
||||
DD.justDragged = false;
|
||||
Konva.listenClickTap = true;
|
||||
|
||||
if (shape && shape.isListening()) {
|
||||
@ -590,8 +591,6 @@ export class Stage extends Container<BaseLayer> {
|
||||
// don't set inDblClickWindow after dragging
|
||||
Konva.inDblClickWindow = true;
|
||||
clearTimeout(this.dblTimeout);
|
||||
} else if (DD) {
|
||||
DD.justDragged = false;
|
||||
}
|
||||
|
||||
this.dblTimeout = setTimeout(function() {
|
||||
@ -677,6 +676,7 @@ export class Stage extends Container<BaseLayer> {
|
||||
this._changedPointerPositions.forEach(pos => {
|
||||
var shape = this.getIntersection(pos);
|
||||
Konva.listenClickTap = true;
|
||||
DD.justDragged = false;
|
||||
const hasShape = shape && shape.isListening();
|
||||
|
||||
if (!hasShape) {
|
||||
|
@ -475,7 +475,7 @@ suite('DragAndDropEvents', function() {
|
||||
}, 20);
|
||||
});
|
||||
|
||||
test('drag events should not trigger on a click', function() {
|
||||
test('click should not start drag&drop', function() {
|
||||
var stage = addStage();
|
||||
var layer = new Konva.Layer({
|
||||
draggable: true
|
||||
@ -522,4 +522,105 @@ suite('DragAndDropEvents', function() {
|
||||
assert.equal(dragmove, 0, 'dragmove not triggered');
|
||||
assert.equal(dragend, 0, 'dragend not triggered');
|
||||
});
|
||||
|
||||
|
||||
test('drag&drop should not fire click', function() {
|
||||
var stage = addStage();
|
||||
var layer = new Konva.Layer({
|
||||
draggable: true
|
||||
});
|
||||
|
||||
var circle = new Konva.Circle({
|
||||
x: 70,
|
||||
y: 70,
|
||||
radius: 70,
|
||||
fill: 'green',
|
||||
stroke: 'black',
|
||||
strokeWidth: 4,
|
||||
name: 'myCircle',
|
||||
draggable: true
|
||||
});
|
||||
|
||||
layer.add(circle);
|
||||
stage.add(layer);
|
||||
|
||||
var dragstart = 0;
|
||||
circle.on('dragstart', function() {
|
||||
dragstart += 1;
|
||||
});
|
||||
|
||||
var dragmove = 0;
|
||||
circle.on('dragmove', function() {
|
||||
dragmove += 1;
|
||||
});
|
||||
|
||||
var dragend = 0;
|
||||
circle.on('dragend', function() {
|
||||
dragend += 1;
|
||||
});
|
||||
|
||||
var click = 0;
|
||||
circle.on('click', function() {
|
||||
click += 1;
|
||||
});
|
||||
stage.simulateMouseDown({ x: 70, y: 70 });
|
||||
stage.simulateMouseMove({ x: 80, y: 80 });
|
||||
stage.simulateMouseUp({ x: 80, y: 80 });
|
||||
|
||||
assert.equal(click, 0, 'click triggered');
|
||||
assert.equal(dragstart, 1, 'dragstart not triggered');
|
||||
assert.equal(dragmove, 1, 'dragmove not triggered');
|
||||
assert.equal(dragend, 1, 'dragend not triggered');
|
||||
});
|
||||
|
||||
|
||||
test('drag events should not trigger on a click even if we stop drag on dragstart', function() {
|
||||
var stage = addStage();
|
||||
var layer = new Konva.Layer({
|
||||
draggable: true
|
||||
});
|
||||
|
||||
var circle = new Konva.Circle({
|
||||
x: 70,
|
||||
y: 70,
|
||||
radius: 70,
|
||||
fill: 'green',
|
||||
stroke: 'black',
|
||||
strokeWidth: 4,
|
||||
name: 'myCircle',
|
||||
draggable: true
|
||||
});
|
||||
|
||||
layer.add(circle);
|
||||
stage.add(layer);
|
||||
|
||||
var dragstart = 0;
|
||||
circle.on('dragstart', function() {
|
||||
circle.stopDrag();
|
||||
dragstart += 1;
|
||||
});
|
||||
|
||||
var dragmove = 0;
|
||||
circle.on('dragmove', function() {
|
||||
dragmove += 1;
|
||||
});
|
||||
|
||||
var dragend = 0;
|
||||
circle.on('dragend', function() {
|
||||
dragend += 1;
|
||||
});
|
||||
|
||||
var click = 0;
|
||||
circle.on('click', function() {
|
||||
click += 1;
|
||||
});
|
||||
stage.simulateMouseDown({ x: 70, y: 70 });
|
||||
stage.simulateMouseMove({ x: 75, y: 75 });
|
||||
stage.simulateMouseUp({ x: 75, y: 75 });
|
||||
|
||||
assert.equal(click, 0, 'click triggered');
|
||||
assert.equal(dragstart, 1, 'dragstart triggered');
|
||||
assert.equal(dragmove, 0, 'dragmove not triggered');
|
||||
assert.equal(dragend, 1, 'dragend triggered');
|
||||
});
|
||||
});
|
||||
|
@ -14,7 +14,8 @@ suite('Text', function() {
|
||||
});
|
||||
|
||||
// ======================================================
|
||||
test('check text with FALSY values', function() {
|
||||
// TODO: what is the best UX here?
|
||||
test.skip('check text with FALSY values', function() {
|
||||
var stage = addStage();
|
||||
var layer = new Konva.Layer();
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user