@mdesignable/core 1.0.0-beta.64

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (389) hide show
  1. package/LICENSE.md +20 -0
  2. package/README.md +1 -0
  3. package/dist/designable.core.umd.production.js +10 -0
  4. package/dist/designable.core.umd.production.min.js +23505 -0
  5. package/esm/drivers/DragDropDriver.d.ts +14 -0
  6. package/esm/drivers/DragDropDriver.js +157 -0
  7. package/esm/drivers/KeyboardDriver.d.ts +7 -0
  8. package/esm/drivers/KeyboardDriver.js +90 -0
  9. package/esm/drivers/MouseClickDriver.d.ts +8 -0
  10. package/esm/drivers/MouseClickDriver.js +95 -0
  11. package/esm/drivers/MouseMoveDriver.d.ts +8 -0
  12. package/esm/drivers/MouseMoveDriver.js +75 -0
  13. package/esm/drivers/ViewportResizeDriver.d.ts +10 -0
  14. package/esm/drivers/ViewportResizeDriver.js +95 -0
  15. package/esm/drivers/ViewportScrollDriver.d.ts +8 -0
  16. package/esm/drivers/ViewportScrollDriver.js +74 -0
  17. package/esm/drivers/index.d.ts +6 -0
  18. package/esm/drivers/index.js +6 -0
  19. package/esm/effects/index.d.ts +11 -0
  20. package/esm/effects/index.js +11 -0
  21. package/esm/effects/useAutoScrollEffect.d.ts +2 -0
  22. package/esm/effects/useAutoScrollEffect.js +65 -0
  23. package/esm/effects/useContentEditableEffect.d.ts +2 -0
  24. package/esm/effects/useContentEditableEffect.js +167 -0
  25. package/esm/effects/useCursorEffect.d.ts +2 -0
  26. package/esm/effects/useCursorEffect.js +55 -0
  27. package/esm/effects/useDragDropEffect.d.ts +2 -0
  28. package/esm/effects/useDragDropEffect.js +168 -0
  29. package/esm/effects/useFreeSelectionEffect.d.ts +2 -0
  30. package/esm/effects/useFreeSelectionEffect.js +59 -0
  31. package/esm/effects/useKeyboardEffect.d.ts +2 -0
  32. package/esm/effects/useKeyboardEffect.js +17 -0
  33. package/esm/effects/useResizeEffect.d.ts +2 -0
  34. package/esm/effects/useResizeEffect.js +80 -0
  35. package/esm/effects/useSelectionEffect.d.ts +2 -0
  36. package/esm/effects/useSelectionEffect.js +68 -0
  37. package/esm/effects/useTranslateEffect.d.ts +2 -0
  38. package/esm/effects/useTranslateEffect.js +58 -0
  39. package/esm/effects/useViewportEffect.d.ts +2 -0
  40. package/esm/effects/useViewportEffect.js +31 -0
  41. package/esm/effects/useWorkspaceEffect.d.ts +2 -0
  42. package/esm/effects/useWorkspaceEffect.js +29 -0
  43. package/esm/events/cursor/AbstractCursorEvent.d.ts +21 -0
  44. package/esm/events/cursor/AbstractCursorEvent.js +40 -0
  45. package/esm/events/cursor/DragMoveEvent.d.ts +5 -0
  46. package/esm/events/cursor/DragMoveEvent.js +51 -0
  47. package/esm/events/cursor/DragStartEvent.d.ts +5 -0
  48. package/esm/events/cursor/DragStartEvent.js +51 -0
  49. package/esm/events/cursor/DragStopEvent.d.ts +5 -0
  50. package/esm/events/cursor/DragStopEvent.js +51 -0
  51. package/esm/events/cursor/MouseClickEvent.d.ts +8 -0
  52. package/esm/events/cursor/MouseClickEvent.js +61 -0
  53. package/esm/events/cursor/MouseMoveEvent.d.ts +5 -0
  54. package/esm/events/cursor/MouseMoveEvent.js +51 -0
  55. package/esm/events/cursor/index.d.ts +5 -0
  56. package/esm/events/cursor/index.js +5 -0
  57. package/esm/events/history/AbstractHistoryEvent.d.ts +6 -0
  58. package/esm/events/history/AbstractHistoryEvent.js +7 -0
  59. package/esm/events/history/HistoryGotoEvent.d.ts +5 -0
  60. package/esm/events/history/HistoryGotoEvent.js +51 -0
  61. package/esm/events/history/HistoryPushEvent.d.ts +5 -0
  62. package/esm/events/history/HistoryPushEvent.js +51 -0
  63. package/esm/events/history/HistoryRedoEvent.d.ts +5 -0
  64. package/esm/events/history/HistoryRedoEvent.js +51 -0
  65. package/esm/events/history/HistoryUndoEvent.d.ts +5 -0
  66. package/esm/events/history/HistoryUndoEvent.js +51 -0
  67. package/esm/events/history/index.d.ts +4 -0
  68. package/esm/events/history/index.js +4 -0
  69. package/esm/events/index.d.ts +6 -0
  70. package/esm/events/index.js +6 -0
  71. package/esm/events/keyboard/AbstractKeyboardEvent.d.ts +15 -0
  72. package/esm/events/keyboard/AbstractKeyboardEvent.js +61 -0
  73. package/esm/events/keyboard/KeyDownEvent.d.ts +5 -0
  74. package/esm/events/keyboard/KeyDownEvent.js +51 -0
  75. package/esm/events/keyboard/KeyUpEvent.d.ts +5 -0
  76. package/esm/events/keyboard/KeyUpEvent.js +51 -0
  77. package/esm/events/keyboard/index.d.ts +2 -0
  78. package/esm/events/keyboard/index.js +2 -0
  79. package/esm/events/mutation/AbstractMutationNodeEvent.d.ts +13 -0
  80. package/esm/events/mutation/AbstractMutationNodeEvent.js +7 -0
  81. package/esm/events/mutation/AppendNodeEvent.d.ts +5 -0
  82. package/esm/events/mutation/AppendNodeEvent.js +51 -0
  83. package/esm/events/mutation/CloneNodeEvent.d.ts +5 -0
  84. package/esm/events/mutation/CloneNodeEvent.js +51 -0
  85. package/esm/events/mutation/DragNodeEvent.d.ts +5 -0
  86. package/esm/events/mutation/DragNodeEvent.js +51 -0
  87. package/esm/events/mutation/DropNodeEvent.d.ts +5 -0
  88. package/esm/events/mutation/DropNodeEvent.js +51 -0
  89. package/esm/events/mutation/FromNodeEvent.d.ts +13 -0
  90. package/esm/events/mutation/FromNodeEvent.js +8 -0
  91. package/esm/events/mutation/HoverNodeEvent.d.ts +5 -0
  92. package/esm/events/mutation/HoverNodeEvent.js +51 -0
  93. package/esm/events/mutation/InsertAfterEvent.d.ts +5 -0
  94. package/esm/events/mutation/InsertAfterEvent.js +51 -0
  95. package/esm/events/mutation/InsertBeforeEvent.d.ts +5 -0
  96. package/esm/events/mutation/InsertBeforeEvent.js +51 -0
  97. package/esm/events/mutation/InsertChildrenEvent.d.ts +5 -0
  98. package/esm/events/mutation/InsertChildrenEvent.js +51 -0
  99. package/esm/events/mutation/PrependNodeEvent.d.ts +5 -0
  100. package/esm/events/mutation/PrependNodeEvent.js +51 -0
  101. package/esm/events/mutation/RemoveNodeEvent.d.ts +5 -0
  102. package/esm/events/mutation/RemoveNodeEvent.js +51 -0
  103. package/esm/events/mutation/SelectNodeEvent.d.ts +5 -0
  104. package/esm/events/mutation/SelectNodeEvent.js +51 -0
  105. package/esm/events/mutation/UnSelectNodeEvent.d.ts +5 -0
  106. package/esm/events/mutation/UnSelectNodeEvent.js +51 -0
  107. package/esm/events/mutation/UpdateChildrenEvent.d.ts +5 -0
  108. package/esm/events/mutation/UpdateChildrenEvent.js +51 -0
  109. package/esm/events/mutation/UpdateNodePropsEvent.d.ts +5 -0
  110. package/esm/events/mutation/UpdateNodePropsEvent.js +51 -0
  111. package/esm/events/mutation/UserSelectNodeEvent.d.ts +5 -0
  112. package/esm/events/mutation/UserSelectNodeEvent.js +51 -0
  113. package/esm/events/mutation/WrapNodeEvent.d.ts +5 -0
  114. package/esm/events/mutation/WrapNodeEvent.js +51 -0
  115. package/esm/events/mutation/index.d.ts +16 -0
  116. package/esm/events/mutation/index.js +16 -0
  117. package/esm/events/viewport/AbstractViewportEvent.d.ts +16 -0
  118. package/esm/events/viewport/AbstractViewportEvent.js +17 -0
  119. package/esm/events/viewport/ViewportResizeEvent.d.ts +5 -0
  120. package/esm/events/viewport/ViewportResizeEvent.js +51 -0
  121. package/esm/events/viewport/ViewportScrollEvent.d.ts +5 -0
  122. package/esm/events/viewport/ViewportScrollEvent.js +51 -0
  123. package/esm/events/viewport/index.d.ts +2 -0
  124. package/esm/events/viewport/index.js +2 -0
  125. package/esm/events/workbench/AbstractWorkspaceEvent.d.ts +7 -0
  126. package/esm/events/workbench/AbstractWorkspaceEvent.js +7 -0
  127. package/esm/events/workbench/AddWorkspaceEvent.d.ts +5 -0
  128. package/esm/events/workbench/AddWorkspaceEvent.js +51 -0
  129. package/esm/events/workbench/RemoveWorkspaceEvent.d.ts +5 -0
  130. package/esm/events/workbench/RemoveWorkspaceEvent.js +51 -0
  131. package/esm/events/workbench/SwitchWorkspaceEvent.d.ts +5 -0
  132. package/esm/events/workbench/SwitchWorkspaceEvent.js +51 -0
  133. package/esm/events/workbench/index.d.ts +3 -0
  134. package/esm/events/workbench/index.js +3 -0
  135. package/esm/exports.d.ts +5 -0
  136. package/esm/exports.js +5 -0
  137. package/esm/externals.d.ts +12 -0
  138. package/esm/externals.js +113 -0
  139. package/esm/index.d.ts +1 -0
  140. package/esm/index.js +24 -0
  141. package/esm/internals.d.ts +3 -0
  142. package/esm/internals.js +34 -0
  143. package/esm/models/Cursor.d.ts +60 -0
  144. package/esm/models/Cursor.js +151 -0
  145. package/esm/models/Engine.d.ts +29 -0
  146. package/esm/models/Engine.js +112 -0
  147. package/esm/models/History.d.ts +34 -0
  148. package/esm/models/History.js +110 -0
  149. package/esm/models/Hover.d.ts +14 -0
  150. package/esm/models/Hover.js +38 -0
  151. package/esm/models/Keyboard.d.ts +29 -0
  152. package/esm/models/Keyboard.js +126 -0
  153. package/esm/models/MoveHelper.d.ts +66 -0
  154. package/esm/models/MoveHelper.js +363 -0
  155. package/esm/models/Operation.d.ts +29 -0
  156. package/esm/models/Operation.js +75 -0
  157. package/esm/models/Screen.d.ts +31 -0
  158. package/esm/models/Screen.js +73 -0
  159. package/esm/models/Selection.d.ts +29 -0
  160. package/esm/models/Selection.js +192 -0
  161. package/esm/models/Shortcut.d.ts +20 -0
  162. package/esm/models/Shortcut.js +69 -0
  163. package/esm/models/SnapLine.d.ts +27 -0
  164. package/esm/models/SnapLine.js +141 -0
  165. package/esm/models/SpaceBlock.d.ts +40 -0
  166. package/esm/models/SpaceBlock.js +171 -0
  167. package/esm/models/TransformHelper.d.ts +80 -0
  168. package/esm/models/TransformHelper.js +601 -0
  169. package/esm/models/TreeNode.d.ts +115 -0
  170. package/esm/models/TreeNode.js +932 -0
  171. package/esm/models/Viewport.d.ts +90 -0
  172. package/esm/models/Viewport.js +474 -0
  173. package/esm/models/Workbench.d.ts +23 -0
  174. package/esm/models/Workbench.js +98 -0
  175. package/esm/models/Workspace.d.ts +41 -0
  176. package/esm/models/Workspace.js +95 -0
  177. package/esm/models/index.d.ts +13 -0
  178. package/esm/models/index.js +13 -0
  179. package/esm/presets.d.ts +4 -0
  180. package/esm/presets.js +38 -0
  181. package/esm/registry.d.ts +16 -0
  182. package/esm/registry.js +123 -0
  183. package/esm/shortcuts/CursorSwitch.d.ts +2 -0
  184. package/esm/shortcuts/CursorSwitch.js +10 -0
  185. package/esm/shortcuts/MultiSelection.d.ts +5 -0
  186. package/esm/shortcuts/MultiSelection.js +27 -0
  187. package/esm/shortcuts/NodeMutation.d.ts +7 -0
  188. package/esm/shortcuts/NodeMutation.js +40 -0
  189. package/esm/shortcuts/QuickSelection.d.ts +3 -0
  190. package/esm/shortcuts/QuickSelection.js +85 -0
  191. package/esm/shortcuts/UndoRedo.d.ts +3 -0
  192. package/esm/shortcuts/UndoRedo.js +27 -0
  193. package/esm/shortcuts/index.d.ts +5 -0
  194. package/esm/shortcuts/index.js +5 -0
  195. package/esm/types.d.ts +131 -0
  196. package/esm/types.js +1 -0
  197. package/lib/drivers/DragDropDriver.d.ts +14 -0
  198. package/lib/drivers/DragDropDriver.js +160 -0
  199. package/lib/drivers/KeyboardDriver.d.ts +7 -0
  200. package/lib/drivers/KeyboardDriver.js +93 -0
  201. package/lib/drivers/MouseClickDriver.d.ts +8 -0
  202. package/lib/drivers/MouseClickDriver.js +98 -0
  203. package/lib/drivers/MouseMoveDriver.d.ts +8 -0
  204. package/lib/drivers/MouseMoveDriver.js +78 -0
  205. package/lib/drivers/ViewportResizeDriver.d.ts +10 -0
  206. package/lib/drivers/ViewportResizeDriver.js +98 -0
  207. package/lib/drivers/ViewportScrollDriver.d.ts +8 -0
  208. package/lib/drivers/ViewportScrollDriver.js +77 -0
  209. package/lib/drivers/index.d.ts +6 -0
  210. package/lib/drivers/index.js +22 -0
  211. package/lib/effects/index.d.ts +11 -0
  212. package/lib/effects/index.js +27 -0
  213. package/lib/effects/useAutoScrollEffect.d.ts +2 -0
  214. package/lib/effects/useAutoScrollEffect.js +69 -0
  215. package/lib/effects/useContentEditableEffect.d.ts +2 -0
  216. package/lib/effects/useContentEditableEffect.js +171 -0
  217. package/lib/effects/useCursorEffect.d.ts +2 -0
  218. package/lib/effects/useCursorEffect.js +59 -0
  219. package/lib/effects/useDragDropEffect.d.ts +2 -0
  220. package/lib/effects/useDragDropEffect.js +172 -0
  221. package/lib/effects/useFreeSelectionEffect.d.ts +2 -0
  222. package/lib/effects/useFreeSelectionEffect.js +63 -0
  223. package/lib/effects/useKeyboardEffect.d.ts +2 -0
  224. package/lib/effects/useKeyboardEffect.js +21 -0
  225. package/lib/effects/useResizeEffect.d.ts +2 -0
  226. package/lib/effects/useResizeEffect.js +84 -0
  227. package/lib/effects/useSelectionEffect.d.ts +2 -0
  228. package/lib/effects/useSelectionEffect.js +72 -0
  229. package/lib/effects/useTranslateEffect.d.ts +2 -0
  230. package/lib/effects/useTranslateEffect.js +62 -0
  231. package/lib/effects/useViewportEffect.d.ts +2 -0
  232. package/lib/effects/useViewportEffect.js +35 -0
  233. package/lib/effects/useWorkspaceEffect.d.ts +2 -0
  234. package/lib/effects/useWorkspaceEffect.js +33 -0
  235. package/lib/events/cursor/AbstractCursorEvent.d.ts +21 -0
  236. package/lib/events/cursor/AbstractCursorEvent.js +43 -0
  237. package/lib/events/cursor/DragMoveEvent.d.ts +5 -0
  238. package/lib/events/cursor/DragMoveEvent.js +54 -0
  239. package/lib/events/cursor/DragStartEvent.d.ts +5 -0
  240. package/lib/events/cursor/DragStartEvent.js +54 -0
  241. package/lib/events/cursor/DragStopEvent.d.ts +5 -0
  242. package/lib/events/cursor/DragStopEvent.js +54 -0
  243. package/lib/events/cursor/MouseClickEvent.d.ts +8 -0
  244. package/lib/events/cursor/MouseClickEvent.js +64 -0
  245. package/lib/events/cursor/MouseMoveEvent.d.ts +5 -0
  246. package/lib/events/cursor/MouseMoveEvent.js +54 -0
  247. package/lib/events/cursor/index.d.ts +5 -0
  248. package/lib/events/cursor/index.js +21 -0
  249. package/lib/events/history/AbstractHistoryEvent.d.ts +6 -0
  250. package/lib/events/history/AbstractHistoryEvent.js +10 -0
  251. package/lib/events/history/HistoryGotoEvent.d.ts +5 -0
  252. package/lib/events/history/HistoryGotoEvent.js +54 -0
  253. package/lib/events/history/HistoryPushEvent.d.ts +5 -0
  254. package/lib/events/history/HistoryPushEvent.js +54 -0
  255. package/lib/events/history/HistoryRedoEvent.d.ts +5 -0
  256. package/lib/events/history/HistoryRedoEvent.js +54 -0
  257. package/lib/events/history/HistoryUndoEvent.d.ts +5 -0
  258. package/lib/events/history/HistoryUndoEvent.js +54 -0
  259. package/lib/events/history/index.d.ts +4 -0
  260. package/lib/events/history/index.js +20 -0
  261. package/lib/events/index.d.ts +6 -0
  262. package/lib/events/index.js +22 -0
  263. package/lib/events/keyboard/AbstractKeyboardEvent.d.ts +15 -0
  264. package/lib/events/keyboard/AbstractKeyboardEvent.js +64 -0
  265. package/lib/events/keyboard/KeyDownEvent.d.ts +5 -0
  266. package/lib/events/keyboard/KeyDownEvent.js +54 -0
  267. package/lib/events/keyboard/KeyUpEvent.d.ts +5 -0
  268. package/lib/events/keyboard/KeyUpEvent.js +54 -0
  269. package/lib/events/keyboard/index.d.ts +2 -0
  270. package/lib/events/keyboard/index.js +18 -0
  271. package/lib/events/mutation/AbstractMutationNodeEvent.d.ts +13 -0
  272. package/lib/events/mutation/AbstractMutationNodeEvent.js +10 -0
  273. package/lib/events/mutation/AppendNodeEvent.d.ts +5 -0
  274. package/lib/events/mutation/AppendNodeEvent.js +54 -0
  275. package/lib/events/mutation/CloneNodeEvent.d.ts +5 -0
  276. package/lib/events/mutation/CloneNodeEvent.js +54 -0
  277. package/lib/events/mutation/DragNodeEvent.d.ts +5 -0
  278. package/lib/events/mutation/DragNodeEvent.js +54 -0
  279. package/lib/events/mutation/DropNodeEvent.d.ts +5 -0
  280. package/lib/events/mutation/DropNodeEvent.js +54 -0
  281. package/lib/events/mutation/FromNodeEvent.d.ts +13 -0
  282. package/lib/events/mutation/FromNodeEvent.js +11 -0
  283. package/lib/events/mutation/HoverNodeEvent.d.ts +5 -0
  284. package/lib/events/mutation/HoverNodeEvent.js +54 -0
  285. package/lib/events/mutation/InsertAfterEvent.d.ts +5 -0
  286. package/lib/events/mutation/InsertAfterEvent.js +54 -0
  287. package/lib/events/mutation/InsertBeforeEvent.d.ts +5 -0
  288. package/lib/events/mutation/InsertBeforeEvent.js +54 -0
  289. package/lib/events/mutation/InsertChildrenEvent.d.ts +5 -0
  290. package/lib/events/mutation/InsertChildrenEvent.js +54 -0
  291. package/lib/events/mutation/PrependNodeEvent.d.ts +5 -0
  292. package/lib/events/mutation/PrependNodeEvent.js +54 -0
  293. package/lib/events/mutation/RemoveNodeEvent.d.ts +5 -0
  294. package/lib/events/mutation/RemoveNodeEvent.js +54 -0
  295. package/lib/events/mutation/SelectNodeEvent.d.ts +5 -0
  296. package/lib/events/mutation/SelectNodeEvent.js +54 -0
  297. package/lib/events/mutation/UnSelectNodeEvent.d.ts +5 -0
  298. package/lib/events/mutation/UnSelectNodeEvent.js +54 -0
  299. package/lib/events/mutation/UpdateChildrenEvent.d.ts +5 -0
  300. package/lib/events/mutation/UpdateChildrenEvent.js +54 -0
  301. package/lib/events/mutation/UpdateNodePropsEvent.d.ts +5 -0
  302. package/lib/events/mutation/UpdateNodePropsEvent.js +54 -0
  303. package/lib/events/mutation/UserSelectNodeEvent.d.ts +5 -0
  304. package/lib/events/mutation/UserSelectNodeEvent.js +54 -0
  305. package/lib/events/mutation/WrapNodeEvent.d.ts +5 -0
  306. package/lib/events/mutation/WrapNodeEvent.js +54 -0
  307. package/lib/events/mutation/index.d.ts +16 -0
  308. package/lib/events/mutation/index.js +32 -0
  309. package/lib/events/viewport/AbstractViewportEvent.d.ts +16 -0
  310. package/lib/events/viewport/AbstractViewportEvent.js +20 -0
  311. package/lib/events/viewport/ViewportResizeEvent.d.ts +5 -0
  312. package/lib/events/viewport/ViewportResizeEvent.js +54 -0
  313. package/lib/events/viewport/ViewportScrollEvent.d.ts +5 -0
  314. package/lib/events/viewport/ViewportScrollEvent.js +54 -0
  315. package/lib/events/viewport/index.d.ts +2 -0
  316. package/lib/events/viewport/index.js +18 -0
  317. package/lib/events/workbench/AbstractWorkspaceEvent.d.ts +7 -0
  318. package/lib/events/workbench/AbstractWorkspaceEvent.js +10 -0
  319. package/lib/events/workbench/AddWorkspaceEvent.d.ts +5 -0
  320. package/lib/events/workbench/AddWorkspaceEvent.js +54 -0
  321. package/lib/events/workbench/RemoveWorkspaceEvent.d.ts +5 -0
  322. package/lib/events/workbench/RemoveWorkspaceEvent.js +54 -0
  323. package/lib/events/workbench/SwitchWorkspaceEvent.d.ts +5 -0
  324. package/lib/events/workbench/SwitchWorkspaceEvent.js +54 -0
  325. package/lib/events/workbench/index.d.ts +3 -0
  326. package/lib/events/workbench/index.js +19 -0
  327. package/lib/exports.d.ts +5 -0
  328. package/lib/exports.js +21 -0
  329. package/lib/externals.d.ts +12 -0
  330. package/lib/externals.js +126 -0
  331. package/lib/index.d.ts +1 -0
  332. package/lib/index.js +52 -0
  333. package/lib/internals.d.ts +3 -0
  334. package/lib/internals.js +40 -0
  335. package/lib/models/Cursor.d.ts +60 -0
  336. package/lib/models/Cursor.js +154 -0
  337. package/lib/models/Engine.d.ts +29 -0
  338. package/lib/models/Engine.js +115 -0
  339. package/lib/models/History.d.ts +34 -0
  340. package/lib/models/History.js +113 -0
  341. package/lib/models/Hover.d.ts +14 -0
  342. package/lib/models/Hover.js +41 -0
  343. package/lib/models/Keyboard.d.ts +29 -0
  344. package/lib/models/Keyboard.js +129 -0
  345. package/lib/models/MoveHelper.d.ts +66 -0
  346. package/lib/models/MoveHelper.js +366 -0
  347. package/lib/models/Operation.d.ts +29 -0
  348. package/lib/models/Operation.js +78 -0
  349. package/lib/models/Screen.d.ts +31 -0
  350. package/lib/models/Screen.js +76 -0
  351. package/lib/models/Selection.d.ts +29 -0
  352. package/lib/models/Selection.js +195 -0
  353. package/lib/models/Shortcut.d.ts +20 -0
  354. package/lib/models/Shortcut.js +72 -0
  355. package/lib/models/SnapLine.d.ts +27 -0
  356. package/lib/models/SnapLine.js +144 -0
  357. package/lib/models/SpaceBlock.d.ts +40 -0
  358. package/lib/models/SpaceBlock.js +174 -0
  359. package/lib/models/TransformHelper.d.ts +80 -0
  360. package/lib/models/TransformHelper.js +604 -0
  361. package/lib/models/TreeNode.d.ts +115 -0
  362. package/lib/models/TreeNode.js +935 -0
  363. package/lib/models/Viewport.d.ts +90 -0
  364. package/lib/models/Viewport.js +477 -0
  365. package/lib/models/Workbench.d.ts +23 -0
  366. package/lib/models/Workbench.js +101 -0
  367. package/lib/models/Workspace.d.ts +41 -0
  368. package/lib/models/Workspace.js +98 -0
  369. package/lib/models/index.d.ts +13 -0
  370. package/lib/models/index.js +29 -0
  371. package/lib/presets.d.ts +4 -0
  372. package/lib/presets.js +41 -0
  373. package/lib/registry.d.ts +16 -0
  374. package/lib/registry.js +126 -0
  375. package/lib/shortcuts/CursorSwitch.d.ts +2 -0
  376. package/lib/shortcuts/CursorSwitch.js +13 -0
  377. package/lib/shortcuts/MultiSelection.d.ts +5 -0
  378. package/lib/shortcuts/MultiSelection.js +30 -0
  379. package/lib/shortcuts/NodeMutation.d.ts +7 -0
  380. package/lib/shortcuts/NodeMutation.js +43 -0
  381. package/lib/shortcuts/QuickSelection.d.ts +3 -0
  382. package/lib/shortcuts/QuickSelection.js +88 -0
  383. package/lib/shortcuts/UndoRedo.d.ts +3 -0
  384. package/lib/shortcuts/UndoRedo.js +30 -0
  385. package/lib/shortcuts/index.d.ts +5 -0
  386. package/lib/shortcuts/index.js +21 -0
  387. package/lib/types.d.ts +131 -0
  388. package/lib/types.js +2 -0
  389. package/package.json +49 -0
