@zenode/designer 3.5.0
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.
- package/APIs.md +60 -0
- package/LICENSE +12 -0
- package/README.md +219 -0
- package/dist/components/canvas/canvas.cjs +106 -0
- package/dist/components/canvas/canvas.cjs.map +1 -0
- package/dist/components/canvas/canvas.d.ts +15 -0
- package/dist/components/canvas/canvas.js +84 -0
- package/dist/components/canvas/canvas.js.map +1 -0
- package/dist/components/canvas/grid.cjs +167 -0
- package/dist/components/canvas/grid.cjs.map +1 -0
- package/dist/components/canvas/grid.d.ts +5 -0
- package/dist/components/canvas/grid.js +144 -0
- package/dist/components/canvas/grid.js.map +1 -0
- package/dist/components/shapeTypes/circle.d.ts +2 -0
- package/dist/components/shapeTypes/rectangle.d.ts +4 -0
- package/dist/components/shapeTypes/rectangle.js +22 -0
- package/dist/components/shapeTypes/rectangle.js.map +1 -0
- package/dist/components/shapeTypes/rhombus.d.ts +1 -0
- package/dist/config/defaultConfig.cjs +542 -0
- package/dist/config/defaultConfig.cjs.map +1 -0
- package/dist/config/defaultConfig.d.ts +2 -0
- package/dist/config/defaultConfig.js +540 -0
- package/dist/config/defaultConfig.js.map +1 -0
- package/dist/config/testConfig.cjs +553 -0
- package/dist/config/testConfig.cjs.map +1 -0
- package/dist/config/testConfig.d.ts +2 -0
- package/dist/config/testConfig.js +551 -0
- package/dist/config/testConfig.js.map +1 -0
- package/dist/config/testConfig1.d.ts +2 -0
- package/dist/config/testXML.cjs +17 -0
- package/dist/config/testXML.cjs.map +1 -0
- package/dist/config/testXML.d.ts +1 -0
- package/dist/config/testXML.js +15 -0
- package/dist/config/testXML.js.map +1 -0
- package/dist/connections/paths/curved.cjs +34 -0
- package/dist/connections/paths/curved.cjs.map +1 -0
- package/dist/connections/paths/curved.d.ts +2 -0
- package/dist/connections/paths/curved.js +32 -0
- package/dist/connections/paths/curved.js.map +1 -0
- package/dist/connections/paths/index.cjs +16 -0
- package/dist/connections/paths/index.cjs.map +1 -0
- package/dist/connections/paths/index.d.ts +12 -0
- package/dist/connections/paths/index.js +14 -0
- package/dist/connections/paths/index.js.map +1 -0
- package/dist/connections/paths/l-bent.cjs +59 -0
- package/dist/connections/paths/l-bent.cjs.map +1 -0
- package/dist/connections/paths/l-bent.d.ts +5 -0
- package/dist/connections/paths/l-bent.js +57 -0
- package/dist/connections/paths/l-bent.js.map +1 -0
- package/dist/connections/paths/s-shaped.cjs +24 -0
- package/dist/connections/paths/s-shaped.cjs.map +1 -0
- package/dist/connections/paths/s-shaped.d.ts +5 -0
- package/dist/connections/paths/s-shaped.js +22 -0
- package/dist/connections/paths/s-shaped.js.map +1 -0
- package/dist/connections/paths/straight.cjs +9 -0
- package/dist/connections/paths/straight.cjs.map +1 -0
- package/dist/connections/paths/straight.d.ts +2 -0
- package/dist/connections/paths/straight.js +7 -0
- package/dist/connections/paths/straight.js.map +1 -0
- package/dist/connections/render.cjs +382 -0
- package/dist/connections/render.cjs.map +1 -0
- package/dist/connections/render.d.ts +29 -0
- package/dist/connections/render.js +360 -0
- package/dist/connections/render.js.map +1 -0
- package/dist/connections/routing/index.d.ts +14 -0
- package/dist/connections/routing/smartRouter.cjs +26 -0
- package/dist/connections/routing/smartRouter.cjs.map +1 -0
- package/dist/connections/routing/smartRouter.d.ts +13 -0
- package/dist/connections/routing/smartRouter.js +24 -0
- package/dist/connections/routing/smartRouter.js.map +1 -0
- package/dist/contextpad/defaults.cjs +181 -0
- package/dist/contextpad/defaults.cjs.map +1 -0
- package/dist/contextpad/defaults.d.ts +2 -0
- package/dist/contextpad/defaults.js +179 -0
- package/dist/contextpad/defaults.js.map +1 -0
- package/dist/contextpad/registry.cjs +54 -0
- package/dist/contextpad/registry.cjs.map +1 -0
- package/dist/contextpad/registry.d.ts +21 -0
- package/dist/contextpad/registry.js +52 -0
- package/dist/contextpad/registry.js.map +1 -0
- package/dist/contextpad/renderer.cjs +347 -0
- package/dist/contextpad/renderer.cjs.map +1 -0
- package/dist/contextpad/renderer.d.ts +32 -0
- package/dist/contextpad/renderer.js +326 -0
- package/dist/contextpad/renderer.js.map +1 -0
- package/dist/core/engine.cjs +2254 -0
- package/dist/core/engine.cjs.map +1 -0
- package/dist/core/engine.d.ts +444 -0
- package/dist/core/engine.js +2233 -0
- package/dist/core/engine.js.map +1 -0
- package/dist/core/eventManager.cjs +29 -0
- package/dist/core/eventManager.cjs.map +1 -0
- package/dist/core/eventManager.d.ts +6 -0
- package/dist/core/eventManager.js +27 -0
- package/dist/core/eventManager.js.map +1 -0
- package/dist/core/history/command.cjs +182 -0
- package/dist/core/history/command.cjs.map +1 -0
- package/dist/core/history/command.d.ts +119 -0
- package/dist/core/history/command.js +171 -0
- package/dist/core/history/command.js.map +1 -0
- package/dist/core/history/undoManager.cjs +54 -0
- package/dist/core/history/undoManager.cjs.map +1 -0
- package/dist/core/history/undoManager.d.ts +18 -0
- package/dist/core/history/undoManager.js +52 -0
- package/dist/core/history/undoManager.js.map +1 -0
- package/dist/core/license.cjs +36 -0
- package/dist/core/license.cjs.map +1 -0
- package/dist/core/license.d.ts +16 -0
- package/dist/core/license.js +34 -0
- package/dist/core/license.js.map +1 -0
- package/dist/core/samples.cjs +68 -0
- package/dist/core/samples.cjs.map +1 -0
- package/dist/core/samples.d.ts +6 -0
- package/dist/core/samples.js +66 -0
- package/dist/core/samples.js.map +1 -0
- package/dist/core/serialization.cjs +123 -0
- package/dist/core/serialization.cjs.map +1 -0
- package/dist/core/serialization.d.ts +26 -0
- package/dist/core/serialization.js +121 -0
- package/dist/core/serialization.js.map +1 -0
- package/dist/core/validation.cjs +92 -0
- package/dist/core/validation.cjs.map +1 -0
- package/dist/core/validation.d.ts +24 -0
- package/dist/core/validation.js +89 -0
- package/dist/core/validation.js.map +1 -0
- package/dist/core/zoom&PanManager.d.ts +16 -0
- package/dist/core/zoom_PanManager.cjs +96 -0
- package/dist/core/zoom_PanManager.cjs.map +1 -0
- package/dist/core/zoom_PanManager.js +75 -0
- package/dist/core/zoom_PanManager.js.map +1 -0
- package/dist/effects/engine.cjs +203 -0
- package/dist/effects/engine.cjs.map +1 -0
- package/dist/effects/engine.d.ts +6 -0
- package/dist/effects/engine.js +182 -0
- package/dist/effects/engine.js.map +1 -0
- package/dist/events/drag.cjs +299 -0
- package/dist/events/drag.cjs.map +1 -0
- package/dist/events/drag.d.ts +19 -0
- package/dist/events/drag.js +278 -0
- package/dist/events/drag.js.map +1 -0
- package/dist/events/mouseClick.cjs +36 -0
- package/dist/events/mouseClick.cjs.map +1 -0
- package/dist/events/mouseClick.d.ts +26 -0
- package/dist/events/mouseClick.js +34 -0
- package/dist/events/mouseClick.js.map +1 -0
- package/dist/events/mouseMove.cjs +104 -0
- package/dist/events/mouseMove.cjs.map +1 -0
- package/dist/events/mouseMove.d.ts +11 -0
- package/dist/events/mouseMove.js +82 -0
- package/dist/events/mouseMove.js.map +1 -0
- package/dist/events/resize.cjs +98 -0
- package/dist/events/resize.cjs.map +1 -0
- package/dist/events/resize.d.ts +14 -0
- package/dist/events/resize.js +77 -0
- package/dist/events/resize.js.map +1 -0
- package/dist/examples/keyboard-shortcuts.d.ts +10 -0
- package/dist/icons.bundle.js +763 -0
- package/dist/icons.bundle.js.map +1 -0
- package/dist/icons.cjs +105 -0
- package/dist/icons.cjs.map +1 -0
- package/dist/icons.d.ts +7 -0
- package/dist/icons.js +89 -0
- package/dist/icons.js.map +1 -0
- package/dist/index.cjs +284 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.ts +160 -0
- package/dist/index.js +204 -0
- package/dist/index.js.map +1 -0
- package/dist/model/configurationModel.d.ts +280 -0
- package/dist/model/interface.d.ts +95 -0
- package/dist/model/shapeModel.d.ts +28 -0
- package/dist/node_modules/lucide/dist/esm/createElement.cjs +36 -0
- package/dist/node_modules/lucide/dist/esm/createElement.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/createElement.js +34 -0
- package/dist/node_modules/lucide/dist/esm/createElement.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/defaultAttributes.cjs +23 -0
- package/dist/node_modules/lucide/dist/esm/defaultAttributes.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/defaultAttributes.js +21 -0
- package/dist/node_modules/lucide/dist/esm/defaultAttributes.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/arrow-down-right.cjs +16 -0
- package/dist/node_modules/lucide/dist/esm/icons/arrow-down-right.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/arrow-down-right.js +14 -0
- package/dist/node_modules/lucide/dist/esm/icons/arrow-down-right.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/arrow-right.cjs +16 -0
- package/dist/node_modules/lucide/dist/esm/icons/arrow-right.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/arrow-right.js +14 -0
- package/dist/node_modules/lucide/dist/esm/icons/arrow-right.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/arrow-up-right.cjs +16 -0
- package/dist/node_modules/lucide/dist/esm/icons/arrow-up-right.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/arrow-up-right.js +14 -0
- package/dist/node_modules/lucide/dist/esm/icons/arrow-up-right.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/box.cjs +22 -0
- package/dist/node_modules/lucide/dist/esm/icons/box.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/box.js +20 -0
- package/dist/node_modules/lucide/dist/esm/icons/box.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/chevron-down.cjs +13 -0
- package/dist/node_modules/lucide/dist/esm/icons/chevron-down.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/chevron-down.js +11 -0
- package/dist/node_modules/lucide/dist/esm/icons/chevron-down.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/chevron-right.cjs +13 -0
- package/dist/node_modules/lucide/dist/esm/icons/chevron-right.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/chevron-right.js +11 -0
- package/dist/node_modules/lucide/dist/esm/icons/chevron-right.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle-alert.cjs +17 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle-alert.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle-alert.js +15 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle-alert.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle-check-big.cjs +16 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle-check-big.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle-check-big.js +14 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle-check-big.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle-question-mark.cjs +17 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle-question-mark.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle-question-mark.js +15 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle-question-mark.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle.cjs +13 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle.js +11 -0
- package/dist/node_modules/lucide/dist/esm/icons/circle.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/cloud.cjs +13 -0
- package/dist/node_modules/lucide/dist/esm/icons/cloud.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/cloud.js +11 -0
- package/dist/node_modules/lucide/dist/esm/icons/cloud.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/copy.cjs +16 -0
- package/dist/node_modules/lucide/dist/esm/icons/copy.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/copy.js +14 -0
- package/dist/node_modules/lucide/dist/esm/icons/copy.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/database.cjs +17 -0
- package/dist/node_modules/lucide/dist/esm/icons/database.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/database.js +15 -0
- package/dist/node_modules/lucide/dist/esm/icons/database.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/diamond.cjs +20 -0
- package/dist/node_modules/lucide/dist/esm/icons/diamond.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/diamond.js +18 -0
- package/dist/node_modules/lucide/dist/esm/icons/diamond.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/download.cjs +17 -0
- package/dist/node_modules/lucide/dist/esm/icons/download.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/download.js +15 -0
- package/dist/node_modules/lucide/dist/esm/icons/download.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/eye-off.cjs +28 -0
- package/dist/node_modules/lucide/dist/esm/icons/eye-off.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/eye-off.js +26 -0
- package/dist/node_modules/lucide/dist/esm/icons/eye-off.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/eye.cjs +21 -0
- package/dist/node_modules/lucide/dist/esm/icons/eye.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/eye.js +19 -0
- package/dist/node_modules/lucide/dist/esm/icons/eye.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/grid-3x3.cjs +19 -0
- package/dist/node_modules/lucide/dist/esm/icons/grid-3x3.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/grid-3x3.js +17 -0
- package/dist/node_modules/lucide/dist/esm/icons/grid-3x3.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/history.cjs +17 -0
- package/dist/node_modules/lucide/dist/esm/icons/history.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/history.js +15 -0
- package/dist/node_modules/lucide/dist/esm/icons/history.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/info.cjs +17 -0
- package/dist/node_modules/lucide/dist/esm/icons/info.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/info.js +15 -0
- package/dist/node_modules/lucide/dist/esm/icons/info.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/lasso.cjs +17 -0
- package/dist/node_modules/lucide/dist/esm/icons/lasso.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/lasso.js +15 -0
- package/dist/node_modules/lucide/dist/esm/icons/lasso.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/maximize.cjs +18 -0
- package/dist/node_modules/lucide/dist/esm/icons/maximize.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/maximize.js +16 -0
- package/dist/node_modules/lucide/dist/esm/icons/maximize.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/minimize.cjs +18 -0
- package/dist/node_modules/lucide/dist/esm/icons/minimize.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/minimize.js +16 -0
- package/dist/node_modules/lucide/dist/esm/icons/minimize.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/mouse-pointer.cjs +21 -0
- package/dist/node_modules/lucide/dist/esm/icons/mouse-pointer.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/mouse-pointer.js +19 -0
- package/dist/node_modules/lucide/dist/esm/icons/mouse-pointer.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/move.cjs +20 -0
- package/dist/node_modules/lucide/dist/esm/icons/move.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/move.js +18 -0
- package/dist/node_modules/lucide/dist/esm/icons/move.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/panels-top-left.cjs +17 -0
- package/dist/node_modules/lucide/dist/esm/icons/panels-top-left.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/panels-top-left.js +15 -0
- package/dist/node_modules/lucide/dist/esm/icons/panels-top-left.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/pen.cjs +20 -0
- package/dist/node_modules/lucide/dist/esm/icons/pen.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/pen.js +18 -0
- package/dist/node_modules/lucide/dist/esm/icons/pen.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/plus.cjs +16 -0
- package/dist/node_modules/lucide/dist/esm/icons/plus.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/plus.js +14 -0
- package/dist/node_modules/lucide/dist/esm/icons/plus.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/search.cjs +16 -0
- package/dist/node_modules/lucide/dist/esm/icons/search.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/search.js +14 -0
- package/dist/node_modules/lucide/dist/esm/icons/search.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/settings.cjs +21 -0
- package/dist/node_modules/lucide/dist/esm/icons/settings.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/settings.js +19 -0
- package/dist/node_modules/lucide/dist/esm/icons/settings.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/share-2.cjs +19 -0
- package/dist/node_modules/lucide/dist/esm/icons/share-2.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/share-2.js +17 -0
- package/dist/node_modules/lucide/dist/esm/icons/share-2.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/square.cjs +13 -0
- package/dist/node_modules/lucide/dist/esm/icons/square.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/square.js +11 -0
- package/dist/node_modules/lucide/dist/esm/icons/square.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/sticky-note.cjs +21 -0
- package/dist/node_modules/lucide/dist/esm/icons/sticky-note.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/sticky-note.js +19 -0
- package/dist/node_modules/lucide/dist/esm/icons/sticky-note.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/trash-2.cjs +19 -0
- package/dist/node_modules/lucide/dist/esm/icons/trash-2.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/trash-2.js +17 -0
- package/dist/node_modules/lucide/dist/esm/icons/trash-2.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/triangle.cjs +15 -0
- package/dist/node_modules/lucide/dist/esm/icons/triangle.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/triangle.js +13 -0
- package/dist/node_modules/lucide/dist/esm/icons/triangle.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/x.cjs +16 -0
- package/dist/node_modules/lucide/dist/esm/icons/x.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/x.js +14 -0
- package/dist/node_modules/lucide/dist/esm/icons/x.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/zap.cjs +20 -0
- package/dist/node_modules/lucide/dist/esm/icons/zap.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/icons/zap.js +18 -0
- package/dist/node_modules/lucide/dist/esm/icons/zap.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/lucide.cjs +56 -0
- package/dist/node_modules/lucide/dist/esm/lucide.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/lucide.js +54 -0
- package/dist/node_modules/lucide/dist/esm/lucide.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/replaceElement.cjs +73 -0
- package/dist/node_modules/lucide/dist/esm/replaceElement.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/replaceElement.js +67 -0
- package/dist/node_modules/lucide/dist/esm/replaceElement.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/hasA11yProp.cjs +20 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/hasA11yProp.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/hasA11yProp.js +18 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/hasA11yProp.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/mergeClasses.cjs +15 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/mergeClasses.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/mergeClasses.js +13 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/mergeClasses.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/toCamelCase.cjs +16 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/toCamelCase.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/toCamelCase.js +14 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/toCamelCase.js.map +1 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/toPascalCase.cjs +19 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/toPascalCase.cjs.map +1 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/toPascalCase.js +17 -0
- package/dist/node_modules/lucide/dist/esm/shared/src/utils/toPascalCase.js.map +1 -0
- package/dist/nodes/content.cjs +186 -0
- package/dist/nodes/content.cjs.map +1 -0
- package/dist/nodes/content.d.ts +16 -0
- package/dist/nodes/content.js +184 -0
- package/dist/nodes/content.js.map +1 -0
- package/dist/nodes/geometry/ellipsePath.cjs +18 -0
- package/dist/nodes/geometry/ellipsePath.cjs.map +1 -0
- package/dist/nodes/geometry/ellipsePath.d.ts +5 -0
- package/dist/nodes/geometry/ellipsePath.js +16 -0
- package/dist/nodes/geometry/ellipsePath.js.map +1 -0
- package/dist/nodes/geometry/kitePath.cjs +15 -0
- package/dist/nodes/geometry/kitePath.cjs.map +1 -0
- package/dist/nodes/geometry/kitePath.d.ts +5 -0
- package/dist/nodes/geometry/kitePath.js +13 -0
- package/dist/nodes/geometry/kitePath.js.map +1 -0
- package/dist/nodes/geometry/octagonPath.cjs +23 -0
- package/dist/nodes/geometry/octagonPath.cjs.map +1 -0
- package/dist/nodes/geometry/octagonPath.d.ts +4 -0
- package/dist/nodes/geometry/octagonPath.js +21 -0
- package/dist/nodes/geometry/octagonPath.js.map +1 -0
- package/dist/nodes/geometry/parallelogramPath.cjs +16 -0
- package/dist/nodes/geometry/parallelogramPath.cjs.map +1 -0
- package/dist/nodes/geometry/parallelogramPath.d.ts +5 -0
- package/dist/nodes/geometry/parallelogramPath.js +14 -0
- package/dist/nodes/geometry/parallelogramPath.js.map +1 -0
- package/dist/nodes/geometry/pentagonPath.cjs +23 -0
- package/dist/nodes/geometry/pentagonPath.cjs.map +1 -0
- package/dist/nodes/geometry/pentagonPath.d.ts +4 -0
- package/dist/nodes/geometry/pentagonPath.js +21 -0
- package/dist/nodes/geometry/pentagonPath.js.map +1 -0
- package/dist/nodes/geometry/polygonPath.cjs +28 -0
- package/dist/nodes/geometry/polygonPath.cjs.map +1 -0
- package/dist/nodes/geometry/polygonPath.d.ts +5 -0
- package/dist/nodes/geometry/polygonPath.js +26 -0
- package/dist/nodes/geometry/polygonPath.js.map +1 -0
- package/dist/nodes/geometry/rectanglePath.cjs +23 -0
- package/dist/nodes/geometry/rectanglePath.cjs.map +1 -0
- package/dist/nodes/geometry/rectanglePath.d.ts +4 -0
- package/dist/nodes/geometry/rectanglePath.js +21 -0
- package/dist/nodes/geometry/rectanglePath.js.map +1 -0
- package/dist/nodes/geometry/semicirclePath.cjs +17 -0
- package/dist/nodes/geometry/semicirclePath.cjs.map +1 -0
- package/dist/nodes/geometry/semicirclePath.d.ts +5 -0
- package/dist/nodes/geometry/semicirclePath.js +15 -0
- package/dist/nodes/geometry/semicirclePath.js.map +1 -0
- package/dist/nodes/geometry/starPath.cjs +28 -0
- package/dist/nodes/geometry/starPath.cjs.map +1 -0
- package/dist/nodes/geometry/starPath.d.ts +4 -0
- package/dist/nodes/geometry/starPath.js +26 -0
- package/dist/nodes/geometry/starPath.js.map +1 -0
- package/dist/nodes/geometry/trapezoidPath.cjs +16 -0
- package/dist/nodes/geometry/trapezoidPath.cjs.map +1 -0
- package/dist/nodes/geometry/trapezoidPath.d.ts +5 -0
- package/dist/nodes/geometry/trapezoidPath.js +14 -0
- package/dist/nodes/geometry/trapezoidPath.js.map +1 -0
- package/dist/nodes/geometry/trianglePath.cjs +14 -0
- package/dist/nodes/geometry/trianglePath.cjs.map +1 -0
- package/dist/nodes/geometry/trianglePath.d.ts +5 -0
- package/dist/nodes/geometry/trianglePath.js +12 -0
- package/dist/nodes/geometry/trianglePath.js.map +1 -0
- package/dist/nodes/overlay.cjs +136 -0
- package/dist/nodes/overlay.cjs.map +1 -0
- package/dist/nodes/overlay.d.ts +24 -0
- package/dist/nodes/overlay.js +130 -0
- package/dist/nodes/overlay.js.map +1 -0
- package/dist/nodes/placement.cjs +346 -0
- package/dist/nodes/placement.cjs.map +1 -0
- package/dist/nodes/placement.d.ts +66 -0
- package/dist/nodes/placement.js +325 -0
- package/dist/nodes/placement.js.map +1 -0
- package/dist/nodes/ports.cjs +196 -0
- package/dist/nodes/ports.cjs.map +1 -0
- package/dist/nodes/ports.d.ts +12 -0
- package/dist/nodes/ports.js +194 -0
- package/dist/nodes/ports.js.map +1 -0
- package/dist/nodes/registry.cjs +26 -0
- package/dist/nodes/registry.cjs.map +1 -0
- package/dist/nodes/registry.d.ts +8 -0
- package/dist/nodes/registry.js +24 -0
- package/dist/nodes/registry.js.map +1 -0
- package/dist/nodes/shapes/circle.cjs +50 -0
- package/dist/nodes/shapes/circle.cjs.map +1 -0
- package/dist/nodes/shapes/circle.d.ts +2 -0
- package/dist/nodes/shapes/circle.js +48 -0
- package/dist/nodes/shapes/circle.js.map +1 -0
- package/dist/nodes/shapes/decagon.cjs +51 -0
- package/dist/nodes/shapes/decagon.cjs.map +1 -0
- package/dist/nodes/shapes/decagon.d.ts +5 -0
- package/dist/nodes/shapes/decagon.js +49 -0
- package/dist/nodes/shapes/decagon.js.map +1 -0
- package/dist/nodes/shapes/heptagon.cjs +51 -0
- package/dist/nodes/shapes/heptagon.cjs.map +1 -0
- package/dist/nodes/shapes/heptagon.d.ts +5 -0
- package/dist/nodes/shapes/heptagon.js +49 -0
- package/dist/nodes/shapes/heptagon.js.map +1 -0
- package/dist/nodes/shapes/hexagon.cjs +51 -0
- package/dist/nodes/shapes/hexagon.cjs.map +1 -0
- package/dist/nodes/shapes/hexagon.d.ts +5 -0
- package/dist/nodes/shapes/hexagon.js +49 -0
- package/dist/nodes/shapes/hexagon.js.map +1 -0
- package/dist/nodes/shapes/kite.cjs +43 -0
- package/dist/nodes/shapes/kite.cjs.map +1 -0
- package/dist/nodes/shapes/kite.d.ts +5 -0
- package/dist/nodes/shapes/kite.js +41 -0
- package/dist/nodes/shapes/kite.js.map +1 -0
- package/dist/nodes/shapes/nonagon.cjs +51 -0
- package/dist/nodes/shapes/nonagon.cjs.map +1 -0
- package/dist/nodes/shapes/nonagon.d.ts +5 -0
- package/dist/nodes/shapes/nonagon.js +49 -0
- package/dist/nodes/shapes/nonagon.js.map +1 -0
- package/dist/nodes/shapes/octagon.cjs +46 -0
- package/dist/nodes/shapes/octagon.cjs.map +1 -0
- package/dist/nodes/shapes/octagon.d.ts +2 -0
- package/dist/nodes/shapes/octagon.js +44 -0
- package/dist/nodes/shapes/octagon.js.map +1 -0
- package/dist/nodes/shapes/oval.cjs +43 -0
- package/dist/nodes/shapes/oval.cjs.map +1 -0
- package/dist/nodes/shapes/oval.d.ts +5 -0
- package/dist/nodes/shapes/oval.js +41 -0
- package/dist/nodes/shapes/oval.js.map +1 -0
- package/dist/nodes/shapes/parallelogram.cjs +44 -0
- package/dist/nodes/shapes/parallelogram.cjs.map +1 -0
- package/dist/nodes/shapes/parallelogram.d.ts +5 -0
- package/dist/nodes/shapes/parallelogram.js +42 -0
- package/dist/nodes/shapes/parallelogram.js.map +1 -0
- package/dist/nodes/shapes/pentagon.cjs +46 -0
- package/dist/nodes/shapes/pentagon.cjs.map +1 -0
- package/dist/nodes/shapes/pentagon.d.ts +2 -0
- package/dist/nodes/shapes/pentagon.js +44 -0
- package/dist/nodes/shapes/pentagon.js.map +1 -0
- package/dist/nodes/shapes/rectangle.cjs +43 -0
- package/dist/nodes/shapes/rectangle.cjs.map +1 -0
- package/dist/nodes/shapes/rectangle.d.ts +2 -0
- package/dist/nodes/shapes/rectangle.js +41 -0
- package/dist/nodes/shapes/rectangle.js.map +1 -0
- package/dist/nodes/shapes/rhombus.cjs +38 -0
- package/dist/nodes/shapes/rhombus.cjs.map +1 -0
- package/dist/nodes/shapes/rhombus.d.ts +2 -0
- package/dist/nodes/shapes/rhombus.js +36 -0
- package/dist/nodes/shapes/rhombus.js.map +1 -0
- package/dist/nodes/shapes/semicircle.cjs +38 -0
- package/dist/nodes/shapes/semicircle.cjs.map +1 -0
- package/dist/nodes/shapes/semicircle.d.ts +2 -0
- package/dist/nodes/shapes/semicircle.js +36 -0
- package/dist/nodes/shapes/semicircle.js.map +1 -0
- package/dist/nodes/shapes/star.cjs +51 -0
- package/dist/nodes/shapes/star.cjs.map +1 -0
- package/dist/nodes/shapes/star.d.ts +2 -0
- package/dist/nodes/shapes/star.js +49 -0
- package/dist/nodes/shapes/star.js.map +1 -0
- package/dist/nodes/shapes/trapezoid.cjs +44 -0
- package/dist/nodes/shapes/trapezoid.cjs.map +1 -0
- package/dist/nodes/shapes/trapezoid.d.ts +5 -0
- package/dist/nodes/shapes/trapezoid.js +42 -0
- package/dist/nodes/shapes/trapezoid.js.map +1 -0
- package/dist/nodes/shapes/triangle.cjs +42 -0
- package/dist/nodes/shapes/triangle.cjs.map +1 -0
- package/dist/nodes/shapes/triangle.d.ts +5 -0
- package/dist/nodes/shapes/triangle.js +40 -0
- package/dist/nodes/shapes/triangle.js.map +1 -0
- package/dist/types/index.d.ts +213 -0
- package/dist/utils/configMerger.cjs +147 -0
- package/dist/utils/configMerger.cjs.map +1 -0
- package/dist/utils/configMerger.d.ts +2 -0
- package/dist/utils/configMerger.js +145 -0
- package/dist/utils/configMerger.js.map +1 -0
- package/dist/utils/helpers.cjs +21 -0
- package/dist/utils/helpers.cjs.map +1 -0
- package/dist/utils/helpers.d.ts +13 -0
- package/dist/utils/helpers.js +18 -0
- package/dist/utils/helpers.js.map +1 -0
- package/dist/zenode.cjs.js +1228 -0
- package/dist/zenode.cjs.js.map +1 -0
- package/dist/zenode.esm.js +1203 -0
- package/dist/zenode.esm.js.map +1 -0
- package/dist/zenode.umd.js +1232 -0
- package/dist/zenode.umd.js.map +1 -0
- package/package.json +60 -0
|
@@ -0,0 +1,325 @@
|
|
|
1
|
+
import * as d3 from 'd3';
|
|
2
|
+
import { createDragBehavior } from '../events/drag.js';
|
|
3
|
+
import { renderPorts } from './ports.js';
|
|
4
|
+
import { buildResolvedShapeConfig, renderSelectionRing, renderResizeHandles } from './overlay.js';
|
|
5
|
+
import { applyEffects } from '../effects/engine.js';
|
|
6
|
+
import { renderNodeContent } from './content.js';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Renders placed nodes using D3 data join. Keeps g.placed-nodes in sync with engine state.
|
|
10
|
+
*/
|
|
11
|
+
function getShapeStyle(node, config) {
|
|
12
|
+
var _a;
|
|
13
|
+
const list = (_a = config.shapes.default) === null || _a === void 0 ? void 0 : _a[node.type];
|
|
14
|
+
if (!Array.isArray(list))
|
|
15
|
+
return undefined;
|
|
16
|
+
return list.find((s) => s.id === node.shapeVariantId);
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Renders the placed nodes layer using a D3 data join. Call after state changes.
|
|
20
|
+
* @param placedNodesGroup - D3 selection for g.placed-nodes
|
|
21
|
+
* @param placedNodes - Current array of placed nodes
|
|
22
|
+
* @param config - Engine config for shape styles
|
|
23
|
+
*/
|
|
24
|
+
function renderPlacedNodes(placedNodesGroup, placedNodes, api) {
|
|
25
|
+
const dragBehavior = createDragBehavior(api);
|
|
26
|
+
const binding = placedNodesGroup
|
|
27
|
+
.selectAll("g.node")
|
|
28
|
+
.data(placedNodes, (d) => d.id);
|
|
29
|
+
binding
|
|
30
|
+
.join((enter) => {
|
|
31
|
+
const g = enter
|
|
32
|
+
.append("g")
|
|
33
|
+
.attr("class", "node placed-node")
|
|
34
|
+
.attr("data-id", (d) => d.id)
|
|
35
|
+
.attr("transform", (d) => `translate(${d.x},${d.y}) rotate(${d.rotation || 0})`)
|
|
36
|
+
.call(dragBehavior)
|
|
37
|
+
.on("click", function (event) {
|
|
38
|
+
event.stopPropagation();
|
|
39
|
+
const sel = d3.select(this);
|
|
40
|
+
const d = sel.datum();
|
|
41
|
+
api.setSelectedNodeIds([d.id], d.id);
|
|
42
|
+
});
|
|
43
|
+
g.each(function (d) {
|
|
44
|
+
const style = getShapeStyle(d, api.config);
|
|
45
|
+
if (!style)
|
|
46
|
+
return;
|
|
47
|
+
const el = d3.select(this);
|
|
48
|
+
const renderer = api.shapeRegistry.get(d.type);
|
|
49
|
+
const resolvedConfig = buildResolvedShapeConfig(d, style);
|
|
50
|
+
// Clear only if needed, but renderer.draw usually appends.
|
|
51
|
+
// If renderer.draw is called every time, it might be doubling up elements.
|
|
52
|
+
el.selectAll("path, circle, rect").filter(":not(.port):not(.selection-ring)").remove();
|
|
53
|
+
renderer.draw(el, resolvedConfig, {});
|
|
54
|
+
applyEffects(el, renderer.getPath(resolvedConfig), d.visualState);
|
|
55
|
+
renderNodeContent(el, d.content, renderer.getBounds(resolvedConfig), api.getEditingNodeId() === d.id);
|
|
56
|
+
});
|
|
57
|
+
return g;
|
|
58
|
+
}, (update) => {
|
|
59
|
+
update.attr("transform", (d) => `translate(${d.x},${d.y}) rotate(${d.rotation || 0})`);
|
|
60
|
+
update.each(function (d) {
|
|
61
|
+
const style = getShapeStyle(d, api.config);
|
|
62
|
+
if (!style)
|
|
63
|
+
return;
|
|
64
|
+
const el = d3.select(this);
|
|
65
|
+
const renderer = api.shapeRegistry.get(d.type);
|
|
66
|
+
const resolvedConfig = buildResolvedShapeConfig(d, style);
|
|
67
|
+
// --- Render Ghost (Original State) Preview ---
|
|
68
|
+
const activeOp = api.getActiveOperation();
|
|
69
|
+
el.selectAll(".node-ghost").remove();
|
|
70
|
+
const selection = api.getSelectedNodeIds();
|
|
71
|
+
// Support ghost if node itself is moving, or if it's in a moving visual group
|
|
72
|
+
const isInMovingGroup = api.getVisualGroups().some(g => g.nodeIds.includes(d.id) &&
|
|
73
|
+
g.nodeIds.some(nid => { var _a; return ((_a = activeOp === null || activeOp === void 0 ? void 0 : activeOp.selectionStates) === null || _a === void 0 ? void 0 : _a.has(nid)) || nid === (activeOp === null || activeOp === void 0 ? void 0 : activeOp.nodeId); }));
|
|
74
|
+
const shouldShowGhost = (activeOp && activeOp.type === 'drag') && (selection.includes(d.id) || isInMovingGroup);
|
|
75
|
+
if (shouldShowGhost && activeOp) {
|
|
76
|
+
const ghostG = el.insert("g", ":first-child").attr("class", "node-ghost");
|
|
77
|
+
let ghostNode = d;
|
|
78
|
+
if (activeOp.selectionStates && activeOp.selectionStates.has(d.id)) {
|
|
79
|
+
ghostNode = activeOp.selectionStates.get(d.id);
|
|
80
|
+
}
|
|
81
|
+
else if (activeOp.nodeId === d.id) {
|
|
82
|
+
ghostNode = activeOp.originalData;
|
|
83
|
+
}
|
|
84
|
+
const ghostStyle = getShapeStyle(ghostNode, api.config);
|
|
85
|
+
if (ghostStyle) {
|
|
86
|
+
const ghostResolved = buildResolvedShapeConfig(ghostNode, ghostStyle);
|
|
87
|
+
// Counter-transform the ghost so it stays at the original logical position
|
|
88
|
+
// while the parent 'g.node' has moved to the new (d.x, d.y)
|
|
89
|
+
const dx = ghostNode.x - d.x;
|
|
90
|
+
const dy = ghostNode.y - d.y;
|
|
91
|
+
const currentRotation = d.rotation || 0;
|
|
92
|
+
const ghostRotation = ghostNode.rotation || 0;
|
|
93
|
+
ghostG.attr("transform", `rotate(${-currentRotation}) translate(${dx},${dy}) rotate(${ghostRotation})`);
|
|
94
|
+
renderer.draw(ghostG, ghostResolved, {});
|
|
95
|
+
// Apply configurable styles
|
|
96
|
+
const ghostCfg = api.config.canvasProperties.ghostPreview;
|
|
97
|
+
const groupGhostCfg = api.config.canvasProperties.groupGhostPreview;
|
|
98
|
+
if (ghostCfg) {
|
|
99
|
+
const groups = api.getVisualGroups();
|
|
100
|
+
const isInMovingGroup = groups.some(g => g.nodeIds.includes(d.id) &&
|
|
101
|
+
g.nodeIds.some(nid => { var _a; return ((_a = activeOp === null || activeOp === void 0 ? void 0 : activeOp.selectionStates) === null || _a === void 0 ? void 0 : _a.has(nid)) || nid === (activeOp === null || activeOp === void 0 ? void 0 : activeOp.nodeId); }));
|
|
102
|
+
const strokeColor = isInMovingGroup && groupGhostCfg
|
|
103
|
+
? groupGhostCfg.strokeColor
|
|
104
|
+
: ghostCfg.strokeColor;
|
|
105
|
+
const dashArray = isInMovingGroup && groupGhostCfg
|
|
106
|
+
? groupGhostCfg.strokeDashArray
|
|
107
|
+
: ghostCfg.strokeDashArray;
|
|
108
|
+
ghostG.style("opacity", ghostCfg.opacity)
|
|
109
|
+
.style("filter", ghostCfg.filter)
|
|
110
|
+
.style("pointer-events", "none");
|
|
111
|
+
ghostG.selectAll("path, rect, circle")
|
|
112
|
+
.style("stroke-dasharray", dashArray.join(" "))
|
|
113
|
+
.style("stroke", strokeColor)
|
|
114
|
+
.style("stroke-width", ghostCfg.strokeWidth)
|
|
115
|
+
.style("fill", ghostCfg.fillColor);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
// Ensure we don't clear ports during update
|
|
120
|
+
el.selectAll("path, circle, rect, g.node-content").filter(":not(.port):not(.selection-ring):not(.node-ghost *)").remove();
|
|
121
|
+
renderer.draw(el, resolvedConfig, {});
|
|
122
|
+
applyEffects(el, renderer.getPath(resolvedConfig), d.visualState);
|
|
123
|
+
renderNodeContent(el, d.content, renderer.getBounds(resolvedConfig), api.getEditingNodeId() === d.id);
|
|
124
|
+
});
|
|
125
|
+
return update;
|
|
126
|
+
}, (exit) => exit.remove());
|
|
127
|
+
// We don't need the second .each loop here because we moved the logic into join
|
|
128
|
+
// syncSelectionRings will still call renderPorts
|
|
129
|
+
syncSelectionRings(placedNodesGroup, api, placedNodes);
|
|
130
|
+
renderVisualGroups(placedNodesGroup, api);
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Calculates and renders a boundary around visual groups that have at least one member selected.
|
|
134
|
+
*/
|
|
135
|
+
function renderVisualGroups(placedNodesGroup, api, placedNodes) {
|
|
136
|
+
var _a;
|
|
137
|
+
const parent = api.canvasObject.visualGroups;
|
|
138
|
+
if (!parent || !parent.selectAll)
|
|
139
|
+
return;
|
|
140
|
+
const groups = api.getVisualGroups();
|
|
141
|
+
const selectedIds = new Set(api.getSelectedNodeIds());
|
|
142
|
+
const isConnMode = ((_a = api.isConnectionModeEnabled) === null || _a === void 0 ? void 0 : _a.call(api)) || false;
|
|
143
|
+
// --- Boundary Data Join ---
|
|
144
|
+
const boundaries = parent.selectAll("g.visual-group-boundary")
|
|
145
|
+
.data(groups, (d) => d.id);
|
|
146
|
+
// Remove old boundaries
|
|
147
|
+
boundaries.exit().remove();
|
|
148
|
+
// Create new boundaries
|
|
149
|
+
const boundEnter = boundaries.enter().append("g")
|
|
150
|
+
.attr("class", d => `visual-group-boundary ${d.id}`)
|
|
151
|
+
.attr("data-group-nodes", d => d.nodeIds.join(","));
|
|
152
|
+
// Update all boundaries (enter + update)
|
|
153
|
+
const boundsAll = boundEnter.merge(boundaries);
|
|
154
|
+
boundsAll.each(function (group) {
|
|
155
|
+
const g = d3.select(this);
|
|
156
|
+
const bounds = api.getGroupBounds(group.id);
|
|
157
|
+
if (!bounds) {
|
|
158
|
+
g.style("display", "none");
|
|
159
|
+
return;
|
|
160
|
+
}
|
|
161
|
+
g.style("display", "block");
|
|
162
|
+
const { x, y, width: w, height: h } = bounds;
|
|
163
|
+
const isGroupActive = group.nodeIds.some((id) => selectedIds.has(id));
|
|
164
|
+
g.attr("transform", `translate(${x}, ${y})`)
|
|
165
|
+
.attr("data-group-nodes", group.nodeIds.join(','));
|
|
166
|
+
// Layer 1: Background rect (clickable)
|
|
167
|
+
let bg = g.select("rect.bg-rect");
|
|
168
|
+
if (bg.empty()) {
|
|
169
|
+
bg = g.append("rect").attr("class", "bg-rect");
|
|
170
|
+
}
|
|
171
|
+
bg.attr("width", w)
|
|
172
|
+
.attr("height", h)
|
|
173
|
+
.attr("rx", 8)
|
|
174
|
+
.attr("fill", "var(--zenode-selection-color, #4A90E2)")
|
|
175
|
+
.attr("opacity", isGroupActive ? 0.05 : 0.01)
|
|
176
|
+
.style("pointer-events", isGroupActive ? "all" : "none") // Only intercept if already active or during specific triggers
|
|
177
|
+
.style("cursor", "move")
|
|
178
|
+
.on("mousedown", (event) => {
|
|
179
|
+
// Only trigger group selection if not dragging ports
|
|
180
|
+
if (!event.target.classList.contains('port')) {
|
|
181
|
+
api.setSelectedNodeIds(group.nodeIds, 'collective-group-trigger');
|
|
182
|
+
}
|
|
183
|
+
});
|
|
184
|
+
// Layer 1.5: Hit-test area for the border specifically
|
|
185
|
+
let borderHit = g.select("rect.border-hit");
|
|
186
|
+
if (borderHit.empty()) {
|
|
187
|
+
borderHit = g.append("rect").attr("class", "border-hit");
|
|
188
|
+
}
|
|
189
|
+
borderHit.attr("width", w + 10)
|
|
190
|
+
.attr("height", h + 10)
|
|
191
|
+
.attr("x", -5)
|
|
192
|
+
.attr("y", -5)
|
|
193
|
+
.attr("fill", "transparent")
|
|
194
|
+
.style("cursor", "move")
|
|
195
|
+
.on("mousedown", (event) => {
|
|
196
|
+
// Allow drag and node events to proceed by not stopping propagation
|
|
197
|
+
api.setSelectedNodeIds(group.nodeIds, 'collective-group-trigger');
|
|
198
|
+
});
|
|
199
|
+
// Layer 2: Dashed border
|
|
200
|
+
let border = g.select("rect.border-rect");
|
|
201
|
+
if (border.empty()) {
|
|
202
|
+
border = g.append("rect").attr("class", "border-rect");
|
|
203
|
+
}
|
|
204
|
+
border.attr("width", w)
|
|
205
|
+
.attr("height", h)
|
|
206
|
+
.attr("rx", 8)
|
|
207
|
+
.attr("fill", "none")
|
|
208
|
+
.attr("stroke", "var(--zenode-selection-color, #4A90E2)")
|
|
209
|
+
.attr("stroke-width", 2)
|
|
210
|
+
.attr("stroke-dasharray", isGroupActive ? "6 4" : "none")
|
|
211
|
+
.attr("opacity", isGroupActive ? 0.8 : 0.2)
|
|
212
|
+
.style("pointer-events", "none");
|
|
213
|
+
// Layer 3: Group Ports
|
|
214
|
+
g.selectAll(".group-port").remove();
|
|
215
|
+
if (isConnMode) {
|
|
216
|
+
const ports = api.getGroupPorts(group.id);
|
|
217
|
+
if (ports) {
|
|
218
|
+
Object.entries(ports).forEach(([portId, pos]) => {
|
|
219
|
+
const relX = pos.x - x;
|
|
220
|
+
const relY = pos.y - y;
|
|
221
|
+
const portCfg = api.config.canvasProperties.ports;
|
|
222
|
+
if (!portCfg)
|
|
223
|
+
return;
|
|
224
|
+
g.append("circle")
|
|
225
|
+
.attr("class", "port group-port")
|
|
226
|
+
.attr("cx", relX)
|
|
227
|
+
.attr("cy", relY)
|
|
228
|
+
.attr("r", portCfg.radius)
|
|
229
|
+
.attr("fill", portCfg.fillColor)
|
|
230
|
+
.attr("stroke", portCfg.strokeColor)
|
|
231
|
+
.attr("stroke-width", portCfg.strokeWidth)
|
|
232
|
+
.style("cursor", portCfg.cursor)
|
|
233
|
+
.style("pointer-events", "all")
|
|
234
|
+
.on("mousedown", (event) => {
|
|
235
|
+
event.stopPropagation();
|
|
236
|
+
event.preventDefault();
|
|
237
|
+
const startPoint = api.getCanvasPoint(event);
|
|
238
|
+
api.startConnectionDrag(group.id, portId, startPoint);
|
|
239
|
+
});
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
// Attach drag behavior
|
|
244
|
+
const dragBehavior = api.createDragBehavior();
|
|
245
|
+
g.call(dragBehavior);
|
|
246
|
+
});
|
|
247
|
+
// Only groups containing nodes in the active selectionStates should show ghosts
|
|
248
|
+
const activeOp = api.getActiveOperation();
|
|
249
|
+
const ghostCfg = api.config.canvasProperties.groupGhostPreview;
|
|
250
|
+
const ghostParent = (api.ghostsLayer || parent);
|
|
251
|
+
// Only groups containing nodes in the active selectionStates should show ghosts
|
|
252
|
+
const movingGroups = ((ghostCfg === null || ghostCfg === void 0 ? void 0 : ghostCfg.enabled) && activeOp && activeOp.type === 'drag')
|
|
253
|
+
? groups.filter(g => {
|
|
254
|
+
const selectionStates = activeOp.selectionStates;
|
|
255
|
+
// Show ghost if this group is being dragged, or ANY of its members are dragging
|
|
256
|
+
return (g.id === activeOp.nodeId) ||
|
|
257
|
+
(selectionStates && g.nodeIds.some(id => selectionStates.has(id)));
|
|
258
|
+
})
|
|
259
|
+
: [];
|
|
260
|
+
const ghosts = ghostParent.selectAll("g.visual-group-ghost")
|
|
261
|
+
.data(movingGroups, (d) => d.id);
|
|
262
|
+
ghosts.exit().remove();
|
|
263
|
+
const ghostEnter = ghosts.enter().append("g")
|
|
264
|
+
.attr("class", "visual-group-ghost")
|
|
265
|
+
.style("pointer-events", "none");
|
|
266
|
+
const ghostAll = ghostEnter.merge(ghosts);
|
|
267
|
+
ghostAll.each(function (group) {
|
|
268
|
+
const g = d3.select(this);
|
|
269
|
+
const oBounds = api.getGroupBounds(group.id, activeOp.selectionStates);
|
|
270
|
+
if (!oBounds) {
|
|
271
|
+
g.style("display", "none");
|
|
272
|
+
return;
|
|
273
|
+
}
|
|
274
|
+
g.style("display", "block");
|
|
275
|
+
const { x: oX, y: oY, width: oW, height: oH } = oBounds;
|
|
276
|
+
g.attr("transform", `translate(${oX}, ${oY})`);
|
|
277
|
+
let rect = g.select("rect");
|
|
278
|
+
if (rect.empty()) {
|
|
279
|
+
rect = g.append("rect");
|
|
280
|
+
}
|
|
281
|
+
rect.attr("width", oW)
|
|
282
|
+
.attr("height", oH)
|
|
283
|
+
.attr("rx", 8)
|
|
284
|
+
.attr("fill", ghostCfg.fillColor || "transparent")
|
|
285
|
+
.attr("stroke", ghostCfg.strokeColor || "#005bc4")
|
|
286
|
+
.attr("stroke-width", ghostCfg.strokeWidth || 1.5)
|
|
287
|
+
.attr("stroke-dasharray", (ghostCfg.strokeDashArray || [4, 4]).join(" "))
|
|
288
|
+
.attr("opacity", ghostCfg.opacity || 0.4);
|
|
289
|
+
});
|
|
290
|
+
}
|
|
291
|
+
function syncSelectionRings(placedNodesGroup, api, placedNodes) {
|
|
292
|
+
const selected = new Set(api.getSelectedNodeIds());
|
|
293
|
+
const selectionStroke = "var(--zenode-selection-color, #4A90E2)";
|
|
294
|
+
placedNodesGroup
|
|
295
|
+
.selectAll("g.node")
|
|
296
|
+
.each(function (nodeDatum) {
|
|
297
|
+
const group = d3.select(this);
|
|
298
|
+
const isSelected = selected.has(nodeDatum.id);
|
|
299
|
+
group.classed("selected", isSelected);
|
|
300
|
+
group.selectAll(".selection-ring").remove();
|
|
301
|
+
if (!isSelected)
|
|
302
|
+
return;
|
|
303
|
+
const style = getShapeStyle(nodeDatum, api.config);
|
|
304
|
+
if (!style)
|
|
305
|
+
return;
|
|
306
|
+
renderSelectionRing(group, nodeDatum, style, api.shapeRegistry, selectionStroke, 4);
|
|
307
|
+
renderResizeHandles(group, nodeDatum, style, api);
|
|
308
|
+
});
|
|
309
|
+
// Finally render ports for ALL nodes to ensure they are always on top
|
|
310
|
+
placedNodesGroup
|
|
311
|
+
.selectAll("g.node")
|
|
312
|
+
.each(function (d) {
|
|
313
|
+
const el = d3.select(this);
|
|
314
|
+
renderPorts(el, d, api.config, api.shapeRegistry, api);
|
|
315
|
+
});
|
|
316
|
+
// Guard for stale ids after node deletions.
|
|
317
|
+
const presentIds = new Set(placedNodes.map((n) => n.id));
|
|
318
|
+
const filtered = [...selected].filter((id) => presentIds.has(id));
|
|
319
|
+
if (filtered.length !== selected.size) {
|
|
320
|
+
api.setSelectedNodeIds(filtered);
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
|
|
324
|
+
export { renderPlacedNodes };
|
|
325
|
+
//# sourceMappingURL=placement.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"placement.js","sources":["../../src/nodes/placement.ts"],"sourcesContent":[null],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,196 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var overlay = require('./overlay.cjs');
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Renders connection ports for a node.
|
|
7
|
+
* @param nodeGroup - The D3 selection of the node's <g> element
|
|
8
|
+
* @param node - The node data
|
|
9
|
+
* @param config - The engine configuration
|
|
10
|
+
* @param registry - The shape registry to get the renderer
|
|
11
|
+
*/
|
|
12
|
+
function renderPorts(nodeGroup, node, config, registry, engine) {
|
|
13
|
+
const portConfig = config.canvasProperties.ports;
|
|
14
|
+
if (!portConfig || !portConfig.enabled) {
|
|
15
|
+
return;
|
|
16
|
+
}
|
|
17
|
+
const style = getShapeStyle(node, config);
|
|
18
|
+
if (!style) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
const renderer = registry.get(node.type);
|
|
22
|
+
const resolvedConfig = overlay.buildResolvedShapeConfig(node, style);
|
|
23
|
+
const ports = renderer.getPorts(resolvedConfig);
|
|
24
|
+
const bounds = renderer.getBounds(resolvedConfig);
|
|
25
|
+
// --- Connection Ports Logic ---
|
|
26
|
+
const portData = Object.entries(ports).map(([key, pos]) => ({
|
|
27
|
+
id: key,
|
|
28
|
+
x: pos.x,
|
|
29
|
+
y: pos.y,
|
|
30
|
+
}));
|
|
31
|
+
const portSelection = nodeGroup
|
|
32
|
+
.selectAll("circle.port")
|
|
33
|
+
.data(portData, (d) => d.id);
|
|
34
|
+
portSelection
|
|
35
|
+
.join((enter) => enter.append("circle").attr("class", "port"), (update) => update, (exit) => exit.remove())
|
|
36
|
+
.attr("cx", (d) => d.x)
|
|
37
|
+
.attr("cy", (d) => d.y)
|
|
38
|
+
.attr("r", portConfig.radius)
|
|
39
|
+
.attr("fill", portConfig.fillColor)
|
|
40
|
+
.attr("stroke", portConfig.strokeColor)
|
|
41
|
+
.attr("stroke-width", portConfig.strokeWidth)
|
|
42
|
+
.attr("opacity", () => {
|
|
43
|
+
if (!engine.connectionModeEnabled)
|
|
44
|
+
return 0;
|
|
45
|
+
return portConfig.showOnHoverOnly ? 0 : portConfig.opacity;
|
|
46
|
+
})
|
|
47
|
+
.style("pointer-events", () => engine.connectionModeEnabled ? "all" : "none")
|
|
48
|
+
.style("cursor", () => engine.connectionModeEnabled ? portConfig.cursor : "default")
|
|
49
|
+
.on("mousedown", function (event, d) {
|
|
50
|
+
if (!engine.connectionModeEnabled)
|
|
51
|
+
return;
|
|
52
|
+
event.stopPropagation();
|
|
53
|
+
event.preventDefault();
|
|
54
|
+
const startPoint = engine.getCanvasPoint(event);
|
|
55
|
+
engine.startConnectionDrag(node.id, d.id, startPoint);
|
|
56
|
+
});
|
|
57
|
+
// --- Rotation Handles Logic ---
|
|
58
|
+
const isSelected = engine.getSelectedNodeIds().includes(node.id);
|
|
59
|
+
const isRotationMode = engine.isRotationModeEnabled && engine.isRotationModeEnabled();
|
|
60
|
+
const handleOffset = 15;
|
|
61
|
+
const rotationHandleData = (isSelected && isRotationMode) ? [
|
|
62
|
+
{ id: "rotate-top", x: bounds.x + bounds.width / 2, y: bounds.y - handleOffset },
|
|
63
|
+
{ id: "rotate-right", x: bounds.x + bounds.width + handleOffset, y: bounds.y + bounds.height / 2 },
|
|
64
|
+
{ id: "rotate-bottom", x: bounds.x + bounds.width / 2, y: bounds.y + bounds.height + handleOffset },
|
|
65
|
+
{ id: "rotate-left", x: bounds.x - handleOffset, y: bounds.y + bounds.height / 2 },
|
|
66
|
+
] : [];
|
|
67
|
+
// Simple SVG curved arrow for rotation cursor
|
|
68
|
+
const rotateCursor = `url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M21 2v6h-6M3 12a9 9 0 0 1 15-6.7L21 8'/%3E%3C/svg%3E") 10 10, crosshair`;
|
|
69
|
+
const handleSelection = nodeGroup
|
|
70
|
+
.selectAll("circle.rotate-handle")
|
|
71
|
+
.data(rotationHandleData, (d) => d.id);
|
|
72
|
+
handleSelection
|
|
73
|
+
.join((enter) => enter.append("circle").attr("class", "rotate-handle"), (update) => update, (exit) => exit.remove())
|
|
74
|
+
.attr("cx", (d) => d.x)
|
|
75
|
+
.attr("cy", (d) => d.y)
|
|
76
|
+
.attr("r", 5)
|
|
77
|
+
.attr("fill", "#4A90E2")
|
|
78
|
+
.attr("stroke", "#ffffff")
|
|
79
|
+
.attr("stroke-width", 2)
|
|
80
|
+
.style("cursor", rotateCursor)
|
|
81
|
+
.on("mousedown", function (event) {
|
|
82
|
+
event.stopPropagation();
|
|
83
|
+
event.preventDefault();
|
|
84
|
+
const startPoint = engine.getCanvasPoint(event);
|
|
85
|
+
const startDx = startPoint.x - node.x;
|
|
86
|
+
const startDy = startPoint.y - node.y;
|
|
87
|
+
const startMouseAngle = Math.atan2(startDy, startDx) * (180 / Math.PI);
|
|
88
|
+
const startNodeRotation = node.rotation || 0;
|
|
89
|
+
const onMouseMove = (moveEvent) => {
|
|
90
|
+
const currentPoint = engine.getCanvasPoint(moveEvent);
|
|
91
|
+
const dx = currentPoint.x - node.x;
|
|
92
|
+
const dy = currentPoint.y - node.y;
|
|
93
|
+
const currentMouseAngle = Math.atan2(dy, dx) * (180 / Math.PI);
|
|
94
|
+
let deltaAngle = currentMouseAngle - startMouseAngle;
|
|
95
|
+
// Calculate new rotation and apply 15-degree snapping
|
|
96
|
+
let newRotation = startNodeRotation + deltaAngle;
|
|
97
|
+
newRotation = Math.round(newRotation / 15) * 15;
|
|
98
|
+
engine.rotateNode(node.id, newRotation, false);
|
|
99
|
+
};
|
|
100
|
+
const onMouseUp = () => {
|
|
101
|
+
engine.endOperation();
|
|
102
|
+
window.removeEventListener("mousemove", onMouseMove);
|
|
103
|
+
window.removeEventListener("mouseup", onMouseUp);
|
|
104
|
+
};
|
|
105
|
+
engine.beginOperation(node.id, 'rotate');
|
|
106
|
+
window.addEventListener("mousemove", onMouseMove);
|
|
107
|
+
window.addEventListener("mouseup", onMouseUp);
|
|
108
|
+
});
|
|
109
|
+
// --- Resize Handles Logic ---
|
|
110
|
+
const isResizeMode = engine.isResizeModeEnabled && engine.isResizeModeEnabled();
|
|
111
|
+
const resizeCursor = `url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M15 3h6v6M9 21H3v-6M21 3l-7 7M3 21l7-7'/%3E%3C/svg%3E") 10 10, nwse-resize`;
|
|
112
|
+
// 4 edge handles: N (top), S (bottom), E (right), W (left)
|
|
113
|
+
const resizeHandleOffset = 0;
|
|
114
|
+
const resizeHandleData = (isSelected && isResizeMode) ? [
|
|
115
|
+
{ id: "resize-n", x: bounds.x + bounds.width / 2, y: bounds.y + resizeHandleOffset, axis: "h" },
|
|
116
|
+
{ id: "resize-s", x: bounds.x + bounds.width / 2, y: bounds.y + bounds.height - resizeHandleOffset, axis: "h" },
|
|
117
|
+
{ id: "resize-e", x: bounds.x + bounds.width - resizeHandleOffset, y: bounds.y + bounds.height / 2, axis: "w" },
|
|
118
|
+
{ id: "resize-w", x: bounds.x + resizeHandleOffset, y: bounds.y + bounds.height / 2, axis: "w" },
|
|
119
|
+
] : [];
|
|
120
|
+
const resizeHandleSelection = nodeGroup
|
|
121
|
+
.selectAll("rect.resize-handle")
|
|
122
|
+
.data(resizeHandleData, (d) => d.id);
|
|
123
|
+
resizeHandleSelection
|
|
124
|
+
.join((enter) => enter.append("rect").attr("class", "resize-handle"), (update) => update, (exit) => exit.remove())
|
|
125
|
+
.attr("x", (d) => d.x - 5)
|
|
126
|
+
.attr("y", (d) => d.y - 5)
|
|
127
|
+
.attr("width", 10)
|
|
128
|
+
.attr("height", 10)
|
|
129
|
+
.attr("rx", 2)
|
|
130
|
+
.attr("fill", "#22C55E")
|
|
131
|
+
.attr("stroke", "#ffffff")
|
|
132
|
+
.attr("stroke-width", 2)
|
|
133
|
+
.style("cursor", resizeCursor)
|
|
134
|
+
.on("mousedown", function (event, d) {
|
|
135
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
|
|
136
|
+
event.stopPropagation();
|
|
137
|
+
event.preventDefault();
|
|
138
|
+
// Resolve current dimensions and base constraints
|
|
139
|
+
const style = getShapeStyle(node, config);
|
|
140
|
+
const baseW = (_d = (_c = (_b = (_a = node.baseDimensions) === null || _a === void 0 ? void 0 : _a.width) !== null && _b !== void 0 ? _b : node.width) !== null && _c !== void 0 ? _c : style === null || style === void 0 ? void 0 : style.width) !== null && _d !== void 0 ? _d : 100;
|
|
141
|
+
const baseH = (_h = (_g = (_f = (_e = node.baseDimensions) === null || _e === void 0 ? void 0 : _e.height) !== null && _f !== void 0 ? _f : node.height) !== null && _g !== void 0 ? _g : style === null || style === void 0 ? void 0 : style.height) !== null && _h !== void 0 ? _h : 100;
|
|
142
|
+
const baseR = (_m = (_l = (_k = (_j = node.baseDimensions) === null || _j === void 0 ? void 0 : _j.radius) !== null && _k !== void 0 ? _k : node.radius) !== null && _l !== void 0 ? _l : style === null || style === void 0 ? void 0 : style.radius) !== null && _m !== void 0 ? _m : 30;
|
|
143
|
+
const minW = baseW * 0.5, maxW = baseW * 2;
|
|
144
|
+
const minH = baseH * 0.5, maxH = baseH * 2;
|
|
145
|
+
const minR = baseR * 0.5, maxR = baseR * 2;
|
|
146
|
+
const startPoint = engine.getCanvasPoint(event);
|
|
147
|
+
const startW = (_o = node.width) !== null && _o !== void 0 ? _o : baseW;
|
|
148
|
+
const startH = (_p = node.height) !== null && _p !== void 0 ? _p : baseH;
|
|
149
|
+
const startR = (_q = node.radius) !== null && _q !== void 0 ? _q : baseR;
|
|
150
|
+
const onMouseMove = (moveEvent) => {
|
|
151
|
+
const currentPoint = engine.getCanvasPoint(moveEvent);
|
|
152
|
+
const dx = currentPoint.x - startPoint.x;
|
|
153
|
+
const dy = currentPoint.y - startPoint.y;
|
|
154
|
+
if (node.type === "circle") {
|
|
155
|
+
const delta = d.axis === "w" ? dx : dy;
|
|
156
|
+
const newR = Math.max(minR, Math.min(maxR, startR + delta));
|
|
157
|
+
engine.updateNodeDimensions(node.id, { radius: newR }, false);
|
|
158
|
+
}
|
|
159
|
+
else if (d.axis === "w") {
|
|
160
|
+
const dir = d.id === "resize-e" ? 1 : -1;
|
|
161
|
+
const newW = Math.max(minW, Math.min(maxW, startW + dir * dx * 2));
|
|
162
|
+
engine.updateNodeDimensions(node.id, { width: newW }, false);
|
|
163
|
+
}
|
|
164
|
+
else {
|
|
165
|
+
const dir = d.id === "resize-s" ? 1 : -1;
|
|
166
|
+
const newH = Math.max(minH, Math.min(maxH, startH + dir * dy * 2));
|
|
167
|
+
engine.updateNodeDimensions(node.id, { height: newH }, false);
|
|
168
|
+
}
|
|
169
|
+
};
|
|
170
|
+
const onMouseUp = () => {
|
|
171
|
+
engine.endOperation();
|
|
172
|
+
window.removeEventListener("mousemove", onMouseMove);
|
|
173
|
+
window.removeEventListener("mouseup", onMouseUp);
|
|
174
|
+
};
|
|
175
|
+
engine.beginOperation(node.id, 'resize');
|
|
176
|
+
window.addEventListener("mousemove", onMouseMove);
|
|
177
|
+
window.addEventListener("mouseup", onMouseUp);
|
|
178
|
+
});
|
|
179
|
+
// Bring all handles to front
|
|
180
|
+
nodeGroup.selectAll("circle.port, circle.rotate-handle, rect.resize-handle").each(function () {
|
|
181
|
+
const el = this;
|
|
182
|
+
if (el.parentNode) {
|
|
183
|
+
el.parentNode.appendChild(el);
|
|
184
|
+
}
|
|
185
|
+
});
|
|
186
|
+
}
|
|
187
|
+
function getShapeStyle(node, config) {
|
|
188
|
+
var _a;
|
|
189
|
+
const list = (_a = config.shapes.default) === null || _a === void 0 ? void 0 : _a[node.type];
|
|
190
|
+
if (!Array.isArray(list))
|
|
191
|
+
return undefined;
|
|
192
|
+
return list.find((s) => s.id === node.shapeVariantId);
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
exports.renderPorts = renderPorts;
|
|
196
|
+
//# sourceMappingURL=ports.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ports.cjs","sources":["../../src/nodes/ports.ts"],"sourcesContent":[null],"names":["buildResolvedShapeConfig"],"mappings":";;;;AAMA;;;;;;AAMG;AACG,SAAU,WAAW,CACzB,SAA0D,EAC1D,IAAgB,EAChB,MAAc,EACd,QAAuB,EACvB,MAAW,EAAA;AAEX,IAAA,MAAM,UAAU,GAAG,MAAM,CAAC,gBAAgB,CAAC,KAAK;IAChD,IAAI,CAAC,UAAU,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE;QACtC;;IAGF,MAAM,KAAK,GAAG,aAAa,CAAC,IAAI,EAAE,MAAM,CAAC;IACzC,IAAI,CAAC,KAAK,EAAE;QACV;;IAGF,MAAM,QAAQ,GAAG,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;IACxC,MAAM,cAAc,GAAGA,gCAAwB,CAAC,IAAI,EAAE,KAAK,CAAC;IAC5D,MAAM,KAAK,GAAG,QAAQ,CAAC,QAAQ,CAAC,cAAc,CAAC;IAC/C,MAAM,MAAM,GAAG,QAAQ,CAAC,SAAS,CAAC,cAAc,CAAC;;IAGjD,MAAM,QAAQ,GAAI,MAAM,CAAC,OAAO,CAAC,KAAK,CAA0C,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,MAAM;AACpG,QAAA,EAAE,EAAE,GAAG;QACP,CAAC,EAAE,GAAG,CAAC,CAAC;QACR,CAAC,EAAE,GAAG,CAAC,CAAC;AACT,KAAA,CAAC,CAAC;IAEH,MAAM,aAAa,GAAG;SACnB,SAAS,CAAyD,aAAa;AAC/E,SAAA,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;IAE9B;AACG,SAAA,IAAI,CACH,CAAC,KAAK,KAAK,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,EACvD,CAAC,MAAM,KAAK,MAAM,EAClB,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,EAAE;SAExB,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;SACrB,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;AACrB,SAAA,IAAI,CAAC,GAAG,EAAE,UAAU,CAAC,MAAM;AAC3B,SAAA,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,SAAS;AACjC,SAAA,IAAI,CAAC,QAAQ,EAAE,UAAU,CAAC,WAAW;AACrC,SAAA,IAAI,CAAC,cAAc,EAAE,UAAU,CAAC,WAAW;AAC3C,SAAA,IAAI,CAAC,SAAS,EAAE,MAAK;QAClB,IAAI,CAAC,MAAM,CAAC,qBAAqB;AAAE,YAAA,OAAO,CAAC;AAC3C,QAAA,OAAO,UAAU,CAAC,eAAe,GAAG,CAAC,GAAG,UAAU,CAAC,OAAO;AAC9D,KAAC;AACA,SAAA,KAAK,CAAC,gBAAgB,EAAE,MAAM,MAAM,CAAC,qBAAqB,GAAG,KAAK,GAAG,MAAM;AAC3E,SAAA,KAAK,CAAC,QAAQ,EAAE,MAAM,MAAM,CAAC,qBAAqB,GAAG,UAAU,CAAC,MAAM,GAAG,SAAS;AAClF,SAAA,EAAE,CAAC,WAAW,EAAE,UAAS,KAAiB,EAAE,CAAC,EAAA;QAC1C,IAAI,CAAC,MAAM,CAAC,qBAAqB;YAAE;QACnC,KAAK,CAAC,eAAe,EAAE;QACvB,KAAK,CAAC,cAAc,EAAE;QAEtB,MAAM,UAAU,GAAG,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC;AAC/C,QAAA,MAAM,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,UAAU,CAAC;AACzD,KAAC,CAAC;;AAGJ,IAAA,MAAM,UAAU,GAAG,MAAM,CAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC;IAChE,MAAM,cAAc,GAAG,MAAM,CAAC,qBAAqB,IAAI,MAAM,CAAC,qBAAqB,EAAE;IACrF,MAAM,YAAY,GAAG,EAAE;IACvB,MAAM,kBAAkB,GAAG,CAAC,UAAU,IAAI,cAAc,IAAI;QAC1D,EAAE,EAAE,EAAE,YAAY,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,YAAY,EAAE;QAChF,EAAE,EAAE,EAAE,cAAc,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,KAAK,GAAG,YAAY,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;QAClG,EAAE,EAAE,EAAE,eAAe,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,GAAG,YAAY,EAAE;QACnG,EAAE,EAAE,EAAE,aAAa,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,YAAY,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE;KACnF,GAAG,EAAE;;IAGN,MAAM,YAAY,GAAG,CAAA,4RAAA,CAA8R;IAEnT,MAAM,eAAe,GAAG;SACrB,SAAS,CAAyD,sBAAsB;AACxF,SAAA,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;IAExC;AACG,SAAA,IAAI,CACH,CAAC,KAAK,KAAK,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,eAAe,CAAC,EAChE,CAAC,MAAM,KAAK,MAAM,EAClB,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,EAAE;SAExB,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;SACrB,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;AACrB,SAAA,IAAI,CAAC,GAAG,EAAE,CAAC;AACX,SAAA,IAAI,CAAC,MAAM,EAAE,SAAS;AACtB,SAAA,IAAI,CAAC,QAAQ,EAAE,SAAS;AACxB,SAAA,IAAI,CAAC,cAAc,EAAE,CAAC;AACtB,SAAA,KAAK,CAAC,QAAQ,EAAE,YAAY;AAC5B,SAAA,EAAE,CAAC,WAAW,EAAE,UAAS,KAAiB,EAAA;QACvC,KAAK,CAAC,eAAe,EAAE;QACvB,KAAK,CAAC,cAAc,EAAE;QAEtB,MAAM,UAAU,GAAG,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC;QAC/C,MAAM,OAAO,GAAG,UAAU,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;QACrC,MAAM,OAAO,GAAG,UAAU,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;AACrC,QAAA,MAAM,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,CAAC,IAAI,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC;AACtE,QAAA,MAAM,iBAAiB,GAAG,IAAI,CAAC,QAAQ,IAAI,CAAC;AAE5C,QAAA,MAAM,WAAW,GAAG,CAAC,SAAqB,KAAI;YAC1C,MAAM,YAAY,GAAG,MAAM,CAAC,cAAc,CAAC,SAAS,CAAC;YACrD,MAAM,EAAE,GAAG,YAAY,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;YAClC,MAAM,EAAE,GAAG,YAAY,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;AAElC,YAAA,MAAM,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,IAAI,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC;AAC9D,YAAA,IAAI,UAAU,GAAG,iBAAiB,GAAG,eAAe;;AAGpD,YAAA,IAAI,WAAW,GAAG,iBAAiB,GAAG,UAAU;YAChD,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,WAAW,GAAG,EAAE,CAAC,GAAG,EAAE;YAE/C,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,EAAE,WAAW,EAAE,KAAK,CAAC;AAClD,SAAC;QAED,MAAM,SAAS,GAAG,MAAK;YACnB,MAAM,CAAC,YAAY,EAAE;AACrB,YAAA,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,WAAW,CAAC;AACpD,YAAA,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,SAAS,CAAC;AACpD,SAAC;QAED,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,EAAE,QAAQ,CAAC;AACxC,QAAA,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,WAAW,CAAC;AACjD,QAAA,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,SAAS,CAAC;AACjD,KAAC,CAAC;;IAGJ,MAAM,YAAY,GAAG,MAAM,CAAC,mBAAmB,IAAI,MAAM,CAAC,mBAAmB,EAAE;IAC/E,MAAM,YAAY,GAAG,CAAA,+RAAA,CAAiS;;IAGtT,MAAM,kBAAkB,GAAG,CAAC;IAC5B,MAAM,gBAAgB,GAAG,CAAC,UAAU,IAAI,YAAY,IAAI;QACtD,EAAE,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,kBAAkB,EAAE,IAAI,EAAE,GAAG,EAAE;AAC/F,QAAA,EAAE,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,GAAG,kBAAkB,EAAE,IAAI,EAAE,GAAG,EAAE;AAC/G,QAAA,EAAE,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,KAAK,GAAG,kBAAkB,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE;QAC/G,EAAE,EAAE,EAAE,UAAU,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,kBAAkB,EAAE,CAAC,EAAE,MAAM,CAAC,CAAC,GAAG,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,IAAI,EAAE,GAAG,EAAE;KACjG,GAAG,EAAE;IAEN,MAAM,qBAAqB,GAAG;SAC3B,SAAS,CAAqE,oBAAoB;AAClG,SAAA,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;IAEtC;AACG,SAAA,IAAI,CACH,CAAC,KAAK,KAAK,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,eAAe,CAAC,EAC9D,CAAC,MAAM,KAAK,MAAM,EAClB,CAAC,IAAI,KAAK,IAAI,CAAC,MAAM,EAAE;AAExB,SAAA,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC;AACxB,SAAA,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC;AACxB,SAAA,IAAI,CAAC,OAAO,EAAE,EAAE;AAChB,SAAA,IAAI,CAAC,QAAQ,EAAE,EAAE;AACjB,SAAA,IAAI,CAAC,IAAI,EAAE,CAAC;AACZ,SAAA,IAAI,CAAC,MAAM,EAAE,SAAS;AACtB,SAAA,IAAI,CAAC,QAAQ,EAAE,SAAS;AACxB,SAAA,IAAI,CAAC,cAAc,EAAE,CAAC;AACtB,SAAA,KAAK,CAAC,QAAQ,EAAE,YAAY;AAC5B,SAAA,EAAE,CAAC,WAAW,EAAE,UAAS,KAAiB,EAAE,CAAC,EAAA;;QAC1C,KAAK,CAAC,eAAe,EAAE;QACvB,KAAK,CAAC,cAAc,EAAE;;QAGtB,MAAM,KAAK,GAAG,aAAa,CAAC,IAAI,EAAE,MAAM,CAAC;QACzC,MAAM,KAAK,GAAG,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,MAAA,IAAI,CAAC,cAAc,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,KAAK,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAI,IAAI,CAAC,KAAK,MAAI,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAA,KAAK,KAAL,IAAA,IAAA,KAAK,KAAL,MAAA,GAAA,MAAA,GAAA,KAAK,CAAE,KAAK,MAAI,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAA,GAAG;QAC7E,MAAM,KAAK,GAAG,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,MAAA,IAAI,CAAC,cAAc,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,MAAM,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAI,IAAI,CAAC,MAAM,MAAI,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAA,KAAK,KAAL,IAAA,IAAA,KAAK,KAAL,MAAA,GAAA,MAAA,GAAA,KAAK,CAAE,MAAM,MAAI,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAA,GAAG;QAChF,MAAM,KAAK,GAAG,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,CAAA,EAAA,GAAA,MAAA,IAAI,CAAC,cAAc,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAE,MAAM,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAI,IAAI,CAAC,MAAM,MAAI,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAA,KAAK,KAAL,IAAA,IAAA,KAAK,KAAL,MAAA,GAAA,MAAA,GAAA,KAAK,CAAE,MAAM,MAAI,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAA,EAAE;QAC/E,MAAM,IAAI,GAAG,KAAK,GAAG,GAAG,EAAE,IAAI,GAAG,KAAK,GAAG,CAAC;QAC1C,MAAM,IAAI,GAAG,KAAK,GAAG,GAAG,EAAE,IAAI,GAAG,KAAK,GAAG,CAAC;QAC1C,MAAM,IAAI,GAAG,KAAK,GAAG,GAAG,EAAE,IAAI,GAAG,KAAK,GAAG,CAAC;QAE1C,MAAM,UAAU,GAAG,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC;QAC/C,MAAM,MAAM,GAAG,CAAA,EAAA,GAAA,IAAI,CAAC,KAAK,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAI,KAAK;QAClC,MAAM,MAAM,GAAG,CAAA,EAAA,GAAA,IAAI,CAAC,MAAM,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAI,KAAK;QACnC,MAAM,MAAM,GAAG,CAAA,EAAA,GAAA,IAAI,CAAC,MAAM,MAAA,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,EAAA,GAAI,KAAK;AAEnC,QAAA,MAAM,WAAW,GAAG,CAAC,SAAqB,KAAI;YAC1C,MAAM,YAAY,GAAG,MAAM,CAAC,cAAc,CAAC,SAAS,CAAC;YACrD,MAAM,EAAE,GAAG,YAAY,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC;YACxC,MAAM,EAAE,GAAG,YAAY,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC;AAExC,YAAA,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,EAAE;AACxB,gBAAA,MAAM,KAAK,GAAG,CAAC,CAAC,IAAI,KAAK,GAAG,GAAG,EAAE,GAAG,EAAE;AACtC,gBAAA,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,KAAK,CAAC,CAAC;AAC3D,gBAAA,MAAM,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,KAAK,CAAC;;AAC1D,iBAAA,IAAI,CAAC,CAAC,IAAI,KAAK,GAAG,EAAE;AACvB,gBAAA,MAAM,GAAG,GAAG,CAAC,CAAC,EAAE,KAAK,UAAU,GAAG,CAAC,GAAG,EAAE;gBACxC,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,GAAG,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAClE,gBAAA,MAAM,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE,KAAK,CAAC;;iBACzD;AACH,gBAAA,MAAM,GAAG,GAAG,CAAC,CAAC,EAAE,KAAK,UAAU,GAAG,CAAC,GAAG,EAAE;gBACxC,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,GAAG,GAAG,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;AAClE,gBAAA,MAAM,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,KAAK,CAAC;;AAErE,SAAC;QAED,MAAM,SAAS,GAAG,MAAK;YACnB,MAAM,CAAC,YAAY,EAAE;AACrB,YAAA,MAAM,CAAC,mBAAmB,CAAC,WAAW,EAAE,WAAW,CAAC;AACpD,YAAA,MAAM,CAAC,mBAAmB,CAAC,SAAS,EAAE,SAAS,CAAC;AACpD,SAAC;QAED,MAAM,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,EAAE,QAAQ,CAAC;AACxC,QAAA,MAAM,CAAC,gBAAgB,CAAC,WAAW,EAAE,WAAW,CAAC;AACjD,QAAA,MAAM,CAAC,gBAAgB,CAAC,SAAS,EAAE,SAAS,CAAC;AACjD,KAAC,CAAC;;AAGJ,IAAA,SAAS,CAAC,SAAS,CAAkB,uDAAuD,CAAC,CAAC,IAAI,CAAC,YAAA;QACjG,MAAM,EAAE,GAAG,IAAkB;AAC7B,QAAA,IAAI,EAAE,CAAC,UAAU,EAAE;AACjB,YAAA,EAAE,CAAC,UAAU,CAAC,WAAW,CAAC,EAAE,CAAC;;AAEjC,KAAC,CAAC;AACJ;AAEA,SAAS,aAAa,CAAC,IAAgB,EAAE,MAAc,EAAA;;AACrD,IAAA,MAAM,IAAI,GAAG,CAAA,EAAA,GAAA,MAAM,CAAC,MAAM,CAAC,OAAO,MAAG,IAAA,IAAA,EAAA,KAAA,MAAA,GAAA,MAAA,GAAA,EAAA,CAAA,IAAI,CAAC,IAA0C,CAAC;AACrF,IAAA,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;AAAE,QAAA,OAAO,SAAS;AAC1C,IAAA,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAQ,KAAK,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,cAAc,CAAC;AAC9D;;;;"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import * as d3 from "d3";
|
|
2
|
+
import { PlacedNode } from "../model/interface.js";
|
|
3
|
+
import { Config } from "../model/configurationModel.js";
|
|
4
|
+
import { ShapeRegistry } from "./registry.js";
|
|
5
|
+
/**
|
|
6
|
+
* Renders connection ports for a node.
|
|
7
|
+
* @param nodeGroup - The D3 selection of the node's <g> element
|
|
8
|
+
* @param node - The node data
|
|
9
|
+
* @param config - The engine configuration
|
|
10
|
+
* @param registry - The shape registry to get the renderer
|
|
11
|
+
*/
|
|
12
|
+
export declare function renderPorts(nodeGroup: d3.Selection<SVGGElement, PlacedNode, any, any>, node: PlacedNode, config: Config, registry: ShapeRegistry, engine: any): void;
|