Skip to content

Commit

Permalink
Sortable: Fix positioning when moving a Draggable item into a Sortable
Browse files Browse the repository at this point in the history
PR jquerygh-1793 removed setting `this.offset.parent` in the Draggable
`refreshPositions` method which broke position calculations when moving
a Draggable item into a connected Sortable. restore that assignment.

Ref jquerygh-1793
Fixes jquerygh-2001
  • Loading branch information
mgol committed Nov 8, 2021
1 parent efe3b22 commit 2fb8097
Show file tree
Hide file tree
Showing 2 changed files with 63 additions and 0 deletions.
57 changes: 57 additions & 0 deletions tests/unit/sortable/options.js
Original file line number Diff line number Diff line change
Expand Up @@ -488,6 +488,63 @@ QUnit.test( "{ placholder: String } tbody", function( assert ) {
} );
} );

// gh-2001
// Sortable: Draggable items moved into a sortable had incorrect position
QUnit.test( "{ connectToSortable: Selector } positioning (gh-2001)", function( assert ) {
assert.expect( 1 );

// Code from jQuery Simulate with minor modifications.
function findCenter( elem ) {
var offset,
document = $( elem[ 0 ].ownerDocument );
offset = elem.offset();

return {
x: Math.floor( offset.left + elem.outerWidth() / 2 - document.scrollLeft() ),
y: Math.floor( offset.top + elem.outerHeight() / 2 - document.scrollTop( ) )
};
}

var sortableElem = $( "#sortable" );

sortableElem.css( "position", "relative" );

var item = $( "<div></div>" )
.text( "6" )
.insertBefore( "#sortable" );

// Padding
$( "<div></div>" )
.css( {
width: "100px",
height: "100px"
} )
.insertBefore( "#sortable" );

item.draggable( {
connectToSortable: "#sortable"
} );
sortableElem.sortable();

// Simulate a drag without a drop.
var center = findCenter( item );
item.simulate( "mousedown", {
clientX: center.x,
clientY: center.y
} );
item.simulate( "mousemove", {
clientX: center.x,
clientY: center.y + 60
} );
item.simulate( "mousemove", {
clientX: center.x,
clientY: center.y + 120
} );

assert.ok( item.offset().top > sortableElem.children().eq( 0 ).offset().top,
"Draggable offset correct after moving into a sortable" );
} );

/*
Test("{ revert: false }, default", function() {
ok(false, "missing test - untested code is broken code.");
Expand Down
6 changes: 6 additions & 0 deletions ui/widgets/sortable.js
Original file line number Diff line number Diff line change
Expand Up @@ -885,6 +885,12 @@ return $.widget( "ui.sortable", $.ui.mouse, {
this.options.axis === "x" || this._isFloating( this.items[ 0 ].item ) :
false;

// This has to be redone because due to the item being moved out/into the offsetParent,
// the offsetParent's position will change
if ( this.offsetParent && this.helper ) {
this.offset.parent = this._getParentOffset();
}

this._refreshItemPositions( fast );

var i, p;
Expand Down

0 comments on commit 2fb8097

Please sign in to comment.