Compare commits
1 commit
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
473583922e |
1 changed files with 24 additions and 10 deletions
|
|
@ -60,7 +60,7 @@ function DragdropHandler(mouseHandler) {
|
||||||
var mouseTarget = editor.container;
|
var mouseTarget = editor.container;
|
||||||
var dragSelectionMarker, x, y;
|
var dragSelectionMarker, x, y;
|
||||||
var timerId, range;
|
var timerId, range;
|
||||||
var dragCursor, counter = 0;
|
var dragCursor, dragLeaveT = null;
|
||||||
var dragOperation;
|
var dragOperation;
|
||||||
|
|
||||||
this.onDragStart = function(e) {
|
this.onDragStart = function(e) {
|
||||||
|
|
@ -105,9 +105,11 @@ function DragdropHandler(mouseHandler) {
|
||||||
this.onDragEnter = function(e) {
|
this.onDragEnter = function(e) {
|
||||||
if (editor.getReadOnly() || !canAccept(e.dataTransfer))
|
if (editor.getReadOnly() || !canAccept(e.dataTransfer))
|
||||||
return;
|
return;
|
||||||
|
if (dragLeaveT) {
|
||||||
|
dragLeaveT = null;
|
||||||
|
}
|
||||||
if (!dragSelectionMarker)
|
if (!dragSelectionMarker)
|
||||||
addDragMarker();
|
addDragMarker();
|
||||||
counter++;
|
|
||||||
// dataTransfer object does not save dropEffect across events on IE, so we store it in dragOperation
|
// dataTransfer object does not save dropEffect across events on IE, so we store it in dragOperation
|
||||||
e.dataTransfer.dropEffect = dragOperation = getDropEffect(e);
|
e.dataTransfer.dropEffect = dragOperation = getDropEffect(e);
|
||||||
return event.preventDefault(e);
|
return event.preventDefault(e);
|
||||||
|
|
@ -116,10 +118,12 @@ function DragdropHandler(mouseHandler) {
|
||||||
this.onDragOver = function(e) {
|
this.onDragOver = function(e) {
|
||||||
if (editor.getReadOnly() || !canAccept(e.dataTransfer))
|
if (editor.getReadOnly() || !canAccept(e.dataTransfer))
|
||||||
return;
|
return;
|
||||||
|
if (dragLeaveT) {
|
||||||
|
dragLeaveT = null;
|
||||||
|
}
|
||||||
// Opera doesn't trigger dragenter event on drag start
|
// Opera doesn't trigger dragenter event on drag start
|
||||||
if (!dragSelectionMarker) {
|
if (!dragSelectionMarker) {
|
||||||
addDragMarker();
|
addDragMarker();
|
||||||
counter++;
|
|
||||||
}
|
}
|
||||||
if (onMouseMoveTimer !== null)
|
if (onMouseMoveTimer !== null)
|
||||||
onMouseMoveTimer = null;
|
onMouseMoveTimer = null;
|
||||||
|
|
@ -131,13 +135,23 @@ function DragdropHandler(mouseHandler) {
|
||||||
};
|
};
|
||||||
|
|
||||||
this.onDragLeave = function(e) {
|
this.onDragLeave = function(e) {
|
||||||
counter--;
|
if (!dragLeaveT && dragSelectionMarker) {
|
||||||
if (counter <= 0 && dragSelectionMarker) {
|
dragLeaveT = Date.now();
|
||||||
clearDragMarker();
|
dragLeaveTimer = setTimeout(onDragLeaveInternal, 100);
|
||||||
dragOperation = null;
|
|
||||||
return event.preventDefault(e);
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
var dragLeaveTimer = null;
|
||||||
|
function onDragLeaveInternal() {
|
||||||
|
dragLeaveTimer = null;
|
||||||
|
if (!dragLeaveT) return;
|
||||||
|
var dt = Date.now() - dragLeaveT;
|
||||||
|
if (dt <= 80) {
|
||||||
|
dragLeaveTimer = setTimeout(onDragLeaveInternal, 100 - dt);
|
||||||
|
} else {
|
||||||
|
clearDragMarker();
|
||||||
|
dragLeaveT = dragOperation = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
this.onDrop = function(e) {
|
this.onDrop = function(e) {
|
||||||
if (!dragSelectionMarker)
|
if (!dragSelectionMarker)
|
||||||
|
|
@ -217,7 +231,7 @@ function DragdropHandler(mouseHandler) {
|
||||||
editor.clearSelection();
|
editor.clearSelection();
|
||||||
clearInterval(timerId);
|
clearInterval(timerId);
|
||||||
timerId = setInterval(onDragInterval, 20);
|
timerId = setInterval(onDragInterval, 20);
|
||||||
counter = 0;
|
dragLeaveT = null;
|
||||||
event.addListener(document, "mousemove", onMouseMove);
|
event.addListener(document, "mousemove", onMouseMove);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -229,7 +243,7 @@ function DragdropHandler(mouseHandler) {
|
||||||
editor.selection.fromOrientedRange(range);
|
editor.selection.fromOrientedRange(range);
|
||||||
editor.$blockScrolling -= 1;
|
editor.$blockScrolling -= 1;
|
||||||
range = null;
|
range = null;
|
||||||
counter = 0;
|
dragLeaveT = null;
|
||||||
event.removeListener(document, "mousemove", onMouseMove);
|
event.removeListener(document, "mousemove", onMouseMove);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue