in plugins/struts2-dojo-plugin/src/main/resources/org/apache/struts2/static/dojo/src/dnd/HtmlDragAndDrop.js [214:368]
dojo.declare("dojo.dnd.HtmlDropTarget", dojo.dnd.DropTarget, {vertical:false, onDragOver:function (e) {
if (!this.accepts(e.dragObjects)) {
return false;
}
this.childBoxes = [];
for (var i = 0, child; i < this.domNode.childNodes.length; i++) {
child = this.domNode.childNodes[i];
if (child.nodeType != dojo.html.ELEMENT_NODE) {
continue;
}
var pos = dojo.html.getAbsolutePosition(child, true);
var inner = dojo.html.getBorderBox(child);
this.childBoxes.push({top:pos.y, bottom:pos.y + inner.height, left:pos.x, right:pos.x + inner.width, height:inner.height, width:inner.width, node:child});
}
return true;
}, _getNodeUnderMouse:function (e) {
for (var i = 0, child; i < this.childBoxes.length; i++) {
with (this.childBoxes[i]) {
if (e.pageX >= left && e.pageX <= right && e.pageY >= top && e.pageY <= bottom) {
return i;
}
}
}
return -1;
}, createDropIndicator:function () {
this.dropIndicator = document.createElement("div");
with (this.dropIndicator.style) {
position = "absolute";
zIndex = 999;
if (this.vertical) {
borderLeftWidth = "1px";
borderLeftColor = "black";
borderLeftStyle = "solid";
height = dojo.html.getBorderBox(this.domNode).height + "px";
top = dojo.html.getAbsolutePosition(this.domNode, true).y + "px";
} else {
borderTopWidth = "1px";
borderTopColor = "black";
borderTopStyle = "solid";
width = dojo.html.getBorderBox(this.domNode).width + "px";
left = dojo.html.getAbsolutePosition(this.domNode, true).x + "px";
}
}
}, onDragMove:function (e, dragObjects) {
var i = this._getNodeUnderMouse(e);
if (!this.dropIndicator) {
this.createDropIndicator();
}
var gravity = this.vertical ? dojo.html.gravity.WEST : dojo.html.gravity.NORTH;
var hide = false;
if (i < 0) {
if (this.childBoxes.length) {
var before = (dojo.html.gravity(this.childBoxes[0].node, e) & gravity);
if (before) {
hide = true;
}
} else {
var before = true;
}
} else {
var child = this.childBoxes[i];
var before = (dojo.html.gravity(child.node, e) & gravity);
if (child.node === dragObjects[0].dragSource.domNode) {
hide = true;
} else {
var currentPosChild = before ? (i > 0 ? this.childBoxes[i - 1] : child) : (i < this.childBoxes.length - 1 ? this.childBoxes[i + 1] : child);
if (currentPosChild.node === dragObjects[0].dragSource.domNode) {
hide = true;
}
}
}
if (hide) {
this.dropIndicator.style.display = "none";
return;
} else {
this.dropIndicator.style.display = "";
}
this.placeIndicator(e, dragObjects, i, before);
if (!dojo.html.hasParent(this.dropIndicator)) {
dojo.body().appendChild(this.dropIndicator);
}
}, placeIndicator:function (e, dragObjects, boxIndex, before) {
var targetProperty = this.vertical ? "left" : "top";
var child;
if (boxIndex < 0) {
if (this.childBoxes.length) {
child = before ? this.childBoxes[0] : this.childBoxes[this.childBoxes.length - 1];
} else {
this.dropIndicator.style[targetProperty] = dojo.html.getAbsolutePosition(this.domNode, true)[this.vertical ? "x" : "y"] + "px";
}
} else {
child = this.childBoxes[boxIndex];
}
if (child) {
this.dropIndicator.style[targetProperty] = (before ? child[targetProperty] : child[this.vertical ? "right" : "bottom"]) + "px";
if (this.vertical) {
this.dropIndicator.style.height = child.height + "px";
this.dropIndicator.style.top = child.top + "px";
} else {
this.dropIndicator.style.width = child.width + "px";
this.dropIndicator.style.left = child.left + "px";
}
}
}, onDragOut:function (e) {
if (this.dropIndicator) {
dojo.html.removeNode(this.dropIndicator);
delete this.dropIndicator;
}
}, onDrop:function (e) {
this.onDragOut(e);
var i = this._getNodeUnderMouse(e);
var gravity = this.vertical ? dojo.html.gravity.WEST : dojo.html.gravity.NORTH;
if (i < 0) {
if (this.childBoxes.length) {
if (dojo.html.gravity(this.childBoxes[0].node, e) & gravity) {
return this.insert(e, this.childBoxes[0].node, "before");
} else {
return this.insert(e, this.childBoxes[this.childBoxes.length - 1].node, "after");
}
}
return this.insert(e, this.domNode, "append");
}
var child = this.childBoxes[i];
if (dojo.html.gravity(child.node, e) & gravity) {
return this.insert(e, child.node, "before");
} else {
return this.insert(e, child.node, "after");
}
}, insert:function (e, refNode, position) {
var node = e.dragObject.domNode;
if (position == "before") {
return dojo.html.insertBefore(node, refNode);
} else {
if (position == "after") {
return dojo.html.insertAfter(node, refNode);
} else {
if (position == "append") {
refNode.appendChild(node);
return true;
}
}
}
return false;
}}, function (node, types) {
if (arguments.length == 0) {
return;
}
this.domNode = dojo.byId(node);
dojo.dnd.DropTarget.call(this);
if (types && dojo.lang.isString(types)) {
types = [types];
}
this.acceptedTypes = types || [];
dojo.dnd.dragManager.registerDropTarget(this);
});