@sulesky/next-core 1.0.3

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 (488) hide show
  1. package/LICENSE.md +20 -0
  2. package/README.md +1 -0
  3. package/dist/designable.core.umd.production.js +1 -0
  4. package/dist/designable.core.umd.production.min.js +7994 -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 +94 -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 +933 -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 +97 -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 +62 -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 +936 -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 +43 -0
  390. package/rollup.config.mjs +3 -0
  391. package/src/drivers/DragDropDriver.ts +143 -0
  392. package/src/drivers/KeyboardDriver.ts +49 -0
  393. package/src/drivers/MouseClickDriver.ts +61 -0
  394. package/src/drivers/MouseMoveDriver.ts +34 -0
  395. package/src/drivers/ViewportResizeDriver.ts +52 -0
  396. package/src/drivers/ViewportScrollDriver.ts +34 -0
  397. package/src/drivers/index.ts +6 -0
  398. package/src/effects/index.ts +11 -0
  399. package/src/effects/useAutoScrollEffect.ts +82 -0
  400. package/src/effects/useContentEditableEffect.ts +207 -0
  401. package/src/effects/useCursorEffect.ts +62 -0
  402. package/src/effects/useDragDropEffect.ts +185 -0
  403. package/src/effects/useFreeSelectionEffect.ts +66 -0
  404. package/src/effects/useKeyboardEffect.ts +20 -0
  405. package/src/effects/useResizeEffect.ts +92 -0
  406. package/src/effects/useSelectionEffect.ts +68 -0
  407. package/src/effects/useTranslateEffect.ts +59 -0
  408. package/src/effects/useViewportEffect.ts +29 -0
  409. package/src/effects/useWorkspaceEffect.ts +35 -0
  410. package/src/events/cursor/AbstractCursorEvent.ts +62 -0
  411. package/src/events/cursor/DragMoveEvent.ts +6 -0
  412. package/src/events/cursor/DragStartEvent.ts +9 -0
  413. package/src/events/cursor/DragStopEvent.ts +6 -0
  414. package/src/events/cursor/MouseClickEvent.ts +16 -0
  415. package/src/events/cursor/MouseMoveEvent.ts +9 -0
  416. package/src/events/cursor/index.ts +5 -0
  417. package/src/events/history/AbstractHistoryEvent.ts +9 -0
  418. package/src/events/history/HistoryGotoEvent.ts +9 -0
  419. package/src/events/history/HistoryPushEvent.ts +9 -0
  420. package/src/events/history/HistoryRedoEvent.ts +9 -0
  421. package/src/events/history/HistoryUndoEvent.ts +9 -0
  422. package/src/events/history/index.ts +4 -0
  423. package/src/events/index.ts +6 -0
  424. package/src/events/keyboard/AbstractKeyboardEvent.ts +48 -0
  425. package/src/events/keyboard/KeyDownEvent.ts +9 -0
  426. package/src/events/keyboard/KeyUpEvent.ts +6 -0
  427. package/src/events/keyboard/index.ts +2 -0
  428. package/src/events/mutation/AbstractMutationNodeEvent.ts +21 -0
  429. package/src/events/mutation/AppendNodeEvent.ts +9 -0
  430. package/src/events/mutation/CloneNodeEvent.ts +9 -0
  431. package/src/events/mutation/DragNodeEvent.ts +9 -0
  432. package/src/events/mutation/DropNodeEvent.ts +9 -0
  433. package/src/events/mutation/FromNodeEvent.ts +19 -0
  434. package/src/events/mutation/HoverNodeEvent.ts +9 -0
  435. package/src/events/mutation/InsertAfterEvent.ts +9 -0
  436. package/src/events/mutation/InsertBeforeEvent.ts +9 -0
  437. package/src/events/mutation/InsertChildrenEvent.ts +9 -0
  438. package/src/events/mutation/PrependNodeEvent.ts +9 -0
  439. package/src/events/mutation/RemoveNodeEvent.ts +9 -0
  440. package/src/events/mutation/SelectNodeEvent.ts +9 -0
  441. package/src/events/mutation/UnSelectNodeEvent.ts +9 -0
  442. package/src/events/mutation/UpdateChildrenEvent.ts +9 -0
  443. package/src/events/mutation/UpdateNodePropsEvent.ts +9 -0
  444. package/src/events/mutation/UserSelectNodeEvent.ts +9 -0
  445. package/src/events/mutation/WrapNodeEvent.ts +9 -0
  446. package/src/events/mutation/index.ts +16 -0
  447. package/src/events/viewport/AbstractViewportEvent.ts +30 -0
  448. package/src/events/viewport/ViewportResizeEvent.ts +9 -0
  449. package/src/events/viewport/ViewportScrollEvent.ts +9 -0
  450. package/src/events/viewport/index.ts +2 -0
  451. package/src/events/workbench/AbstractWorkspaceEvent.ts +10 -0
  452. package/src/events/workbench/AddWorkspaceEvent.ts +8 -0
  453. package/src/events/workbench/RemoveWorkspaceEvent.ts +9 -0
  454. package/src/events/workbench/SwitchWorkspaceEvent.ts +9 -0
  455. package/src/events/workbench/index.ts +3 -0
  456. package/src/exports.ts +5 -0
  457. package/src/externals.ts +87 -0
  458. package/src/index.ts +15 -0
  459. package/src/internals.ts +37 -0
  460. package/src/models/Cursor.ts +198 -0
  461. package/src/models/Engine.ts +108 -0
  462. package/src/models/History.ts +125 -0
  463. package/src/models/Hover.ts +49 -0
  464. package/src/models/Keyboard.ts +126 -0
  465. package/src/models/MoveHelper.ts +383 -0
  466. package/src/models/Operation.ts +91 -0
  467. package/src/models/Screen.ts +83 -0
  468. package/src/models/Selection.ts +177 -0
  469. package/src/models/Shortcut.ts +81 -0
  470. package/src/models/SnapLine.ts +129 -0
  471. package/src/models/SpaceBlock.ts +199 -0
  472. package/src/models/TransformHelper.ts +648 -0
  473. package/src/models/TreeNode.ts +894 -0
  474. package/src/models/Viewport.ts +516 -0
  475. package/src/models/Workbench.ts +120 -0
  476. package/src/models/Workspace.ts +142 -0
  477. package/src/models/index.ts +13 -0
  478. package/src/presets.ts +73 -0
  479. package/src/registry.ts +147 -0
  480. package/src/shortcuts/CursorSwitch.ts +11 -0
  481. package/src/shortcuts/MultiSelection.ts +31 -0
  482. package/src/shortcuts/NodeMutation.ts +49 -0
  483. package/src/shortcuts/QuickSelection.ts +81 -0
  484. package/src/shortcuts/UndoRedo.ts +29 -0
  485. package/src/shortcuts/index.ts +5 -0
  486. package/src/types.ts +185 -0
  487. package/tsconfig.build.json +10 -0
  488. package/tsconfig.json +5 -0
