Browse Source

Fix bugs when dragged element has iframes

When the dragged element has iframes, it is undraggable, gets stuck, and other weird behaviors.
To fix it, on drag-start I take iframes out of the dragged element and out of DOM, and return them to place on drop.
pull/1143/head
Oria 8 years ago committed by GitHub
parent
commit
885f07c031
  1. 29
      Sortable.js

29
Sortable.js

@ -54,6 +54,7 @@
touchEvt, touchEvt,
moved, moved,
iframe_stash,
/** @const */ /** @const */
R_SPACE = /\s+/g, R_SPACE = /\s+/g,
@ -397,6 +398,20 @@
dragEl.style['will-change'] = 'transform'; dragEl.style['will-change'] = 'transform';
dragStartFn = function () { dragStartFn = function () {
// stash iframes because they prevent dragging
iframe_stash = null;
var iframes = dragEl.querySelectorAll('iframe');
if (iframes && iframes.length)
{
iframe_stash = document.createElement('x'); // intentionally not adding it to DOM
for (var i = 0; i < iframes.length; i++)
{
iframes[i].sortable_parentElement = iframes[i].parentElement;
iframes[i].sortable_nextElementSibling = iframes[i].nextElementSibling;
iframe_stash.appendChild(iframes[i]);
}
}
// Delayed drag has been triggered // Delayed drag has been triggered
// we can re-enable the events: touchmove/mousemove // we can re-enable the events: touchmove/mousemove
_this._disableDelayedDrag(); _this._disableDelayedDrag();
@ -889,6 +904,20 @@
this._offUpEvents(); this._offUpEvents();
// unstash iframes
if (iframe_stash)
{
for (var i = 0; i < iframe_stash.children.length; i++)
{
var iframe = iframe_stash.children[i];
if (iframe.sortable_nextElementSibling)
iframe.sortable_parentElement.insertBefore(iframe, iframe.sortable_nextElementSibling)
else
iframe.sortable_parentElement.appendChild(iframe);
}
iframe_stash = null;
}
if (evt) { if (evt) {
if (moved) { if (moved) {
evt.preventDefault(); evt.preventDefault();

Loading…
Cancel
Save