@mdesignable/core 1.0.0-beta.64

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (389) hide show
  1. package/LICENSE.md +20 -0
  2. package/README.md +1 -0
  3. package/dist/designable.core.umd.production.js +10 -0
  4. package/dist/designable.core.umd.production.min.js +23505 -0
  5. package/esm/drivers/DragDropDriver.d.ts +14 -0
  6. package/esm/drivers/DragDropDriver.js +157 -0
  7. package/esm/drivers/KeyboardDriver.d.ts +7 -0
  8. package/esm/drivers/KeyboardDriver.js +90 -0
  9. package/esm/drivers/MouseClickDriver.d.ts +8 -0
  10. package/esm/drivers/MouseClickDriver.js +95 -0
  11. package/esm/drivers/MouseMoveDriver.d.ts +8 -0
  12. package/esm/drivers/MouseMoveDriver.js +75 -0
  13. package/esm/drivers/ViewportResizeDriver.d.ts +10 -0
  14. package/esm/drivers/ViewportResizeDriver.js +95 -0
  15. package/esm/drivers/ViewportScrollDriver.d.ts +8 -0
  16. package/esm/drivers/ViewportScrollDriver.js +74 -0
  17. package/esm/drivers/index.d.ts +6 -0
  18. package/esm/drivers/index.js +6 -0
  19. package/esm/effects/index.d.ts +11 -0
  20. package/esm/effects/index.js +11 -0
  21. package/esm/effects/useAutoScrollEffect.d.ts +2 -0
  22. package/esm/effects/useAutoScrollEffect.js +65 -0
  23. package/esm/effects/useContentEditableEffect.d.ts +2 -0
  24. package/esm/effects/useContentEditableEffect.js +167 -0
  25. package/esm/effects/useCursorEffect.d.ts +2 -0
  26. package/esm/effects/useCursorEffect.js +55 -0
  27. package/esm/effects/useDragDropEffect.d.ts +2 -0
  28. package/esm/effects/useDragDropEffect.js +168 -0
  29. package/esm/effects/useFreeSelectionEffect.d.ts +2 -0
  30. package/esm/effects/useFreeSelectionEffect.js +59 -0
  31. package/esm/effects/useKeyboardEffect.d.ts +2 -0
  32. package/esm/effects/useKeyboardEffect.js +17 -0
  33. package/esm/effects/useResizeEffect.d.ts +2 -0
  34. package/esm/effects/useResizeEffect.js +80 -0
  35. package/esm/effects/useSelectionEffect.d.ts +2 -0
  36. package/esm/effects/useSelectionEffect.js +68 -0
  37. package/esm/effects/useTranslateEffect.d.ts +2 -0
  38. package/esm/effects/useTranslateEffect.js +58 -0
  39. package/esm/effects/useViewportEffect.d.ts +2 -0
  40. package/esm/effects/useViewportEffect.js +31 -0
  41. package/esm/effects/useWorkspaceEffect.d.ts +2 -0
  42. package/esm/effects/useWorkspaceEffect.js +29 -0
  43. package/esm/events/cursor/AbstractCursorEvent.d.ts +21 -0
  44. package/esm/events/cursor/AbstractCursorEvent.js +40 -0
  45. package/esm/events/cursor/DragMoveEvent.d.ts +5 -0
  46. package/esm/events/cursor/DragMoveEvent.js +51 -0
  47. package/esm/events/cursor/DragStartEvent.d.ts +5 -0
  48. package/esm/events/cursor/DragStartEvent.js +51 -0
  49. package/esm/events/cursor/DragStopEvent.d.ts +5 -0
  50. package/esm/events/cursor/DragStopEvent.js +51 -0
  51. package/esm/events/cursor/MouseClickEvent.d.ts +8 -0
  52. package/esm/events/cursor/MouseClickEvent.js +61 -0
  53. package/esm/events/cursor/MouseMoveEvent.d.ts +5 -0
  54. package/esm/events/cursor/MouseMoveEvent.js +51 -0
  55. package/esm/events/cursor/index.d.ts +5 -0
  56. package/esm/events/cursor/index.js +5 -0
  57. package/esm/events/history/AbstractHistoryEvent.d.ts +6 -0
  58. package/esm/events/history/AbstractHistoryEvent.js +7 -0
  59. package/esm/events/history/HistoryGotoEvent.d.ts +5 -0
  60. package/esm/events/history/HistoryGotoEvent.js +51 -0
  61. package/esm/events/history/HistoryPushEvent.d.ts +5 -0
  62. package/esm/events/history/HistoryPushEvent.js +51 -0
  63. package/esm/events/history/HistoryRedoEvent.d.ts +5 -0
  64. package/esm/events/history/HistoryRedoEvent.js +51 -0
  65. package/esm/events/history/HistoryUndoEvent.d.ts +5 -0
  66. package/esm/events/history/HistoryUndoEvent.js +51 -0
  67. package/esm/events/history/index.d.ts +4 -0
  68. package/esm/events/history/index.js +4 -0
  69. package/esm/events/index.d.ts +6 -0
  70. package/esm/events/index.js +6 -0
  71. package/esm/events/keyboard/AbstractKeyboardEvent.d.ts +15 -0
  72. package/esm/events/keyboard/AbstractKeyboardEvent.js +61 -0
  73. package/esm/events/keyboard/KeyDownEvent.d.ts +5 -0
  74. package/esm/events/keyboard/KeyDownEvent.js +51 -0
  75. package/esm/events/keyboard/KeyUpEvent.d.ts +5 -0
  76. package/esm/events/keyboard/KeyUpEvent.js +51 -0
  77. package/esm/events/keyboard/index.d.ts +2 -0
  78. package/esm/events/keyboard/index.js +2 -0
  79. package/esm/events/mutation/AbstractMutationNodeEvent.d.ts +13 -0
  80. package/esm/events/mutation/AbstractMutationNodeEvent.js +7 -0
  81. package/esm/events/mutation/AppendNodeEvent.d.ts +5 -0
  82. package/esm/events/mutation/AppendNodeEvent.js +51 -0
  83. package/esm/events/mutation/CloneNodeEvent.d.ts +5 -0
  84. package/esm/events/mutation/CloneNodeEvent.js +51 -0
  85. package/esm/events/mutation/DragNodeEvent.d.ts +5 -0
  86. package/esm/events/mutation/DragNodeEvent.js +51 -0
  87. package/esm/events/mutation/DropNodeEvent.d.ts +5 -0
  88. package/esm/events/mutation/DropNodeEvent.js +51 -0
  89. package/esm/events/mutation/FromNodeEvent.d.ts +13 -0
  90. package/esm/events/mutation/FromNodeEvent.js +8 -0
  91. package/esm/events/mutation/HoverNodeEvent.d.ts +5 -0
  92. package/esm/events/mutation/HoverNodeEvent.js +51 -0
  93. package/esm/events/mutation/InsertAfterEvent.d.ts +5 -0
  94. package/esm/events/mutation/InsertAfterEvent.js +51 -0
  95. package/esm/events/mutation/InsertBeforeEvent.d.ts +5 -0
  96. package/esm/events/mutation/InsertBeforeEvent.js +51 -0
  97. package/esm/events/mutation/InsertChildrenEvent.d.ts +5 -0
  98. package/esm/events/mutation/InsertChildrenEvent.js +51 -0
  99. package/esm/events/mutation/PrependNodeEvent.d.ts +5 -0
  100. package/esm/events/mutation/PrependNodeEvent.js +51 -0
  101. package/esm/events/mutation/RemoveNodeEvent.d.ts +5 -0
  102. package/esm/events/mutation/RemoveNodeEvent.js +51 -0
  103. package/esm/events/mutation/SelectNodeEvent.d.ts +5 -0
  104. package/esm/events/mutation/SelectNodeEvent.js +51 -0
  105. package/esm/events/mutation/UnSelectNodeEvent.d.ts +5 -0
  106. package/esm/events/mutation/UnSelectNodeEvent.js +51 -0
  107. package/esm/events/mutation/UpdateChildrenEvent.d.ts +5 -0
  108. package/esm/events/mutation/UpdateChildrenEvent.js +51 -0
  109. package/esm/events/mutation/UpdateNodePropsEvent.d.ts +5 -0
  110. package/esm/events/mutation/UpdateNodePropsEvent.js +51 -0
  111. package/esm/events/mutation/UserSelectNodeEvent.d.ts +5 -0
  112. package/esm/events/mutation/UserSelectNodeEvent.js +51 -0
  113. package/esm/events/mutation/WrapNodeEvent.d.ts +5 -0
  114. package/esm/events/mutation/WrapNodeEvent.js +51 -0
  115. package/esm/events/mutation/index.d.ts +16 -0
  116. package/esm/events/mutation/index.js +16 -0
  117. package/esm/events/viewport/AbstractViewportEvent.d.ts +16 -0
  118. package/esm/events/viewport/AbstractViewportEvent.js +17 -0
  119. package/esm/events/viewport/ViewportResizeEvent.d.ts +5 -0
  120. package/esm/events/viewport/ViewportResizeEvent.js +51 -0
  121. package/esm/events/viewport/ViewportScrollEvent.d.ts +5 -0
  122. package/esm/events/viewport/ViewportScrollEvent.js +51 -0
  123. package/esm/events/viewport/index.d.ts +2 -0
  124. package/esm/events/viewport/index.js +2 -0
  125. package/esm/events/workbench/AbstractWorkspaceEvent.d.ts +7 -0
  126. package/esm/events/workbench/AbstractWorkspaceEvent.js +7 -0
  127. package/esm/events/workbench/AddWorkspaceEvent.d.ts +5 -0
  128. package/esm/events/workbench/AddWorkspaceEvent.js +51 -0
  129. package/esm/events/workbench/RemoveWorkspaceEvent.d.ts +5 -0
  130. package/esm/events/workbench/RemoveWorkspaceEvent.js +51 -0
  131. package/esm/events/workbench/SwitchWorkspaceEvent.d.ts +5 -0
  132. package/esm/events/workbench/SwitchWorkspaceEvent.js +51 -0
  133. package/esm/events/workbench/index.d.ts +3 -0
  134. package/esm/events/workbench/index.js +3 -0
  135. package/esm/exports.d.ts +5 -0
  136. package/esm/exports.js +5 -0
  137. package/esm/externals.d.ts +12 -0
  138. package/esm/externals.js +113 -0
  139. package/esm/index.d.ts +1 -0
  140. package/esm/index.js +24 -0
  141. package/esm/internals.d.ts +3 -0
  142. package/esm/internals.js +34 -0
  143. package/esm/models/Cursor.d.ts +60 -0
  144. package/esm/models/Cursor.js +151 -0
  145. package/esm/models/Engine.d.ts +29 -0
  146. package/esm/models/Engine.js +112 -0
  147. package/esm/models/History.d.ts +34 -0
  148. package/esm/models/History.js +110 -0
  149. package/esm/models/Hover.d.ts +14 -0
  150. package/esm/models/Hover.js +38 -0
  151. package/esm/models/Keyboard.d.ts +29 -0
  152. package/esm/models/Keyboard.js +126 -0
  153. package/esm/models/MoveHelper.d.ts +66 -0
  154. package/esm/models/MoveHelper.js +363 -0
  155. package/esm/models/Operation.d.ts +29 -0
  156. package/esm/models/Operation.js +75 -0
  157. package/esm/models/Screen.d.ts +31 -0
  158. package/esm/models/Screen.js +73 -0
  159. package/esm/models/Selection.d.ts +29 -0
  160. package/esm/models/Selection.js +192 -0
  161. package/esm/models/Shortcut.d.ts +20 -0
  162. package/esm/models/Shortcut.js +69 -0
  163. package/esm/models/SnapLine.d.ts +27 -0
  164. package/esm/models/SnapLine.js +141 -0
  165. package/esm/models/SpaceBlock.d.ts +40 -0
  166. package/esm/models/SpaceBlock.js +171 -0
  167. package/esm/models/TransformHelper.d.ts +80 -0
  168. package/esm/models/TransformHelper.js +601 -0
  169. package/esm/models/TreeNode.d.ts +115 -0
  170. package/esm/models/TreeNode.js +932 -0
  171. package/esm/models/Viewport.d.ts +90 -0
  172. package/esm/models/Viewport.js +474 -0
  173. package/esm/models/Workbench.d.ts +23 -0
  174. package/esm/models/Workbench.js +98 -0
  175. package/esm/models/Workspace.d.ts +41 -0
  176. package/esm/models/Workspace.js +95 -0
  177. package/esm/models/index.d.ts +13 -0
  178. package/esm/models/index.js +13 -0
  179. package/esm/presets.d.ts +4 -0
  180. package/esm/presets.js +38 -0
  181. package/esm/registry.d.ts +16 -0
  182. package/esm/registry.js +123 -0
  183. package/esm/shortcuts/CursorSwitch.d.ts +2 -0
  184. package/esm/shortcuts/CursorSwitch.js +10 -0
  185. package/esm/shortcuts/MultiSelection.d.ts +5 -0
  186. package/esm/shortcuts/MultiSelection.js +27 -0
  187. package/esm/shortcuts/NodeMutation.d.ts +7 -0
  188. package/esm/shortcuts/NodeMutation.js +40 -0
  189. package/esm/shortcuts/QuickSelection.d.ts +3 -0
  190. package/esm/shortcuts/QuickSelection.js +85 -0
  191. package/esm/shortcuts/UndoRedo.d.ts +3 -0
  192. package/esm/shortcuts/UndoRedo.js +27 -0
  193. package/esm/shortcuts/index.d.ts +5 -0
  194. package/esm/shortcuts/index.js +5 -0
  195. package/esm/types.d.ts +131 -0
  196. package/esm/types.js +1 -0
  197. package/lib/drivers/DragDropDriver.d.ts +14 -0
  198. package/lib/drivers/DragDropDriver.js +160 -0
  199. package/lib/drivers/KeyboardDriver.d.ts +7 -0
  200. package/lib/drivers/KeyboardDriver.js +93 -0
  201. package/lib/drivers/MouseClickDriver.d.ts +8 -0
  202. package/lib/drivers/MouseClickDriver.js +98 -0
  203. package/lib/drivers/MouseMoveDriver.d.ts +8 -0
  204. package/lib/drivers/MouseMoveDriver.js +78 -0
  205. package/lib/drivers/ViewportResizeDriver.d.ts +10 -0
  206. package/lib/drivers/ViewportResizeDriver.js +98 -0
  207. package/lib/drivers/ViewportScrollDriver.d.ts +8 -0
  208. package/lib/drivers/ViewportScrollDriver.js +77 -0
  209. package/lib/drivers/index.d.ts +6 -0
  210. package/lib/drivers/index.js +22 -0
  211. package/lib/effects/index.d.ts +11 -0
  212. package/lib/effects/index.js +27 -0
  213. package/lib/effects/useAutoScrollEffect.d.ts +2 -0
  214. package/lib/effects/useAutoScrollEffect.js +69 -0
  215. package/lib/effects/useContentEditableEffect.d.ts +2 -0
  216. package/lib/effects/useContentEditableEffect.js +171 -0
  217. package/lib/effects/useCursorEffect.d.ts +2 -0
  218. package/lib/effects/useCursorEffect.js +59 -0
  219. package/lib/effects/useDragDropEffect.d.ts +2 -0
  220. package/lib/effects/useDragDropEffect.js +172 -0
  221. package/lib/effects/useFreeSelectionEffect.d.ts +2 -0
  222. package/lib/effects/useFreeSelectionEffect.js +63 -0
  223. package/lib/effects/useKeyboardEffect.d.ts +2 -0
  224. package/lib/effects/useKeyboardEffect.js +21 -0
  225. package/lib/effects/useResizeEffect.d.ts +2 -0
  226. package/lib/effects/useResizeEffect.js +84 -0
  227. package/lib/effects/useSelectionEffect.d.ts +2 -0
  228. package/lib/effects/useSelectionEffect.js +72 -0
  229. package/lib/effects/useTranslateEffect.d.ts +2 -0
  230. package/lib/effects/useTranslateEffect.js +62 -0
  231. package/lib/effects/useViewportEffect.d.ts +2 -0
  232. package/lib/effects/useViewportEffect.js +35 -0
  233. package/lib/effects/useWorkspaceEffect.d.ts +2 -0
  234. package/lib/effects/useWorkspaceEffect.js +33 -0
  235. package/lib/events/cursor/AbstractCursorEvent.d.ts +21 -0
  236. package/lib/events/cursor/AbstractCursorEvent.js +43 -0
  237. package/lib/events/cursor/DragMoveEvent.d.ts +5 -0
  238. package/lib/events/cursor/DragMoveEvent.js +54 -0
  239. package/lib/events/cursor/DragStartEvent.d.ts +5 -0
  240. package/lib/events/cursor/DragStartEvent.js +54 -0
  241. package/lib/events/cursor/DragStopEvent.d.ts +5 -0
  242. package/lib/events/cursor/DragStopEvent.js +54 -0
  243. package/lib/events/cursor/MouseClickEvent.d.ts +8 -0
  244. package/lib/events/cursor/MouseClickEvent.js +64 -0
  245. package/lib/events/cursor/MouseMoveEvent.d.ts +5 -0
  246. package/lib/events/cursor/MouseMoveEvent.js +54 -0
  247. package/lib/events/cursor/index.d.ts +5 -0
  248. package/lib/events/cursor/index.js +21 -0
  249. package/lib/events/history/AbstractHistoryEvent.d.ts +6 -0
  250. package/lib/events/history/AbstractHistoryEvent.js +10 -0
  251. package/lib/events/history/HistoryGotoEvent.d.ts +5 -0
  252. package/lib/events/history/HistoryGotoEvent.js +54 -0
  253. package/lib/events/history/HistoryPushEvent.d.ts +5 -0
  254. package/lib/events/history/HistoryPushEvent.js +54 -0
  255. package/lib/events/history/HistoryRedoEvent.d.ts +5 -0
  256. package/lib/events/history/HistoryRedoEvent.js +54 -0
  257. package/lib/events/history/HistoryUndoEvent.d.ts +5 -0
  258. package/lib/events/history/HistoryUndoEvent.js +54 -0
  259. package/lib/events/history/index.d.ts +4 -0
  260. package/lib/events/history/index.js +20 -0
  261. package/lib/events/index.d.ts +6 -0
  262. package/lib/events/index.js +22 -0
  263. package/lib/events/keyboard/AbstractKeyboardEvent.d.ts +15 -0
  264. package/lib/events/keyboard/AbstractKeyboardEvent.js +64 -0
  265. package/lib/events/keyboard/KeyDownEvent.d.ts +5 -0
  266. package/lib/events/keyboard/KeyDownEvent.js +54 -0
  267. package/lib/events/keyboard/KeyUpEvent.d.ts +5 -0
  268. package/lib/events/keyboard/KeyUpEvent.js +54 -0
  269. package/lib/events/keyboard/index.d.ts +2 -0
  270. package/lib/events/keyboard/index.js +18 -0
  271. package/lib/events/mutation/AbstractMutationNodeEvent.d.ts +13 -0
  272. package/lib/events/mutation/AbstractMutationNodeEvent.js +10 -0
  273. package/lib/events/mutation/AppendNodeEvent.d.ts +5 -0
  274. package/lib/events/mutation/AppendNodeEvent.js +54 -0
  275. package/lib/events/mutation/CloneNodeEvent.d.ts +5 -0
  276. package/lib/events/mutation/CloneNodeEvent.js +54 -0
  277. package/lib/events/mutation/DragNodeEvent.d.ts +5 -0
  278. package/lib/events/mutation/DragNodeEvent.js +54 -0
  279. package/lib/events/mutation/DropNodeEvent.d.ts +5 -0
  280. package/lib/events/mutation/DropNodeEvent.js +54 -0
  281. package/lib/events/mutation/FromNodeEvent.d.ts +13 -0
  282. package/lib/events/mutation/FromNodeEvent.js +11 -0
  283. package/lib/events/mutation/HoverNodeEvent.d.ts +5 -0
  284. package/lib/events/mutation/HoverNodeEvent.js +54 -0
  285. package/lib/events/mutation/InsertAfterEvent.d.ts +5 -0
  286. package/lib/events/mutation/InsertAfterEvent.js +54 -0
  287. package/lib/events/mutation/InsertBeforeEvent.d.ts +5 -0
  288. package/lib/events/mutation/InsertBeforeEvent.js +54 -0
  289. package/lib/events/mutation/InsertChildrenEvent.d.ts +5 -0
  290. package/lib/events/mutation/InsertChildrenEvent.js +54 -0
  291. package/lib/events/mutation/PrependNodeEvent.d.ts +5 -0
  292. package/lib/events/mutation/PrependNodeEvent.js +54 -0
  293. package/lib/events/mutation/RemoveNodeEvent.d.ts +5 -0
  294. package/lib/events/mutation/RemoveNodeEvent.js +54 -0
  295. package/lib/events/mutation/SelectNodeEvent.d.ts +5 -0
  296. package/lib/events/mutation/SelectNodeEvent.js +54 -0
  297. package/lib/events/mutation/UnSelectNodeEvent.d.ts +5 -0
  298. package/lib/events/mutation/UnSelectNodeEvent.js +54 -0
  299. package/lib/events/mutation/UpdateChildrenEvent.d.ts +5 -0
  300. package/lib/events/mutation/UpdateChildrenEvent.js +54 -0
  301. package/lib/events/mutation/UpdateNodePropsEvent.d.ts +5 -0
  302. package/lib/events/mutation/UpdateNodePropsEvent.js +54 -0
  303. package/lib/events/mutation/UserSelectNodeEvent.d.ts +5 -0
  304. package/lib/events/mutation/UserSelectNodeEvent.js +54 -0
  305. package/lib/events/mutation/WrapNodeEvent.d.ts +5 -0
  306. package/lib/events/mutation/WrapNodeEvent.js +54 -0
  307. package/lib/events/mutation/index.d.ts +16 -0
  308. package/lib/events/mutation/index.js +32 -0
  309. package/lib/events/viewport/AbstractViewportEvent.d.ts +16 -0
  310. package/lib/events/viewport/AbstractViewportEvent.js +20 -0
  311. package/lib/events/viewport/ViewportResizeEvent.d.ts +5 -0
  312. package/lib/events/viewport/ViewportResizeEvent.js +54 -0
  313. package/lib/events/viewport/ViewportScrollEvent.d.ts +5 -0
  314. package/lib/events/viewport/ViewportScrollEvent.js +54 -0
  315. package/lib/events/viewport/index.d.ts +2 -0
  316. package/lib/events/viewport/index.js +18 -0
  317. package/lib/events/workbench/AbstractWorkspaceEvent.d.ts +7 -0
  318. package/lib/events/workbench/AbstractWorkspaceEvent.js +10 -0
  319. package/lib/events/workbench/AddWorkspaceEvent.d.ts +5 -0
  320. package/lib/events/workbench/AddWorkspaceEvent.js +54 -0
  321. package/lib/events/workbench/RemoveWorkspaceEvent.d.ts +5 -0
  322. package/lib/events/workbench/RemoveWorkspaceEvent.js +54 -0
  323. package/lib/events/workbench/SwitchWorkspaceEvent.d.ts +5 -0
  324. package/lib/events/workbench/SwitchWorkspaceEvent.js +54 -0
  325. package/lib/events/workbench/index.d.ts +3 -0
  326. package/lib/events/workbench/index.js +19 -0
  327. package/lib/exports.d.ts +5 -0
  328. package/lib/exports.js +21 -0
  329. package/lib/externals.d.ts +12 -0
  330. package/lib/externals.js +126 -0
  331. package/lib/index.d.ts +1 -0
  332. package/lib/index.js +52 -0
  333. package/lib/internals.d.ts +3 -0
  334. package/lib/internals.js +40 -0
  335. package/lib/models/Cursor.d.ts +60 -0
  336. package/lib/models/Cursor.js +154 -0
  337. package/lib/models/Engine.d.ts +29 -0
  338. package/lib/models/Engine.js +115 -0
  339. package/lib/models/History.d.ts +34 -0
  340. package/lib/models/History.js +113 -0
  341. package/lib/models/Hover.d.ts +14 -0
  342. package/lib/models/Hover.js +41 -0
  343. package/lib/models/Keyboard.d.ts +29 -0
  344. package/lib/models/Keyboard.js +129 -0
  345. package/lib/models/MoveHelper.d.ts +66 -0
  346. package/lib/models/MoveHelper.js +366 -0
  347. package/lib/models/Operation.d.ts +29 -0
  348. package/lib/models/Operation.js +78 -0
  349. package/lib/models/Screen.d.ts +31 -0
  350. package/lib/models/Screen.js +76 -0
  351. package/lib/models/Selection.d.ts +29 -0
  352. package/lib/models/Selection.js +195 -0
  353. package/lib/models/Shortcut.d.ts +20 -0
  354. package/lib/models/Shortcut.js +72 -0
  355. package/lib/models/SnapLine.d.ts +27 -0
  356. package/lib/models/SnapLine.js +144 -0
  357. package/lib/models/SpaceBlock.d.ts +40 -0
  358. package/lib/models/SpaceBlock.js +174 -0
  359. package/lib/models/TransformHelper.d.ts +80 -0
  360. package/lib/models/TransformHelper.js +604 -0
  361. package/lib/models/TreeNode.d.ts +115 -0
  362. package/lib/models/TreeNode.js +935 -0
  363. package/lib/models/Viewport.d.ts +90 -0
  364. package/lib/models/Viewport.js +477 -0
  365. package/lib/models/Workbench.d.ts +23 -0
  366. package/lib/models/Workbench.js +101 -0
  367. package/lib/models/Workspace.d.ts +41 -0
  368. package/lib/models/Workspace.js +98 -0
  369. package/lib/models/index.d.ts +13 -0
  370. package/lib/models/index.js +29 -0
  371. package/lib/presets.d.ts +4 -0
  372. package/lib/presets.js +41 -0
  373. package/lib/registry.d.ts +16 -0
  374. package/lib/registry.js +126 -0
  375. package/lib/shortcuts/CursorSwitch.d.ts +2 -0
  376. package/lib/shortcuts/CursorSwitch.js +13 -0
  377. package/lib/shortcuts/MultiSelection.d.ts +5 -0
  378. package/lib/shortcuts/MultiSelection.js +30 -0
  379. package/lib/shortcuts/NodeMutation.d.ts +7 -0
  380. package/lib/shortcuts/NodeMutation.js +43 -0
  381. package/lib/shortcuts/QuickSelection.d.ts +3 -0
  382. package/lib/shortcuts/QuickSelection.js +88 -0
  383. package/lib/shortcuts/UndoRedo.d.ts +3 -0
  384. package/lib/shortcuts/UndoRedo.js +30 -0
  385. package/lib/shortcuts/index.d.ts +5 -0
  386. package/lib/shortcuts/index.js +21 -0
  387. package/lib/types.d.ts +131 -0
  388. package/lib/types.js +2 -0
  389. package/package.json +49 -0
