@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
package/lib/types.d.ts ADDED
@@ -0,0 +1,131 @@
1
+ import { IEventProps, Event } from '@sulesky/next-shared';
2
+ import { ISchema } from '@formily/json-schema';
3
+ import { Engine, ITreeNode, ScreenType, Shortcut, Viewport, Workbench, Workspace, TreeNode } from './models';
4
+ export type IEngineProps<T = Event> = IEventProps<T> & {
5
+ shortcuts?: Shortcut[];
6
+ sourceIdAttrName?: string;
7
+ nodeIdAttrName?: string;
8
+ contentEditableAttrName?: string;
9
+ contentEditableNodeIdAttrName?: string;
10
+ clickStopPropagationAttrName?: string;
11
+ outlineNodeIdAttrName?: string;
12
+ nodeSelectionIdAttrName?: string;
13
+ nodeDragHandlerAttrName?: string;
14
+ screenResizeHandlerAttrName?: string;
15
+ nodeResizeHandlerAttrName?: string;
16
+ nodeTranslateAttrName?: string;
17
+ defaultComponentTree?: ITreeNode;
18
+ defaultScreenType?: ScreenType;
19
+ rootComponentName?: string;
20
+ };
21
+ export type IEngineContext = {
22
+ workspace: Workspace;
23
+ workbench: Workbench;
24
+ engine: Engine;
25
+ viewport: Viewport;
26
+ };
27
+ export type IResizable = {
28
+ width?: (node: TreeNode, element: Element) => {
29
+ plus: () => void;
30
+ minus: () => void;
31
+ };
32
+ height?: (node: TreeNode, element: Element) => {
33
+ plus: () => void;
34
+ minus: () => void;
35
+ };
36
+ };
37
+ export type ITranslate = {
38
+ x: (node: TreeNode, element: HTMLElement, diffX: string | number) => {
39
+ translate: () => void;
40
+ };
41
+ y: (node: TreeNode, element: HTMLElement, diffY: string | number) => {
42
+ translate: () => void;
43
+ };
44
+ };
45
+ export interface IDesignerProps {
46
+ package?: string;
47
+ registry?: string;
48
+ version?: string;
49
+ path?: string;
50
+ title?: string;
51
+ description?: string;
52
+ icon?: string;
53
+ droppable?: boolean;
54
+ draggable?: boolean;
55
+ deletable?: boolean;
56
+ cloneable?: boolean;
57
+ resizable?: IResizable;
58
+ translatable?: ITranslate;
59
+ inlineChildrenLayout?: boolean;
60
+ selfRenderChildren?: boolean;
61
+ propsSchema?: ISchema;
62
+ defaultProps?: any;
63
+ getDragNodes?: (node: TreeNode) => TreeNode | TreeNode[];
64
+ getDropNodes?: (node: TreeNode, parent: TreeNode) => TreeNode | TreeNode[];
65
+ getComponentProps?: (node: TreeNode) => any;
66
+ allowAppend?: (target: TreeNode, sources?: TreeNode[]) => boolean;
67
+ allowSiblings?: (target: TreeNode, sources?: TreeNode[]) => boolean;
68
+ allowDrop?: (target: TreeNode) => boolean;
69
+ [key: string]: any;
70
+ }
71
+ export type IDesignerPropsMap = Record<string, IDesignerProps>;
72
+ export type IDesignerControllerProps = IDesignerProps | ((node: TreeNode) => IDesignerProps);
73
+ export type IDesignerControllerPropsMap = Record<string, IDesignerControllerProps>;
74
+ export interface IDesignerLocales {
75
+ [ISOCode: string]: {
76
+ [key: string]: any;
77
+ };
78
+ }
79
+ export interface IDesignerMiniLocales {
80
+ [ISOCode: string]: string;
81
+ }
82
+ export interface IDesignerBehaviors {
83
+ [key: string]: IBehaviorHost;
84
+ }
85
+ export interface IDesignerStore<P> {
86
+ value: P;
87
+ }
88
+ export type IDesignerIcons = Record<string, any>;
89
+ export type IDesignerIconsStore = IDesignerStore<IDesignerIcons>;
90
+ export type IDesignerLocaleStore = IDesignerStore<IDesignerLocales>;
91
+ export type IDesignerBehaviorStore = IDesignerStore<IBehavior[]>;
92
+ export type IDesignerLanguageStore = IDesignerStore<string>;
93
+ export type WorkbenchTypes = 'DESIGNABLE' | 'PREVIEW' | 'JSONTREE' | 'MARKUP' | (string & {});
94
+ export interface IBehavior {
95
+ name: string;
96
+ extends?: string[];
97
+ selector: (node: TreeNode) => boolean;
98
+ designerProps?: IDesignerControllerProps;
99
+ designerLocales?: IDesignerLocales;
100
+ }
101
+ export interface IBehaviorCreator {
102
+ name: string;
103
+ extends?: string[];
104
+ selector: string | ((node: TreeNode) => boolean);
105
+ designerProps?: IDesignerControllerProps;
106
+ designerLocales?: IDesignerLocales;
107
+ }
108
+ export interface IBehaviorHost {
109
+ Behavior?: IBehavior[];
110
+ }
111
+ export type IBehaviorLike = IBehavior[] | IBehaviorHost;
112
+ export interface IResource {
113
+ title?: string | IDesignerMiniLocales;
114
+ description?: string | IDesignerMiniLocales;
115
+ icon?: any;
116
+ thumb?: string;
117
+ span?: number;
118
+ node?: TreeNode;
119
+ }
120
+ export interface IResourceHost {
121
+ Resource?: IResource[];
122
+ }
123
+ export type IResourceLike = IResource[] | IResourceHost;
124
+ export interface IResourceCreator {
125
+ title?: string | IDesignerMiniLocales;
126
+ description?: string | IDesignerMiniLocales;
127
+ icon?: any;
128
+ thumb?: string;
129
+ span?: number;
130
+ elements?: ITreeNode[];
131
+ }
package/lib/types.js ADDED
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
package/package.json ADDED
@@ -0,0 +1,43 @@
1
+ {
2
+ "name": "@sulesky/next-core",
3
+ "version": "1.0.3",
4
+ "license": "MIT",
5
+ "main": "lib",
6
+ "types": "lib/index.d.ts",
7
+ "engines": {
8
+ "npm": ">=3.0.0"
9
+ },
10
+ "module": "esm",
11
+ "repository": {
12
+ "type": "git",
13
+ "url": "git+https://github.com/kapelan/designable.git"
14
+ },
15
+ "bugs": {
16
+ "url": "https://github.com/kapelan/designable/issues"
17
+ },
18
+ "homepage": "https://github.com/kapelan/designable#readme",
19
+ "scripts": {
20
+ "build": "rimraf -rf lib esm dist && npm run build:cjs && npm run build:esm && npm run build:umd",
21
+ "build:cjs": "tsc --project tsconfig.build.json",
22
+ "build:esm": "tsc --project tsconfig.build.json --module es2015 --outDir esm",
23
+ "build:umd": "rollup --config rollup.config.mjs"
24
+ },
25
+ "devDependencies": {
26
+ "@formily/json-schema": "^2.3.0",
27
+ "@formily/path": "^2.3.0",
28
+ "@formily/reactive": "^2.3.0"
29
+ },
30
+ "peerDependencies": {
31
+ "@formily/json-schema": "^2.3.0",
32
+ "@formily/path": "^2.3.0",
33
+ "@formily/reactive": "^2.3.0"
34
+ },
35
+ "dependencies": {
36
+ "@juggle/resize-observer": "^3.3.1",
37
+ "@sulesky/next-shared": "1.0.3"
38
+ },
39
+ "publishConfig": {
40
+ "access": "public"
41
+ },
42
+ "gitHead": "c352e7550efc1420491dfc18b9418ec4fcfcc4ae"
43
+ }
@@ -0,0 +1,3 @@
1
+ import baseConfig from '../../scripts/rollup.base.mjs'
2
+
3
+ export default baseConfig('designable.core', 'Designable.Core')
@@ -0,0 +1,143 @@
1
+ import { EventDriver } from '@sulesky/next-shared'
2
+ import { Engine } from '../models/Engine'
3
+ import { DragStartEvent, DragMoveEvent, DragStopEvent } from '../events'
4
+
5
+ const GlobalState = {
6
+ dragging: false,
7
+ onMouseDownAt: 0,
8
+ startEvent: null,
9
+ moveEvent: null,
10
+ }
11
+
12
+ export class DragDropDriver extends EventDriver<Engine> {
13
+ mouseDownTimer = null
14
+
15
+ startEvent: MouseEvent
16
+
17
+ onMouseDown = (e: MouseEvent) => {
18
+ if (e.button !== 0 || e.ctrlKey || e.metaKey) {
19
+ return
20
+ }
21
+ if (
22
+ e.target['isContentEditable'] ||
23
+ e.target['contentEditable'] === 'true'
24
+ ) {
25
+ return true
26
+ }
27
+ if (e.target?.['closest']?.('.monaco-editor')) return
28
+ GlobalState.startEvent = e
29
+ GlobalState.dragging = false
30
+ GlobalState.onMouseDownAt = Date.now()
31
+ this.batchAddEventListener('mouseup', this.onMouseUp)
32
+ this.batchAddEventListener('dragend', this.onMouseUp)
33
+ this.batchAddEventListener('dragstart', this.onStartDrag)
34
+ this.batchAddEventListener('mousemove', this.onDistanceChange)
35
+ }
36
+
37
+ onMouseUp = (e: MouseEvent) => {
38
+ if (GlobalState.dragging) {
39
+ this.dispatch(
40
+ new DragStopEvent({
41
+ clientX: e.clientX,
42
+ clientY: e.clientY,
43
+ pageX: e.pageX,
44
+ pageY: e.pageY,
45
+ target: e.target,
46
+ view: e.view,
47
+ })
48
+ )
49
+ }
50
+ this.batchRemoveEventListener(
51
+ 'contextmenu',
52
+ this.onContextMenuWhileDragging,
53
+ true
54
+ )
55
+ this.batchRemoveEventListener('mouseup', this.onMouseUp)
56
+ this.batchRemoveEventListener('mousedown', this.onMouseDown)
57
+ this.batchRemoveEventListener('dragover', this.onMouseMove)
58
+ this.batchRemoveEventListener('mousemove', this.onMouseMove)
59
+ this.batchRemoveEventListener('mousemove', this.onDistanceChange)
60
+ GlobalState.dragging = false
61
+ }
62
+
63
+ onMouseMove = (e: MouseEvent | DragEvent) => {
64
+ if (
65
+ e.clientX === GlobalState.moveEvent?.clientX &&
66
+ e.clientY === GlobalState.moveEvent?.clientY
67
+ )
68
+ return
69
+ this.dispatch(
70
+ new DragMoveEvent({
71
+ clientX: e.clientX,
72
+ clientY: e.clientY,
73
+ pageX: e.pageX,
74
+ pageY: e.pageY,
75
+ target: e.target,
76
+ view: e.view,
77
+ })
78
+ )
79
+ GlobalState.moveEvent = e
80
+ }
81
+
82
+ onContextMenuWhileDragging = (e: MouseEvent) => {
83
+ e.preventDefault()
84
+ }
85
+
86
+ onStartDrag = (e: MouseEvent | DragEvent) => {
87
+ if (GlobalState.dragging) return
88
+ GlobalState.startEvent = GlobalState.startEvent || e
89
+ this.batchAddEventListener('dragover', this.onMouseMove)
90
+ this.batchAddEventListener('mousemove', this.onMouseMove)
91
+ this.batchAddEventListener(
92
+ 'contextmenu',
93
+ this.onContextMenuWhileDragging,
94
+ true
95
+ )
96
+ this.dispatch(
97
+ new DragStartEvent({
98
+ clientX: GlobalState.startEvent.clientX,
99
+ clientY: GlobalState.startEvent.clientY,
100
+ pageX: GlobalState.startEvent.pageX,
101
+ pageY: GlobalState.startEvent.pageY,
102
+ target: GlobalState.startEvent.target,
103
+ view: GlobalState.startEvent.view,
104
+ })
105
+ )
106
+ GlobalState.dragging = true
107
+ }
108
+
109
+ onDistanceChange = (e: MouseEvent) => {
110
+ const distance = Math.sqrt(
111
+ Math.pow(e.pageX - GlobalState.startEvent.pageX, 2) +
112
+ Math.pow(e.pageY - GlobalState.startEvent.pageY, 2)
113
+ )
114
+ const timeDelta = Date.now() - GlobalState.onMouseDownAt
115
+ if (timeDelta > 10 && e !== GlobalState.startEvent && distance > 4) {
116
+ this.batchRemoveEventListener('mousemove', this.onDistanceChange)
117
+ this.onStartDrag(e)
118
+ }
119
+ }
120
+
121
+ attach() {
122
+ this.batchAddEventListener('mousedown', this.onMouseDown, true)
123
+ }
124
+
125
+ detach() {
126
+ GlobalState.dragging = false
127
+ GlobalState.moveEvent = null
128
+ GlobalState.onMouseDownAt = null
129
+ GlobalState.startEvent = null
130
+ this.batchRemoveEventListener('mousedown', this.onMouseDown, true)
131
+ this.batchRemoveEventListener('dragstart', this.onStartDrag)
132
+ this.batchRemoveEventListener('dragend', this.onMouseUp)
133
+ this.batchRemoveEventListener('dragover', this.onMouseMove)
134
+ this.batchRemoveEventListener('mouseup', this.onMouseUp)
135
+ this.batchRemoveEventListener('mousemove', this.onMouseMove)
136
+ this.batchRemoveEventListener('mousemove', this.onDistanceChange)
137
+ this.batchRemoveEventListener(
138
+ 'contextmenu',
139
+ this.onContextMenuWhileDragging,
140
+ true
141
+ )
142
+ }
143
+ }
@@ -0,0 +1,49 @@
1
+ import { EventDriver } from '@sulesky/next-shared'
2
+ import { KeyDownEvent, KeyUpEvent } from '../events'
3
+
4
+ function filter(event: KeyboardEvent) {
5
+ const target: any = event.target
6
+ const { tagName } = target
7
+ let flag = true
8
+ // ignore: isContentEditable === 'true', <input> and <textarea> when readOnly state is false, <select>、Web Components
9
+ if (
10
+ target['isContentEditable'] ||
11
+ ((tagName === 'INPUT' ||
12
+ tagName === 'TEXTAREA' ||
13
+ tagName === 'SELECT' ||
14
+ customElements.get(tagName.toLocaleLowerCase())) &&
15
+ !target.readOnly)
16
+ ) {
17
+ flag = false
18
+ }
19
+ return flag
20
+ }
21
+
22
+ export class KeyboardDriver extends EventDriver {
23
+ onKeyDown = (e: KeyboardEvent) => {
24
+ if (!filter(e)) return
25
+ this.dispatch(new KeyDownEvent(e))
26
+ }
27
+
28
+ onKeyUp = (e: KeyboardEvent) => {
29
+ this.dispatch(new KeyUpEvent(e))
30
+ }
31
+
32
+ attach() {
33
+ this.addEventListener('keydown', this.onKeyDown, {
34
+ mode: 'onlyParent',
35
+ })
36
+ this.addEventListener('keyup', this.onKeyUp, {
37
+ mode: 'onlyParent',
38
+ })
39
+ }
40
+
41
+ detach() {
42
+ this.removeEventListener('keydown', this.onKeyDown, {
43
+ mode: 'onlyParent',
44
+ })
45
+ this.removeEventListener('keyup', this.onKeyUp, {
46
+ mode: 'onlyParent',
47
+ })
48
+ }
49
+ }
@@ -0,0 +1,61 @@
1
+ import { EventDriver } from '@sulesky/next-shared'
2
+ import { Engine } from '../models/Engine'
3
+ import { MouseClickEvent, MouseDoubleClickEvent } from '../events'
4
+
5
+ export class MouseClickDriver extends EventDriver<Engine> {
6
+ onMouseClick = (e: MouseEvent) => {
7
+ const target = e.target as HTMLElement
8
+ if (
9
+ target?.closest(`*[${this.engine.props.clickStopPropagationAttrName}]`)
10
+ ) {
11
+ return
12
+ }
13
+ this.dispatch(
14
+ new MouseClickEvent({
15
+ clientX: e.clientX,
16
+ clientY: e.clientY,
17
+ pageX: e.pageX,
18
+ pageY: e.pageY,
19
+ target: e.target,
20
+ view: e.view,
21
+ })
22
+ )
23
+ }
24
+
25
+ onMouseDoubleClick = (e: MouseEvent) => {
26
+ const target = e.target as HTMLElement
27
+ if (
28
+ target?.closest(`*[${this.engine.props.clickStopPropagationAttrName}]`)
29
+ ) {
30
+ return
31
+ }
32
+ this.dispatch(
33
+ new MouseDoubleClickEvent({
34
+ clientX: e.clientX,
35
+ clientY: e.clientY,
36
+ pageX: e.pageX,
37
+ pageY: e.pageY,
38
+ target: e.target,
39
+ view: e.view,
40
+ })
41
+ )
42
+ }
43
+
44
+ attach() {
45
+ this.addEventListener('click', this.onMouseClick, {
46
+ mode: 'onlyChild',
47
+ })
48
+ this.addEventListener('dblclick', this.onMouseDoubleClick, {
49
+ mode: 'onlyChild',
50
+ })
51
+ }
52
+
53
+ detach() {
54
+ this.removeEventListener('click', this.onMouseClick, {
55
+ mode: 'onlyChild',
56
+ })
57
+ this.removeEventListener('dblclick', this.onMouseDoubleClick, {
58
+ mode: 'onlyChild',
59
+ })
60
+ }
61
+ }
@@ -0,0 +1,34 @@
1
+ import { EventDriver } from '@sulesky/next-shared'
2
+ import { Engine } from '../models/Engine'
3
+ import { MouseMoveEvent } from '../events'
4
+ export class MouseMoveDriver extends EventDriver<Engine> {
5
+ request = null
6
+
7
+ onMouseMove = (e: MouseEvent) => {
8
+ this.request = requestAnimationFrame(() => {
9
+ cancelAnimationFrame(this.request)
10
+ this.dispatch(
11
+ new MouseMoveEvent({
12
+ clientX: e.clientX,
13
+ clientY: e.clientY,
14
+ pageX: e.pageX,
15
+ pageY: e.pageY,
16
+ target: e.target,
17
+ view: e.view,
18
+ })
19
+ )
20
+ })
21
+ }
22
+
23
+ attach() {
24
+ this.addEventListener('mousemove', this.onMouseMove, {
25
+ mode: 'onlyOne',
26
+ })
27
+ }
28
+
29
+ detach() {
30
+ this.removeEventListener('mouseover', this.onMouseMove, {
31
+ mode: 'onlyOne',
32
+ })
33
+ }
34
+ }
@@ -0,0 +1,52 @@
1
+ import { EventDriver } from '@sulesky/next-shared'
2
+ import { Engine } from '../models/Engine'
3
+ import { ViewportResizeEvent } from '../events'
4
+ import { ResizeObserver } from '@juggle/resize-observer'
5
+ import { globalThisPolyfill } from '@sulesky/next-shared'
6
+
7
+ export class ViewportResizeDriver extends EventDriver<Engine> {
8
+ request = null
9
+
10
+ resizeObserver: ResizeObserver = null
11
+
12
+ onResize = (e: any) => {
13
+ if (e.preventDefault) e.preventDefault()
14
+ this.request = requestAnimationFrame(() => {
15
+ cancelAnimationFrame(this.request)
16
+ this.dispatch(
17
+ new ViewportResizeEvent({
18
+ scrollX: this.contentWindow.scrollX,
19
+ scrollY: this.contentWindow.scrollY,
20
+ width: this.contentWindow.innerWidth,
21
+ height: this.contentWindow.innerHeight,
22
+ innerHeight: this.contentWindow.innerHeight,
23
+ innerWidth: this.contentWindow.innerWidth,
24
+ view: this.contentWindow,
25
+ target: e.target || this.container,
26
+ })
27
+ )
28
+ })
29
+ }
30
+
31
+ attach() {
32
+ if (this.contentWindow && this.contentWindow !== globalThisPolyfill) {
33
+ this.addEventListener('resize', this.onResize)
34
+ } else {
35
+ if (this.container && this.container !== document) {
36
+ this.resizeObserver = new ResizeObserver(this.onResize)
37
+ this.resizeObserver.observe(this.container as HTMLElement)
38
+ }
39
+ }
40
+ }
41
+
42
+ detach() {
43
+ if (this.contentWindow && this.contentWindow !== globalThisPolyfill) {
44
+ this.removeEventListener('resize', this.onResize)
45
+ } else if (this.resizeObserver) {
46
+ if (this.container && this.container !== document) {
47
+ this.resizeObserver.unobserve(this.container as HTMLElement)
48
+ this.resizeObserver.disconnect()
49
+ }
50
+ }
51
+ }
52
+ }
@@ -0,0 +1,34 @@
1
+ import { EventDriver, globalThisPolyfill } from '@sulesky/next-shared'
2
+ import { Engine } from '../models/Engine'
3
+ import { ViewportScrollEvent } from '../events'
4
+
5
+ export class ViewportScrollDriver extends EventDriver<Engine> {
6
+ request = null
7
+
8
+ onScroll = (e: UIEvent) => {
9
+ e.preventDefault()
10
+ this.request = globalThisPolyfill.requestAnimationFrame(() => {
11
+ this.dispatch(
12
+ new ViewportScrollEvent({
13
+ scrollX: this.contentWindow.scrollX,
14
+ scrollY: this.contentWindow.scrollY,
15
+ width: this.contentWindow.document.body.clientWidth,
16
+ height: this.contentWindow.document.body.clientHeight,
17
+ innerHeight: this.contentWindow.innerHeight,
18
+ innerWidth: this.contentWindow.innerWidth,
19
+ view: this.contentWindow,
20
+ target: e.target,
21
+ })
22
+ )
23
+ cancelAnimationFrame(this.request)
24
+ })
25
+ }
26
+
27
+ attach() {
28
+ this.addEventListener('scroll', this.onScroll)
29
+ }
30
+
31
+ detach() {
32
+ this.removeEventListener('scroll', this.onScroll)
33
+ }
34
+ }
@@ -0,0 +1,6 @@
1
+ export * from './DragDropDriver'
2
+ export * from './MouseClickDriver'
3
+ export * from './MouseMoveDriver'
4
+ export * from './ViewportResizeDriver'
5
+ export * from './ViewportScrollDriver'
6
+ export * from './KeyboardDriver'
@@ -0,0 +1,11 @@
1
+ export * from './useCursorEffect'
2
+ export * from './useViewportEffect'
3
+ export * from './useDragDropEffect'
4
+ export * from './useResizeEffect'
5
+ export * from './useSelectionEffect'
6
+ export * from './useFreeSelectionEffect'
7
+ export * from './useKeyboardEffect'
8
+ export * from './useAutoScrollEffect'
9
+ export * from './useWorkspaceEffect'
10
+ export * from './useContentEditableEffect'
11
+ export * from './useTranslateEffect'
@@ -0,0 +1,82 @@
1
+ import { Engine, CursorStatus, Viewport } from '../models'
2
+ import { DragMoveEvent, DragStartEvent, DragStopEvent } from '../events'
3
+ import {
4
+ calcAutoScrollBasicInfo,
5
+ scrollAnimate,
6
+ IAutoScrollBasicInfo,
7
+ IPoint,
8
+ Point,
9
+ } from '@sulesky/next-shared'
10
+
11
+ export const useAutoScrollEffect = (engine: Engine) => {
12
+ let xScroller: IAutoScrollBasicInfo = null
13
+ let yScroller: IAutoScrollBasicInfo = null
14
+ let xScrollerAnimationStop = null
15
+ let yScrollerAnimationStop = null
16
+
17
+ const scrolling = (point: IPoint, viewport: Viewport) => {
18
+ if (engine.cursor.status === CursorStatus.Dragging) {
19
+ xScroller = calcAutoScrollBasicInfo(point, 'x', viewport.rect)
20
+ yScroller = calcAutoScrollBasicInfo(point, 'y', viewport.rect)
21
+ if (xScroller) {
22
+ if (xScrollerAnimationStop) {
23
+ xScrollerAnimationStop()
24
+ }
25
+ xScrollerAnimationStop = scrollAnimate(
26
+ viewport.scrollContainer,
27
+ 'x',
28
+ xScroller.direction,
29
+ xScroller.speed
30
+ )
31
+ } else {
32
+ if (xScrollerAnimationStop) {
33
+ xScrollerAnimationStop()
34
+ }
35
+ }
36
+ if (yScroller) {
37
+ if (yScrollerAnimationStop) {
38
+ yScrollerAnimationStop()
39
+ }
40
+ yScrollerAnimationStop = scrollAnimate(
41
+ viewport.scrollContainer,
42
+ 'y',
43
+ yScroller.direction,
44
+ yScroller.speed
45
+ )
46
+ } else {
47
+ if (yScrollerAnimationStop) {
48
+ yScrollerAnimationStop()
49
+ }
50
+ }
51
+ }
52
+ }
53
+
54
+ engine.subscribeTo(DragStartEvent, () => {
55
+ engine.workbench.eachWorkspace((workspace) => {
56
+ workspace.viewport.takeDragStartSnapshot()
57
+ })
58
+ })
59
+
60
+ engine.subscribeTo(DragMoveEvent, (event) => {
61
+ engine.workbench.eachWorkspace((workspace) => {
62
+ const viewport = workspace.viewport
63
+ const outline = workspace.outline
64
+ const point = new Point(event.data.topClientX, event.data.topClientY)
65
+ if (outline.isPointInViewport(point)) {
66
+ scrolling(point, outline)
67
+ } else if (viewport.isPointInViewport(point)) {
68
+ scrolling(point, viewport)
69
+ }
70
+ })
71
+ })
72
+ engine.subscribeTo(DragStopEvent, () => {
73
+ xScroller = null
74
+ yScroller = null
75
+ if (xScrollerAnimationStop) {
76
+ xScrollerAnimationStop()
77
+ }
78
+ if (yScrollerAnimationStop) {
79
+ yScrollerAnimationStop()
80
+ }
81
+ })
82
+ }