@@ -0,0 +1,14 @@
1
+ import { Operation } from './Operation';
2
+ import { TreeNode } from './TreeNode';
3
+ export interface IHoverProps {
4
+ operation: Operation;
5
+ }
6
+ export declare class Hover {
7
+ node: TreeNode;
8
+ operation: Operation;
9
+ constructor(props?: IHoverProps);
10
+ setHover(node?: TreeNode): void;
11
+ clear(): void;
12
+ trigger(): unknown;
13
+ makeObservable(): void;
14
+ }
@@ -0,0 +1,38 @@
1
+ import { observable, define, action } from '@formily/reactive';
2
+ import { HoverNodeEvent } from '../events';
3
+ var Hover = /** @class */ (function () {
4
+ function Hover(props) {
5
+ this.node = null;
6
+ this.operation = props === null || props === void 0 ? void 0 : props.operation;
7
+ this.makeObservable();
8
+ }
9
+ Hover.prototype.setHover = function (node) {
10
+ if (node) {
11
+ this.node = node;
12
+ }
13
+ else {
14
+ this.node = null;
15
+ }
16
+ this.trigger();
17
+ };
18
+ Hover.prototype.clear = function () {
19
+ this.node = null;
20
+ };
21
+ Hover.prototype.trigger = function () {
22
+ if (this.operation) {
23
+ return this.operation.dispatch(new HoverNodeEvent({
24
+ target: this.operation.tree,
25
+ source: this.node,
26
+ }));
27
+ }
28
+ };
29
+ Hover.prototype.makeObservable = function () {
30
+ define(this, {
31
+ node: observable.ref,
32
+ setHover: action,
33
+ clear: action,
34
+ });
35
+ };
36
+ return Hover;
37
+ }());
38
+ export { Hover };
@@ -0,0 +1,29 @@
1
+ import { KeyCode } from '@mdesignable/shared';
2
+ import { Engine } from './Engine';
3
+ import { Shortcut } from './Shortcut';
4
+ import { AbstractKeyboardEvent } from '../events/keyboard/AbstractKeyboardEvent';
5
+ import { IEngineContext } from '../types';
6
+ export interface IKeyboard {
7
+ engine: Engine;
8
+ }
9
+ export declare class Keyboard {
10
+ engine: Engine;
11
+ shortcuts: Shortcut[];
12
+ sequence: KeyCode[];
13
+ keyDown: KeyCode;
14
+ modifiers: {};
15
+ requestTimer: any;
16
+ constructor(engine?: Engine);
17
+ matchCodes(context: IEngineContext): boolean;
18
+ preventCodes(): boolean;
19
+ includes(key: KeyCode): boolean;
20
+ excludes(key: KeyCode): void;
21
+ addKeyCode(key: KeyCode): void;
22
+ removeKeyCode(key: KeyCode): void;
23
+ isModifier(code: KeyCode): boolean;
24
+ handleModifiers(event: AbstractKeyboardEvent): void;
25
+ handleKeyboard(event: AbstractKeyboardEvent, context: IEngineContext): void;
26
+ isKeyDown(code: KeyCode): boolean;
27
+ requestClean(duration?: number): void;
28
+ makeObservable(): void;
29
+ }
@@ -0,0 +1,126 @@
1
+ var __read = (this && this.__read) || function (o, n) {
2
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
3
+ if (!m) return o;
4
+ var i = m.call(o), r, ar = [], e;
5
+ try {
6
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
7
+ }
8
+ catch (error) { e = { error: error }; }
9
+ finally {
10
+ try {
11
+ if (r && !r.done && (m = i["return"])) m.call(i);
12
+ }
13
+ finally { if (e) throw e.error; }
14
+ }
15
+ return ar;
16
+ };
17
+ import { observable, define, action } from '@formily/reactive';
18
+ import { KeyCode } from '@mdesignable/shared';
19
+ import { Shortcut } from './Shortcut';
20
+ var Modifiers = [
21
+ ['metaKey', KeyCode.Meta],
22
+ ['shiftKey', KeyCode.Shift],
23
+ ['ctrlKey', KeyCode.Control],
24
+ ['altKey', KeyCode.Alt],
25
+ ];
26
+ var Keyboard = /** @class */ (function () {
27
+ function Keyboard(engine) {
28
+ var _a;
29
+ this.shortcuts = [];
30
+ this.sequence = [];
31
+ this.keyDown = null;
32
+ this.modifiers = {};
33
+ this.requestTimer = null;
34
+ this.engine = engine;
35
+ this.shortcuts = ((_a = engine.props) === null || _a === void 0 ? void 0 : _a.shortcuts) || [];
36
+ this.makeObservable();
37
+ }
38
+ Keyboard.prototype.matchCodes = function (context) {
39
+ for (var i = 0; i < this.shortcuts.length; i++) {
40
+ var shortcut = this.shortcuts[i];
41
+ if (shortcut.match(this.sequence, context)) {
42
+ return true;
43
+ }
44
+ }
45
+ return false;
46
+ };
47
+ Keyboard.prototype.preventCodes = function () {
48
+ var _this = this;
49
+ return this.shortcuts.some(function (shortcut) {
50
+ return shortcut.preventCodes(_this.sequence);
51
+ });
52
+ };
53
+ Keyboard.prototype.includes = function (key) {
54
+ return this.sequence.some(function (code) { return Shortcut.matchCode(code, key); });
55
+ };
56
+ Keyboard.prototype.excludes = function (key) {
57
+ this.sequence = this.sequence.filter(function (code) { return !Shortcut.matchCode(key, code); });
58
+ };
59
+ Keyboard.prototype.addKeyCode = function (key) {
60
+ if (!this.includes(key)) {
61
+ this.sequence.push(key);
62
+ }
63
+ };
64
+ Keyboard.prototype.removeKeyCode = function (key) {
65
+ if (this.includes(key)) {
66
+ this.excludes(key);
67
+ }
68
+ };
69
+ Keyboard.prototype.isModifier = function (code) {
70
+ return Modifiers.some(function (modifier) { return Shortcut.matchCode(modifier[1], code); });
71
+ };
72
+ Keyboard.prototype.handleModifiers = function (event) {
73
+ var _this = this;
74
+ Modifiers.forEach(function (_a) {
75
+ var _b = __read(_a, 2), key = _b[0], code = _b[1];
76
+ if (event[key]) {
77
+ if (!_this.includes(code)) {
78
+ _this.sequence = [code].concat(_this.sequence);
79
+ }
80
+ }
81
+ });
82
+ };
83
+ Keyboard.prototype.handleKeyboard = function (event, context) {
84
+ if (event.eventType === 'keydown') {
85
+ this.keyDown = event.data;
86
+ this.addKeyCode(this.keyDown);
87
+ this.handleModifiers(event);
88
+ if (this.matchCodes(context)) {
89
+ this.sequence = [];
90
+ }
91
+ this.requestClean(4000);
92
+ if (this.preventCodes()) {
93
+ event.preventDefault();
94
+ event.stopPropagation();
95
+ }
96
+ }
97
+ else {
98
+ if (this.isModifier(event.data)) {
99
+ this.sequence = [];
100
+ }
101
+ this.keyDown = null;
102
+ }
103
+ };
104
+ Keyboard.prototype.isKeyDown = function (code) {
105
+ return this.keyDown === code;
106
+ };
107
+ Keyboard.prototype.requestClean = function (duration) {
108
+ var _this = this;
109
+ if (duration === void 0) { duration = 320; }
110
+ clearTimeout(this.requestTimer);
111
+ this.requestTimer = setTimeout(function () {
112
+ _this.keyDown = null;
113
+ _this.sequence = [];
114
+ clearTimeout(_this.requestTimer);
115
+ }, duration);
116
+ };
117
+ Keyboard.prototype.makeObservable = function () {
118
+ define(this, {
119
+ sequence: observable.shallow,
120
+ keyDown: observable.ref,
121
+ handleKeyboard: action,
122
+ });
123
+ };
124
+ return Keyboard;
125
+ }());
126
+ export { Keyboard };
@@ -0,0 +1,66 @@
1
+ import { Operation } from './Operation';
2
+ import { TreeNode } from './TreeNode';
3
+ import { IPoint, Rect } from '@mdesignable/shared';
4
+ import { Viewport } from './Viewport';
5
+ export declare enum ClosestPosition {
6
+ Before = "BEFORE",
7
+ ForbidBefore = "FORBID_BEFORE",
8
+ After = "After",
9
+ ForbidAfter = "FORBID_AFTER",
10
+ Upper = "UPPER",
11
+ ForbidUpper = "FORBID_UPPER",
12
+ Under = "UNDER",
13
+ ForbidUnder = "FORBID_UNDER",
14
+ Inner = "INNER",
15
+ ForbidInner = "FORBID_INNER",
16
+ InnerAfter = "INNER_AFTER",
17
+ ForbidInnerAfter = "FORBID_INNER_AFTER",
18
+ InnerBefore = "INNER_BEFORE",
19
+ ForbidInnerBefore = "FORBID_INNER_BEFORE",
20
+ Forbid = "FORBID"
21
+ }
22
+ export interface IMoveHelperProps {
23
+ operation: Operation;
24
+ }
25
+ export interface IMoveHelperDragStartProps {
26
+ dragNodes: TreeNode[];
27
+ }
28
+ export interface IMoveHelperDragDropProps {
29
+ dropNode: TreeNode;
30
+ }
31
+ export interface IMoveHelperDragMoveProps {
32
+ touchNode: TreeNode;
33
+ point: IPoint;
34
+ }
35
+ export declare class MoveHelper {
36
+ operation: Operation;
37
+ rootNode: TreeNode;
38
+ dragNodes: TreeNode[];
39
+ touchNode: TreeNode;
40
+ closestNode: TreeNode;
41
+ activeViewport: Viewport;
42
+ viewportClosestRect: Rect;
43
+ outlineClosestRect: Rect;
44
+ viewportClosestOffsetRect: Rect;
45
+ outlineClosestOffsetRect: Rect;
46
+ viewportClosestDirection: ClosestPosition;
47
+ outlineClosestDirection: ClosestPosition;
48
+ dragging: boolean;
49
+ constructor(props: IMoveHelperProps);
50
+ get cursor(): import("./Cursor").Cursor;
51
+ get viewport(): Viewport;
52
+ get outline(): Viewport;
53
+ get hasDragNodes(): boolean;
54
+ get closestDirection(): ClosestPosition;
55
+ getClosestLayout(viewport: Viewport): "vertical" | "horizontal";
56
+ calcClosestPosition(point: IPoint, viewport: Viewport): ClosestPosition;
57
+ calcClosestNode(point: IPoint, viewport: Viewport): TreeNode;
58
+ calcClosestRect(viewport: Viewport, closestDirection: ClosestPosition): Rect;
59
+ calcClosestOffsetRect(viewport: Viewport, closestDirection: ClosestPosition): Rect;
60
+ dragStart(props: IMoveHelperDragStartProps): void;
61
+ dragMove(props: IMoveHelperDragMoveProps): void;
62
+ dragDrop(props: IMoveHelperDragDropProps): void;
63
+ dragEnd(): void;
64
+ trigger(event: any): unknown;
65
+ makeObservable(): void;
66
+ }
@@ -0,0 +1,363 @@
1
+ var __read = (this && this.__read) || function (o, n) {
2
+ var m = typeof Symbol === "function" && o[Symbol.iterator];
3
+ if (!m) return o;
4
+ var i = m.call(o), r, ar = [], e;
5
+ try {
6
+ while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
7
+ }
8
+ catch (error) { e = { error: error }; }
9
+ finally {
10
+ try {
11
+ if (r && !r.done && (m = i["return"])) m.call(i);
12
+ }
13
+ finally { if (e) throw e.error; }
14
+ }
15
+ return ar;
16
+ };
17
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
18
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
19
+ if (ar || !(i in from)) {
20
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
21
+ ar[i] = from[i];
22
+ }
23
+ }
24
+ return to.concat(ar || Array.prototype.slice.call(from));
25
+ };
26
+ import { TreeNode } from './TreeNode';
27
+ import { observable, define, action } from '@formily/reactive';
28
+ import { calcDistanceOfPointToRect, calcDistancePointToEdge, isNearAfter, isPointInRect, } from '@mdesignable/shared';
29
+ import { DragNodeEvent, DropNodeEvent } from '../events';
30
+ import { CursorDragType } from './Cursor';
31
+ export var ClosestPosition;
32
+ (function (ClosestPosition) {
33
+ ClosestPosition["Before"] = "BEFORE";
34
+ ClosestPosition["ForbidBefore"] = "FORBID_BEFORE";
35
+ ClosestPosition["After"] = "After";
36
+ ClosestPosition["ForbidAfter"] = "FORBID_AFTER";
37
+ ClosestPosition["Upper"] = "UPPER";
38
+ ClosestPosition["ForbidUpper"] = "FORBID_UPPER";
39
+ ClosestPosition["Under"] = "UNDER";
40
+ ClosestPosition["ForbidUnder"] = "FORBID_UNDER";
41
+ ClosestPosition["Inner"] = "INNER";
42
+ ClosestPosition["ForbidInner"] = "FORBID_INNER";
43
+ ClosestPosition["InnerAfter"] = "INNER_AFTER";
44
+ ClosestPosition["ForbidInnerAfter"] = "FORBID_INNER_AFTER";
45
+ ClosestPosition["InnerBefore"] = "INNER_BEFORE";
46
+ ClosestPosition["ForbidInnerBefore"] = "FORBID_INNER_BEFORE";
47
+ ClosestPosition["Forbid"] = "FORBID";
48
+ })(ClosestPosition || (ClosestPosition = {}));
49
+ var MoveHelper = /** @class */ (function () {
50
+ function MoveHelper(props) {
51
+ this.dragNodes = [];
52
+ this.touchNode = null;
53
+ this.closestNode = null;
54
+ this.activeViewport = null;
55
+ this.viewportClosestRect = null;
56
+ this.outlineClosestRect = null;
57
+ this.viewportClosestOffsetRect = null;
58
+ this.outlineClosestOffsetRect = null;
59
+ this.viewportClosestDirection = null;
60
+ this.outlineClosestDirection = null;
61
+ this.dragging = false;
62
+ this.operation = props.operation;
63
+ this.rootNode = this.operation.tree;
64
+ this.makeObservable();
65
+ }
66
+ Object.defineProperty(MoveHelper.prototype, "cursor", {
67
+ get: function () {
68
+ return this.operation.engine.cursor;
69
+ },
70
+ enumerable: false,
71
+ configurable: true
72
+ });
73
+ Object.defineProperty(MoveHelper.prototype, "viewport", {
74
+ get: function () {
75
+ return this.operation.workspace.viewport;
76
+ },
77
+ enumerable: false,
78
+ configurable: true
79
+ });
80
+ Object.defineProperty(MoveHelper.prototype, "outline", {
81
+ get: function () {
82
+ return this.operation.workspace.outline;
83
+ },
84
+ enumerable: false,
85
+ configurable: true
86
+ });
87
+ Object.defineProperty(MoveHelper.prototype, "hasDragNodes", {
88
+ get: function () {
89
+ return this.dragNodes.length > 0;
90
+ },
91
+ enumerable: false,
92
+ configurable: true
93
+ });
94
+ Object.defineProperty(MoveHelper.prototype, "closestDirection", {
95
+ get: function () {
96
+ if (this.activeViewport === this.outline) {
97
+ return this.outlineClosestDirection;
98
+ }
99
+ return this.viewportClosestDirection;
100
+ },
101
+ enumerable: false,
102
+ configurable: true
103
+ });
104
+ MoveHelper.prototype.getClosestLayout = function (viewport) {
105
+ return viewport.getValidNodeLayout(this.closestNode);
106
+ };
107
+ MoveHelper.prototype.calcClosestPosition = function (point, viewport) {
108
+ var _this = this;
109
+ var closestNode = this.closestNode;
110
+ if (!closestNode || !viewport.isPointInViewport(point))
111
+ return ClosestPosition.Forbid;
112
+ var closestRect = viewport.getValidNodeRect(closestNode);
113
+ var isInline = this.getClosestLayout(viewport) === 'horizontal';
114
+ if (!closestRect) {
115
+ return;
116
+ }
117
+ var isAfter = isNearAfter(point, closestRect, viewport.moveInsertionType === 'block' ? false : isInline);
118
+ var getValidParent = function (node) {
119
+ var _a;
120
+ if (!node)
121
+ return;
122
+ if ((_a = node.parent) === null || _a === void 0 ? void 0 : _a.allowSibling(_this.dragNodes))
123
+ return node.parent;
124
+ return getValidParent(node.parent);
125
+ };
126
+ if (isPointInRect(point, closestRect, viewport.moveSensitive)) {
127
+ if (!closestNode.allowAppend(this.dragNodes)) {
128
+ if (!closestNode.allowSibling(this.dragNodes)) {
129
+ var parentClosestNode = getValidParent(closestNode);
130
+ if (parentClosestNode) {
131
+ this.closestNode = parentClosestNode;
132
+ }
133
+ if (isInline) {
134
+ if (parentClosestNode) {
135
+ if (isAfter) {
136
+ return ClosestPosition.After;
137
+ }
138
+ return ClosestPosition.Before;
139
+ }
140
+ if (isAfter) {
141
+ return ClosestPosition.ForbidAfter;
142
+ }
143
+ return ClosestPosition.ForbidBefore;
144
+ }
145
+ else {
146
+ if (parentClosestNode) {
147
+ if (isAfter) {
148
+ return ClosestPosition.Under;
149
+ }
150
+ return ClosestPosition.Upper;
151
+ }
152
+ if (isAfter) {
153
+ return ClosestPosition.ForbidUnder;
154
+ }
155
+ return ClosestPosition.ForbidUpper;
156
+ }
157
+ }
158
+ else {
159
+ if (isInline) {
160
+ return isAfter ? ClosestPosition.After : ClosestPosition.Before;
161
+ }
162
+ else {
163
+ return isAfter ? ClosestPosition.Under : ClosestPosition.Upper;
164
+ }
165
+ }
166
+ }
167
+ if (closestNode.contains.apply(closestNode, __spreadArray([], __read(this.dragNodes), false))) {
168
+ if (isAfter) {
169
+ return ClosestPosition.InnerAfter;
170
+ }
171
+ return ClosestPosition.InnerBefore;
172
+ }
173
+ else {
174
+ return ClosestPosition.Inner;
175
+ }
176
+ }
177
+ else if (closestNode === closestNode.root) {
178
+ return isAfter ? ClosestPosition.InnerAfter : ClosestPosition.InnerBefore;
179
+ }
180
+ else {
181
+ if (!closestNode.allowSibling(this.dragNodes)) {
182
+ var parentClosestNode = getValidParent(closestNode);
183
+ if (parentClosestNode) {
184
+ this.closestNode = parentClosestNode;
185
+ }
186
+ if (isInline) {
187
+ if (parentClosestNode) {
188
+ if (isAfter) {
189
+ return ClosestPosition.After;
190
+ }
191
+ return ClosestPosition.Before;
192
+ }
193
+ return isAfter
194
+ ? ClosestPosition.ForbidAfter
195
+ : ClosestPosition.ForbidBefore;
196
+ }
197
+ else {
198
+ if (parentClosestNode) {
199
+ if (isAfter) {
200
+ return ClosestPosition.Under;
201
+ }
202
+ return ClosestPosition.Upper;
203
+ }
204
+ return isAfter
205
+ ? ClosestPosition.ForbidUnder
206
+ : ClosestPosition.ForbidUpper;
207
+ }
208
+ }
209
+ if (isInline) {
210
+ return isAfter ? ClosestPosition.After : ClosestPosition.Before;
211
+ }
212
+ else {
213
+ return isAfter ? ClosestPosition.Under : ClosestPosition.Upper;
214
+ }
215
+ }
216
+ };
217
+ MoveHelper.prototype.calcClosestNode = function (point, viewport) {
218
+ var _a, _b;
219
+ if (this.touchNode) {
220
+ var touchNodeRect = viewport.getValidNodeRect(this.touchNode);
221
+ if (!touchNodeRect)
222
+ return;
223
+ if ((_b = (_a = this.touchNode) === null || _a === void 0 ? void 0 : _a.children) === null || _b === void 0 ? void 0 : _b.length) {
224
+ var touchDistance = calcDistancePointToEdge(point, touchNodeRect);
225
+ var minDistance_1 = touchDistance;
226
+ var minDistanceNode_1 = this.touchNode;
227
+ this.touchNode.eachChildren(function (node) {
228
+ var rect = viewport.getElementRectById(node.id);
229
+ if (!rect)
230
+ return;
231
+ var distance = isPointInRect(point, rect, viewport.moveSensitive)
232
+ ? 0
233
+ : calcDistanceOfPointToRect(point, rect);
234
+ if (distance <= minDistance_1) {
235
+ minDistance_1 = distance;
236
+ minDistanceNode_1 = node;
237
+ }
238
+ });
239
+ return minDistanceNode_1;
240
+ }
241
+ else {
242
+ return this.touchNode;
243
+ }
244
+ }
245
+ return this.operation.tree;
246
+ };
247
+ MoveHelper.prototype.calcClosestRect = function (viewport, closestDirection) {
248
+ var closestNode = this.closestNode;
249
+ if (!closestNode || !closestDirection)
250
+ return;
251
+ var closestRect = viewport.getValidNodeRect(closestNode);
252
+ if (closestDirection === ClosestPosition.InnerAfter ||
253
+ closestDirection === ClosestPosition.InnerBefore) {
254
+ return viewport.getChildrenRect(closestNode);
255
+ }
256
+ else {
257
+ return closestRect;
258
+ }
259
+ };
260
+ MoveHelper.prototype.calcClosestOffsetRect = function (viewport, closestDirection) {
261
+ var closestNode = this.closestNode;
262
+ if (!closestNode || !closestDirection)
263
+ return;
264
+ var closestRect = viewport.getValidNodeOffsetRect(closestNode);
265
+ if (closestDirection === ClosestPosition.InnerAfter ||
266
+ closestDirection === ClosestPosition.InnerBefore) {
267
+ return viewport.getChildrenOffsetRect(closestNode);
268
+ }
269
+ else {
270
+ return closestRect;
271
+ }
272
+ };
273
+ MoveHelper.prototype.dragStart = function (props) {
274
+ var nodes = TreeNode.filterDraggable(props === null || props === void 0 ? void 0 : props.dragNodes);
275
+ if (nodes.length) {
276
+ this.dragNodes = nodes;
277
+ this.trigger(new DragNodeEvent({
278
+ target: this.operation.tree,
279
+ source: this.dragNodes,
280
+ }));
281
+ this.viewport.cacheElements();
282
+ this.cursor.setDragType(CursorDragType.Move);
283
+ this.dragging = true;
284
+ }
285
+ };
286
+ MoveHelper.prototype.dragMove = function (props) {
287
+ var point = props.point, touchNode = props.touchNode;
288
+ if (!this.dragging)
289
+ return;
290
+ if (this.outline.isPointInViewport(point, false)) {
291
+ this.activeViewport = this.outline;
292
+ this.touchNode = touchNode;
293
+ this.closestNode = this.calcClosestNode(point, this.outline);
294
+ }
295
+ else if (this.viewport.isPointInViewport(point, false)) {
296
+ this.activeViewport = this.viewport;
297
+ this.touchNode = touchNode;
298
+ this.closestNode = this.calcClosestNode(point, this.viewport);
299
+ }
300
+ if (!this.activeViewport)
301
+ return;
302
+ if (this.activeViewport === this.outline) {
303
+ this.outlineClosestDirection = this.calcClosestPosition(point, this.outline);
304
+ this.viewportClosestDirection = this.outlineClosestDirection;
305
+ }
306
+ else {
307
+ this.viewportClosestDirection = this.calcClosestPosition(point, this.viewport);
308
+ this.outlineClosestDirection = this.viewportClosestDirection;
309
+ }
310
+ if (this.outline.mounted) {
311
+ this.outlineClosestRect = this.calcClosestRect(this.outline, this.outlineClosestDirection);
312
+ this.outlineClosestOffsetRect = this.calcClosestOffsetRect(this.outline, this.outlineClosestDirection);
313
+ }
314
+ if (this.viewport.mounted) {
315
+ this.viewportClosestRect = this.calcClosestRect(this.viewport, this.viewportClosestDirection);
316
+ this.viewportClosestOffsetRect = this.calcClosestOffsetRect(this.viewport, this.viewportClosestDirection);
317
+ }
318
+ };
319
+ MoveHelper.prototype.dragDrop = function (props) {
320
+ this.trigger(new DropNodeEvent({
321
+ target: this.operation.tree,
322
+ source: props === null || props === void 0 ? void 0 : props.dropNode,
323
+ }));
324
+ };
325
+ MoveHelper.prototype.dragEnd = function () {
326
+ this.dragging = false;
327
+ this.dragNodes = [];
328
+ this.touchNode = null;
329
+ this.closestNode = null;
330
+ this.activeViewport = null;
331
+ this.outlineClosestDirection = null;
332
+ this.outlineClosestOffsetRect = null;
333
+ this.outlineClosestRect = null;
334
+ this.viewportClosestDirection = null;
335
+ this.viewportClosestOffsetRect = null;
336
+ this.viewportClosestRect = null;
337
+ this.viewport.clearCache();
338
+ };
339
+ MoveHelper.prototype.trigger = function (event) {
340
+ if (this.operation) {
341
+ return this.operation.dispatch(event);
342
+ }
343
+ };
344
+ MoveHelper.prototype.makeObservable = function () {
345
+ define(this, {
346
+ dragging: observable.ref,
347
+ dragNodes: observable.ref,
348
+ touchNode: observable.ref,
349
+ closestNode: observable.ref,
350
+ outlineClosestDirection: observable.ref,
351
+ outlineClosestOffsetRect: observable.ref,
352
+ outlineClosestRect: observable.ref,
353
+ viewportClosestDirection: observable.ref,
354
+ viewportClosestOffsetRect: observable.ref,
355
+ viewportClosestRect: observable.ref,
356
+ dragStart: action,
357
+ dragMove: action,
358
+ dragEnd: action,
359
+ });
360
+ };
361
+ return MoveHelper;
362
+ }());
363
+ export { MoveHelper };
@@ -0,0 +1,29 @@
1
+ import { Workspace } from './Workspace';
2
+ import { Engine } from './Engine';
3
+ import { TreeNode, ITreeNode } from './TreeNode';
4
+ import { Selection } from './Selection';
5
+ import { Hover } from './Hover';
6
+ import { TransformHelper } from './TransformHelper';
7
+ import { MoveHelper } from './MoveHelper';
8
+ import { ICustomEvent } from '@mdesignable/shared';
9
+ export interface IOperation {
10
+ tree?: ITreeNode;
11
+ selected?: string[];
12
+ }
13
+ export declare class Operation {
14
+ workspace: Workspace;
15
+ engine: Engine;
16
+ tree: TreeNode;
17
+ selection: Selection;
18
+ hover: Hover;
19
+ transformHelper: TransformHelper;
20
+ moveHelper: MoveHelper;
21
+ requests: {
22
+ snapshot: any;
23
+ };
24
+ constructor(workspace: Workspace);
25
+ dispatch<T>(event: ICustomEvent, callback?: () => T): T;
26
+ snapshot(type?: string): void;
27
+ from(operation?: IOperation): void;
28
+ serialize(): IOperation;
29
+ }