|
|
@ -58,27 +58,6 @@ |
|
|
|
|
|
|
|
|
|
|
|
_silent = false, |
|
|
|
_silent = false, |
|
|
|
|
|
|
|
|
|
|
|
_dispatchEvent = function (sortable, rootEl, name, targetEl, fromEl, startIndex, newIndex) { |
|
|
|
|
|
|
|
var evt = document.createEvent('Event'), |
|
|
|
|
|
|
|
options = (sortable || rootEl[expando]).options, |
|
|
|
|
|
|
|
onName = 'on' + name.charAt(0).toUpperCase() + name.substr(1); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
evt.initEvent(name, true, true); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
evt.item = targetEl || rootEl; |
|
|
|
|
|
|
|
evt.from = fromEl || rootEl; |
|
|
|
|
|
|
|
evt.clone = cloneEl; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
evt.oldIndex = startIndex; |
|
|
|
|
|
|
|
evt.newIndex = newIndex; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (options[onName]) { |
|
|
|
|
|
|
|
options[onName].call(sortable, evt); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
rootEl.dispatchEvent(evt); |
|
|
|
|
|
|
|
}, |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
abs = Math.abs, |
|
|
|
abs = Math.abs, |
|
|
|
slice = [].slice, |
|
|
|
slice = [].slice, |
|
|
|
|
|
|
|
|
|
|
@ -537,13 +516,13 @@ |
|
|
|
|
|
|
|
|
|
|
|
if (activeGroup && !options.disabled && |
|
|
|
if (activeGroup && !options.disabled && |
|
|
|
(isOwner |
|
|
|
(isOwner |
|
|
|
? canSort || (revert = !rootEl.contains(dragEl)) |
|
|
|
? canSort || (revert = !rootEl.contains(dragEl)) // Reverting item into the original list
|
|
|
|
: activeGroup.pull && groupPut && ( |
|
|
|
: activeGroup.pull && groupPut && ( |
|
|
|
(activeGroup.name === group.name) || // by Name
|
|
|
|
(activeGroup.name === group.name) || // by Name
|
|
|
|
(groupPut.indexOf && ~groupPut.indexOf(activeGroup.name)) // by Array
|
|
|
|
(groupPut.indexOf && ~groupPut.indexOf(activeGroup.name)) // by Array
|
|
|
|
) |
|
|
|
) |
|
|
|
) && |
|
|
|
) && |
|
|
|
(evt.rootEl === void 0 || evt.rootEl === this.el) |
|
|
|
(evt.rootEl === void 0 || evt.rootEl === this.el) // touch fallback
|
|
|
|
) { |
|
|
|
) { |
|
|
|
// Smart auto-scrolling
|
|
|
|
// Smart auto-scrolling
|
|
|
|
_autoScroll(evt, options, this.el); |
|
|
|
_autoScroll(evt, options, this.el); |
|
|
@ -582,10 +561,12 @@ |
|
|
|
|
|
|
|
|
|
|
|
_cloneHide(isOwner); |
|
|
|
_cloneHide(isOwner); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (_onMove(rootEl, el, dragEl, dragRect, target, targetRect)) { |
|
|
|
el.appendChild(dragEl); |
|
|
|
el.appendChild(dragEl); |
|
|
|
this._animate(dragRect, dragEl); |
|
|
|
this._animate(dragRect, dragEl); |
|
|
|
target && this._animate(targetRect, target); |
|
|
|
target && this._animate(targetRect, target); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
else if (target && !target.animated && target !== dragEl && (target.parentNode[expando] !== void 0)) { |
|
|
|
else if (target && !target.animated && target !== dragEl && (target.parentNode[expando] !== void 0)) { |
|
|
|
if (lastEl !== target) { |
|
|
|
if (lastEl !== target) { |
|
|
|
lastEl = target; |
|
|
|
lastEl = target; |
|
|
@ -604,6 +585,7 @@ |
|
|
|
after |
|
|
|
after |
|
|
|
; |
|
|
|
; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (_onMove(rootEl, el, dragEl, dragRect, target, targetRect)) { |
|
|
|
_silent = true; |
|
|
|
_silent = true; |
|
|
|
setTimeout(_unsilent, 30); |
|
|
|
setTimeout(_unsilent, 30); |
|
|
|
|
|
|
|
|
|
|
@ -625,6 +607,7 @@ |
|
|
|
this._animate(targetRect, target); |
|
|
|
this._animate(targetRect, target); |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
} |
|
|
|
}, |
|
|
|
}, |
|
|
|
|
|
|
|
|
|
|
|
_animate: function (prevRect, target) { |
|
|
|
_animate: function (prevRect, target) { |
|
|
@ -986,6 +969,54 @@ |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function _dispatchEvent(sortable, rootEl, name, targetEl, fromEl, startIndex, newIndex) { |
|
|
|
|
|
|
|
var evt = document.createEvent('Event'), |
|
|
|
|
|
|
|
options = (sortable || rootEl[expando]).options, |
|
|
|
|
|
|
|
onName = 'on' + name.charAt(0).toUpperCase() + name.substr(1); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
evt.initEvent(name, true, true); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
evt.to = rootEl; |
|
|
|
|
|
|
|
evt.from = fromEl || rootEl; |
|
|
|
|
|
|
|
evt.item = targetEl || rootEl; |
|
|
|
|
|
|
|
evt.clone = cloneEl; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
evt.oldIndex = startIndex; |
|
|
|
|
|
|
|
evt.newIndex = newIndex; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (options[onName]) { |
|
|
|
|
|
|
|
options[onName].call(sortable, evt); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
rootEl.dispatchEvent(evt); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function _onMove(fromEl, toEl, dragEl, dragRect, targetEl, targetRect) { |
|
|
|
|
|
|
|
var evt, |
|
|
|
|
|
|
|
sortable = fromEl[expando], |
|
|
|
|
|
|
|
onMoveFn = sortable.options.onMove, |
|
|
|
|
|
|
|
retVal; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (onMoveFn) { |
|
|
|
|
|
|
|
evt = document.createEvent('Event'); |
|
|
|
|
|
|
|
evt.initEvent('move', true, true); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
evt.to = toEl; |
|
|
|
|
|
|
|
evt.from = fromEl; |
|
|
|
|
|
|
|
evt.dragged = dragEl; |
|
|
|
|
|
|
|
evt.draggedRect = dragRect; |
|
|
|
|
|
|
|
evt.related = targetEl || toEl; |
|
|
|
|
|
|
|
evt.relatedRect = targetRect || toEl.getBoundingClientRect(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
retVal = onMoveFn.call(sortable, evt); |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return retVal !== false; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function _disableDraggable(el) { |
|
|
|
function _disableDraggable(el) { |
|
|
|
el.draggable = false; |
|
|
|
el.draggable = false; |
|
|
|
} |
|
|
|
} |
|
|
|