@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,177 @@
1
+ import { observable, define, action } from '@formily/reactive'
2
+ import { Operation } from './Operation'
3
+ import { SelectNodeEvent, UnSelectNodeEvent } from '../events'
4
+ import { TreeNode } from './TreeNode'
5
+ import { isStr, isArr } from '@sulesky/next-shared'
6
+
7
+ export interface ISelection {
8
+ selected?: string[]
9
+ operation?: Operation
10
+ }
11
+
12
+ export class Selection {
13
+ operation: Operation
14
+ selected: string[] = []
15
+ indexes: Record<string, boolean> = {}
16
+
17
+ constructor(props?: ISelection) {
18
+ if (props.selected) {
19
+ this.selected = props.selected
20
+ }
21
+ if (props.operation) {
22
+ this.operation = props.operation
23
+ }
24
+ this.makeObservable()
25
+ }
26
+
27
+ makeObservable() {
28
+ define(this, {
29
+ selected: observable,
30
+ select: action,
31
+ batchSelect: action,
32
+ add: action,
33
+ remove: action,
34
+ clear: action,
35
+ crossAddTo: action,
36
+ })
37
+ }
38
+
39
+ trigger(type = SelectNodeEvent) {
40
+ return this.operation.dispatch(
41
+ new type({
42
+ target: this.operation.tree,
43
+ source: this.selectedNodes,
44
+ })
45
+ )
46
+ }
47
+
48
+ select(id: string | TreeNode) {
49
+ if (isStr(id)) {
50
+ if (this.selected.length === 1 && this.selected.includes(id)) {
51
+ this.trigger(SelectNodeEvent)
52
+ return
53
+ }
54
+ this.selected = [id]
55
+ this.indexes = { [id]: true }
56
+ this.trigger(SelectNodeEvent)
57
+ } else {
58
+ this.select(id?.id)
59
+ }
60
+ }
61
+
62
+ safeSelect(id: string | TreeNode) {
63
+ if (!id) return
64
+ this.select(id)
65
+ }
66
+
67
+ mapIds(ids: any) {
68
+ return isArr(ids)
69
+ ? ids.map((node: any) => (isStr(node) ? node : node?.id))
70
+ : []
71
+ }
72
+
73
+ batchSelect(ids: string[] | TreeNode[]) {
74
+ this.selected = this.mapIds(ids)
75
+ this.indexes = this.selected.reduce((buf, id) => {
76
+ buf[id] = true
77
+ return buf
78
+ }, {})
79
+ this.trigger(SelectNodeEvent)
80
+ }
81
+
82
+ batchSafeSelect(ids: string[] | TreeNode[]) {
83
+ if (!ids?.length) return
84
+ this.batchSelect(ids)
85
+ }
86
+
87
+ get selectedNodes() {
88
+ return this.selected.map((id) => this.operation.tree.findById(id))
89
+ }
90
+
91
+ get first() {
92
+ if (this.selected && this.selected.length) return this.selected[0]
93
+ }
94
+
95
+ get last() {
96
+ if (this.selected && this.selected.length)
97
+ return this.selected[this.selected.length - 1]
98
+ }
99
+
100
+ get length() {
101
+ return this.selected.length
102
+ }
103
+
104
+ add(...ids: string[] | TreeNode[]) {
105
+ this.mapIds(ids).forEach((id) => {
106
+ if (isStr(id)) {
107
+ if (!this.selected.includes(id)) {
108
+ this.selected.push(id)
109
+ this.indexes[id] = true
110
+ }
111
+ } else {
112
+ this.add(id?.id)
113
+ }
114
+ })
115
+ this.trigger()
116
+ }
117
+
118
+ crossAddTo(node: TreeNode) {
119
+ if (node.parent) {
120
+ const selectedNodes = this.selectedNodes
121
+ if (this.has(node)) {
122
+ this.remove(node)
123
+ } else {
124
+ const minDistanceNode = selectedNodes.reduce(
125
+ (minDistanceNode, item) => {
126
+ return item.distanceTo(node) < minDistanceNode.distanceTo(node)
127
+ ? item
128
+ : minDistanceNode
129
+ },
130
+ selectedNodes[0]
131
+ )
132
+ if (minDistanceNode) {
133
+ const crossNodes = node.crossSiblings(minDistanceNode)
134
+ crossNodes.forEach((node) => {
135
+ if (!this.has(node.id)) {
136
+ this.selected.push(node.id)
137
+ this.indexes[node.id] = true
138
+ }
139
+ })
140
+ }
141
+ if (!this.has(node.id)) {
142
+ this.selected.push(node.id)
143
+ this.indexes[node.id] = true
144
+ }
145
+ }
146
+ }
147
+ }
148
+
149
+ remove(...ids: string[] | TreeNode[]) {
150
+ this.mapIds(ids).forEach((id) => {
151
+ if (isStr(id)) {
152
+ this.selected = this.selected.filter((item) => item !== id)
153
+ delete this.indexes[id]
154
+ } else {
155
+ this.remove(id?.id)
156
+ }
157
+ })
158
+ this.trigger(UnSelectNodeEvent)
159
+ }
160
+
161
+ has(...ids: string[] | TreeNode[]) {
162
+ return this.mapIds(ids).some((id) => {
163
+ if (isStr(id)) {
164
+ return this.indexes[id]
165
+ } else {
166
+ if (!id?.id) return false
167
+ return this.has(id?.id)
168
+ }
169
+ })
170
+ }
171
+
172
+ clear() {
173
+ this.selected = []
174
+ this.indexes = {}
175
+ this.trigger(UnSelectNodeEvent)
176
+ }
177
+ }
@@ -0,0 +1,81 @@
1
+ import { isFn, KeyCode } from '@sulesky/next-shared'
2
+ import { IEngineContext } from '../types'
3
+
4
+ export { KeyCode }
5
+
6
+ export interface IShortcutProps {
7
+ codes?: KeyCode[] | KeyCode[][]
8
+ matcher?: (codes: KeyCode[]) => boolean
9
+ handler?: (context: IEngineContext) => void
10
+ }
11
+
12
+ export class Shortcut {
13
+ codes: KeyCode[][]
14
+ handler: (context: IEngineContext) => void
15
+ matcher: (codes: KeyCode[]) => boolean
16
+ constructor(props: IShortcutProps) {
17
+ this.codes = this.parseCodes(props.codes)
18
+ this.handler = props.handler
19
+ this.matcher = props.matcher
20
+ }
21
+
22
+ parseCodes(codes: Array<KeyCode | KeyCode[]>) {
23
+ const results: KeyCode[][] = []
24
+ codes.forEach((code) => {
25
+ if (Array.isArray(code)) {
26
+ results.push(code)
27
+ } else {
28
+ results.push([code])
29
+ }
30
+ })
31
+ return results
32
+ }
33
+
34
+ preventCodes(codes: KeyCode[]) {
35
+ if (this.codes.length) {
36
+ for (let i = 0; i < codes.length; i++) {
37
+ const sequence = this.codes[i] ?? []
38
+ for (let j = 0; j < sequence.length; j++) {
39
+ if (!Shortcut.matchCode(codes[j], sequence[j])) {
40
+ return false
41
+ }
42
+ }
43
+ }
44
+ return true
45
+ }
46
+ return false
47
+ }
48
+
49
+ matched(matched: boolean, context: IEngineContext) {
50
+ if (isFn(this.handler) && matched) {
51
+ this.handler(context)
52
+ }
53
+ return matched
54
+ }
55
+
56
+ match(codes: KeyCode[], context: IEngineContext) {
57
+ return this.codes.some((sequence) => {
58
+ const sortedSelf = Shortcut.sortCodes(sequence)
59
+ const sortedTarget: KeyCode[] = Shortcut.sortCodes(codes)
60
+ if (isFn(this.matcher)) {
61
+ return this.matched(this.matcher(sortedTarget), context)
62
+ }
63
+ if (sortedTarget.length !== sortedSelf.length)
64
+ return this.matched(false, context)
65
+ for (let i = 0; i < sortedSelf.length; i++) {
66
+ if (!Shortcut.matchCode(sortedTarget[i], sortedSelf[i])) {
67
+ return this.matched(false, context)
68
+ }
69
+ }
70
+ return this.matched(true, context)
71
+ })
72
+ }
73
+
74
+ static matchCode = (code1: KeyCode, code2: KeyCode) => {
75
+ return code1?.toLocaleLowerCase?.() === code2?.toLocaleLowerCase?.()
76
+ }
77
+
78
+ static sortCodes = (codes: KeyCode[]): KeyCode[] => {
79
+ return codes.map((code) => code.toLocaleLowerCase()).sort() as any
80
+ }
81
+ }
@@ -0,0 +1,129 @@
1
+ import {
2
+ calcRectOfAxisLineSegment,
3
+ ILineSegment,
4
+ IPoint,
5
+ calcOffsetOfSnapLineSegmentToEdge,
6
+ Rect,
7
+ } from '@sulesky/next-shared'
8
+ import { TreeNode } from './TreeNode'
9
+ import { TransformHelper } from './TransformHelper'
10
+
11
+ export type ISnapLineType = 'ruler' | 'space-block' | 'normal'
12
+
13
+ export type ISnapLine = ILineSegment & {
14
+ type?: ISnapLineType
15
+ distance?: number
16
+ id?: string
17
+ refer?: TreeNode
18
+ }
19
+
20
+ export class SnapLine {
21
+ _id: string
22
+ type: ISnapLineType
23
+ distance: number
24
+ refer: TreeNode
25
+ start: IPoint
26
+ end: IPoint
27
+ helper: TransformHelper
28
+ constructor(helper: TransformHelper, line: ISnapLine) {
29
+ this.helper = helper
30
+ this.type = line.type || 'normal'
31
+ this._id = line.id
32
+ this.refer = line.refer
33
+ this.start = { ...line.start }
34
+ this.end = { ...line.end }
35
+ this.distance = line.distance
36
+ }
37
+
38
+ get id() {
39
+ return (
40
+ this._id ?? `${this.start.x}-${this.start.y}-${this.end.x}-${this.end.y}`
41
+ )
42
+ }
43
+
44
+ get direction() {
45
+ if (this.start?.x === this.end?.x) return 'v'
46
+ return 'h'
47
+ }
48
+
49
+ get closest() {
50
+ return this.distance < TransformHelper.threshold
51
+ }
52
+
53
+ get rect() {
54
+ return calcRectOfAxisLineSegment(this)
55
+ }
56
+
57
+ translate(node: TreeNode, translate: IPoint) {
58
+ if (!node || !node?.parent) return
59
+ const parent = node.parent
60
+ const dragNodeRect = node.getValidElementOffsetRect()
61
+ const parentRect = parent.getValidElementOffsetRect()
62
+ const edgeOffset = calcOffsetOfSnapLineSegmentToEdge(this, dragNodeRect)
63
+ if (this.direction === 'h') {
64
+ translate.y = this.start.y - parentRect.y - edgeOffset.y
65
+ } else {
66
+ translate.x = this.start.x - parentRect.x - edgeOffset.x
67
+ }
68
+ }
69
+
70
+ resize(node: TreeNode, rect: Rect) {
71
+ if (!node || !node?.parent) return
72
+ const parent = node.parent
73
+ const dragNodeRect = node.getValidElementOffsetRect()
74
+ const parentRect = parent.getValidElementOffsetRect()
75
+ const edgeOffset = calcOffsetOfSnapLineSegmentToEdge(this, dragNodeRect)
76
+ const cursorRect = this.helper.cursorDragNodesRect
77
+ const snapEdge = this.snapEdge(rect)
78
+ if (this.direction === 'h') {
79
+ const y = this.start.y - parentRect.y - edgeOffset.y
80
+ switch (this.helper.direction) {
81
+ case 'left-top':
82
+ case 'center-top':
83
+ case 'right-top':
84
+ if (snapEdge !== 'ht') return
85
+ rect.y = y
86
+ rect.height = cursorRect.bottom - y
87
+ break
88
+ case 'left-bottom':
89
+ case 'center-bottom':
90
+ case 'right-bottom':
91
+ if (snapEdge !== 'hb') return
92
+ rect.height = this.start.y - cursorRect.top
93
+ break
94
+ }
95
+ } else {
96
+ const x = this.start.x - parentRect.x - edgeOffset.x
97
+ switch (this.helper.direction) {
98
+ case 'left-top':
99
+ case 'left-bottom':
100
+ case 'left-center':
101
+ if (snapEdge !== 'vl') return
102
+ rect.x = x
103
+ rect.width = cursorRect.right - x
104
+ break
105
+ case 'right-center':
106
+ case 'right-top':
107
+ case 'right-bottom':
108
+ if (snapEdge !== 'vr') return
109
+ rect.width = this.start.x - cursorRect.left
110
+ break
111
+ }
112
+ }
113
+ }
114
+
115
+ snapEdge(rect: Rect) {
116
+ const threshold = TransformHelper.threshold
117
+ if (this.direction === 'h') {
118
+ if (Math.abs(this.start.y - rect.top) < threshold) return 'ht'
119
+ if (Math.abs(this.start.y - (rect.top + rect.height / 2)) < threshold)
120
+ return 'hc'
121
+ if (Math.abs(this.start.y - rect.bottom) < threshold) return 'hb'
122
+ } else {
123
+ if (Math.abs(this.start.x - rect.left) < threshold) return 'vl'
124
+ if (Math.abs(this.start.x - (rect.left + rect.width / 2)) < threshold)
125
+ return 'vc'
126
+ if (Math.abs(this.start.x - rect.right) < threshold) return 'vr'
127
+ }
128
+ }
129
+ }
@@ -0,0 +1,199 @@
1
+ import {
2
+ calcExtendsLineSegmentOfRect,
3
+ calcDistanceOfSnapLineToEdges,
4
+ LineSegment,
5
+ Rect,
6
+ } from '@sulesky/next-shared'
7
+ import { SnapLine } from './SnapLine'
8
+ import { TransformHelper } from './TransformHelper'
9
+ import { TreeNode } from './TreeNode'
10
+
11
+ export type ISpaceBlockType =
12
+ | 'top'
13
+ | 'right'
14
+ | 'bottom'
15
+ | 'left'
16
+ | (string & {})
17
+
18
+ export interface ISpaceBlock {
19
+ id?: string
20
+ refer?: TreeNode
21
+ rect?: Rect
22
+ distance?: number
23
+ type?: ISpaceBlockType
24
+ }
25
+
26
+ export type AroundSpaceBlock = Record<ISpaceBlockType, SpaceBlock>
27
+
28
+ export class SpaceBlock {
29
+ _id: string
30
+ distance: number
31
+ refer: TreeNode
32
+ helper: TransformHelper
33
+ rect: Rect
34
+ type: ISpaceBlockType
35
+ constructor(helper: TransformHelper, box: ISpaceBlock) {
36
+ this.helper = helper
37
+ this.distance = box.distance
38
+ this.refer = box.refer
39
+ this.rect = box.rect
40
+ this.type = box.type
41
+ }
42
+
43
+ get referRect() {
44
+ if (!this.refer) return
45
+ return this.helper.getNodeRect(this.refer)
46
+ }
47
+
48
+ get id() {
49
+ return (
50
+ this._id ??
51
+ `${this.rect.x}-${this.rect.y}-${this.rect.width}-${this.rect.height}`
52
+ )
53
+ }
54
+
55
+ get next() {
56
+ const spaceBlock = this.helper.calcAroundSpaceBlocks(this.referRect)
57
+ return spaceBlock[this.type as any]
58
+ }
59
+
60
+ get extendsLine() {
61
+ if (!this.needExtendsLine) return
62
+ const dragNodesRect = this.helper.dragNodesRect
63
+ return calcExtendsLineSegmentOfRect(dragNodesRect, this.referRect)
64
+ }
65
+
66
+ get needExtendsLine() {
67
+ const targetRect = this.crossDragNodesRect
68
+ const referRect = this.crossReferRect
69
+ if (this.type === 'top' || this.type === 'bottom') {
70
+ const rightDelta = referRect.right - targetRect.left
71
+ const leftDelta = targetRect.right - referRect.left
72
+ return (
73
+ rightDelta < targetRect.width / 2 || leftDelta < targetRect.width / 2
74
+ )
75
+ } else {
76
+ const topDelta = targetRect.bottom - referRect.top
77
+ const bottomDelta = referRect.bottom - targetRect.top
78
+ return (
79
+ topDelta < targetRect.height / 2 || bottomDelta < targetRect.height / 2
80
+ )
81
+ }
82
+ return true
83
+ }
84
+
85
+ get crossReferRect() {
86
+ const referRect = this.referRect
87
+ if (this.type === 'top' || this.type === 'bottom') {
88
+ return new Rect(
89
+ referRect.x,
90
+ this.rect.y,
91
+ referRect.width,
92
+ this.rect.height
93
+ )
94
+ } else {
95
+ return new Rect(
96
+ this.rect.x,
97
+ referRect.y,
98
+ this.rect.width,
99
+ referRect.height
100
+ )
101
+ }
102
+ }
103
+
104
+ get crossDragNodesRect() {
105
+ const dragNodesRect = this.helper.dragNodesRect
106
+ if (this.type === 'top' || this.type === 'bottom') {
107
+ return new Rect(
108
+ dragNodesRect.x,
109
+ this.rect.y,
110
+ dragNodesRect.width,
111
+ this.rect.height
112
+ )
113
+ } else {
114
+ return new Rect(
115
+ this.rect.x,
116
+ dragNodesRect.y,
117
+ this.rect.width,
118
+ dragNodesRect.height
119
+ )
120
+ }
121
+ }
122
+
123
+ get isometrics() {
124
+ const results: SpaceBlock[] = []
125
+ let spaceBlock: SpaceBlock = this as any
126
+ while ((spaceBlock = spaceBlock.next)) {
127
+ if (
128
+ Math.abs(spaceBlock.distance - this.distance) <
129
+ TransformHelper.threshold
130
+ ) {
131
+ if (results.some((box) => box.distance !== spaceBlock.distance))
132
+ continue
133
+ results.push(spaceBlock)
134
+ }
135
+ }
136
+ return results
137
+ }
138
+
139
+ get snapLine() {
140
+ if (!this.isometrics.length) return
141
+ const nextRect = this.next.rect
142
+ const referRect = this.referRect
143
+ let line: LineSegment
144
+ if (this.type === 'top') {
145
+ line = new LineSegment(
146
+ {
147
+ x: nextRect.left,
148
+ y: referRect.bottom + nextRect.height,
149
+ },
150
+ {
151
+ x: nextRect.right,
152
+ y: referRect.bottom + nextRect.height,
153
+ }
154
+ )
155
+ } else if (this.type === 'bottom') {
156
+ line = new LineSegment(
157
+ {
158
+ x: nextRect.left,
159
+ y: referRect.top - nextRect.height,
160
+ },
161
+ {
162
+ x: nextRect.right,
163
+ y: referRect.top - nextRect.height,
164
+ }
165
+ )
166
+ } else if (this.type === 'left') {
167
+ line = new LineSegment(
168
+ {
169
+ x: referRect.right + nextRect.width,
170
+ y: nextRect.top,
171
+ },
172
+ {
173
+ x: referRect.right + nextRect.width,
174
+ y: nextRect.bottom,
175
+ }
176
+ )
177
+ } else {
178
+ line = new LineSegment(
179
+ {
180
+ x: referRect.left - nextRect.width,
181
+ y: nextRect.top,
182
+ },
183
+ {
184
+ x: referRect.left - nextRect.width,
185
+ y: nextRect.bottom,
186
+ }
187
+ )
188
+ }
189
+ const distance = calcDistanceOfSnapLineToEdges(
190
+ line,
191
+ this.helper.dragNodesEdgeLines
192
+ )
193
+ return new SnapLine(this.helper, {
194
+ ...line,
195
+ distance,
196
+ type: 'space-block',
197
+ })
198
+ }
199
+ }