1 /** Because scriptaculous DnD sucks..
2 Written by Mathew McBride <matt@mcbridematt.dhs.org> / <matt@comalies>
4 var draggedElement = null;
5 var currentDropTargets = null;
7 var dragAndDropElement = null;
9 function mouseDownHandler(event) {
10 var target = event.target;
11 var actualTarget = target;
12 if (target.nodeName.toLowerCase() == "td") {
13 actualTarget = target.parentNode;
15 if (!actualTarget.dropEnabled) {
19 draggedElement = actualTarget;
22 function mouseUpHandler(event) {
23 var target = event.target;
24 var dropped = dropTarget;
25 if (dragAndDropElement != null) {
26 if (dropped != null && dropped.dropHandler) {
27 dropped.dropHandler(dropped,draggedElement);
29 document.body.removeChild(dragAndDropElement);
31 dragAndDropElement = null;
32 draggedElement = null;
37 function mouseMoveHandler(event) {
38 if (draggedElement != null) {
39 if (dragAndDropElement == null) {
40 dragAndDropElement = draggedElement.ctdlDnDElement();
41 dragAndDropElement.setAttribute("class", "draganddrop");
42 document.body.appendChild(dragAndDropElement);
44 var clientX = event.clientX+5;
45 var clientY = event.clientY+5;
46 dragAndDropElement.style.top = clientY + "px";
47 dragAndDropElement.style.left = clientX + "px";
51 function mouseMoveOver(event) {
52 if (event.target.dropTarget) {
53 dropTarget = event.target;
56 function mouseMoveOut(event) {
61 document.observe("dom:loaded", setupDragDrop);
62 function setupDragDrop() {
63 if (document.addEventListener != undefined) {
64 $(document.body).observe('mousedown', mouseDownHandler);
65 $(document.body).observe('mouseup',mouseUpHandler);
66 $(document.body).observe('mousemove',mouseMoveHandler);
67 $(document.body).observe('mouseover', mouseMoveOver);
68 $(document.body).observe('mouseout', mouseMoveOut);
71 function turnOffTextSelect() {
72 document.onmousedown = new Function("return false");
73 document.onmouseup = new Function("return true");
75 function turnOnTextSelect() {
76 document.onmousedown = null;
77 document.onmouseup = null;