Sortable: Using the new core intersectHeight/intersectWidth methods.

This commit is contained in:
Eduardo Lundgren 2008-11-10 05:17:12 +00:00
parent 91377e4e5c
commit acf15c4f08

View File

@ -58,18 +58,18 @@ $.widget("ui.sortable", $.extend({}, $.ui.mouse, {
sender: inst ? inst.element : null sender: inst ? inst.element : null
}; };
}, },
cancel: function() { cancel: function() {
if(this.dragging) { if(this.dragging) {
this._mouseUp(); this._mouseUp();
if(this.options.helper == "original") if(this.options.helper == "original")
this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper"); this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper");
else else
this.currentItem.show(); this.currentItem.show();
//Post deactivating events to containers //Post deactivating events to containers
for (var i = this.containers.length - 1; i >= 0; i--){ for (var i = this.containers.length - 1; i >= 0; i--){
this.containers[i]._propagate("deactivate", null, this); this.containers[i]._propagate("deactivate", null, this);
@ -78,28 +78,28 @@ $.widget("ui.sortable", $.extend({}, $.ui.mouse, {
this.containers[i].containerCache.over = 0; this.containers[i].containerCache.over = 0;
} }
} }
} }
//$(this.placeholder[0]).remove(); would have been the jQuery way - unfortunately, it unbinds ALL events from the original node! //$(this.placeholder[0]).remove(); would have been the jQuery way - unfortunately, it unbinds ALL events from the original node!
if(this.placeholder[0].parentNode) this.placeholder[0].parentNode.removeChild(this.placeholder[0]); if(this.placeholder[0].parentNode) this.placeholder[0].parentNode.removeChild(this.placeholder[0]);
if(this.options.helper != "original" && this.helper && this.helper[0].parentNode) this.helper.remove(); if(this.options.helper != "original" && this.helper && this.helper[0].parentNode) this.helper.remove();
$.extend(this, { $.extend(this, {
helper: null, helper: null,
dragging: false, dragging: false,
reverting: false, reverting: false,
_noFinalSort: null _noFinalSort: null
}); });
if(this.domPosition.prev) { if(this.domPosition.prev) {
$(this.domPosition.prev).after(this.currentItem); $(this.domPosition.prev).after(this.currentItem);
} else { } else {
$(this.domPosition.parent).prepend(this.currentItem); $(this.domPosition.parent).prepend(this.currentItem);
} }
return true; return true;
}, },
_propagate: function(n,e,inst, noPropagation) { _propagate: function(n,e,inst, noPropagation) {
@ -156,19 +156,12 @@ $.widget("ui.sortable", $.extend({}, $.ui.mouse, {
_intersectsWithEdge: function(item) { _intersectsWithEdge: function(item) {
var dyClick = this.offset.click.top, dxClick = this.offset.click.left; var dyClick = this.offset.click.top, dxClick = this.offset.click.left;
var helperHeight = this.helperProportions.height, helperWidth = this.helperProportions.width;
var helperTop = this.positionAbs.top, helperLeft = this.positionAbs.left; var helperTop = this.positionAbs.top, helperLeft = this.positionAbs.left;
var itemHeight = item.height, itemWidth = item.width; var itemHeight = item.height, itemWidth = item.width;
var itemTop = item.top, itemLeft = item.left; var itemTop = item.top, itemLeft = item.left;
var isOverElementHeight = var isOverElementHeight = $.ui.intersectHeight(helperTop + dyClick, itemTop, itemHeight);
((helperTop + dyClick) > itemTop) && var isOverElementWidth = $.ui.intersectWidth(helperLeft + dxClick, itemLeft, itemWidth);
((helperTop + dyClick) < (itemTop + itemHeight));
var isOverElementWidth =
((helperLeft + dxClick) > itemLeft) &&
((helperLeft + dxClick) < (itemLeft + itemWidth));
var isOverElement = isOverElementHeight && isOverElementWidth; var isOverElement = isOverElementHeight && isOverElementWidth;
var verticalDirection = this._getDragVerticalDirection(); var verticalDirection = this._getDragVerticalDirection();
var horizontalDirection = this._getDragHorizontalDirection(); var horizontalDirection = this._getDragHorizontalDirection();
@ -837,10 +830,10 @@ $.widget("ui.sortable", $.extend({}, $.ui.mouse, {
} }
this._propagate("beforeStop", e, null, noPropagation); this._propagate("beforeStop", e, null, noPropagation);
//$(this.placeholder[0]).remove(); would have been the jQuery way - unfortunately, it unbinds ALL events from the original node! //$(this.placeholder[0]).remove(); would have been the jQuery way - unfortunately, it unbinds ALL events from the original node!
this.placeholder[0].parentNode.removeChild(this.placeholder[0]); this.placeholder[0].parentNode.removeChild(this.placeholder[0]);
if(this.options.helper != "original") this.helper.remove(); this.helper = null; if(this.options.helper != "original") this.helper.remove(); this.helper = null;
this._propagate("stop", e, null, noPropagation); this._propagate("stop", e, null, noPropagation);