@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,516 @@
1
+ import {
2
+ calcBoundingRect,
3
+ calcElementLayout,
4
+ isHTMLElement,
5
+ isPointInRect,
6
+ IPoint,
7
+ requestIdle,
8
+ cancelIdle,
9
+ globalThisPolyfill,
10
+ Rect,
11
+ IRect,
12
+ isRectInRect,
13
+ } from '@sulesky/next-shared'
14
+ import { action, define, observable } from '@formily/reactive'
15
+ import { Workspace } from './Workspace'
16
+ import { Engine } from './Engine'
17
+ import { TreeNode } from './TreeNode'
18
+
19
+ export interface IViewportProps {
20
+ engine: Engine
21
+ workspace: Workspace
22
+ viewportElement: HTMLElement
23
+ contentWindow: Window
24
+ nodeIdAttrName: string
25
+ moveSensitive?: boolean
26
+ moveInsertionType?: IViewportMoveInsertionType
27
+ }
28
+
29
+ export interface IViewportData {
30
+ scrollX?: number
31
+ scrollY?: number
32
+ width?: number
33
+ height?: number
34
+ }
35
+
36
+ export type IViewportMoveInsertionType = 'all' | 'inline' | 'block'
37
+
38
+ /**
39
+ * 视口模型
40
+ */
41
+ export class Viewport {
42
+ workspace: Workspace
43
+
44
+ engine: Engine
45
+
46
+ contentWindow: Window
47
+
48
+ viewportElement: HTMLElement
49
+
50
+ dragStartSnapshot: IViewportData
51
+
52
+ scrollX = 0
53
+
54
+ scrollY = 0
55
+
56
+ width = 0
57
+
58
+ height = 0
59
+
60
+ mounted = false
61
+
62
+ attachRequest: number
63
+
64
+ nodeIdAttrName: string
65
+
66
+ moveSensitive: boolean
67
+
68
+ moveInsertionType: IViewportMoveInsertionType
69
+
70
+ nodeElementsStore: Record<string, HTMLElement[]> = {}
71
+
72
+ constructor(props: IViewportProps) {
73
+ this.workspace = props.workspace
74
+ this.engine = props.engine
75
+ this.moveSensitive = props.moveSensitive ?? false
76
+ this.moveInsertionType = props.moveInsertionType ?? 'all'
77
+ this.viewportElement = props.viewportElement
78
+ this.contentWindow = props.contentWindow
79
+ this.nodeIdAttrName = props.nodeIdAttrName
80
+ this.digestViewport()
81
+ this.makeObservable()
82
+ this.attachEvents()
83
+ }
84
+
85
+ get isScrollLeft() {
86
+ return this.scrollX === 0
87
+ }
88
+
89
+ get isScrollTop() {
90
+ return this.scrollY === 0
91
+ }
92
+
93
+ get isScrollRight() {
94
+ if (this.isIframe) {
95
+ return (
96
+ this.width + this.contentWindow.scrollX >=
97
+ this.contentWindow?.document?.body?.scrollWidth
98
+ )
99
+ } else if (this.viewportElement) {
100
+ return (
101
+ this.viewportElement.offsetWidth + this.scrollX >=
102
+ this.viewportElement.scrollWidth
103
+ )
104
+ }
105
+ }
106
+
107
+ get isScrollBottom() {
108
+ if (this.isIframe) {
109
+ if (!this.contentWindow?.document?.body) return false
110
+ return (
111
+ this.height + this.contentWindow.scrollY >=
112
+ this.contentWindow.document.body.scrollHeight
113
+ )
114
+ } else if (this.viewportElement) {
115
+ if (!this.viewportElement) return false
116
+ return (
117
+ this.viewportElement.offsetHeight + this.viewportElement.scrollTop >=
118
+ this.viewportElement.scrollHeight
119
+ )
120
+ }
121
+ }
122
+
123
+ get viewportRoot() {
124
+ return this.isIframe
125
+ ? this.contentWindow?.document?.body
126
+ : this.viewportElement
127
+ }
128
+
129
+ get isMaster() {
130
+ return this.contentWindow === globalThisPolyfill
131
+ }
132
+
133
+ get isIframe() {
134
+ return !!this.contentWindow?.frameElement && !this.isMaster
135
+ }
136
+
137
+ get scrollContainer() {
138
+ return this.isIframe ? this.contentWindow : this.viewportElement
139
+ }
140
+
141
+ get rect() {
142
+ const viewportElement = this.viewportElement
143
+ if (viewportElement) return viewportElement.getBoundingClientRect()
144
+ }
145
+
146
+ get innerRect() {
147
+ const rect = this.rect
148
+ return new Rect(0, 0, rect?.width, rect?.height)
149
+ }
150
+
151
+ get offsetX() {
152
+ const rect = this.rect
153
+ if (!rect) return 0
154
+ return rect.x
155
+ }
156
+
157
+ get offsetY() {
158
+ const rect = this.rect
159
+ if (!rect) return 0
160
+ return rect.y
161
+ }
162
+
163
+ get scale() {
164
+ if (!this.viewportElement) return 1
165
+ const clientRect = this.viewportElement.getBoundingClientRect()
166
+ const offsetWidth = this.viewportElement.offsetWidth
167
+ if (!clientRect.width || !offsetWidth) return 1
168
+ return Math.round(clientRect.width / offsetWidth)
169
+ }
170
+
171
+ get dragScrollXDelta() {
172
+ return this.scrollX - this.dragStartSnapshot.scrollX
173
+ }
174
+
175
+ get dragScrollYDelta() {
176
+ return this.scrollY - this.dragStartSnapshot.scrollY
177
+ }
178
+
179
+ cacheElements() {
180
+ this.nodeElementsStore = {}
181
+ this.viewportRoot
182
+ ?.querySelectorAll(`*[${this.nodeIdAttrName}]`)
183
+ .forEach((element: HTMLElement) => {
184
+ const id = element.getAttribute(this.nodeIdAttrName)
185
+ this.nodeElementsStore[id] = this.nodeElementsStore[id] || []
186
+ this.nodeElementsStore[id].push(element)
187
+ })
188
+ }
189
+
190
+ clearCache() {
191
+ this.nodeElementsStore = {}
192
+ }
193
+
194
+ getCurrentData() {
195
+ const data: IViewportData = {}
196
+ if (this.isIframe) {
197
+ data.scrollX = this.contentWindow?.scrollX || 0
198
+ data.scrollY = this.contentWindow?.scrollY || 0
199
+ data.width = this.contentWindow?.innerWidth || 0
200
+ data.height = this.contentWindow?.innerHeight || 0
201
+ } else if (this.viewportElement) {
202
+ data.scrollX = this.viewportElement?.scrollLeft || 0
203
+ data.scrollY = this.viewportElement?.scrollTop || 0
204
+ data.width = this.viewportElement?.clientWidth || 0
205
+ data.height = this.viewportElement?.clientHeight || 0
206
+ }
207
+ return data
208
+ }
209
+
210
+ takeDragStartSnapshot() {
211
+ this.dragStartSnapshot = this.getCurrentData()
212
+ }
213
+
214
+ digestViewport() {
215
+ Object.assign(this, this.getCurrentData())
216
+ }
217
+
218
+ elementFromPoint(point: IPoint) {
219
+ if (this.contentWindow?.document) {
220
+ return this.contentWindow.document.elementFromPoint(point.x, point.y)
221
+ }
222
+ }
223
+
224
+ matchViewport(
225
+ target: HTMLElement | Element | Window | Document | EventTarget
226
+ ) {
227
+ if (this.isIframe) {
228
+ return (
229
+ target === this.viewportElement ||
230
+ target === this.contentWindow ||
231
+ target === this.contentWindow?.document
232
+ )
233
+ } else {
234
+ return target === this.viewportElement
235
+ }
236
+ }
237
+
238
+ attachEvents() {
239
+ const engine = this.engine
240
+ cancelIdle(this.attachRequest)
241
+ this.attachRequest = requestIdle(() => {
242
+ if (!engine) return
243
+ if (this.isIframe) {
244
+ this.workspace.attachEvents(this.contentWindow, this.contentWindow)
245
+ } else if (isHTMLElement(this.viewportElement)) {
246
+ this.workspace.attachEvents(this.viewportElement, this.contentWindow)
247
+ }
248
+ })
249
+ }
250
+
251
+ detachEvents() {
252
+ if (this.isIframe) {
253
+ this.workspace.detachEvents(this.contentWindow)
254
+ this.workspace.detachEvents(this.viewportElement)
255
+ } else if (this.viewportElement) {
256
+ this.workspace.detachEvents(this.viewportElement)
257
+ }
258
+ }
259
+
260
+ onMount(element: HTMLElement, contentWindow: Window) {
261
+ this.mounted = true
262
+ this.viewportElement = element
263
+ this.contentWindow = contentWindow
264
+ this.attachEvents()
265
+ this.digestViewport()
266
+ }
267
+
268
+ onUnmount() {
269
+ this.mounted = false
270
+ this.detachEvents()
271
+ }
272
+
273
+ isPointInViewport(point: IPoint, sensitive?: boolean) {
274
+ if (!this.rect) return false
275
+ if (!this.containsElement(document.elementFromPoint(point.x, point.y))) {
276
+ return false
277
+ }
278
+ return isPointInRect(point, this.rect, sensitive)
279
+ }
280
+
281
+ isRectInViewport(rect: IRect) {
282
+ if (!this.rect) return false
283
+ if (!this.containsElement(document.elementFromPoint(rect.x, rect.y))) {
284
+ return false
285
+ }
286
+ return isRectInRect(rect, this.rect)
287
+ }
288
+
289
+ isPointInViewportArea(point: IPoint, sensitive?: boolean) {
290
+ if (!this.rect) return false
291
+ return isPointInRect(point, this.rect, sensitive)
292
+ }
293
+
294
+ isOffsetPointInViewport(point: IPoint, sensitive?: boolean) {
295
+ if (!this.innerRect) return false
296
+ if (!this.containsElement(document.elementFromPoint(point.x, point.y)))
297
+ return false
298
+ return isPointInRect(point, this.innerRect, sensitive)
299
+ }
300
+
301
+ isOffsetRectInViewport(rect: IRect) {
302
+ if (!this.innerRect) return false
303
+ if (!this.containsElement(document.elementFromPoint(rect.x, rect.y))) {
304
+ return false
305
+ }
306
+ return isRectInRect(rect, this.innerRect)
307
+ }
308
+
309
+ makeObservable() {
310
+ define(this, {
311
+ scrollX: observable.ref,
312
+ scrollY: observable.ref,
313
+ width: observable.ref,
314
+ height: observable.ref,
315
+ digestViewport: action,
316
+ viewportElement: observable.ref,
317
+ contentWindow: observable.ref,
318
+ })
319
+ }
320
+
321
+ findElementById(id: string): HTMLElement {
322
+ if (!id) return
323
+ if (this.nodeElementsStore[id]) return this.nodeElementsStore[id][0]
324
+ return this.viewportRoot?.querySelector(
325
+ `*[${this.nodeIdAttrName}='${id}']`
326
+ ) as HTMLElement
327
+ }
328
+
329
+ findElementsById(id: string): HTMLElement[] {
330
+ if (!id) return []
331
+ if (this.nodeElementsStore[id]) return this.nodeElementsStore[id]
332
+ return Array.from(
333
+ this.viewportRoot?.querySelectorAll(
334
+ `*[${this.nodeIdAttrName}='${id}']`
335
+ ) ?? []
336
+ )
337
+ }
338
+
339
+ containsElement(element: HTMLElement | Element | EventTarget) {
340
+ let root: Element | HTMLDocument = this.viewportElement
341
+ if (root === element) return true
342
+ return root?.contains(element as any)
343
+ }
344
+
345
+ getOffsetPoint(topPoint: IPoint) {
346
+ const data = this.getCurrentData()
347
+ return {
348
+ x: topPoint.x - this.offsetX + data.scrollX,
349
+ y: topPoint.y - this.offsetY + data.scrollY,
350
+ }
351
+ }
352
+
353
+ //相对于页面
354
+ getElementRect(element: HTMLElement | Element) {
355
+ const rect = element.getBoundingClientRect()
356
+ const offsetWidth = element['offsetWidth']
357
+ ? element['offsetWidth']
358
+ : rect.width
359
+ const offsetHeight = element['offsetHeight']
360
+ ? element['offsetHeight']
361
+ : rect.height
362
+ return new Rect(
363
+ rect.x,
364
+ rect.y,
365
+ this.scale !== 1 ? offsetWidth : rect.width,
366
+ this.scale !== 1 ? offsetHeight : rect.height
367
+ )
368
+ }
369
+
370
+ //相对于页面
371
+ getElementRectById(id: string) {
372
+ const elements = this.findElementsById(id)
373
+ const rect = calcBoundingRect(
374
+ elements.map((element) => this.getElementRect(element))
375
+ )
376
+ if (rect) {
377
+ if (this.isIframe) {
378
+ return new Rect(
379
+ rect.x + this.offsetX,
380
+ rect.y + this.offsetY,
381
+ rect.width,
382
+ rect.height
383
+ )
384
+ } else {
385
+ return new Rect(rect.x, rect.y, rect.width, rect.height)
386
+ }
387
+ }
388
+ }
389
+
390
+ //相对于视口
391
+ getElementOffsetRect(element: HTMLElement | Element) {
392
+ const elementRect = element.getBoundingClientRect()
393
+ if (elementRect) {
394
+ if (this.isIframe) {
395
+ return new Rect(
396
+ elementRect.x + this.contentWindow.scrollX,
397
+ elementRect.y + this.contentWindow.scrollY,
398
+ elementRect.width,
399
+ elementRect.height
400
+ )
401
+ } else {
402
+ return new Rect(
403
+ (elementRect.x - this.offsetX + this.viewportElement.scrollLeft) /
404
+ this.scale,
405
+ (elementRect.y - this.offsetY + this.viewportElement.scrollTop) /
406
+ this.scale,
407
+ elementRect.width,
408
+ elementRect.height
409
+ )
410
+ }
411
+ }
412
+ }
413
+
414
+ //相对于视口
415
+ getElementOffsetRectById(id: string) {
416
+ const elements = this.findElementsById(id)
417
+ if (!elements.length) return
418
+ const elementRect = calcBoundingRect(
419
+ elements.map((element) => this.getElementRect(element))
420
+ )
421
+ if (elementRect) {
422
+ if (this.isIframe) {
423
+ return new Rect(
424
+ elementRect.x + this.contentWindow.scrollX,
425
+ elementRect.y + this.contentWindow.scrollY,
426
+ elementRect.width,
427
+ elementRect.height
428
+ )
429
+ } else {
430
+ return new Rect(
431
+ (elementRect.x - this.offsetX + this.viewportElement.scrollLeft) /
432
+ this.scale,
433
+ (elementRect.y - this.offsetY + this.viewportElement.scrollTop) /
434
+ this.scale,
435
+ elementRect.width,
436
+ elementRect.height
437
+ )
438
+ }
439
+ }
440
+ }
441
+
442
+ getValidNodeElement(node: TreeNode): Element {
443
+ const getNodeElement = (node: TreeNode) => {
444
+ if (!node) return
445
+ const ele = this.findElementById(node.id)
446
+ if (ele) {
447
+ return ele
448
+ } else {
449
+ return getNodeElement(node.parent)
450
+ }
451
+ }
452
+ return getNodeElement(node)
453
+ }
454
+
455
+ getChildrenRect(node: TreeNode): Rect {
456
+ if (!node?.children?.length) return
457
+ return calcBoundingRect(
458
+ node.children.reduce((buf, child) => {
459
+ const rect = this.getValidNodeRect(child)
460
+ if (rect) {
461
+ return buf.concat(rect)
462
+ }
463
+ return buf
464
+ }, [])
465
+ )
466
+ }
467
+
468
+ getChildrenOffsetRect(node: TreeNode): Rect {
469
+ if (!node?.children?.length) return
470
+
471
+ return calcBoundingRect(
472
+ node.children.reduce((buf, child) => {
473
+ const rect = this.getValidNodeOffsetRect(child)
474
+ if (rect) {
475
+ return buf.concat(rect)
476
+ }
477
+ return buf
478
+ }, [])
479
+ )
480
+ }
481
+
482
+ getValidNodeRect(node: TreeNode): Rect {
483
+ if (!node) return
484
+ const rect = this.getElementRectById(node.id)
485
+ if (node && node === node.root && node.isInOperation) {
486
+ if (!rect) return this.rect
487
+ return calcBoundingRect([this.rect, rect])
488
+ }
489
+
490
+ if (rect) {
491
+ return rect
492
+ } else {
493
+ return this.getChildrenRect(node)
494
+ }
495
+ }
496
+
497
+ getValidNodeOffsetRect(node: TreeNode): Rect {
498
+ if (!node) return
499
+ const rect = this.getElementOffsetRectById(node.id)
500
+ if (node && node === node.root && node.isInOperation) {
501
+ if (!rect) return this.innerRect
502
+ return calcBoundingRect([this.innerRect, rect])
503
+ }
504
+ if (rect) {
505
+ return rect
506
+ } else {
507
+ return this.getChildrenOffsetRect(node)
508
+ }
509
+ }
510
+
511
+ getValidNodeLayout(node: TreeNode) {
512
+ if (!node) return 'vertical'
513
+ if (node.parent?.designerProps?.inlineChildrenLayout) return 'horizontal'
514
+ return calcElementLayout(this.findElementById(node.id))
515
+ }
516
+ }
@@ -0,0 +1,120 @@
1
+ import { Engine } from './Engine'
2
+ import { Workspace, IWorkspaceProps } from './Workspace'
3
+ import { observable, define, action } from '@formily/reactive'
4
+ import {
5
+ AddWorkspaceEvent,
6
+ RemoveWorkspaceEvent,
7
+ SwitchWorkspaceEvent,
8
+ } from '../events'
9
+ import { IEngineContext, WorkbenchTypes } from '../types'
10
+ export class Workbench {
11
+ workspaces: Workspace[]
12
+
13
+ currentWorkspace: Workspace
14
+
15
+ activeWorkspace: Workspace
16
+
17
+ engine: Engine
18
+
19
+ type: WorkbenchTypes = 'DESIGNABLE'
20
+
21
+ constructor(engine: Engine) {
22
+ this.engine = engine
23
+ this.workspaces = []
24
+ this.currentWorkspace = null
25
+ this.activeWorkspace = null
26
+ this.makeObservable()
27
+ }
28
+
29
+ makeObservable() {
30
+ define(this, {
31
+ currentWorkspace: observable.ref,
32
+ workspaces: observable.shallow,
33
+ activeWorkspace: observable.ref,
34
+ type: observable.ref,
35
+ switchWorkspace: action,
36
+ addWorkspace: action,
37
+ removeWorkspace: action,
38
+ setActiveWorkspace: action,
39
+ setWorkbenchType: action,
40
+ })
41
+ }
42
+
43
+ getEventContext(): IEngineContext {
44
+ return {
45
+ engine: this.engine,
46
+ workbench: this.engine.workbench,
47
+ workspace: null,
48
+ viewport: null,
49
+ }
50
+ }
51
+
52
+ switchWorkspace(id: string) {
53
+ const finded = this.findWorkspaceById(id)
54
+ if (finded) {
55
+ this.currentWorkspace = finded
56
+ this.engine.dispatch(new SwitchWorkspaceEvent(finded))
57
+ }
58
+ return this.currentWorkspace
59
+ }
60
+
61
+ setActiveWorkspace(workspace: Workspace) {
62
+ this.activeWorkspace = workspace
63
+ return workspace
64
+ }
65
+
66
+ setWorkbenchType(type: WorkbenchTypes) {
67
+ this.type = type
68
+ }
69
+
70
+ addWorkspace(props: IWorkspaceProps) {
71
+ const finded = this.findWorkspaceById(props.id)
72
+ if (!finded) {
73
+ this.currentWorkspace = new Workspace(this.engine, props)
74
+ this.workspaces.push(this.currentWorkspace)
75
+ this.engine.dispatch(new AddWorkspaceEvent(this.currentWorkspace))
76
+ return this.currentWorkspace
77
+ }
78
+ return finded
79
+ }
80
+
81
+ removeWorkspace(id: string) {
82
+ const findIndex = this.findWorkspaceIndexById(id)
83
+ if (findIndex > -1 && findIndex < this.workspaces.length) {
84
+ const findedWorkspace = this.workspaces[findIndex]
85
+ findedWorkspace.viewport.detachEvents()
86
+ this.workspaces.splice(findIndex, 1)
87
+ if (findedWorkspace === this.currentWorkspace) {
88
+ if (this.workspaces.length && this.workspaces[findIndex]) {
89
+ this.currentWorkspace = this.workspaces[findIndex]
90
+ } else {
91
+ this.currentWorkspace = this.workspaces[this.workspaces.length - 1]
92
+ }
93
+ }
94
+ this.engine.dispatch(new RemoveWorkspaceEvent(findedWorkspace))
95
+ }
96
+ }
97
+
98
+ ensureWorkspace(props: IWorkspaceProps = {}) {
99
+ const workspace = this.findWorkspaceById(props.id)
100
+ if (workspace) return workspace
101
+ this.addWorkspace(props)
102
+ return this.currentWorkspace
103
+ }
104
+
105
+ findWorkspaceById(id: string) {
106
+ return this.workspaces.find((item) => item.id === id)
107
+ }
108
+
109
+ findWorkspaceIndexById(id: string) {
110
+ return this.workspaces.findIndex((item) => item.id === id)
111
+ }
112
+
113
+ mapWorkspace<T>(callbackFn: (value: Workspace, index: number) => T): T[] {
114
+ return this.workspaces.map(callbackFn)
115
+ }
116
+
117
+ eachWorkspace<T>(callbackFn: (value: Workspace, index: number) => T) {
118
+ this.workspaces.forEach(callbackFn)
119
+ }
120
+ }