@yh-ui/flow 0.1.21

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 (354) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +234 -0
  3. package/dist/Flow.d.vue.ts +306 -0
  4. package/dist/Flow.vue +959 -0
  5. package/dist/Flow.vue.d.ts +306 -0
  6. package/dist/__tests__/ai-workflow.ssr.test.cjs +352 -0
  7. package/dist/__tests__/ai-workflow.ssr.test.d.ts +1 -0
  8. package/dist/__tests__/ai-workflow.ssr.test.mjs +283 -0
  9. package/dist/__tests__/ai-workflow.test.cjs +109 -0
  10. package/dist/__tests__/ai-workflow.test.d.ts +1 -0
  11. package/dist/__tests__/ai-workflow.test.mjs +112 -0
  12. package/dist/__tests__/bpmn.ssr.test.cjs +278 -0
  13. package/dist/__tests__/bpmn.ssr.test.d.ts +1 -0
  14. package/dist/__tests__/bpmn.ssr.test.mjs +237 -0
  15. package/dist/__tests__/bpmn.test.cjs +103 -0
  16. package/dist/__tests__/bpmn.test.d.ts +1 -0
  17. package/dist/__tests__/bpmn.test.mjs +106 -0
  18. package/dist/__tests__/custom-types.test.cjs +300 -0
  19. package/dist/__tests__/custom-types.test.d.ts +1 -0
  20. package/dist/__tests__/custom-types.test.mjs +248 -0
  21. package/dist/__tests__/edge.test.cjs +56 -0
  22. package/dist/__tests__/edge.test.d.ts +1 -0
  23. package/dist/__tests__/edge.test.mjs +69 -0
  24. package/dist/__tests__/event-bus.test.cjs +80 -0
  25. package/dist/__tests__/event-bus.test.d.ts +1 -0
  26. package/dist/__tests__/event-bus.test.mjs +51 -0
  27. package/dist/__tests__/flow.ssr.test.cjs +156 -0
  28. package/dist/__tests__/flow.ssr.test.d.ts +1 -0
  29. package/dist/__tests__/flow.ssr.test.mjs +112 -0
  30. package/dist/__tests__/geometry.test.cjs +191 -0
  31. package/dist/__tests__/geometry.test.d.ts +1 -0
  32. package/dist/__tests__/geometry.test.mjs +105 -0
  33. package/dist/__tests__/graph.test.cjs +115 -0
  34. package/dist/__tests__/graph.test.d.ts +1 -0
  35. package/dist/__tests__/graph.test.mjs +85 -0
  36. package/dist/__tests__/history-plugin.test.cjs +191 -0
  37. package/dist/__tests__/history-plugin.test.d.ts +1 -0
  38. package/dist/__tests__/history-plugin.test.mjs +161 -0
  39. package/dist/__tests__/history.test.cjs +81 -0
  40. package/dist/__tests__/history.test.d.ts +1 -0
  41. package/dist/__tests__/history.test.mjs +43 -0
  42. package/dist/__tests__/layout.test.cjs +213 -0
  43. package/dist/__tests__/layout.test.d.ts +1 -0
  44. package/dist/__tests__/layout.test.mjs +170 -0
  45. package/dist/__tests__/node-edit-panel.ssr.test.cjs +168 -0
  46. package/dist/__tests__/node-edit-panel.ssr.test.d.ts +1 -0
  47. package/dist/__tests__/node-edit-panel.ssr.test.mjs +118 -0
  48. package/dist/__tests__/node-group-plugin.test.cjs +235 -0
  49. package/dist/__tests__/node-group-plugin.test.d.ts +1 -0
  50. package/dist/__tests__/node-group-plugin.test.mjs +187 -0
  51. package/dist/__tests__/node-handles.test.cjs +340 -0
  52. package/dist/__tests__/node-handles.test.d.ts +1 -0
  53. package/dist/__tests__/node-handles.test.mjs +230 -0
  54. package/dist/__tests__/plugin.test.cjs +151 -0
  55. package/dist/__tests__/plugin.test.d.ts +1 -0
  56. package/dist/__tests__/plugin.test.mjs +116 -0
  57. package/dist/__tests__/transform.test.cjs +58 -0
  58. package/dist/__tests__/transform.test.d.ts +1 -0
  59. package/dist/__tests__/transform.test.mjs +38 -0
  60. package/dist/__tests__/useAlignment.test.cjs +91 -0
  61. package/dist/__tests__/useAlignment.test.d.ts +1 -0
  62. package/dist/__tests__/useAlignment.test.mjs +52 -0
  63. package/dist/__tests__/useEdges.test.cjs +117 -0
  64. package/dist/__tests__/useEdges.test.d.ts +1 -0
  65. package/dist/__tests__/useEdges.test.mjs +80 -0
  66. package/dist/__tests__/useKeyboard.test.cjs +88 -0
  67. package/dist/__tests__/useKeyboard.test.d.ts +1 -0
  68. package/dist/__tests__/useKeyboard.test.mjs +56 -0
  69. package/dist/__tests__/useNodes.test.cjs +150 -0
  70. package/dist/__tests__/useNodes.test.d.ts +1 -0
  71. package/dist/__tests__/useNodes.test.mjs +80 -0
  72. package/dist/__tests__/useSelection.test.cjs +112 -0
  73. package/dist/__tests__/useSelection.test.d.ts +1 -0
  74. package/dist/__tests__/useSelection.test.mjs +76 -0
  75. package/dist/__tests__/useViewport.test.cjs +171 -0
  76. package/dist/__tests__/useViewport.test.d.ts +1 -0
  77. package/dist/__tests__/useViewport.test.mjs +82 -0
  78. package/dist/__tests__/utils/ssr.cjs +124 -0
  79. package/dist/__tests__/utils/ssr.d.ts +33 -0
  80. package/dist/__tests__/utils/ssr.mjs +129 -0
  81. package/dist/__tests__/validation.test.cjs +95 -0
  82. package/dist/__tests__/validation.test.d.ts +1 -0
  83. package/dist/__tests__/validation.test.mjs +36 -0
  84. package/dist/components/AiNodeEditPanel.d.vue.ts +13 -0
  85. package/dist/components/AiNodeEditPanel.vue +413 -0
  86. package/dist/components/AiNodeEditPanel.vue.d.ts +13 -0
  87. package/dist/components/EdgeEditPanel.d.vue.ts +14 -0
  88. package/dist/components/EdgeEditPanel.vue +205 -0
  89. package/dist/components/EdgeEditPanel.vue.d.ts +14 -0
  90. package/dist/components/NodeEditPanel.d.vue.ts +13 -0
  91. package/dist/components/NodeEditPanel.vue +214 -0
  92. package/dist/components/NodeEditPanel.vue.d.ts +13 -0
  93. package/dist/components/edges/BaseEdge.d.vue.ts +23 -0
  94. package/dist/components/edges/BaseEdge.vue +55 -0
  95. package/dist/components/edges/BaseEdge.vue.d.ts +23 -0
  96. package/dist/components/edges/BezierEdge.d.vue.ts +22 -0
  97. package/dist/components/edges/BezierEdge.vue +57 -0
  98. package/dist/components/edges/BezierEdge.vue.d.ts +22 -0
  99. package/dist/components/edges/DataFlowEdge.d.vue.ts +41 -0
  100. package/dist/components/edges/DataFlowEdge.vue +211 -0
  101. package/dist/components/edges/DataFlowEdge.vue.d.ts +41 -0
  102. package/dist/components/edges/SmoothEdge.d.vue.ts +22 -0
  103. package/dist/components/edges/SmoothEdge.vue +53 -0
  104. package/dist/components/edges/SmoothEdge.vue.d.ts +22 -0
  105. package/dist/components/edges/StepEdge.d.vue.ts +22 -0
  106. package/dist/components/edges/StepEdge.vue +42 -0
  107. package/dist/components/edges/StepEdge.vue.d.ts +22 -0
  108. package/dist/components/edges/index.cjs +41 -0
  109. package/dist/components/edges/index.d.ts +5 -0
  110. package/dist/components/edges/index.mjs +5 -0
  111. package/dist/components/nodes/BaseNode.d.vue.ts +25 -0
  112. package/dist/components/nodes/BaseNode.vue +93 -0
  113. package/dist/components/nodes/BaseNode.vue.d.ts +25 -0
  114. package/dist/components/nodes/CustomNode.d.vue.ts +36 -0
  115. package/dist/components/nodes/CustomNode.vue +44 -0
  116. package/dist/components/nodes/CustomNode.vue.d.ts +36 -0
  117. package/dist/components/nodes/DatabaseNode.d.vue.ts +19 -0
  118. package/dist/components/nodes/DatabaseNode.vue +62 -0
  119. package/dist/components/nodes/DatabaseNode.vue.d.ts +19 -0
  120. package/dist/components/nodes/DiamondNode.d.vue.ts +19 -0
  121. package/dist/components/nodes/DiamondNode.vue +62 -0
  122. package/dist/components/nodes/DiamondNode.vue.d.ts +19 -0
  123. package/dist/components/nodes/GroupNode.d.vue.ts +31 -0
  124. package/dist/components/nodes/GroupNode.vue +48 -0
  125. package/dist/components/nodes/GroupNode.vue.d.ts +31 -0
  126. package/dist/components/nodes/InputNode.d.vue.ts +23 -0
  127. package/dist/components/nodes/InputNode.vue +63 -0
  128. package/dist/components/nodes/InputNode.vue.d.ts +23 -0
  129. package/dist/components/nodes/NodeResizer.d.vue.ts +27 -0
  130. package/dist/components/nodes/NodeResizer.vue +89 -0
  131. package/dist/components/nodes/NodeResizer.vue.d.ts +27 -0
  132. package/dist/components/nodes/NodeToolbar.d.vue.ts +32 -0
  133. package/dist/components/nodes/NodeToolbar.vue +101 -0
  134. package/dist/components/nodes/NodeToolbar.vue.d.ts +32 -0
  135. package/dist/components/nodes/OutputNode.d.vue.ts +21 -0
  136. package/dist/components/nodes/OutputNode.vue +53 -0
  137. package/dist/components/nodes/OutputNode.vue.d.ts +21 -0
  138. package/dist/components/nodes/ai-workflow/AiAgentNode.d.vue.ts +20 -0
  139. package/dist/components/nodes/ai-workflow/AiAgentNode.vue +59 -0
  140. package/dist/components/nodes/ai-workflow/AiAgentNode.vue.d.ts +20 -0
  141. package/dist/components/nodes/ai-workflow/AiConditionNode.d.vue.ts +19 -0
  142. package/dist/components/nodes/ai-workflow/AiConditionNode.vue +65 -0
  143. package/dist/components/nodes/ai-workflow/AiConditionNode.vue.d.ts +19 -0
  144. package/dist/components/nodes/ai-workflow/AiEndNode.d.vue.ts +19 -0
  145. package/dist/components/nodes/ai-workflow/AiEndNode.vue +47 -0
  146. package/dist/components/nodes/ai-workflow/AiEndNode.vue.d.ts +19 -0
  147. package/dist/components/nodes/ai-workflow/AiLlmNode.d.vue.ts +19 -0
  148. package/dist/components/nodes/ai-workflow/AiLlmNode.vue +64 -0
  149. package/dist/components/nodes/ai-workflow/AiLlmNode.vue.d.ts +19 -0
  150. package/dist/components/nodes/ai-workflow/AiMemoryNode.d.vue.ts +19 -0
  151. package/dist/components/nodes/ai-workflow/AiMemoryNode.vue +59 -0
  152. package/dist/components/nodes/ai-workflow/AiMemoryNode.vue.d.ts +19 -0
  153. package/dist/components/nodes/ai-workflow/AiPromptNode.d.vue.ts +19 -0
  154. package/dist/components/nodes/ai-workflow/AiPromptNode.vue +61 -0
  155. package/dist/components/nodes/ai-workflow/AiPromptNode.vue.d.ts +19 -0
  156. package/dist/components/nodes/ai-workflow/AiStartNode.d.vue.ts +19 -0
  157. package/dist/components/nodes/ai-workflow/AiStartNode.vue +47 -0
  158. package/dist/components/nodes/ai-workflow/AiStartNode.vue.d.ts +19 -0
  159. package/dist/components/nodes/ai-workflow/AiToolNode.d.vue.ts +19 -0
  160. package/dist/components/nodes/ai-workflow/AiToolNode.vue +59 -0
  161. package/dist/components/nodes/ai-workflow/AiToolNode.vue.d.ts +19 -0
  162. package/dist/components/nodes/ai-workflow/index.cjs +109 -0
  163. package/dist/components/nodes/ai-workflow/index.d.ts +23 -0
  164. package/dist/components/nodes/ai-workflow/index.mjs +37 -0
  165. package/dist/components/nodes/bpmn/BpmnEndEvent.d.vue.ts +19 -0
  166. package/dist/components/nodes/bpmn/BpmnEndEvent.vue +50 -0
  167. package/dist/components/nodes/bpmn/BpmnEndEvent.vue.d.ts +19 -0
  168. package/dist/components/nodes/bpmn/BpmnExclusiveGateway.d.vue.ts +19 -0
  169. package/dist/components/nodes/bpmn/BpmnExclusiveGateway.vue +60 -0
  170. package/dist/components/nodes/bpmn/BpmnExclusiveGateway.vue.d.ts +19 -0
  171. package/dist/components/nodes/bpmn/BpmnInclusiveGateway.d.vue.ts +19 -0
  172. package/dist/components/nodes/bpmn/BpmnInclusiveGateway.vue +60 -0
  173. package/dist/components/nodes/bpmn/BpmnInclusiveGateway.vue.d.ts +19 -0
  174. package/dist/components/nodes/bpmn/BpmnParallelGateway.d.vue.ts +19 -0
  175. package/dist/components/nodes/bpmn/BpmnParallelGateway.vue +60 -0
  176. package/dist/components/nodes/bpmn/BpmnParallelGateway.vue.d.ts +19 -0
  177. package/dist/components/nodes/bpmn/BpmnServiceTask.d.vue.ts +19 -0
  178. package/dist/components/nodes/bpmn/BpmnServiceTask.vue +55 -0
  179. package/dist/components/nodes/bpmn/BpmnServiceTask.vue.d.ts +19 -0
  180. package/dist/components/nodes/bpmn/BpmnStartEvent.d.vue.ts +19 -0
  181. package/dist/components/nodes/bpmn/BpmnStartEvent.vue +50 -0
  182. package/dist/components/nodes/bpmn/BpmnStartEvent.vue.d.ts +19 -0
  183. package/dist/components/nodes/bpmn/BpmnTask.d.vue.ts +19 -0
  184. package/dist/components/nodes/bpmn/BpmnTask.vue +54 -0
  185. package/dist/components/nodes/bpmn/BpmnTask.vue.d.ts +19 -0
  186. package/dist/components/nodes/bpmn/BpmnUserTask.d.vue.ts +19 -0
  187. package/dist/components/nodes/bpmn/BpmnUserTask.vue +55 -0
  188. package/dist/components/nodes/bpmn/BpmnUserTask.vue.d.ts +19 -0
  189. package/dist/components/nodes/bpmn/index.cjs +109 -0
  190. package/dist/components/nodes/bpmn/index.d.ts +23 -0
  191. package/dist/components/nodes/bpmn/index.mjs +37 -0
  192. package/dist/components/nodes/index.cjs +246 -0
  193. package/dist/components/nodes/index.d.ts +13 -0
  194. package/dist/components/nodes/index.mjs +44 -0
  195. package/dist/core/FlowContext.cjs +21 -0
  196. package/dist/core/FlowContext.d.ts +10 -0
  197. package/dist/core/FlowContext.mjs +13 -0
  198. package/dist/core/index.cjs +104 -0
  199. package/dist/core/index.d.ts +9 -0
  200. package/dist/core/index.mjs +9 -0
  201. package/dist/core/useAlignment.cjs +81 -0
  202. package/dist/core/useAlignment.d.ts +33 -0
  203. package/dist/core/useAlignment.mjs +71 -0
  204. package/dist/core/useEdges.cjs +132 -0
  205. package/dist/core/useEdges.d.ts +29 -0
  206. package/dist/core/useEdges.mjs +89 -0
  207. package/dist/core/useFlow.cjs +40 -0
  208. package/dist/core/useFlow.d.ts +31 -0
  209. package/dist/core/useFlow.mjs +32 -0
  210. package/dist/core/useHistory.cjs +63 -0
  211. package/dist/core/useHistory.d.ts +15 -0
  212. package/dist/core/useHistory.mjs +54 -0
  213. package/dist/core/useKeyboard.cjs +54 -0
  214. package/dist/core/useKeyboard.d.ts +18 -0
  215. package/dist/core/useKeyboard.mjs +45 -0
  216. package/dist/core/useNodeDistribution.cjs +171 -0
  217. package/dist/core/useNodeDistribution.d.ts +12 -0
  218. package/dist/core/useNodeDistribution.mjs +145 -0
  219. package/dist/core/useNodes.cjs +146 -0
  220. package/dist/core/useNodes.d.ts +26 -0
  221. package/dist/core/useNodes.mjs +101 -0
  222. package/dist/core/useSelection.cjs +83 -0
  223. package/dist/core/useSelection.d.ts +18 -0
  224. package/dist/core/useSelection.mjs +53 -0
  225. package/dist/core/useViewport.cjs +157 -0
  226. package/dist/core/useViewport.d.ts +65 -0
  227. package/dist/core/useViewport.mjs +125 -0
  228. package/dist/flow.cjs +240 -0
  229. package/dist/flow.d.ts +276 -0
  230. package/dist/flow.mjs +230 -0
  231. package/dist/index.cjs +378 -0
  232. package/dist/index.d.ts +28 -0
  233. package/dist/index.mjs +50 -0
  234. package/dist/plugins/index.cjs +96 -0
  235. package/dist/plugins/index.d.ts +34 -0
  236. package/dist/plugins/index.mjs +47 -0
  237. package/dist/plugins/plugin.cjs +117 -0
  238. package/dist/plugins/plugin.d.ts +72 -0
  239. package/dist/plugins/plugin.mjs +110 -0
  240. package/dist/plugins/plugins/controls.cjs +38 -0
  241. package/dist/plugins/plugins/controls.d.ts +12 -0
  242. package/dist/plugins/plugins/controls.mjs +28 -0
  243. package/dist/plugins/plugins/export.cjs +102 -0
  244. package/dist/plugins/plugins/export.d.ts +12 -0
  245. package/dist/plugins/plugins/export.mjs +89 -0
  246. package/dist/plugins/plugins/grid.cjs +36 -0
  247. package/dist/plugins/plugins/grid.d.ts +11 -0
  248. package/dist/plugins/plugins/grid.mjs +26 -0
  249. package/dist/plugins/plugins/history.cjs +140 -0
  250. package/dist/plugins/plugins/history.d.ts +53 -0
  251. package/dist/plugins/plugins/history.mjs +132 -0
  252. package/dist/plugins/plugins/index.cjs +104 -0
  253. package/dist/plugins/plugins/index.d.ts +9 -0
  254. package/dist/plugins/plugins/index.mjs +9 -0
  255. package/dist/plugins/plugins/keyboard.cjs +27 -0
  256. package/dist/plugins/plugins/keyboard.d.ts +10 -0
  257. package/dist/plugins/plugins/keyboard.mjs +18 -0
  258. package/dist/plugins/plugins/layout.cjs +275 -0
  259. package/dist/plugins/plugins/layout.d.ts +34 -0
  260. package/dist/plugins/plugins/layout.mjs +246 -0
  261. package/dist/plugins/plugins/minimap.cjs +60 -0
  262. package/dist/plugins/plugins/minimap.d.ts +25 -0
  263. package/dist/plugins/plugins/minimap.mjs +50 -0
  264. package/dist/plugins/plugins/node-group.cjs +209 -0
  265. package/dist/plugins/plugins/node-group.d.ts +26 -0
  266. package/dist/plugins/plugins/node-group.mjs +178 -0
  267. package/dist/plugins/plugins/snap.cjs +36 -0
  268. package/dist/plugins/plugins/snap.d.ts +12 -0
  269. package/dist/plugins/plugins/snap.mjs +26 -0
  270. package/dist/renderer/AlignmentLines.d.vue.ts +5 -0
  271. package/dist/renderer/AlignmentLines.vue +113 -0
  272. package/dist/renderer/AlignmentLines.vue.d.ts +5 -0
  273. package/dist/renderer/Background.d.vue.ts +7 -0
  274. package/dist/renderer/Background.vue +86 -0
  275. package/dist/renderer/Background.vue.d.ts +7 -0
  276. package/dist/renderer/Controls.d.vue.ts +13 -0
  277. package/dist/renderer/Controls.vue +82 -0
  278. package/dist/renderer/Controls.vue.d.ts +13 -0
  279. package/dist/renderer/EdgeHandlesRenderer.d.vue.ts +11 -0
  280. package/dist/renderer/EdgeHandlesRenderer.vue +75 -0
  281. package/dist/renderer/EdgeHandlesRenderer.vue.d.ts +11 -0
  282. package/dist/renderer/EdgeRenderer.d.vue.ts +39 -0
  283. package/dist/renderer/EdgeRenderer.vue +204 -0
  284. package/dist/renderer/EdgeRenderer.vue.d.ts +39 -0
  285. package/dist/renderer/FlowBackground.d.vue.ts +11 -0
  286. package/dist/renderer/FlowBackground.vue +82 -0
  287. package/dist/renderer/FlowBackground.vue.d.ts +11 -0
  288. package/dist/renderer/Minimap.d.vue.ts +30 -0
  289. package/dist/renderer/Minimap.vue +290 -0
  290. package/dist/renderer/Minimap.vue.d.ts +30 -0
  291. package/dist/renderer/NodeRenderer.d.vue.ts +56 -0
  292. package/dist/renderer/NodeRenderer.vue +328 -0
  293. package/dist/renderer/NodeRenderer.vue.d.ts +56 -0
  294. package/dist/renderer/SelectionBox.d.vue.ts +11 -0
  295. package/dist/renderer/SelectionBox.vue +28 -0
  296. package/dist/renderer/SelectionBox.vue.d.ts +11 -0
  297. package/dist/types/edge.cjs +13 -0
  298. package/dist/types/edge.d.ts +65 -0
  299. package/dist/types/edge.mjs +6 -0
  300. package/dist/types/events.cjs +1 -0
  301. package/dist/types/events.d.ts +115 -0
  302. package/dist/types/events.mjs +0 -0
  303. package/dist/types/index.cjs +1 -0
  304. package/dist/types/index.d.ts +366 -0
  305. package/dist/types/index.mjs +0 -0
  306. package/dist/types/node.cjs +9 -0
  307. package/dist/types/node.d.ts +90 -0
  308. package/dist/types/node.mjs +3 -0
  309. package/dist/types/viewport.cjs +42 -0
  310. package/dist/types/viewport.d.ts +62 -0
  311. package/dist/types/viewport.mjs +36 -0
  312. package/dist/utils/bpmn-engine.cjs +390 -0
  313. package/dist/utils/bpmn-engine.d.ts +164 -0
  314. package/dist/utils/bpmn-engine.mjs +378 -0
  315. package/dist/utils/bpmn.cjs +492 -0
  316. package/dist/utils/bpmn.d.ts +53 -0
  317. package/dist/utils/bpmn.mjs +430 -0
  318. package/dist/utils/collaboration.cjs +537 -0
  319. package/dist/utils/collaboration.d.ts +189 -0
  320. package/dist/utils/collaboration.mjs +521 -0
  321. package/dist/utils/custom-types.cjs +138 -0
  322. package/dist/utils/custom-types.d.ts +78 -0
  323. package/dist/utils/custom-types.mjs +108 -0
  324. package/dist/utils/edge.cjs +235 -0
  325. package/dist/utils/edge.d.ts +79 -0
  326. package/dist/utils/edge.mjs +172 -0
  327. package/dist/utils/event-bus.cjs +91 -0
  328. package/dist/utils/event-bus.d.ts +39 -0
  329. package/dist/utils/event-bus.mjs +82 -0
  330. package/dist/utils/geometry.cjs +178 -0
  331. package/dist/utils/geometry.d.ts +186 -0
  332. package/dist/utils/geometry.mjs +144 -0
  333. package/dist/utils/graph.cjs +158 -0
  334. package/dist/utils/graph.d.ts +40 -0
  335. package/dist/utils/graph.mjs +147 -0
  336. package/dist/utils/index.cjs +137 -0
  337. package/dist/utils/index.d.ts +12 -0
  338. package/dist/utils/index.mjs +12 -0
  339. package/dist/utils/performance.cjs +94 -0
  340. package/dist/utils/performance.d.ts +18 -0
  341. package/dist/utils/performance.mjs +82 -0
  342. package/dist/utils/screenshot.cjs +87 -0
  343. package/dist/utils/screenshot.d.ts +22 -0
  344. package/dist/utils/screenshot.mjs +66 -0
  345. package/dist/utils/theme.cjs +228 -0
  346. package/dist/utils/theme.d.ts +92 -0
  347. package/dist/utils/theme.mjs +217 -0
  348. package/dist/utils/transform.cjs +76 -0
  349. package/dist/utils/transform.d.ts +45 -0
  350. package/dist/utils/transform.mjs +57 -0
  351. package/dist/utils/validation.cjs +107 -0
  352. package/dist/utils/validation.d.ts +29 -0
  353. package/dist/utils/validation.mjs +85 -0
  354. package/package.json +61 -0