@@ -0,0 +1,126 @@
1
+ import { observable, define, action } from '@formily/reactive'
2
+ import { KeyCode } from '@sulesky/next-shared'
3
+ import { Engine } from './Engine'
4
+ import { Shortcut } from './Shortcut'
5
+ import { AbstractKeyboardEvent } from '../events/keyboard/AbstractKeyboardEvent'
6
+ import { IEngineContext } from '../types'
7
+
8
+ const Modifiers: [string, KeyCode][] = [
9
+ ['metaKey', KeyCode.Meta],
10
+ ['shiftKey', KeyCode.Shift],
11
+ ['ctrlKey', KeyCode.Control],
12
+ ['altKey', KeyCode.Alt],
13
+ ]
14
+
15
+ export interface IKeyboard {
16
+ engine: Engine
17
+ }
18
+
19
+ export class Keyboard {
20
+ engine: Engine
21
+ shortcuts: Shortcut[] = []
22
+ sequence: KeyCode[] = []
23
+ keyDown: KeyCode = null
24
+ modifiers = {}
25
+ requestTimer = null
26
+
27
+ constructor(engine?: Engine) {
28
+ this.engine = engine
29
+ this.shortcuts = engine.props?.shortcuts || []
30
+ this.makeObservable()
31
+ }
32
+
33
+ matchCodes(context: IEngineContext) {
34
+ for (let i = 0; i < this.shortcuts.length; i++) {
35
+ const shortcut = this.shortcuts[i]
36
+ if (shortcut.match(this.sequence, context)) {
37
+ return true
38
+ }
39
+ }
40
+ return false
41
+ }
42
+
43
+ preventCodes() {
44
+ return this.shortcuts.some((shortcut) => {
45
+ return shortcut.preventCodes(this.sequence)
46
+ })
47
+ }
48
+
49
+ includes(key: KeyCode) {
50
+ return this.sequence.some((code) => Shortcut.matchCode(code, key))
51
+ }
52
+
53
+ excludes(key: KeyCode) {
54
+ this.sequence = this.sequence.filter(
55
+ (code) => !Shortcut.matchCode(key, code)
56
+ )
57
+ }
58
+
59
+ addKeyCode(key: KeyCode) {
60
+ if (!this.includes(key)) {
61
+ this.sequence.push(key)
62
+ }
63
+ }
64
+
65
+ removeKeyCode(key: KeyCode) {
66
+ if (this.includes(key)) {
67
+ this.excludes(key)
68
+ }
69
+ }
70
+
71
+ isModifier(code: KeyCode) {
72
+ return Modifiers.some((modifier) => Shortcut.matchCode(modifier[1], code))
73
+ }
74
+
75
+ handleModifiers(event: AbstractKeyboardEvent) {
76
+ Modifiers.forEach(([key, code]) => {
77
+ if (event[key]) {
78
+ if (!this.includes(code)) {
79
+ this.sequence = [code].concat(this.sequence)
80
+ }
81
+ }
82
+ })
83
+ }
84
+
85
+ handleKeyboard(event: AbstractKeyboardEvent, context: IEngineContext) {
86
+ if (event.eventType === 'keydown') {
87
+ this.keyDown = event.data
88
+ this.addKeyCode(this.keyDown)
89
+ this.handleModifiers(event)
90
+ if (this.matchCodes(context)) {
91
+ this.sequence = []
92
+ }
93
+ this.requestClean(4000)
94
+ if (this.preventCodes()) {
95
+ event.preventDefault()
96
+ event.stopPropagation()
97
+ }
98
+ } else {
99
+ if (this.isModifier(event.data)) {
100
+ this.sequence = []
101
+ }
102
+ this.keyDown = null
103
+ }
104
+ }
105
+
106
+ isKeyDown(code: KeyCode) {
107
+ return this.keyDown === code
108
+ }
109
+
110
+ requestClean(duration = 320) {
111
+ clearTimeout(this.requestTimer)
112
+ this.requestTimer = setTimeout(() => {
113
+ this.keyDown = null
114
+ this.sequence = []
115
+ clearTimeout(this.requestTimer)
116
+ }, duration)
117
+ }
118
+
119
+ makeObservable() {
120
+ define(this, {
121
+ sequence: observable.shallow,
122
+ keyDown: observable.ref,
123
+ handleKeyboard: action,
124
+ })
125
+ }
126
+ }
@@ -0,0 +1,383 @@
1
+ import { Operation } from './Operation'
2
+ import { TreeNode } from './TreeNode'
3
+ import { observable, define, action } from '@formily/reactive'
4
+ import {
5
+ calcDistanceOfPointToRect,
6
+ calcDistancePointToEdge,
7
+ isNearAfter,
8
+ isPointInRect,
9
+ IPoint,
10
+ Rect,
11
+ } from '@sulesky/next-shared'
12
+ import { DragNodeEvent, DropNodeEvent } from '../events'
13
+ import { Viewport } from './Viewport'
14
+ import { CursorDragType } from './Cursor'
15
+
16
+ export enum ClosestPosition {
17
+ Before = 'BEFORE',
18
+ ForbidBefore = 'FORBID_BEFORE',
19
+ After = 'After',
20
+ ForbidAfter = 'FORBID_AFTER',
21
+ Upper = 'UPPER',
22
+ ForbidUpper = 'FORBID_UPPER',
23
+ Under = 'UNDER',
24
+ ForbidUnder = 'FORBID_UNDER',
25
+ Inner = 'INNER',
26
+ ForbidInner = 'FORBID_INNER',
27
+ InnerAfter = 'INNER_AFTER',
28
+ ForbidInnerAfter = 'FORBID_INNER_AFTER',
29
+ InnerBefore = 'INNER_BEFORE',
30
+ ForbidInnerBefore = 'FORBID_INNER_BEFORE',
31
+ Forbid = 'FORBID',
32
+ }
33
+
34
+ export interface IMoveHelperProps {
35
+ operation: Operation
36
+ }
37
+
38
+ export interface IMoveHelperDragStartProps {
39
+ dragNodes: TreeNode[]
40
+ }
41
+
42
+ export interface IMoveHelperDragDropProps {
43
+ dropNode: TreeNode
44
+ }
45
+ export interface IMoveHelperDragMoveProps {
46
+ touchNode: TreeNode
47
+ point: IPoint
48
+ }
49
+
50
+ export class MoveHelper {
51
+ operation: Operation
52
+
53
+ rootNode: TreeNode
54
+
55
+ dragNodes: TreeNode[] = []
56
+
57
+ touchNode: TreeNode = null
58
+
59
+ closestNode: TreeNode = null
60
+
61
+ activeViewport: Viewport = null
62
+
63
+ viewportClosestRect: Rect = null
64
+
65
+ outlineClosestRect: Rect = null
66
+
67
+ viewportClosestOffsetRect: Rect = null
68
+
69
+ outlineClosestOffsetRect: Rect = null
70
+
71
+ viewportClosestDirection: ClosestPosition = null
72
+
73
+ outlineClosestDirection: ClosestPosition = null
74
+
75
+ dragging = false
76
+
77
+ constructor(props: IMoveHelperProps) {
78
+ this.operation = props.operation
79
+ this.rootNode = this.operation.tree
80
+ this.makeObservable()
81
+ }
82
+
83
+ get cursor() {
84
+ return this.operation.engine.cursor
85
+ }
86
+
87
+ get viewport() {
88
+ return this.operation.workspace.viewport
89
+ }
90
+
91
+ get outline() {
92
+ return this.operation.workspace.outline
93
+ }
94
+
95
+ get hasDragNodes() {
96
+ return this.dragNodes.length > 0
97
+ }
98
+
99
+ get closestDirection() {
100
+ if (this.activeViewport === this.outline) {
101
+ return this.outlineClosestDirection
102
+ }
103
+ return this.viewportClosestDirection
104
+ }
105
+
106
+ getClosestLayout(viewport: Viewport) {
107
+ return viewport.getValidNodeLayout(this.closestNode)
108
+ }
109
+
110
+ calcClosestPosition(point: IPoint, viewport: Viewport): ClosestPosition {
111
+ const closestNode = this.closestNode
112
+ if (!closestNode || !viewport.isPointInViewport(point))
113
+ return ClosestPosition.Forbid
114
+ const closestRect = viewport.getValidNodeRect(closestNode)
115
+ const isInline = this.getClosestLayout(viewport) === 'horizontal'
116
+ if (!closestRect) {
117
+ return
118
+ }
119
+ const isAfter = isNearAfter(
120
+ point,
121
+ closestRect,
122
+ viewport.moveInsertionType === 'block' ? false : isInline
123
+ )
124
+ const getValidParent = (node: TreeNode) => {
125
+ if (!node) return
126
+ if (node.parent?.allowSibling(this.dragNodes)) return node.parent
127
+ return getValidParent(node.parent)
128
+ }
129
+ if (isPointInRect(point, closestRect, viewport.moveSensitive)) {
130
+ if (!closestNode.allowAppend(this.dragNodes)) {
131
+ if (!closestNode.allowSibling(this.dragNodes)) {
132
+ const parentClosestNode = getValidParent(closestNode)
133
+ if (parentClosestNode) {
134
+ this.closestNode = parentClosestNode
135
+ }
136
+ if (isInline) {
137
+ if (parentClosestNode) {
138
+ if (isAfter) {
139
+ return ClosestPosition.After
140
+ }
141
+ return ClosestPosition.Before
142
+ }
143
+ if (isAfter) {
144
+ return ClosestPosition.ForbidAfter
145
+ }
146
+ return ClosestPosition.ForbidBefore
147
+ } else {
148
+ if (parentClosestNode) {
149
+ if (isAfter) {
150
+ return ClosestPosition.Under
151
+ }
152
+ return ClosestPosition.Upper
153
+ }
154
+ if (isAfter) {
155
+ return ClosestPosition.ForbidUnder
156
+ }
157
+ return ClosestPosition.ForbidUpper
158
+ }
159
+ } else {
160
+ if (isInline) {
161
+ return isAfter ? ClosestPosition.After : ClosestPosition.Before
162
+ } else {
163
+ return isAfter ? ClosestPosition.Under : ClosestPosition.Upper
164
+ }
165
+ }
166
+ }
167
+ if (closestNode.contains(...this.dragNodes)) {
168
+ if (isAfter) {
169
+ return ClosestPosition.InnerAfter
170
+ }
171
+ return ClosestPosition.InnerBefore
172
+ } else {
173
+ return ClosestPosition.Inner
174
+ }
175
+ } else if (closestNode === closestNode.root) {
176
+ return isAfter ? ClosestPosition.InnerAfter : ClosestPosition.InnerBefore
177
+ } else {
178
+ if (!closestNode.allowSibling(this.dragNodes)) {
179
+ const parentClosestNode = getValidParent(closestNode)
180
+ if (parentClosestNode) {
181
+ this.closestNode = parentClosestNode
182
+ }
183
+ if (isInline) {
184
+ if (parentClosestNode) {
185
+ if (isAfter) {
186
+ return ClosestPosition.After
187
+ }
188
+ return ClosestPosition.Before
189
+ }
190
+ return isAfter
191
+ ? ClosestPosition.ForbidAfter
192
+ : ClosestPosition.ForbidBefore
193
+ } else {
194
+ if (parentClosestNode) {
195
+ if (isAfter) {
196
+ return ClosestPosition.Under
197
+ }
198
+ return ClosestPosition.Upper
199
+ }
200
+ return isAfter
201
+ ? ClosestPosition.ForbidUnder
202
+ : ClosestPosition.ForbidUpper
203
+ }
204
+ }
205
+ if (isInline) {
206
+ return isAfter ? ClosestPosition.After : ClosestPosition.Before
207
+ } else {
208
+ return isAfter ? ClosestPosition.Under : ClosestPosition.Upper
209
+ }
210
+ }
211
+ }
212
+
213
+ calcClosestNode(point: IPoint, viewport: Viewport): TreeNode {
214
+ if (this.touchNode) {
215
+ const touchNodeRect = viewport.getValidNodeRect(this.touchNode)
216
+ if (!touchNodeRect) return
217
+ if (this.touchNode?.children?.length) {
218
+ const touchDistance = calcDistancePointToEdge(point, touchNodeRect)
219
+ let minDistance = touchDistance
220
+ let minDistanceNode = this.touchNode
221
+ this.touchNode.eachChildren((node) => {
222
+ const rect = viewport.getElementRectById(node.id)
223
+ if (!rect) return
224
+ const distance = isPointInRect(point, rect, viewport.moveSensitive)
225
+ ? 0
226
+ : calcDistanceOfPointToRect(point, rect)
227
+ if (distance <= minDistance) {
228
+ minDistance = distance
229
+ minDistanceNode = node
230
+ }
231
+ })
232
+ return minDistanceNode
233
+ } else {
234
+ return this.touchNode
235
+ }
236
+ }
237
+ return this.operation.tree
238
+ }
239
+
240
+ calcClosestRect(viewport: Viewport, closestDirection: ClosestPosition): Rect {
241
+ const closestNode = this.closestNode
242
+ if (!closestNode || !closestDirection) return
243
+ const closestRect = viewport.getValidNodeRect(closestNode)
244
+ if (
245
+ closestDirection === ClosestPosition.InnerAfter ||
246
+ closestDirection === ClosestPosition.InnerBefore
247
+ ) {
248
+ return viewport.getChildrenRect(closestNode)
249
+ } else {
250
+ return closestRect
251
+ }
252
+ }
253
+
254
+ calcClosestOffsetRect(
255
+ viewport: Viewport,
256
+ closestDirection: ClosestPosition
257
+ ): Rect {
258
+ const closestNode = this.closestNode
259
+ if (!closestNode || !closestDirection) return
260
+ const closestRect = viewport.getValidNodeOffsetRect(closestNode)
261
+ if (
262
+ closestDirection === ClosestPosition.InnerAfter ||
263
+ closestDirection === ClosestPosition.InnerBefore
264
+ ) {
265
+ return viewport.getChildrenOffsetRect(closestNode)
266
+ } else {
267
+ return closestRect
268
+ }
269
+ }
270
+
271
+ dragStart(props: IMoveHelperDragStartProps) {
272
+ const nodes = TreeNode.filterDraggable(props?.dragNodes)
273
+ if (nodes.length) {
274
+ this.dragNodes = nodes
275
+ this.trigger(
276
+ new DragNodeEvent({
277
+ target: this.operation.tree,
278
+ source: this.dragNodes,
279
+ })
280
+ )
281
+ this.viewport.cacheElements()
282
+ this.cursor.setDragType(CursorDragType.Move)
283
+ this.dragging = true
284
+ }
285
+ }
286
+
287
+ dragMove(props: IMoveHelperDragMoveProps) {
288
+ const { point, touchNode } = props
289
+ if (!this.dragging) 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
+ } else if (this.viewport.isPointInViewport(point, false)) {
295
+ this.activeViewport = this.viewport
296
+ this.touchNode = touchNode
297
+ this.closestNode = this.calcClosestNode(point, this.viewport)
298
+ }
299
+ if (!this.activeViewport) return
300
+
301
+ if (this.activeViewport === this.outline) {
302
+ this.outlineClosestDirection = this.calcClosestPosition(
303
+ point,
304
+ this.outline
305
+ )
306
+ this.viewportClosestDirection = this.outlineClosestDirection
307
+ } else {
308
+ this.viewportClosestDirection = this.calcClosestPosition(
309
+ point,
310
+ this.viewport
311
+ )
312
+ this.outlineClosestDirection = this.viewportClosestDirection
313
+ }
314
+ if (this.outline.mounted) {
315
+ this.outlineClosestRect = this.calcClosestRect(
316
+ this.outline,
317
+ this.outlineClosestDirection
318
+ )
319
+ this.outlineClosestOffsetRect = this.calcClosestOffsetRect(
320
+ this.outline,
321
+ this.outlineClosestDirection
322
+ )
323
+ }
324
+ if (this.viewport.mounted) {
325
+ this.viewportClosestRect = this.calcClosestRect(
326
+ this.viewport,
327
+ this.viewportClosestDirection
328
+ )
329
+ this.viewportClosestOffsetRect = this.calcClosestOffsetRect(
330
+ this.viewport,
331
+ this.viewportClosestDirection
332
+ )
333
+ }
334
+ }
335
+
336
+ dragDrop(props: IMoveHelperDragDropProps) {
337
+ this.trigger(
338
+ new DropNodeEvent({
339
+ target: this.operation.tree,
340
+ source: props?.dropNode,
341
+ })
342
+ )
343
+ }
344
+
345
+ dragEnd() {
346
+ this.dragging = false
347
+ this.dragNodes = []
348
+ this.touchNode = null
349
+ this.closestNode = null
350
+ this.activeViewport = null
351
+ this.outlineClosestDirection = null
352
+ this.outlineClosestOffsetRect = null
353
+ this.outlineClosestRect = null
354
+ this.viewportClosestDirection = null
355
+ this.viewportClosestOffsetRect = null
356
+ this.viewportClosestRect = null
357
+ this.viewport.clearCache()
358
+ }
359
+
360
+ trigger(event: any) {
361
+ if (this.operation) {
362
+ return this.operation.dispatch(event)
363
+ }
364
+ }
365
+
366
+ makeObservable() {
367
+ define(this, {
368
+ dragging: observable.ref,
369
+ dragNodes: observable.ref,
370
+ touchNode: observable.ref,
371
+ closestNode: observable.ref,
372
+ outlineClosestDirection: observable.ref,
373
+ outlineClosestOffsetRect: observable.ref,
374
+ outlineClosestRect: observable.ref,
375
+ viewportClosestDirection: observable.ref,
376
+ viewportClosestOffsetRect: observable.ref,
377
+ viewportClosestRect: observable.ref,
378
+ dragStart: action,
379
+ dragMove: action,
380
+ dragEnd: action,
381
+ })
382
+ }
383
+ }
@@ -0,0 +1,91 @@
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 { cancelIdle, ICustomEvent, isFn, requestIdle } from '@sulesky/next-shared'
9
+
10
+ export interface IOperation {
11
+ tree?: ITreeNode
12
+ selected?: string[]
13
+ }
14
+
15
+ export class Operation {
16
+ workspace: Workspace
17
+
18
+ engine: Engine
19
+
20
+ tree: TreeNode
21
+
22
+ selection: Selection
23
+
24
+ hover: Hover
25
+
26
+ transformHelper: TransformHelper
27
+
28
+ moveHelper: MoveHelper
29
+
30
+ requests = {
31
+ snapshot: null,
32
+ }
33
+
34
+ constructor(workspace: Workspace) {
35
+ this.engine = workspace.engine
36
+ this.workspace = workspace
37
+ this.tree = new TreeNode({
38
+ componentName: this.engine.props.rootComponentName,
39
+ ...this.engine.props.defaultComponentTree,
40
+ operation: this,
41
+ })
42
+ this.hover = new Hover({
43
+ operation: this,
44
+ })
45
+ this.selection = new Selection({
46
+ operation: this,
47
+ })
48
+ this.moveHelper = new MoveHelper({
49
+ operation: this,
50
+ })
51
+ this.transformHelper = new TransformHelper({
52
+ operation: this,
53
+ })
54
+ this.selection.select(this.tree)
55
+ }
56
+
57
+ dispatch(event: ICustomEvent, callback?: () => void) {
58
+ if (this.workspace.dispatch(event) === false) return
59
+ if (isFn(callback)) return callback()
60
+ }
61
+
62
+ snapshot(type?: string) {
63
+ cancelIdle(this.requests.snapshot)
64
+ if (
65
+ !this.workspace ||
66
+ !this.workspace.history ||
67
+ this.workspace.history.locking
68
+ )
69
+ return
70
+ this.requests.snapshot = requestIdle(() => {
71
+ this.workspace.history.push(type)
72
+ })
73
+ }
74
+
75
+ from(operation?: IOperation) {
76
+ if (!operation) return
77
+ if (operation.tree) {
78
+ this.tree.from(operation.tree)
79
+ }
80
+ if (operation.selected) {
81
+ this.selection.selected = operation.selected
82
+ }
83
+ }
84
+
85
+ serialize(): IOperation {
86
+ return {
87
+ tree: this.tree.serialize(),
88
+ selected: [this.tree.id],
89
+ }
90
+ }
91
+ }
@@ -0,0 +1,83 @@
1
+ import { Engine } from './Engine'
2
+ import { action, define, observable } from '@formily/reactive'
3
+
4
+ export enum ScreenType {
5
+ PC = 'PC',
6
+ Responsive = 'Responsive',
7
+ Mobile = 'Mobile',
8
+ Sketch = 'Sketch',
9
+ }
10
+
11
+ export enum ScreenStatus {
12
+ Normal = 'Normal',
13
+ Resizing = 'Resizing',
14
+ Zooming = 'Zooming',
15
+ }
16
+
17
+ export class Screen {
18
+ type: ScreenType
19
+ scale = 1
20
+ width: number | string = '100%'
21
+ height: number | string = '100%'
22
+ engine: Engine
23
+ background = ''
24
+ flip = false
25
+ status = ScreenStatus.Normal
26
+ constructor(engine: Engine) {
27
+ this.engine = engine
28
+ this.type = engine.props.defaultScreenType
29
+ this.makeObservable()
30
+ }
31
+
32
+ makeObservable() {
33
+ define(this, {
34
+ type: observable.ref,
35
+ scale: observable.ref,
36
+ width: observable.ref,
37
+ height: observable.ref,
38
+ status: observable.ref,
39
+ flip: observable.ref,
40
+ background: observable.ref,
41
+ setType: action,
42
+ setScale: action,
43
+ setSize: action,
44
+ resetSize: action,
45
+ setBackground: action,
46
+ setFlip: action,
47
+ })
48
+ }
49
+
50
+ setStatus(status: ScreenStatus) {
51
+ this.status = status
52
+ }
53
+
54
+ setType(type: ScreenType) {
55
+ this.type = type
56
+ }
57
+
58
+ setScale(scale: number) {
59
+ this.scale = scale
60
+ }
61
+
62
+ setSize(width?: number | string, height?: number | string) {
63
+ if (width) {
64
+ this.width = width
65
+ }
66
+ if (height) {
67
+ this.height = height
68
+ }
69
+ }
70
+
71
+ resetSize() {
72
+ this.width = '100%'
73
+ this.height = '100%'
74
+ }
75
+
76
+ setBackground(background: string) {
77
+ this.background = background
78
+ }
79
+
80
+ setFlip(flip: boolean) {
81
+ this.flip = flip
82
+ }
83
+ }