HtmlDragManager.js
上传用户:kimgenplus
上传日期:2016-06-05
资源大小:20877k
文件大小:9k
源码类别:

OA系统

开发平台:

Java

  1. /*
  2. Copyright (c) 2004-2006, The Dojo Foundation
  3. All Rights Reserved.
  4. Licensed under the Academic Free License version 2.1 or above OR the
  5. modified BSD license. For more information on Dojo licensing, see:
  6. http://dojotoolkit.org/community/licensing.shtml
  7. */
  8. dojo.provide("dojo.dnd.HtmlDragManager");
  9. dojo.require("dojo.dnd.DragAndDrop");
  10. dojo.require("dojo.event.*");
  11. dojo.require("dojo.lang.array");
  12. dojo.require("dojo.html.common");
  13. dojo.require("dojo.html.layout");
  14. dojo.declare("dojo.dnd.HtmlDragManager", dojo.dnd.DragManager, {disabled:false, nestedTargets:false, mouseDownTimer:null, dsCounter:0, dsPrefix:"dojoDragSource", dropTargetDimensions:[], currentDropTarget:null, previousDropTarget:null, _dragTriggered:false, selectedSources:[], dragObjects:[], dragSources:[], dropTargets:[], currentX:null, currentY:null, lastX:null, lastY:null, mouseDownX:null, mouseDownY:null, threshold:7, dropAcceptable:false, cancelEvent:function (e) {
  15. e.stopPropagation();
  16. e.preventDefault();
  17. }, registerDragSource:function (ds) {
  18. if (ds["domNode"]) {
  19. var dp = this.dsPrefix;
  20. var dpIdx = dp + "Idx_" + (this.dsCounter++);
  21. ds.dragSourceId = dpIdx;
  22. this.dragSources[dpIdx] = ds;
  23. ds.domNode.setAttribute(dp, dpIdx);
  24. if (dojo.render.html.ie) {
  25. dojo.event.browser.addListener(ds.domNode, "ondragstart", this.cancelEvent);
  26. }
  27. }
  28. }, unregisterDragSource:function (ds) {
  29. if (ds["domNode"]) {
  30. var dp = this.dsPrefix;
  31. var dpIdx = ds.dragSourceId;
  32. delete ds.dragSourceId;
  33. delete this.dragSources[dpIdx];
  34. ds.domNode.setAttribute(dp, null);
  35. if (dojo.render.html.ie) {
  36. dojo.event.browser.removeListener(ds.domNode, "ondragstart", this.cancelEvent);
  37. }
  38. }
  39. }, registerDropTarget:function (dt) {
  40. this.dropTargets.push(dt);
  41. }, unregisterDropTarget:function (dt) {
  42. var index = dojo.lang.find(this.dropTargets, dt, true);
  43. if (index >= 0) {
  44. this.dropTargets.splice(index, 1);
  45. }
  46. }, getDragSource:function (e) {
  47. var tn = e.target;
  48. if (tn === dojo.body()) {
  49. return;
  50. }
  51. var ta = dojo.html.getAttribute(tn, this.dsPrefix);
  52. while ((!ta) && (tn)) {
  53. tn = tn.parentNode;
  54. if ((!tn) || (tn === dojo.body())) {
  55. return;
  56. }
  57. ta = dojo.html.getAttribute(tn, this.dsPrefix);
  58. }
  59. return this.dragSources[ta];
  60. }, onKeyDown:function (e) {
  61. }, onMouseDown:function (e) {
  62. if (this.disabled) {
  63. return;
  64. }
  65. if (dojo.render.html.ie) {
  66. if (e.button != 1) {
  67. return;
  68. }
  69. } else {
  70. if (e.which != 1) {
  71. return;
  72. }
  73. }
  74. var target = e.target.nodeType == dojo.html.TEXT_NODE ? e.target.parentNode : e.target;
  75. if (dojo.html.isTag(target, "button", "textarea", "input", "select", "option")) {
  76. return;
  77. }
  78. var ds = this.getDragSource(e);
  79. if (!ds) {
  80. return;
  81. }
  82. if (!dojo.lang.inArray(this.selectedSources, ds)) {
  83. this.selectedSources.push(ds);
  84. ds.onSelected();
  85. }
  86. this.mouseDownX = e.pageX;
  87. this.mouseDownY = e.pageY;
  88. e.preventDefault();
  89. dojo.event.connect(document, "onmousemove", this, "onMouseMove");
  90. }, onMouseUp:function (e, cancel) {
  91. if (this.selectedSources.length == 0) {
  92. return;
  93. }
  94. this.mouseDownX = null;
  95. this.mouseDownY = null;
  96. this._dragTriggered = false;
  97. e.dragSource = this.dragSource;
  98. if ((!e.shiftKey) && (!e.ctrlKey)) {
  99. if (this.currentDropTarget) {
  100. this.currentDropTarget.onDropStart();
  101. }
  102. dojo.lang.forEach(this.dragObjects, function (tempDragObj) {
  103. var ret = null;
  104. if (!tempDragObj) {
  105. return;
  106. }
  107. if (this.currentDropTarget) {
  108. e.dragObject = tempDragObj;
  109. var ce = this.currentDropTarget.domNode.childNodes;
  110. if (ce.length > 0) {
  111. e.dropTarget = ce[0];
  112. while (e.dropTarget == tempDragObj.domNode) {
  113. e.dropTarget = e.dropTarget.nextSibling;
  114. }
  115. } else {
  116. e.dropTarget = this.currentDropTarget.domNode;
  117. }
  118. if (this.dropAcceptable) {
  119. ret = this.currentDropTarget.onDrop(e);
  120. } else {
  121. this.currentDropTarget.onDragOut(e);
  122. }
  123. }
  124. e.dragStatus = this.dropAcceptable && ret ? "dropSuccess" : "dropFailure";
  125. dojo.lang.delayThese([function () {
  126. try {
  127. tempDragObj.dragSource.onDragEnd(e);
  128. }
  129. catch (err) {
  130. var ecopy = {};
  131. for (var i in e) {
  132. if (i == "type") {
  133. ecopy.type = "mouseup";
  134. continue;
  135. }
  136. ecopy[i] = e[i];
  137. }
  138. tempDragObj.dragSource.onDragEnd(ecopy);
  139. }
  140. }, function () {
  141. tempDragObj.onDragEnd(e);
  142. }]);
  143. }, this);
  144. this.selectedSources = [];
  145. this.dragObjects = [];
  146. this.dragSource = null;
  147. if (this.currentDropTarget) {
  148. this.currentDropTarget.onDropEnd();
  149. }
  150. } else {
  151. }
  152. dojo.event.disconnect(document, "onmousemove", this, "onMouseMove");
  153. this.currentDropTarget = null;
  154. }, onScroll:function () {
  155. for (var i = 0; i < this.dragObjects.length; i++) {
  156. if (this.dragObjects[i].updateDragOffset) {
  157. this.dragObjects[i].updateDragOffset();
  158. }
  159. }
  160. if (this.dragObjects.length) {
  161. this.cacheTargetLocations();
  162. }
  163. }, _dragStartDistance:function (x, y) {
  164. if ((!this.mouseDownX) || (!this.mouseDownX)) {
  165. return;
  166. }
  167. var dx = Math.abs(x - this.mouseDownX);
  168. var dx2 = dx * dx;
  169. var dy = Math.abs(y - this.mouseDownY);
  170. var dy2 = dy * dy;
  171. return parseInt(Math.sqrt(dx2 + dy2), 10);
  172. }, cacheTargetLocations:function () {
  173. dojo.profile.start("cacheTargetLocations");
  174. this.dropTargetDimensions = [];
  175. dojo.lang.forEach(this.dropTargets, function (tempTarget) {
  176. var tn = tempTarget.domNode;
  177. if (!tn || !tempTarget.accepts([this.dragSource])) {
  178. return;
  179. }
  180. var abs = dojo.html.getAbsolutePosition(tn, true);
  181. var bb = dojo.html.getBorderBox(tn);
  182. this.dropTargetDimensions.push([[abs.x, abs.y], [abs.x + bb.width, abs.y + bb.height], tempTarget]);
  183. }, this);
  184. dojo.profile.end("cacheTargetLocations");
  185. }, onMouseMove:function (e) {
  186. if ((dojo.render.html.ie) && (e.button != 1)) {
  187. this.currentDropTarget = null;
  188. this.onMouseUp(e, true);
  189. return;
  190. }
  191. if ((this.selectedSources.length) && (!this.dragObjects.length)) {
  192. var dx;
  193. var dy;
  194. if (!this._dragTriggered) {
  195. this._dragTriggered = (this._dragStartDistance(e.pageX, e.pageY) > this.threshold);
  196. if (!this._dragTriggered) {
  197. return;
  198. }
  199. dx = e.pageX - this.mouseDownX;
  200. dy = e.pageY - this.mouseDownY;
  201. }
  202. this.dragSource = this.selectedSources[0];
  203. dojo.lang.forEach(this.selectedSources, function (tempSource) {
  204. if (!tempSource) {
  205. return;
  206. }
  207. var tdo = tempSource.onDragStart(e);
  208. if (tdo) {
  209. tdo.onDragStart(e);
  210. tdo.dragOffset.y += dy;
  211. tdo.dragOffset.x += dx;
  212. tdo.dragSource = tempSource;
  213. this.dragObjects.push(tdo);
  214. }
  215. }, this);
  216. this.previousDropTarget = null;
  217. this.cacheTargetLocations();
  218. }
  219. dojo.lang.forEach(this.dragObjects, function (dragObj) {
  220. if (dragObj) {
  221. dragObj.onDragMove(e);
  222. }
  223. });
  224. if (this.currentDropTarget) {
  225. var c = dojo.html.toCoordinateObject(this.currentDropTarget.domNode, true);
  226. var dtp = [[c.x, c.y], [c.x + c.width, c.y + c.height]];
  227. }
  228. if ((!this.nestedTargets) && (dtp) && (this.isInsideBox(e, dtp))) {
  229. if (this.dropAcceptable) {
  230. this.currentDropTarget.onDragMove(e, this.dragObjects);
  231. }
  232. } else {
  233. var bestBox = this.findBestTarget(e);
  234. if (bestBox.target === null) {
  235. if (this.currentDropTarget) {
  236. this.currentDropTarget.onDragOut(e);
  237. this.previousDropTarget = this.currentDropTarget;
  238. this.currentDropTarget = null;
  239. }
  240. this.dropAcceptable = false;
  241. return;
  242. }
  243. if (this.currentDropTarget !== bestBox.target) {
  244. if (this.currentDropTarget) {
  245. this.previousDropTarget = this.currentDropTarget;
  246. this.currentDropTarget.onDragOut(e);
  247. }
  248. this.currentDropTarget = bestBox.target;
  249. e.dragObjects = this.dragObjects;
  250. this.dropAcceptable = this.currentDropTarget.onDragOver(e);
  251. } else {
  252. if (this.dropAcceptable) {
  253. this.currentDropTarget.onDragMove(e, this.dragObjects);
  254. }
  255. }
  256. }
  257. }, findBestTarget:function (e) {
  258. var _this = this;
  259. var bestBox = new Object();
  260. bestBox.target = null;
  261. bestBox.points = null;
  262. dojo.lang.every(this.dropTargetDimensions, function (tmpDA) {
  263. if (!_this.isInsideBox(e, tmpDA)) {
  264. return true;
  265. }
  266. bestBox.target = tmpDA[2];
  267. bestBox.points = tmpDA;
  268. return Boolean(_this.nestedTargets);
  269. });
  270. return bestBox;
  271. }, isInsideBox:function (e, coords) {
  272. if ((e.pageX > coords[0][0]) && (e.pageX < coords[1][0]) && (e.pageY > coords[0][1]) && (e.pageY < coords[1][1])) {
  273. return true;
  274. }
  275. return false;
  276. }, onMouseOver:function (e) {
  277. }, onMouseOut:function (e) {
  278. }});
  279. dojo.dnd.dragManager = new dojo.dnd.HtmlDragManager();
  280. (function () {
  281. var d = document;
  282. var dm = dojo.dnd.dragManager;
  283. dojo.event.connect(d, "onkeydown", dm, "onKeyDown");
  284. dojo.event.connect(d, "onmouseover", dm, "onMouseOver");
  285. dojo.event.connect(d, "onmouseout", dm, "onMouseOut");
  286. dojo.event.connect(d, "onmousedown", dm, "onMouseDown");
  287. dojo.event.connect(d, "onmouseup", dm, "onMouseUp");
  288. dojo.event.connect(window, "onscroll", dm, "onScroll");
  289. })();