@@ -0,0 +1,168 @@
1
+ "use strict";
2
+
3
+ var _vitest = require("vitest");
4
+ var _NodeEditPanel = _interopRequireDefault(require("../components/NodeEditPanel.vue"));
5
+ var _ssr = require("./utils/ssr.cjs");
6
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
7
+ (0, _vitest.describe)("NodeEditPanel SSR", () => {
8
+ (0, _vitest.it)("should render NodeEditPanel in SSR", async () => {
9
+ const html = await (0, _ssr.renderSSR)(_NodeEditPanel.default, {
10
+ visible: true,
11
+ node: {
12
+ id: "node-1",
13
+ type: "default",
14
+ position: {
15
+ x: 0,
16
+ y: 0
17
+ },
18
+ data: {
19
+ label: "Test Node"
20
+ }
21
+ }
22
+ });
23
+ (0, _vitest.expect)(html).toBeDefined();
24
+ });
25
+ (0, _vitest.it)("should render with label field in SSR", async () => {
26
+ const html = await (0, _ssr.renderSSR)(_NodeEditPanel.default, {
27
+ visible: true,
28
+ node: {
29
+ id: "node-1",
30
+ type: "default",
31
+ position: {
32
+ x: 0,
33
+ y: 0
34
+ },
35
+ data: {
36
+ label: "My Node"
37
+ }
38
+ }
39
+ });
40
+ (0, _vitest.expect)(html).toBeDefined();
41
+ });
42
+ (0, _vitest.it)("should render with style fields in SSR", async () => {
43
+ const html = await (0, _ssr.renderSSR)(_NodeEditPanel.default, {
44
+ visible: true,
45
+ node: {
46
+ id: "node-1",
47
+ type: "default",
48
+ position: {
49
+ x: 0,
50
+ y: 0
51
+ },
52
+ data: {
53
+ label: "Style Node"
54
+ },
55
+ style: {
56
+ backgroundColor: "#ff0000"
57
+ }
58
+ }
59
+ });
60
+ (0, _vitest.expect)(html).toBeDefined();
61
+ });
62
+ (0, _vitest.it)("should render with selected class when selected in SSR", async () => {
63
+ const html = await (0, _ssr.renderSSR)(_NodeEditPanel.default, {
64
+ visible: true,
65
+ node: {
66
+ id: "node-1",
67
+ type: "default",
68
+ position: {
69
+ x: 0,
70
+ y: 0
71
+ },
72
+ data: {
73
+ label: "Selected Node"
74
+ },
75
+ selected: true
76
+ }
77
+ });
78
+ (0, _vitest.expect)(html).toBeDefined();
79
+ });
80
+ (0, _vitest.it)("should not render when visible is false in SSR", async () => {
81
+ const html = await (0, _ssr.renderSSR)(_NodeEditPanel.default, {
82
+ visible: false,
83
+ node: {
84
+ id: "node-1",
85
+ type: "default",
86
+ position: {
87
+ x: 0,
88
+ y: 0
89
+ },
90
+ data: {
91
+ label: "Hidden Node"
92
+ }
93
+ }
94
+ });
95
+ (0, _vitest.expect)(html).toBeDefined();
96
+ });
97
+ (0, _vitest.it)("should render close button in SSR", async () => {
98
+ const html = await (0, _ssr.renderSSR)(_NodeEditPanel.default, {
99
+ visible: true,
100
+ node: {
101
+ id: "node-1",
102
+ type: "default",
103
+ position: {
104
+ x: 0,
105
+ y: 0
106
+ },
107
+ data: {
108
+ label: "Test"
109
+ }
110
+ }
111
+ });
112
+ (0, _vitest.expect)(html).toBeDefined();
113
+ });
114
+ (0, _vitest.it)("should render with width and height fields in SSR", async () => {
115
+ const html = await (0, _ssr.renderSSR)(_NodeEditPanel.default, {
116
+ visible: true,
117
+ node: {
118
+ id: "node-1",
119
+ type: "default",
120
+ position: {
121
+ x: 0,
122
+ y: 0
123
+ },
124
+ data: {
125
+ label: "Sized Node"
126
+ },
127
+ width: 200,
128
+ height: 100
129
+ }
130
+ });
131
+ (0, _vitest.expect)(html).toBeDefined();
132
+ });
133
+ (0, _vitest.it)("should render with node ID field in SSR", async () => {
134
+ const html = await (0, _ssr.renderSSR)(_NodeEditPanel.default, {
135
+ visible: true,
136
+ node: {
137
+ id: "custom-node-id",
138
+ type: "default",
139
+ position: {
140
+ x: 0,
141
+ y: 0
142
+ },
143
+ data: {
144
+ label: "ID Node"
145
+ }
146
+ }
147
+ });
148
+ (0, _vitest.expect)(html).toBeDefined();
149
+ });
150
+ (0, _vitest.it)("should hydrate without mismatch", async () => {
151
+ const result = await (0, _ssr.testHydration)(_NodeEditPanel.default, {
152
+ visible: true,
153
+ node: {
154
+ id: "node-1",
155
+ type: "default",
156
+ position: {
157
+ x: 0,
158
+ y: 0
159
+ },
160
+ data: {
161
+ label: "Hydrate Test"
162
+ }
163
+ }
164
+ });
165
+ (0, _vitest.expect)(result.ssrHtml).toBeDefined();
166
+ (0, _vitest.expect)(result.csrHtml).toBeDefined();
167
+ });
168
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,118 @@
1
+ import { describe, it, expect } from "vitest";
2
+ import NodeEditPanel from "../components/NodeEditPanel.vue";
3
+ import { renderSSR, testHydration } from "./utils/ssr.mjs";
4
+ describe("NodeEditPanel SSR", () => {
5
+ it("should render NodeEditPanel in SSR", async () => {
6
+ const html = await renderSSR(NodeEditPanel, {
7
+ visible: true,
8
+ node: {
9
+ id: "node-1",
10
+ type: "default",
11
+ position: { x: 0, y: 0 },
12
+ data: { label: "Test Node" }
13
+ }
14
+ });
15
+ expect(html).toBeDefined();
16
+ });
17
+ it("should render with label field in SSR", async () => {
18
+ const html = await renderSSR(NodeEditPanel, {
19
+ visible: true,
20
+ node: {
21
+ id: "node-1",
22
+ type: "default",
23
+ position: { x: 0, y: 0 },
24
+ data: { label: "My Node" }
25
+ }
26
+ });
27
+ expect(html).toBeDefined();
28
+ });
29
+ it("should render with style fields in SSR", async () => {
30
+ const html = await renderSSR(NodeEditPanel, {
31
+ visible: true,
32
+ node: {
33
+ id: "node-1",
34
+ type: "default",
35
+ position: { x: 0, y: 0 },
36
+ data: { label: "Style Node" },
37
+ style: { backgroundColor: "#ff0000" }
38
+ }
39
+ });
40
+ expect(html).toBeDefined();
41
+ });
42
+ it("should render with selected class when selected in SSR", async () => {
43
+ const html = await renderSSR(NodeEditPanel, {
44
+ visible: true,
45
+ node: {
46
+ id: "node-1",
47
+ type: "default",
48
+ position: { x: 0, y: 0 },
49
+ data: { label: "Selected Node" },
50
+ selected: true
51
+ }
52
+ });
53
+ expect(html).toBeDefined();
54
+ });
55
+ it("should not render when visible is false in SSR", async () => {
56
+ const html = await renderSSR(NodeEditPanel, {
57
+ visible: false,
58
+ node: {
59
+ id: "node-1",
60
+ type: "default",
61
+ position: { x: 0, y: 0 },
62
+ data: { label: "Hidden Node" }
63
+ }
64
+ });
65
+ expect(html).toBeDefined();
66
+ });
67
+ it("should render close button in SSR", async () => {
68
+ const html = await renderSSR(NodeEditPanel, {
69
+ visible: true,
70
+ node: {
71
+ id: "node-1",
72
+ type: "default",
73
+ position: { x: 0, y: 0 },
74
+ data: { label: "Test" }
75
+ }
76
+ });
77
+ expect(html).toBeDefined();
78
+ });
79
+ it("should render with width and height fields in SSR", async () => {
80
+ const html = await renderSSR(NodeEditPanel, {
81
+ visible: true,
82
+ node: {
83
+ id: "node-1",
84
+ type: "default",
85
+ position: { x: 0, y: 0 },
86
+ data: { label: "Sized Node" },
87
+ width: 200,
88
+ height: 100
89
+ }
90
+ });
91
+ expect(html).toBeDefined();
92
+ });
93
+ it("should render with node ID field in SSR", async () => {
94
+ const html = await renderSSR(NodeEditPanel, {
95
+ visible: true,
96
+ node: {
97
+ id: "custom-node-id",
98
+ type: "default",
99
+ position: { x: 0, y: 0 },
100
+ data: { label: "ID Node" }
101
+ }
102
+ });
103
+ expect(html).toBeDefined();
104
+ });
105
+ it("should hydrate without mismatch", async () => {
106
+ const result = await testHydration(NodeEditPanel, {
107
+ visible: true,
108
+ node: {
109
+ id: "node-1",
110
+ type: "default",
111
+ position: { x: 0, y: 0 },
112
+ data: { label: "Hydrate Test" }
113
+ }
114
+ });
115
+ expect(result.ssrHtml).toBeDefined();
116
+ expect(result.csrHtml).toBeDefined();
117
+ });
118
+ });
@@ -0,0 +1,235 @@
1
+ "use strict";
2
+
3
+ var _vitest = require("vitest");
4
+ var _vue = require("vue");
5
+ var _nodeGroup = require("../plugins/plugins/node-group.cjs");
6
+ function createMockFlow(initialNodes = [], initialEdges = []) {
7
+ const nodes = (0, _vue.ref)(initialNodes);
8
+ const edges = (0, _vue.ref)(initialEdges);
9
+ const flow = {
10
+ nodes,
11
+ edges,
12
+ viewport: (0, _vue.ref)({
13
+ x: 0,
14
+ y: 0,
15
+ zoom: 1
16
+ }),
17
+ addNode: _vitest.vi.fn(node => {
18
+ nodes.value = [...nodes.value, node];
19
+ }),
20
+ removeNode: _vitest.vi.fn(id => {
21
+ nodes.value = nodes.value.filter(n => n.id !== id);
22
+ }),
23
+ updateNode: _vitest.vi.fn((id, data) => {
24
+ nodes.value = nodes.value.map(n => n.id === id ? {
25
+ ...n,
26
+ ...data
27
+ } : n);
28
+ }),
29
+ getNode: _vitest.vi.fn(id => nodes.value.find(n => n.id === id)),
30
+ addEdge: _vitest.vi.fn(),
31
+ removeEdge: _vitest.vi.fn(),
32
+ updateEdge: _vitest.vi.fn((id, data) => {
33
+ edges.value = edges.value.map(e => e.id === id ? {
34
+ ...e,
35
+ ...data
36
+ } : e);
37
+ }),
38
+ getEdge: _vitest.vi.fn(),
39
+ setViewport: _vitest.vi.fn(),
40
+ fitView: _vitest.vi.fn(),
41
+ zoomIn: _vitest.vi.fn(),
42
+ zoomOut: _vitest.vi.fn(),
43
+ centerView: _vitest.vi.fn(),
44
+ selectNode: _vitest.vi.fn(),
45
+ selectEdge: _vitest.vi.fn(),
46
+ clearSelection: _vitest.vi.fn(),
47
+ getNodes: () => nodes.value,
48
+ getEdges: () => edges.value,
49
+ getViewport: () => ({
50
+ x: 0,
51
+ y: 0,
52
+ zoom: 1
53
+ }),
54
+ screenToCanvas: _vitest.vi.fn().mockReturnValue({
55
+ x: 0,
56
+ y: 0
57
+ }),
58
+ canvasToScreen: _vitest.vi.fn().mockReturnValue({
59
+ x: 0,
60
+ y: 0
61
+ }),
62
+ on: _vitest.vi.fn(),
63
+ off: _vitest.vi.fn(),
64
+ emit: _vitest.vi.fn(),
65
+ isValidConnection: _vitest.vi.fn().mockReturnValue(true),
66
+ $el: void 0,
67
+ draggingNodeId: (0, _vue.ref)(null),
68
+ draggingPosition: (0, _vue.ref)(null),
69
+ usePlugin: _vitest.vi.fn(),
70
+ removePlugin: _vitest.vi.fn()
71
+ };
72
+ return flow;
73
+ }
74
+ (0, _vitest.describe)("createNodeGroupPlugin", () => {
75
+ (0, _vitest.it)("should be created with correct metadata", () => {
76
+ const plugin = (0, _nodeGroup.createNodeGroupPlugin)();
77
+ (0, _vitest.expect)(plugin.id).toBe("node-group");
78
+ (0, _vitest.expect)(plugin.name).toBe("NodeGroup");
79
+ });
80
+ (0, _vitest.it)("should expose groupSelectedNodes on flow instance after install", () => {
81
+ const flow = createMockFlow();
82
+ const plugin = (0, _nodeGroup.createNodeGroupPlugin)();
83
+ plugin.install(flow);
84
+ (0, _vitest.expect)(typeof flow.groupSelectedNodes).toBe("function");
85
+ (0, _vitest.expect)(typeof flow.ungroupNodes).toBe("function");
86
+ (0, _vitest.expect)(typeof flow.toggleGroupCollapse).toBe("function");
87
+ (0, _vitest.expect)(typeof flow.isGroupCollapsed).toBe("function");
88
+ (0, _vitest.expect)(typeof flow.getGroupChildren).toBe("function");
89
+ (0, _vitest.expect)(typeof flow.getGroupRegistry).toBe("function");
90
+ });
91
+ (0, _vitest.it)("should return null when fewer than 2 nodes are selected", () => {
92
+ const nodes = [{
93
+ id: "1",
94
+ type: "default",
95
+ position: {
96
+ x: 0,
97
+ y: 0
98
+ },
99
+ data: {},
100
+ selected: true
101
+ }];
102
+ const flow = createMockFlow(nodes);
103
+ const plugin = (0, _nodeGroup.createNodeGroupPlugin)();
104
+ plugin.install(flow);
105
+ const result = flow.groupSelectedNodes;
106
+ (0, _vitest.expect)(result()).toBeNull();
107
+ });
108
+ (0, _vitest.it)("should create a group node when 2+ nodes are selected", () => {
109
+ const nodes = [{
110
+ id: "1",
111
+ type: "default",
112
+ position: {
113
+ x: 100,
114
+ y: 100
115
+ },
116
+ data: {},
117
+ selected: true,
118
+ width: 150,
119
+ height: 50
120
+ }, {
121
+ id: "2",
122
+ type: "default",
123
+ position: {
124
+ x: 300,
125
+ y: 100
126
+ },
127
+ data: {},
128
+ selected: true,
129
+ width: 150,
130
+ height: 50
131
+ }];
132
+ const flow = createMockFlow(nodes);
133
+ const plugin = (0, _nodeGroup.createNodeGroupPlugin)({
134
+ groupIdPrefix: "grp"
135
+ });
136
+ plugin.install(flow);
137
+ const groupSelected = flow.groupSelectedNodes;
138
+ const groupId = groupSelected("Test Group");
139
+ (0, _vitest.expect)(groupId).toBeTruthy();
140
+ (0, _vitest.expect)(groupId).toMatch(/^grp-/);
141
+ (0, _vitest.expect)(flow.addNode).toHaveBeenCalled();
142
+ });
143
+ (0, _vitest.it)("should register group info in registry after grouping", () => {
144
+ const nodes = [{
145
+ id: "a",
146
+ type: "default",
147
+ position: {
148
+ x: 50,
149
+ y: 50
150
+ },
151
+ data: {},
152
+ selected: true,
153
+ width: 100,
154
+ height: 50
155
+ }, {
156
+ id: "b",
157
+ type: "default",
158
+ position: {
159
+ x: 200,
160
+ y: 50
161
+ },
162
+ data: {},
163
+ selected: true,
164
+ width: 100,
165
+ height: 50
166
+ }];
167
+ const flow = createMockFlow(nodes);
168
+ const plugin = (0, _nodeGroup.createNodeGroupPlugin)();
169
+ plugin.install(flow);
170
+ const groupSelected = flow.groupSelectedNodes;
171
+ const groupId = groupSelected();
172
+ const registry = flow.getGroupRegistry();
173
+ (0, _vitest.expect)(registry.has(groupId)).toBe(true);
174
+ });
175
+ (0, _vitest.it)("should toggle group collapse and hide children", () => {
176
+ const childNodes = [{
177
+ id: "c1",
178
+ type: "default",
179
+ position: {
180
+ x: 20,
181
+ y: 20
182
+ },
183
+ data: {},
184
+ parentId: "group-1",
185
+ width: 100,
186
+ height: 40
187
+ }];
188
+ const flow = createMockFlow(childNodes);
189
+ const plugin = (0, _nodeGroup.createNodeGroupPlugin)();
190
+ plugin.install(flow);
191
+ const registry = flow.getGroupRegistry();
192
+ registry.set("group-1", {
193
+ groupId: "group-1",
194
+ childIds: ["c1"],
195
+ collapsed: false,
196
+ originalPositions: {}
197
+ });
198
+ flow.nodes.value.push({
199
+ id: "group-1",
200
+ type: "group",
201
+ position: {
202
+ x: 0,
203
+ y: 0
204
+ },
205
+ data: {},
206
+ style: {
207
+ width: 200,
208
+ height: 150
209
+ },
210
+ width: 200,
211
+ height: 150
212
+ });
213
+ const toggleCollapse = flow.toggleGroupCollapse;
214
+ toggleCollapse("group-1");
215
+ (0, _vitest.expect)(flow.updateNode).toHaveBeenCalledWith("c1", _vitest.expect.objectContaining({
216
+ hidden: true
217
+ }));
218
+ });
219
+ (0, _vitest.it)("should cleanup registry on destroy", () => {
220
+ const flow = createMockFlow();
221
+ const plugin = (0, _nodeGroup.createNodeGroupPlugin)();
222
+ plugin.install(flow);
223
+ plugin.destroy?.();
224
+ const registry = flow.getGroupRegistry();
225
+ (0, _vitest.expect)(registry.size).toBe(0);
226
+ });
227
+ (0, _vitest.it)("should not install when disabled", () => {
228
+ const flow = createMockFlow();
229
+ const plugin = (0, _nodeGroup.createNodeGroupPlugin)({
230
+ enabled: false
231
+ });
232
+ plugin.install(flow);
233
+ (0, _vitest.expect)(flow.groupSelectedNodes).toBeUndefined();
234
+ });
235
+ });
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,187 @@
1
+ import { describe, it, expect, vi } from "vitest";
2
+ import { ref } from "vue";
3
+ import { createNodeGroupPlugin } from "../plugins/plugins/node-group.mjs";
4
+ function createMockFlow(initialNodes = [], initialEdges = []) {
5
+ const nodes = ref(initialNodes);
6
+ const edges = ref(initialEdges);
7
+ const flow = {
8
+ nodes,
9
+ edges,
10
+ viewport: ref({ x: 0, y: 0, zoom: 1 }),
11
+ addNode: vi.fn((node) => {
12
+ nodes.value = [...nodes.value, node];
13
+ }),
14
+ removeNode: vi.fn((id) => {
15
+ nodes.value = nodes.value.filter((n) => n.id !== id);
16
+ }),
17
+ updateNode: vi.fn((id, data) => {
18
+ nodes.value = nodes.value.map((n) => n.id === id ? { ...n, ...data } : n);
19
+ }),
20
+ getNode: vi.fn((id) => nodes.value.find((n) => n.id === id)),
21
+ addEdge: vi.fn(),
22
+ removeEdge: vi.fn(),
23
+ updateEdge: vi.fn((id, data) => {
24
+ edges.value = edges.value.map((e) => e.id === id ? { ...e, ...data } : e);
25
+ }),
26
+ getEdge: vi.fn(),
27
+ setViewport: vi.fn(),
28
+ fitView: vi.fn(),
29
+ zoomIn: vi.fn(),
30
+ zoomOut: vi.fn(),
31
+ centerView: vi.fn(),
32
+ selectNode: vi.fn(),
33
+ selectEdge: vi.fn(),
34
+ clearSelection: vi.fn(),
35
+ getNodes: () => nodes.value,
36
+ getEdges: () => edges.value,
37
+ getViewport: () => ({ x: 0, y: 0, zoom: 1 }),
38
+ screenToCanvas: vi.fn().mockReturnValue({ x: 0, y: 0 }),
39
+ canvasToScreen: vi.fn().mockReturnValue({ x: 0, y: 0 }),
40
+ on: vi.fn(),
41
+ off: vi.fn(),
42
+ emit: vi.fn(),
43
+ isValidConnection: vi.fn().mockReturnValue(true),
44
+ $el: void 0,
45
+ draggingNodeId: ref(null),
46
+ draggingPosition: ref(null),
47
+ usePlugin: vi.fn(),
48
+ removePlugin: vi.fn()
49
+ };
50
+ return flow;
51
+ }
52
+ describe("createNodeGroupPlugin", () => {
53
+ it("should be created with correct metadata", () => {
54
+ const plugin = createNodeGroupPlugin();
55
+ expect(plugin.id).toBe("node-group");
56
+ expect(plugin.name).toBe("NodeGroup");
57
+ });
58
+ it("should expose groupSelectedNodes on flow instance after install", () => {
59
+ const flow = createMockFlow();
60
+ const plugin = createNodeGroupPlugin();
61
+ plugin.install(flow);
62
+ expect(typeof flow.groupSelectedNodes).toBe("function");
63
+ expect(typeof flow.ungroupNodes).toBe("function");
64
+ expect(typeof flow.toggleGroupCollapse).toBe("function");
65
+ expect(typeof flow.isGroupCollapsed).toBe("function");
66
+ expect(typeof flow.getGroupChildren).toBe("function");
67
+ expect(typeof flow.getGroupRegistry).toBe("function");
68
+ });
69
+ it("should return null when fewer than 2 nodes are selected", () => {
70
+ const nodes = [
71
+ { id: "1", type: "default", position: { x: 0, y: 0 }, data: {}, selected: true }
72
+ ];
73
+ const flow = createMockFlow(nodes);
74
+ const plugin = createNodeGroupPlugin();
75
+ plugin.install(flow);
76
+ const result = flow.groupSelectedNodes;
77
+ expect(result()).toBeNull();
78
+ });
79
+ it("should create a group node when 2+ nodes are selected", () => {
80
+ const nodes = [
81
+ {
82
+ id: "1",
83
+ type: "default",
84
+ position: { x: 100, y: 100 },
85
+ data: {},
86
+ selected: true,
87
+ width: 150,
88
+ height: 50
89
+ },
90
+ {
91
+ id: "2",
92
+ type: "default",
93
+ position: { x: 300, y: 100 },
94
+ data: {},
95
+ selected: true,
96
+ width: 150,
97
+ height: 50
98
+ }
99
+ ];
100
+ const flow = createMockFlow(nodes);
101
+ const plugin = createNodeGroupPlugin({ groupIdPrefix: "grp" });
102
+ plugin.install(flow);
103
+ const groupSelected = flow.groupSelectedNodes;
104
+ const groupId = groupSelected("Test Group");
105
+ expect(groupId).toBeTruthy();
106
+ expect(groupId).toMatch(/^grp-/);
107
+ expect(flow.addNode).toHaveBeenCalled();
108
+ });
109
+ it("should register group info in registry after grouping", () => {
110
+ const nodes = [
111
+ {
112
+ id: "a",
113
+ type: "default",
114
+ position: { x: 50, y: 50 },
115
+ data: {},
116
+ selected: true,
117
+ width: 100,
118
+ height: 50
119
+ },
120
+ {
121
+ id: "b",
122
+ type: "default",
123
+ position: { x: 200, y: 50 },
124
+ data: {},
125
+ selected: true,
126
+ width: 100,
127
+ height: 50
128
+ }
129
+ ];
130
+ const flow = createMockFlow(nodes);
131
+ const plugin = createNodeGroupPlugin();
132
+ plugin.install(flow);
133
+ const groupSelected = flow.groupSelectedNodes;
134
+ const groupId = groupSelected();
135
+ const registry = flow.getGroupRegistry();
136
+ expect(registry.has(groupId)).toBe(true);
137
+ });
138
+ it("should toggle group collapse and hide children", () => {
139
+ const childNodes = [
140
+ {
141
+ id: "c1",
142
+ type: "default",
143
+ position: { x: 20, y: 20 },
144
+ data: {},
145
+ parentId: "group-1",
146
+ width: 100,
147
+ height: 40
148
+ }
149
+ ];
150
+ const flow = createMockFlow(childNodes);
151
+ const plugin = createNodeGroupPlugin();
152
+ plugin.install(flow);
153
+ const registry = flow.getGroupRegistry();
154
+ registry.set("group-1", {
155
+ groupId: "group-1",
156
+ childIds: ["c1"],
157
+ collapsed: false,
158
+ originalPositions: {}
159
+ });
160
+ flow.nodes.value.push({
161
+ id: "group-1",
162
+ type: "group",
163
+ position: { x: 0, y: 0 },
164
+ data: {},
165
+ style: { width: 200, height: 150 },
166
+ width: 200,
167
+ height: 150
168
+ });
169
+ const toggleCollapse = flow.toggleGroupCollapse;
170
+ toggleCollapse("group-1");
171
+ expect(flow.updateNode).toHaveBeenCalledWith("c1", expect.objectContaining({ hidden: true }));
172
+ });
173
+ it("should cleanup registry on destroy", () => {
174
+ const flow = createMockFlow();
175
+ const plugin = createNodeGroupPlugin();
176
+ plugin.install(flow);
177
+ plugin.destroy?.();
178
+ const registry = flow.getGroupRegistry();
179
+ expect(registry.size).toBe(0);
180
+ });
181
+ it("should not install when disabled", () => {
182
+ const flow = createMockFlow();
183
+ const plugin = createNodeGroupPlugin({ enabled: false });
184
+ plugin.install(flow);
185
+ expect(flow.groupSelectedNodes).toBeUndefined();
186
+ });
187
+ });