@@ -0,0 +1,90 @@
1
+ import { IPoint, Rect, IRect } from '@mdesignable/shared';
2
+ import { Workspace } from './Workspace';
3
+ import { Engine } from './Engine';
4
+ import { TreeNode } from './TreeNode';
5
+ export interface IViewportProps {
6
+ engine: Engine;
7
+ workspace: Workspace;
8
+ viewportElement: HTMLElement;
9
+ contentWindow: Window;
10
+ nodeIdAttrName: string;
11
+ moveSensitive?: boolean;
12
+ moveInsertionType?: IViewportMoveInsertionType;
13
+ }
14
+ export interface IViewportData {
15
+ scrollX?: number;
16
+ scrollY?: number;
17
+ width?: number;
18
+ height?: number;
19
+ }
20
+ export type IViewportMoveInsertionType = 'all' | 'inline' | 'block';
21
+ /**
22
+ * 视口模型
23
+ */
24
+ export declare class Viewport {
25
+ workspace: Workspace;
26
+ engine: Engine;
27
+ contentWindow: Window;
28
+ viewportElement: HTMLElement;
29
+ dragStartSnapshot: IViewportData;
30
+ scrollX: number;
31
+ scrollY: number;
32
+ width: number;
33
+ height: number;
34
+ mounted: boolean;
35
+ attachRequest: number;
36
+ nodeIdAttrName: string;
37
+ moveSensitive: boolean;
38
+ moveInsertionType: IViewportMoveInsertionType;
39
+ nodeElementsStore: Record<string, HTMLElement[]>;
40
+ constructor(props: IViewportProps);
41
+ get isScrollLeft(): boolean;
42
+ get isScrollTop(): boolean;
43
+ get isScrollRight(): boolean;
44
+ get isScrollBottom(): boolean;
45
+ get viewportRoot(): HTMLElement;
46
+ get isMaster(): boolean;
47
+ get isIframe(): boolean;
48
+ get scrollContainer(): Window | HTMLElement;
49
+ get rect(): DOMRect;
50
+ get innerRect(): Rect;
51
+ get offsetX(): number;
52
+ get offsetY(): number;
53
+ get scale(): number;
54
+ get dragScrollXDelta(): number;
55
+ get dragScrollYDelta(): number;
56
+ cacheElements(): void;
57
+ clearCache(): void;
58
+ getCurrentData(): IViewportData;
59
+ takeDragStartSnapshot(): void;
60
+ digestViewport(): void;
61
+ elementFromPoint(point: IPoint): Element;
62
+ matchViewport(target: HTMLElement | Element | Window | Document | EventTarget): boolean;
63
+ attachEvents(): void;
64
+ detachEvents(): void;
65
+ onMount(element: HTMLElement, contentWindow: Window): void;
66
+ onUnmount(): void;
67
+ isPointInViewport(point: IPoint, sensitive?: boolean): boolean;
68
+ isRectInViewport(rect: IRect): boolean;
69
+ isPointInViewportArea(point: IPoint, sensitive?: boolean): boolean;
70
+ isOffsetPointInViewport(point: IPoint, sensitive?: boolean): boolean;
71
+ isOffsetRectInViewport(rect: IRect): boolean;
72
+ makeObservable(): void;
73
+ findElementById(id: string): HTMLElement;
74
+ findElementsById(id: string): HTMLElement[];
75
+ containsElement(element: HTMLElement | Element | EventTarget): boolean;
76
+ getOffsetPoint(topPoint: IPoint): {
77
+ x: number;
78
+ y: number;
79
+ };
80
+ getElementRect(element: HTMLElement | Element): Rect;
81
+ getElementRectById(id: string): Rect;
82
+ getElementOffsetRect(element: HTMLElement | Element): Rect;
83
+ getElementOffsetRectById(id: string): Rect;
84
+ getValidNodeElement(node: TreeNode): Element;
85
+ getChildrenRect(node: TreeNode): Rect;
86
+ getChildrenOffsetRect(node: TreeNode): Rect;
87
+ getValidNodeRect(node: TreeNode): Rect;
88
+ getValidNodeOffsetRect(node: TreeNode): Rect;
89
+ getValidNodeLayout(node: TreeNode): "vertical" | "horizontal";
90
+ }
@@ -0,0 +1,477 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Viewport = void 0;
4
+ var shared_1 = require("@mdesignable/shared");
5
+ var reactive_1 = require("@formily/reactive");
6
+ /**
7
+ * 视口模型
8
+ */
9
+ var Viewport = /** @class */ (function () {
10
+ function Viewport(props) {
11
+ var _a, _b;
12
+ this.scrollX = 0;
13
+ this.scrollY = 0;
14
+ this.width = 0;
15
+ this.height = 0;
16
+ this.mounted = false;
17
+ this.nodeElementsStore = {};
18
+ this.workspace = props.workspace;
19
+ this.engine = props.engine;
20
+ this.moveSensitive = (_a = props.moveSensitive) !== null && _a !== void 0 ? _a : false;
21
+ this.moveInsertionType = (_b = props.moveInsertionType) !== null && _b !== void 0 ? _b : 'all';
22
+ this.viewportElement = props.viewportElement;
23
+ this.contentWindow = props.contentWindow;
24
+ this.nodeIdAttrName = props.nodeIdAttrName;
25
+ this.digestViewport();
26
+ this.makeObservable();
27
+ this.attachEvents();
28
+ }
29
+ Object.defineProperty(Viewport.prototype, "isScrollLeft", {
30
+ get: function () {
31
+ return this.scrollX === 0;
32
+ },
33
+ enumerable: false,
34
+ configurable: true
35
+ });
36
+ Object.defineProperty(Viewport.prototype, "isScrollTop", {
37
+ get: function () {
38
+ return this.scrollY === 0;
39
+ },
40
+ enumerable: false,
41
+ configurable: true
42
+ });
43
+ Object.defineProperty(Viewport.prototype, "isScrollRight", {
44
+ get: function () {
45
+ var _a, _b, _c;
46
+ if (this.isIframe) {
47
+ return (this.width + this.contentWindow.scrollX >=
48
+ ((_c = (_b = (_a = this.contentWindow) === null || _a === void 0 ? void 0 : _a.document) === null || _b === void 0 ? void 0 : _b.body) === null || _c === void 0 ? void 0 : _c.scrollWidth));
49
+ }
50
+ else if (this.viewportElement) {
51
+ return (this.viewportElement.offsetWidth + this.scrollX >=
52
+ this.viewportElement.scrollWidth);
53
+ }
54
+ },
55
+ enumerable: false,
56
+ configurable: true
57
+ });
58
+ Object.defineProperty(Viewport.prototype, "isScrollBottom", {
59
+ get: function () {
60
+ var _a, _b;
61
+ if (this.isIframe) {
62
+ if (!((_b = (_a = this.contentWindow) === null || _a === void 0 ? void 0 : _a.document) === null || _b === void 0 ? void 0 : _b.body))
63
+ return false;
64
+ return (this.height + this.contentWindow.scrollY >=
65
+ this.contentWindow.document.body.scrollHeight);
66
+ }
67
+ else if (this.viewportElement) {
68
+ if (!this.viewportElement)
69
+ return false;
70
+ return (this.viewportElement.offsetHeight + this.viewportElement.scrollTop >=
71
+ this.viewportElement.scrollHeight);
72
+ }
73
+ },
74
+ enumerable: false,
75
+ configurable: true
76
+ });
77
+ Object.defineProperty(Viewport.prototype, "viewportRoot", {
78
+ get: function () {
79
+ var _a, _b;
80
+ return this.isIframe
81
+ ? (_b = (_a = this.contentWindow) === null || _a === void 0 ? void 0 : _a.document) === null || _b === void 0 ? void 0 : _b.body
82
+ : this.viewportElement;
83
+ },
84
+ enumerable: false,
85
+ configurable: true
86
+ });
87
+ Object.defineProperty(Viewport.prototype, "isMaster", {
88
+ get: function () {
89
+ return this.contentWindow === shared_1.globalThisPolyfill;
90
+ },
91
+ enumerable: false,
92
+ configurable: true
93
+ });
94
+ Object.defineProperty(Viewport.prototype, "isIframe", {
95
+ get: function () {
96
+ var _a;
97
+ return !!((_a = this.contentWindow) === null || _a === void 0 ? void 0 : _a.frameElement) && !this.isMaster;
98
+ },
99
+ enumerable: false,
100
+ configurable: true
101
+ });
102
+ Object.defineProperty(Viewport.prototype, "scrollContainer", {
103
+ get: function () {
104
+ return this.isIframe ? this.contentWindow : this.viewportElement;
105
+ },
106
+ enumerable: false,
107
+ configurable: true
108
+ });
109
+ Object.defineProperty(Viewport.prototype, "rect", {
110
+ get: function () {
111
+ var viewportElement = this.viewportElement;
112
+ if (viewportElement)
113
+ return viewportElement.getBoundingClientRect();
114
+ },
115
+ enumerable: false,
116
+ configurable: true
117
+ });
118
+ Object.defineProperty(Viewport.prototype, "innerRect", {
119
+ get: function () {
120
+ var rect = this.rect;
121
+ return new shared_1.Rect(0, 0, rect === null || rect === void 0 ? void 0 : rect.width, rect === null || rect === void 0 ? void 0 : rect.height);
122
+ },
123
+ enumerable: false,
124
+ configurable: true
125
+ });
126
+ Object.defineProperty(Viewport.prototype, "offsetX", {
127
+ get: function () {
128
+ var rect = this.rect;
129
+ if (!rect)
130
+ return 0;
131
+ return rect.x;
132
+ },
133
+ enumerable: false,
134
+ configurable: true
135
+ });
136
+ Object.defineProperty(Viewport.prototype, "offsetY", {
137
+ get: function () {
138
+ var rect = this.rect;
139
+ if (!rect)
140
+ return 0;
141
+ return rect.y;
142
+ },
143
+ enumerable: false,
144
+ configurable: true
145
+ });
146
+ Object.defineProperty(Viewport.prototype, "scale", {
147
+ get: function () {
148
+ if (!this.viewportElement)
149
+ return 1;
150
+ var clientRect = this.viewportElement.getBoundingClientRect();
151
+ var offsetWidth = this.viewportElement.offsetWidth;
152
+ if (!clientRect.width || !offsetWidth)
153
+ return 1;
154
+ return Math.round(clientRect.width / offsetWidth);
155
+ },
156
+ enumerable: false,
157
+ configurable: true
158
+ });
159
+ Object.defineProperty(Viewport.prototype, "dragScrollXDelta", {
160
+ get: function () {
161
+ return this.scrollX - this.dragStartSnapshot.scrollX;
162
+ },
163
+ enumerable: false,
164
+ configurable: true
165
+ });
166
+ Object.defineProperty(Viewport.prototype, "dragScrollYDelta", {
167
+ get: function () {
168
+ return this.scrollY - this.dragStartSnapshot.scrollY;
169
+ },
170
+ enumerable: false,
171
+ configurable: true
172
+ });
173
+ Viewport.prototype.cacheElements = function () {
174
+ var _this = this;
175
+ var _a;
176
+ this.nodeElementsStore = {};
177
+ (_a = this.viewportRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll("*[".concat(this.nodeIdAttrName, "]")).forEach(function (element) {
178
+ var id = element.getAttribute(_this.nodeIdAttrName);
179
+ _this.nodeElementsStore[id] = _this.nodeElementsStore[id] || [];
180
+ _this.nodeElementsStore[id].push(element);
181
+ });
182
+ };
183
+ Viewport.prototype.clearCache = function () {
184
+ this.nodeElementsStore = {};
185
+ };
186
+ Viewport.prototype.getCurrentData = function () {
187
+ var _a, _b, _c, _d, _e, _f, _g, _h;
188
+ var data = {};
189
+ if (this.isIframe) {
190
+ data.scrollX = ((_a = this.contentWindow) === null || _a === void 0 ? void 0 : _a.scrollX) || 0;
191
+ data.scrollY = ((_b = this.contentWindow) === null || _b === void 0 ? void 0 : _b.scrollY) || 0;
192
+ data.width = ((_c = this.contentWindow) === null || _c === void 0 ? void 0 : _c.innerWidth) || 0;
193
+ data.height = ((_d = this.contentWindow) === null || _d === void 0 ? void 0 : _d.innerHeight) || 0;
194
+ }
195
+ else if (this.viewportElement) {
196
+ data.scrollX = ((_e = this.viewportElement) === null || _e === void 0 ? void 0 : _e.scrollLeft) || 0;
197
+ data.scrollY = ((_f = this.viewportElement) === null || _f === void 0 ? void 0 : _f.scrollTop) || 0;
198
+ data.width = ((_g = this.viewportElement) === null || _g === void 0 ? void 0 : _g.clientWidth) || 0;
199
+ data.height = ((_h = this.viewportElement) === null || _h === void 0 ? void 0 : _h.clientHeight) || 0;
200
+ }
201
+ return data;
202
+ };
203
+ Viewport.prototype.takeDragStartSnapshot = function () {
204
+ this.dragStartSnapshot = this.getCurrentData();
205
+ };
206
+ Viewport.prototype.digestViewport = function () {
207
+ Object.assign(this, this.getCurrentData());
208
+ };
209
+ Viewport.prototype.elementFromPoint = function (point) {
210
+ var _a;
211
+ if ((_a = this.contentWindow) === null || _a === void 0 ? void 0 : _a.document) {
212
+ return this.contentWindow.document.elementFromPoint(point.x, point.y);
213
+ }
214
+ };
215
+ Viewport.prototype.matchViewport = function (target) {
216
+ var _a;
217
+ if (this.isIframe) {
218
+ return (target === this.viewportElement ||
219
+ target === this.contentWindow ||
220
+ target === ((_a = this.contentWindow) === null || _a === void 0 ? void 0 : _a.document));
221
+ }
222
+ else {
223
+ return target === this.viewportElement;
224
+ }
225
+ };
226
+ Viewport.prototype.attachEvents = function () {
227
+ var _this = this;
228
+ var engine = this.engine;
229
+ (0, shared_1.cancelIdle)(this.attachRequest);
230
+ this.attachRequest = (0, shared_1.requestIdle)(function () {
231
+ if (!engine)
232
+ return;
233
+ if (_this.isIframe) {
234
+ _this.workspace.attachEvents(_this.contentWindow, _this.contentWindow);
235
+ }
236
+ else if ((0, shared_1.isHTMLElement)(_this.viewportElement)) {
237
+ _this.workspace.attachEvents(_this.viewportElement, _this.contentWindow);
238
+ }
239
+ });
240
+ };
241
+ Viewport.prototype.detachEvents = function () {
242
+ if (this.isIframe) {
243
+ this.workspace.detachEvents(this.contentWindow);
244
+ this.workspace.detachEvents(this.viewportElement);
245
+ }
246
+ else if (this.viewportElement) {
247
+ this.workspace.detachEvents(this.viewportElement);
248
+ }
249
+ };
250
+ Viewport.prototype.onMount = function (element, contentWindow) {
251
+ this.mounted = true;
252
+ this.viewportElement = element;
253
+ this.contentWindow = contentWindow;
254
+ this.attachEvents();
255
+ this.digestViewport();
256
+ };
257
+ Viewport.prototype.onUnmount = function () {
258
+ this.mounted = false;
259
+ this.detachEvents();
260
+ };
261
+ Viewport.prototype.isPointInViewport = function (point, sensitive) {
262
+ if (!this.rect)
263
+ return false;
264
+ if (!this.containsElement(document.elementFromPoint(point.x, point.y))) {
265
+ return false;
266
+ }
267
+ return (0, shared_1.isPointInRect)(point, this.rect, sensitive);
268
+ };
269
+ Viewport.prototype.isRectInViewport = function (rect) {
270
+ if (!this.rect || !rect)
271
+ return false;
272
+ if (!this.containsElement(document.elementFromPoint(rect.x, rect.y))) {
273
+ return false;
274
+ }
275
+ return (0, shared_1.isRectInRect)(rect, this.rect);
276
+ };
277
+ Viewport.prototype.isPointInViewportArea = function (point, sensitive) {
278
+ if (!this.rect)
279
+ return false;
280
+ return (0, shared_1.isPointInRect)(point, this.rect, sensitive);
281
+ };
282
+ Viewport.prototype.isOffsetPointInViewport = function (point, sensitive) {
283
+ if (!this.innerRect)
284
+ return false;
285
+ if (!this.containsElement(document.elementFromPoint(point.x, point.y)))
286
+ return false;
287
+ return (0, shared_1.isPointInRect)(point, this.innerRect, sensitive);
288
+ };
289
+ Viewport.prototype.isOffsetRectInViewport = function (rect) {
290
+ if (!this.innerRect)
291
+ return false;
292
+ if (!this.containsElement(document.elementFromPoint(rect.x, rect.y))) {
293
+ return false;
294
+ }
295
+ return (0, shared_1.isRectInRect)(rect, this.innerRect);
296
+ };
297
+ Viewport.prototype.makeObservable = function () {
298
+ (0, reactive_1.define)(this, {
299
+ scrollX: reactive_1.observable.ref,
300
+ scrollY: reactive_1.observable.ref,
301
+ width: reactive_1.observable.ref,
302
+ height: reactive_1.observable.ref,
303
+ digestViewport: reactive_1.action,
304
+ viewportElement: reactive_1.observable.ref,
305
+ contentWindow: reactive_1.observable.ref,
306
+ });
307
+ };
308
+ Viewport.prototype.findElementById = function (id) {
309
+ var _a;
310
+ if (!id)
311
+ return;
312
+ if (this.nodeElementsStore[id])
313
+ return this.nodeElementsStore[id][0];
314
+ return (_a = this.viewportRoot) === null || _a === void 0 ? void 0 : _a.querySelector("*[".concat(this.nodeIdAttrName, "='").concat(id, "']"));
315
+ };
316
+ Viewport.prototype.findElementsById = function (id) {
317
+ var _a, _b;
318
+ if (!id)
319
+ return [];
320
+ if (this.nodeElementsStore[id])
321
+ return this.nodeElementsStore[id];
322
+ return Array.from((_b = (_a = this.viewportRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll("*[".concat(this.nodeIdAttrName, "='").concat(id, "']"))) !== null && _b !== void 0 ? _b : []);
323
+ };
324
+ Viewport.prototype.containsElement = function (element) {
325
+ var root = this.viewportElement;
326
+ if (root === element)
327
+ return true;
328
+ return root === null || root === void 0 ? void 0 : root.contains(element);
329
+ };
330
+ Viewport.prototype.getOffsetPoint = function (topPoint) {
331
+ var data = this.getCurrentData();
332
+ return {
333
+ x: topPoint.x - this.offsetX + data.scrollX,
334
+ y: topPoint.y - this.offsetY + data.scrollY,
335
+ };
336
+ };
337
+ //相对于页面
338
+ Viewport.prototype.getElementRect = function (element) {
339
+ var rect = element.getBoundingClientRect();
340
+ var offsetWidth = element['offsetWidth']
341
+ ? element['offsetWidth']
342
+ : rect.width;
343
+ var offsetHeight = element['offsetHeight']
344
+ ? element['offsetHeight']
345
+ : rect.height;
346
+ return new shared_1.Rect(rect.x, rect.y, this.scale !== 1 ? offsetWidth : rect.width, this.scale !== 1 ? offsetHeight : rect.height);
347
+ };
348
+ //相对于页面
349
+ Viewport.prototype.getElementRectById = function (id) {
350
+ var _this = this;
351
+ var elements = this.findElementsById(id);
352
+ var rect = (0, shared_1.calcBoundingRect)(elements.map(function (element) { return _this.getElementRect(element); }));
353
+ if (rect) {
354
+ if (this.isIframe) {
355
+ return new shared_1.Rect(rect.x + this.offsetX, rect.y + this.offsetY, rect.width, rect.height);
356
+ }
357
+ else {
358
+ return new shared_1.Rect(rect.x, rect.y, rect.width, rect.height);
359
+ }
360
+ }
361
+ };
362
+ //相对于视口
363
+ Viewport.prototype.getElementOffsetRect = function (element) {
364
+ var elementRect = element.getBoundingClientRect();
365
+ if (elementRect) {
366
+ if (this.isIframe) {
367
+ return new shared_1.Rect(elementRect.x + this.contentWindow.scrollX, elementRect.y + this.contentWindow.scrollY, elementRect.width, elementRect.height);
368
+ }
369
+ else {
370
+ return new shared_1.Rect((elementRect.x - this.offsetX + this.viewportElement.scrollLeft) /
371
+ this.scale, (elementRect.y - this.offsetY + this.viewportElement.scrollTop) /
372
+ this.scale, elementRect.width, elementRect.height);
373
+ }
374
+ }
375
+ };
376
+ //相对于视口
377
+ Viewport.prototype.getElementOffsetRectById = function (id) {
378
+ var _this = this;
379
+ var elements = this.findElementsById(id);
380
+ if (!elements.length)
381
+ return;
382
+ var elementRect = (0, shared_1.calcBoundingRect)(elements.map(function (element) { return _this.getElementRect(element); }));
383
+ if (elementRect) {
384
+ if (this.isIframe) {
385
+ return new shared_1.Rect(elementRect.x + this.contentWindow.scrollX, elementRect.y + this.contentWindow.scrollY, elementRect.width, elementRect.height);
386
+ }
387
+ else {
388
+ return new shared_1.Rect((elementRect.x - this.offsetX + this.viewportElement.scrollLeft) /
389
+ this.scale, (elementRect.y - this.offsetY + this.viewportElement.scrollTop) /
390
+ this.scale, elementRect.width, elementRect.height);
391
+ }
392
+ }
393
+ };
394
+ Viewport.prototype.getValidNodeElement = function (node) {
395
+ var _this = this;
396
+ var getNodeElement = function (node) {
397
+ if (!node)
398
+ return;
399
+ var ele = _this.findElementById(node.id);
400
+ if (ele) {
401
+ return ele;
402
+ }
403
+ else {
404
+ return getNodeElement(node.parent);
405
+ }
406
+ };
407
+ return getNodeElement(node);
408
+ };
409
+ Viewport.prototype.getChildrenRect = function (node) {
410
+ var _this = this;
411
+ var _a;
412
+ if (!((_a = node === null || node === void 0 ? void 0 : node.children) === null || _a === void 0 ? void 0 : _a.length))
413
+ return;
414
+ return (0, shared_1.calcBoundingRect)(node.children.reduce(function (buf, child) {
415
+ var rect = _this.getValidNodeRect(child);
416
+ if (rect) {
417
+ return buf.concat(rect);
418
+ }
419
+ return buf;
420
+ }, []));
421
+ };
422
+ Viewport.prototype.getChildrenOffsetRect = function (node) {
423
+ var _this = this;
424
+ var _a;
425
+ if (!((_a = node === null || node === void 0 ? void 0 : node.children) === null || _a === void 0 ? void 0 : _a.length))
426
+ return;
427
+ return (0, shared_1.calcBoundingRect)(node.children.reduce(function (buf, child) {
428
+ var rect = _this.getValidNodeOffsetRect(child);
429
+ if (rect) {
430
+ return buf.concat(rect);
431
+ }
432
+ return buf;
433
+ }, []));
434
+ };
435
+ Viewport.prototype.getValidNodeRect = function (node) {
436
+ if (!node)
437
+ return;
438
+ var rect = this.getElementRectById(node.id);
439
+ if (node && node === node.root && node.isInOperation) {
440
+ if (!rect)
441
+ return this.rect;
442
+ return (0, shared_1.calcBoundingRect)([this.rect, rect]);
443
+ }
444
+ if (rect) {
445
+ return rect;
446
+ }
447
+ else {
448
+ return this.getChildrenRect(node);
449
+ }
450
+ };
451
+ Viewport.prototype.getValidNodeOffsetRect = function (node) {
452
+ if (!node)
453
+ return;
454
+ var rect = this.getElementOffsetRectById(node.id);
455
+ if (node && node === node.root && node.isInOperation) {
456
+ if (!rect)
457
+ return this.innerRect;
458
+ return (0, shared_1.calcBoundingRect)([this.innerRect, rect]);
459
+ }
460
+ if (rect) {
461
+ return rect;
462
+ }
463
+ else {
464
+ return this.getChildrenOffsetRect(node);
465
+ }
466
+ };
467
+ Viewport.prototype.getValidNodeLayout = function (node) {
468
+ var _a, _b;
469
+ if (!node)
470
+ return 'vertical';
471
+ if ((_b = (_a = node.parent) === null || _a === void 0 ? void 0 : _a.designerProps) === null || _b === void 0 ? void 0 : _b.inlineChildrenLayout)
472
+ return 'horizontal';
473
+ return (0, shared_1.calcElementLayout)(this.findElementById(node.id));
474
+ };
475
+ return Viewport;
476
+ }());
477
+ exports.Viewport = Viewport;
@@ -0,0 +1,23 @@
1
+ import { Engine } from './Engine';
2
+ import { Workspace, IWorkspaceProps } from './Workspace';
3
+ import { IEngineContext, WorkbenchTypes } from '../types';
4
+ export declare class Workbench {
5
+ workspaces: Workspace[];
6
+ currentWorkspace: Workspace;
7
+ activeWorkspace: Workspace;
8
+ engine: Engine;
9
+ type: WorkbenchTypes;
10
+ constructor(engine: Engine);
11
+ makeObservable(): void;
12
+ getEventContext(): IEngineContext;
13
+ switchWorkspace(id: string): Workspace;
14
+ setActiveWorkspace(workspace: Workspace): Workspace;
15
+ setWorkbenchType(type: WorkbenchTypes): void;
16
+ addWorkspace(props: IWorkspaceProps): Workspace;
17
+ removeWorkspace(id: string): void;
18
+ ensureWorkspace(props?: IWorkspaceProps): Workspace;
19
+ findWorkspaceById(id: string): Workspace;
20
+ findWorkspaceIndexById(id: string): number;
21
+ mapWorkspace<T>(callbackFn: (value: Workspace, index: number) => T): T[];
22
+ eachWorkspace<T>(callbackFn: (value: Workspace, index: number) => T): void;
23
+ }
@@ -0,0 +1,101 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Workbench = void 0;
4
+ var Workspace_1 = require("./Workspace");
5
+ var reactive_1 = require("@formily/reactive");
6
+ var events_1 = require("../events");
7
+ var Workbench = /** @class */ (function () {
8
+ function Workbench(engine) {
9
+ this.type = 'DESIGNABLE';
10
+ this.engine = engine;
11
+ this.workspaces = [];
12
+ this.currentWorkspace = null;
13
+ this.activeWorkspace = null;
14
+ this.makeObservable();
15
+ }
16
+ Workbench.prototype.makeObservable = function () {
17
+ (0, reactive_1.define)(this, {
18
+ currentWorkspace: reactive_1.observable.ref,
19
+ workspaces: reactive_1.observable.shallow,
20
+ activeWorkspace: reactive_1.observable.ref,
21
+ type: reactive_1.observable.ref,
22
+ switchWorkspace: reactive_1.action,
23
+ addWorkspace: reactive_1.action,
24
+ removeWorkspace: reactive_1.action,
25
+ setActiveWorkspace: reactive_1.action,
26
+ setWorkbenchType: reactive_1.action,
27
+ });
28
+ };
29
+ Workbench.prototype.getEventContext = function () {
30
+ return {
31
+ engine: this.engine,
32
+ workbench: this.engine.workbench,
33
+ workspace: null,
34
+ viewport: null,
35
+ };
36
+ };
37
+ Workbench.prototype.switchWorkspace = function (id) {
38
+ var finded = this.findWorkspaceById(id);
39
+ if (finded) {
40
+ this.currentWorkspace = finded;
41
+ this.engine.dispatch(new events_1.SwitchWorkspaceEvent(finded));
42
+ }
43
+ return this.currentWorkspace;
44
+ };
45
+ Workbench.prototype.setActiveWorkspace = function (workspace) {
46
+ this.activeWorkspace = workspace;
47
+ return workspace;
48
+ };
49
+ Workbench.prototype.setWorkbenchType = function (type) {
50
+ this.type = type;
51
+ };
52
+ Workbench.prototype.addWorkspace = function (props) {
53
+ var finded = this.findWorkspaceById(props.id);
54
+ if (!finded) {
55
+ this.currentWorkspace = new Workspace_1.Workspace(this.engine, props);
56
+ this.workspaces.push(this.currentWorkspace);
57
+ this.engine.dispatch(new events_1.AddWorkspaceEvent(this.currentWorkspace));
58
+ return this.currentWorkspace;
59
+ }
60
+ return finded;
61
+ };
62
+ Workbench.prototype.removeWorkspace = function (id) {
63
+ var findIndex = this.findWorkspaceIndexById(id);
64
+ if (findIndex > -1 && findIndex < this.workspaces.length) {
65
+ var findedWorkspace = this.workspaces[findIndex];
66
+ findedWorkspace.viewport.detachEvents();
67
+ this.workspaces.splice(findIndex, 1);
68
+ if (findedWorkspace === this.currentWorkspace) {
69
+ if (this.workspaces.length && this.workspaces[findIndex]) {
70
+ this.currentWorkspace = this.workspaces[findIndex];
71
+ }
72
+ else {
73
+ this.currentWorkspace = this.workspaces[this.workspaces.length - 1];
74
+ }
75
+ }
76
+ this.engine.dispatch(new events_1.RemoveWorkspaceEvent(findedWorkspace));
77
+ }
78
+ };
79
+ Workbench.prototype.ensureWorkspace = function (props) {
80
+ if (props === void 0) { props = {}; }
81
+ var workspace = this.findWorkspaceById(props.id);
82
+ if (workspace)
83
+ return workspace;
84
+ this.addWorkspace(props);
85
+ return this.currentWorkspace;
86
+ };
87
+ Workbench.prototype.findWorkspaceById = function (id) {
88
+ return this.workspaces.find(function (item) { return item.id === id; });
89
+ };
90
+ Workbench.prototype.findWorkspaceIndexById = function (id) {
91
+ return this.workspaces.findIndex(function (item) { return item.id === id; });
92
+ };
93
+ Workbench.prototype.mapWorkspace = function (callbackFn) {
94
+ return this.workspaces.map(callbackFn);
95
+ };
96
+ Workbench.prototype.eachWorkspace = function (callbackFn) {
97
+ this.workspaces.forEach(callbackFn);
98
+ };
99
+ return Workbench;
100
+ }());
101
+ exports.Workbench = Workbench;