aboutsummaryrefslogtreecommitdiffstats
path: root/ui/draggable.js
diff options
context:
space:
mode:
authorMike Sherov <mike.sherov@gmail.com>2014-08-24 07:19:38 -0400
committerMike Sherov <mike.sherov@gmail.com>2014-08-24 07:19:38 -0400
commitc7bec85cfa7711bb2612278eb980d0d14dade3b9 (patch)
tree4f53b6fe1202f2d9f69a10e77b008fb1cba8b7fd /ui/draggable.js
parentdf7e32fe3798562ffb86d064444f1e0cc8ac59a8 (diff)
downloadjquery-ui-c7bec85cfa7711bb2612278eb980d0d14dade3b9.tar.gz
jquery-ui-c7bec85cfa7711bb2612278eb980d0d14dade3b9.zip
Draggable: append divs to iframe parent for iframefix
This allows the blocking div to move with the iframe in most situations, whereas appending to the body wouldn't. Fixes #9671
Diffstat (limited to 'ui/draggable.js')
-rw-r--r--ui/draggable.js35
1 files changed, 22 insertions, 13 deletions
diff --git a/ui/draggable.js b/ui/draggable.js
index ebafaeb83..997bba107 100644
--- a/ui/draggable.js
+++ b/ui/draggable.js
@@ -109,20 +109,32 @@ $.widget("ui.draggable", $.ui.mouse, {
return false;
}
- $(o.iframeFix === true ? "iframe" : o.iframeFix).each(function() {
- $("<div class='ui-draggable-iframeFix' style='background: #fff;'></div>")
- .css({
- width: this.offsetWidth + "px", height: this.offsetHeight + "px",
- position: "absolute", opacity: "0.001", zIndex: 1000
- })
- .css($(this).offset())
- .appendTo("body");
- });
+ this._blockFrames( o.iframeFix === true ? "iframe" : o.iframeFix );
return true;
},
+ _blockFrames: function( selector ) {
+ this.iframeBlocks = this.document.find( selector ).map(function() {
+ var iframe = $( this );
+
+ return $( "<div>" )
+ .css( "position", "absolute" )
+ .appendTo( iframe.parent() )
+ .outerWidth( iframe.outerWidth() )
+ .outerHeight( iframe.outerHeight() )
+ .offset( iframe.offset() )[ 0 ];
+ });
+ },
+
+ _unblockFrames: function() {
+ if ( this.iframeBlocks ) {
+ this.iframeBlocks.remove();
+ delete this.iframeBlocks;
+ }
+ },
+
_blurActiveElement: function( event ) {
var document = this.document[ 0 ];
@@ -297,10 +309,7 @@ $.widget("ui.draggable", $.ui.mouse, {
},
_mouseUp: function( event ) {
- //Remove frame helpers
- $("div.ui-draggable-iframeFix").each(function() {
- this.parentNode.removeChild(this);
- });
+ this._unblockFrames();
//If the ddmanager is used for droppables, inform the manager that dragging has stopped (see #5003)
if ( $.ui.ddmanager ) {