@nuraly/lumenui 0.2.1 → 0.3.2
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/dist/cdn.js +1 -0
- package/dist/nuralyui.bundle.js +3434 -2085
- package/dist/nuralyui.bundle.js.gz +0 -0
- package/dist/src/components/button/controllers/base.controller.d.ts +15 -0
- package/dist/src/components/button/controllers/base.controller.js +13 -0
- package/dist/src/components/button/controllers/index.d.ts +10 -0
- package/dist/src/components/button/controllers/index.js +10 -0
- package/dist/src/components/button/controllers/keyboard.controller.d.ts +32 -0
- package/dist/src/components/button/controllers/keyboard.controller.js +78 -0
- package/dist/src/components/button/controllers/link.controller.d.ts +30 -0
- package/dist/src/components/button/controllers/link.controller.js +75 -0
- package/dist/src/components/button/controllers/ripple.controller.d.ts +23 -0
- package/dist/src/components/button/controllers/ripple.controller.js +69 -0
- package/dist/src/components/button/interfaces/base-controller.interface.d.ts +61 -0
- package/dist/src/components/button/interfaces/base-controller.interface.js +7 -0
- package/dist/src/components/button/interfaces/index.d.ts +2 -0
- package/dist/src/components/button/interfaces/index.js +2 -0
- package/dist/src/components/button/test/nr-button_test.d.ts +2 -0
- package/dist/src/components/button/test/nr-button_test.js +91 -0
- package/dist/src/components/canvas/base-canvas.component.d.ts +2 -1
- package/dist/src/components/canvas/base-canvas.component.js +6 -0
- package/dist/src/components/canvas/bundle.js +1083 -491
- package/dist/src/components/canvas/bundle.js.gz +0 -0
- package/dist/src/components/canvas/canvas.constants.d.ts +1 -1
- package/dist/src/components/canvas/canvas.constants.js +1 -1
- package/dist/src/components/canvas/chatbot-panel.style.js +50 -59
- package/dist/src/components/canvas/chatbot-trigger/chatbot-trigger-fields.component.d.ts +115 -0
- package/dist/src/components/canvas/chatbot-trigger/chatbot-trigger-fields.component.js +480 -0
- package/dist/src/components/canvas/chatbot-trigger/chatbot-trigger-fields.style.d.ts +7 -0
- package/dist/src/components/canvas/chatbot-trigger/chatbot-trigger-fields.style.js +323 -0
- package/dist/src/components/canvas/chatbot-trigger/chatbot-trigger.types.d.ts +162 -0
- package/dist/src/components/canvas/chatbot-trigger/chatbot-trigger.types.js +88 -0
- package/dist/src/components/canvas/chatbot-trigger/index.d.ts +9 -0
- package/dist/src/components/canvas/chatbot-trigger/index.js +12 -0
- package/dist/src/components/canvas/controllers/base.controller.d.ts +53 -0
- package/dist/src/components/canvas/controllers/base.controller.js +80 -0
- package/dist/src/components/canvas/controllers/clipboard.controller.d.ts +80 -0
- package/dist/src/components/canvas/controllers/clipboard.controller.js +300 -0
- package/dist/src/components/canvas/controllers/collaboration.controller.d.ts +54 -0
- package/dist/src/components/canvas/controllers/collaboration.controller.js +425 -0
- package/dist/src/components/canvas/controllers/config.controller.d.ts +61 -0
- package/dist/src/components/canvas/controllers/config.controller.js +118 -0
- package/dist/src/components/canvas/controllers/connection.controller.d.ts +69 -0
- package/dist/src/components/canvas/controllers/connection.controller.js +183 -0
- package/dist/src/components/canvas/controllers/drag.controller.d.ts +56 -0
- package/dist/src/components/canvas/controllers/drag.controller.js +195 -0
- package/dist/src/components/canvas/controllers/frame.controller.d.ts +94 -0
- package/dist/src/components/canvas/controllers/frame.controller.js +456 -0
- package/dist/src/components/canvas/controllers/index.d.ts +19 -0
- package/dist/src/components/canvas/controllers/index.js +32 -0
- package/dist/src/components/canvas/controllers/keyboard.controller.d.ts +44 -0
- package/dist/src/components/canvas/controllers/keyboard.controller.js +275 -0
- package/dist/src/components/canvas/controllers/marquee.controller.d.ts +71 -0
- package/dist/src/components/canvas/controllers/marquee.controller.js +128 -0
- package/dist/src/components/canvas/controllers/selection.controller.d.ts +85 -0
- package/dist/src/components/canvas/controllers/selection.controller.js +202 -0
- package/dist/src/components/canvas/controllers/touch.controller.d.ts +55 -0
- package/dist/src/components/canvas/controllers/touch.controller.js +299 -0
- package/dist/src/components/canvas/controllers/undo.controller.d.ts +100 -0
- package/dist/src/components/canvas/controllers/undo.controller.js +218 -0
- package/dist/src/components/canvas/controllers/viewport.controller.d.ts +91 -0
- package/dist/src/components/canvas/controllers/viewport.controller.js +287 -0
- package/dist/src/components/canvas/data-node/data-node-config.component.d.ts +67 -0
- package/dist/src/components/canvas/data-node/data-node-config.component.js +496 -0
- package/dist/src/components/canvas/data-node/data-node-fields.component.d.ts +198 -0
- package/dist/src/components/canvas/data-node/data-node-fields.component.js +931 -0
- package/dist/src/components/canvas/data-node/data-node-fields.style.d.ts +7 -0
- package/dist/src/components/canvas/data-node/data-node-fields.style.js +448 -0
- package/dist/src/components/canvas/data-node/data-node.types.d.ts +245 -0
- package/dist/src/components/canvas/data-node/data-node.types.js +158 -0
- package/dist/src/components/canvas/data-node/index.d.ts +9 -0
- package/dist/src/components/canvas/data-node/index.js +12 -0
- package/dist/src/components/canvas/data-node/schema-select.component.d.ts +36 -0
- package/dist/src/components/canvas/data-node/schema-select.component.js +196 -0
- package/dist/src/components/canvas/data-node/table-select.component.d.ts +38 -0
- package/dist/src/components/canvas/data-node/table-select.component.js +199 -0
- package/dist/src/components/canvas/interfaces/canvas-host.interface.d.ts +91 -0
- package/dist/src/components/canvas/interfaces/canvas-host.interface.js +7 -0
- package/dist/src/components/canvas/interfaces/collaboration.interface.d.ts +58 -0
- package/dist/src/components/canvas/interfaces/collaboration.interface.js +10 -0
- package/dist/src/components/canvas/interfaces/index.d.ts +8 -0
- package/dist/src/components/canvas/interfaces/index.js +7 -0
- package/dist/src/components/canvas/templates/chatbot-panel.template.d.ts +28 -0
- package/dist/src/components/canvas/templates/chatbot-panel.template.js +49 -0
- package/dist/src/components/canvas/templates/config-panel.template.d.ts +22 -0
- package/dist/src/components/canvas/templates/config-panel.template.js +22 -0
- package/dist/src/components/canvas/templates/context-menu.template.d.ts +30 -0
- package/dist/src/components/canvas/templates/context-menu.template.js +80 -0
- package/dist/src/components/canvas/templates/edges.template.d.ts +41 -0
- package/dist/src/components/canvas/templates/edges.template.js +243 -0
- package/dist/src/components/canvas/templates/empty-state.template.d.ts +17 -0
- package/dist/src/components/canvas/templates/empty-state.template.js +25 -0
- package/dist/src/components/canvas/templates/frame.template.d.ts +24 -0
- package/dist/src/components/canvas/templates/frame.template.js +74 -0
- package/dist/src/components/canvas/templates/index.d.ts +18 -0
- package/dist/src/components/canvas/templates/index.js +30 -0
- package/dist/src/components/canvas/templates/palette.template.d.ts +27 -0
- package/dist/src/components/canvas/templates/palette.template.js +110 -0
- package/dist/src/components/canvas/templates/presence-bar.template.d.ts +18 -0
- package/dist/src/components/canvas/templates/presence-bar.template.js +60 -0
- package/dist/src/components/canvas/templates/remote-cursors.template.d.ts +19 -0
- package/dist/src/components/canvas/templates/remote-cursors.template.js +43 -0
- package/dist/src/components/canvas/templates/toolbar.template.d.ts +52 -0
- package/dist/src/components/canvas/templates/toolbar.template.js +118 -0
- package/dist/src/components/canvas/templates/wb-floating-toolbar.template.d.ts +30 -0
- package/dist/src/components/canvas/templates/wb-floating-toolbar.template.js +219 -0
- package/dist/src/components/canvas/templates/wb-sidebar.template.d.ts +23 -0
- package/dist/src/components/canvas/templates/wb-sidebar.template.js +152 -0
- package/dist/src/components/canvas/utils/variable-resolver.d.ts +71 -0
- package/dist/src/components/canvas/utils/variable-resolver.js +280 -0
- package/dist/src/components/canvas/workflow-canvas.component.d.ts +7 -0
- package/dist/src/components/canvas/workflow-canvas.component.js +52 -2
- package/dist/src/components/canvas/workflow-canvas.style.js +46 -55
- package/dist/src/components/canvas/workflow-canvas.types.d.ts +8 -1
- package/dist/src/components/canvas/workflow-canvas.types.js +157 -0
- package/dist/src/components/carousel/demo/carousel-demo.d.ts +6 -0
- package/dist/src/components/carousel/demo/carousel-demo.js +68 -0
- package/dist/src/components/chat-panel/bundle.js +216 -0
- package/dist/src/components/chat-panel/bundle.js.gz +0 -0
- package/dist/src/components/chat-panel/chat-panel.component.d.ts +85 -0
- package/dist/src/components/chat-panel/chat-panel.component.js +510 -0
- package/dist/src/components/chat-panel/chat-panel.style.d.ts +2 -0
- package/dist/src/components/chat-panel/chat-panel.style.js +127 -0
- package/dist/src/components/chat-panel/chat-panel.types.d.ts +54 -0
- package/dist/src/components/chat-panel/chat-panel.types.js +2 -0
- package/dist/src/components/chat-panel/index.d.ts +3 -0
- package/dist/src/components/chat-panel/index.js +2 -0
- package/dist/src/components/chatbot/audio-compress.d.ts +26 -0
- package/dist/src/components/chatbot/audio-compress.js +84 -0
- package/dist/src/components/chatbot/bundle.js +388 -144
- package/dist/src/components/chatbot/bundle.js.gz +0 -0
- package/dist/src/components/chatbot/chatbot-audio.controller.d.ts +35 -0
- package/dist/src/components/chatbot/chatbot-audio.controller.js +160 -0
- package/dist/src/components/chatbot/chatbot.component.d.ts +12 -0
- package/dist/src/components/chatbot/chatbot.component.js +41 -2
- package/dist/src/components/chatbot/chatbot.style.js +141 -0
- package/dist/src/components/chatbot/chatbot.types.d.ts +8 -0
- package/dist/src/components/chatbot/controllers/index.d.ts +8 -0
- package/dist/src/components/chatbot/controllers/index.js +8 -0
- package/dist/src/components/chatbot/controllers/scroll.controller.d.ts +34 -0
- package/dist/src/components/chatbot/controllers/scroll.controller.js +43 -0
- package/dist/src/components/chatbot/core/chatbot-core.controller.d.ts +283 -0
- package/dist/src/components/chatbot/core/chatbot-core.controller.js +824 -0
- package/dist/src/components/chatbot/core/event-bus.d.ts +54 -0
- package/dist/src/components/chatbot/core/event-bus.js +102 -0
- package/dist/src/components/chatbot/core/index.d.ts +12 -0
- package/dist/src/components/chatbot/core/index.js +15 -0
- package/dist/src/components/chatbot/core/types.d.ts +403 -0
- package/dist/src/components/chatbot/core/types.js +16 -0
- package/dist/src/components/chatbot/locales/locale-codes.d.ts +14 -0
- package/dist/src/components/chatbot/locales/locale-codes.js +23 -0
- package/dist/src/components/chatbot/plugins/analytics-plugin.d.ts +23 -0
- package/dist/src/components/chatbot/plugins/analytics-plugin.js +52 -0
- package/dist/src/components/chatbot/plugins/artifact-plugin.d.ts +71 -0
- package/dist/src/components/chatbot/plugins/artifact-plugin.js +313 -0
- package/dist/src/components/chatbot/plugins/chat-plugin.d.ts +44 -0
- package/dist/src/components/chatbot/plugins/chat-plugin.js +58 -0
- package/dist/src/components/chatbot/plugins/flight-card-plugin.d.ts +116 -0
- package/dist/src/components/chatbot/plugins/flight-card-plugin.js +594 -0
- package/dist/src/components/chatbot/plugins/flow-diagram-plugin.d.ts +23 -0
- package/dist/src/components/chatbot/plugins/flow-diagram-plugin.js +495 -0
- package/dist/src/components/chatbot/plugins/index.d.ts +16 -0
- package/dist/src/components/chatbot/plugins/index.js +17 -0
- package/dist/src/components/chatbot/plugins/json-graph-renderer-plugin.d.ts +43 -0
- package/dist/src/components/chatbot/plugins/json-graph-renderer-plugin.js +166 -0
- package/dist/src/components/chatbot/plugins/markdown-plugin.d.ts +26 -0
- package/dist/src/components/chatbot/plugins/markdown-plugin.js +68 -0
- package/dist/src/components/chatbot/plugins/persistence-plugin.d.ts +30 -0
- package/dist/src/components/chatbot/plugins/persistence-plugin.js +91 -0
- package/dist/src/components/chatbot/plugins/print-job-card-plugin.d.ts +110 -0
- package/dist/src/components/chatbot/plugins/print-job-card-plugin.js +505 -0
- package/dist/src/components/chatbot/plugins/selection-card-plugin.d.ts +111 -0
- package/dist/src/components/chatbot/plugins/selection-card-plugin.js +318 -0
- package/dist/src/components/chatbot/providers/custom-api-provider.d.ts +63 -0
- package/dist/src/components/chatbot/providers/custom-api-provider.js +240 -0
- package/dist/src/components/chatbot/providers/index.d.ts +16 -0
- package/dist/src/components/chatbot/providers/index.js +13 -0
- package/dist/src/components/chatbot/providers/mock-provider.d.ts +154 -0
- package/dist/src/components/chatbot/providers/mock-provider.js +411 -0
- package/dist/src/components/chatbot/providers/native-ws-provider.d.ts +184 -0
- package/dist/src/components/chatbot/providers/native-ws-provider.js +544 -0
- package/dist/src/components/chatbot/providers/openai-provider.d.ts +32 -0
- package/dist/src/components/chatbot/providers/openai-provider.js +246 -0
- package/dist/src/components/chatbot/providers/socket-provider.d.ts +159 -0
- package/dist/src/components/chatbot/providers/socket-provider.js +390 -0
- package/dist/src/components/chatbot/providers/workflow-socket-provider.d.ts +116 -0
- package/dist/src/components/chatbot/providers/workflow-socket-provider.js +484 -0
- package/dist/src/components/chatbot/storage/index.d.ts +7 -0
- package/dist/src/components/chatbot/storage/index.js +8 -0
- package/dist/src/components/chatbot/storage/storage-implementations.d.ts +43 -0
- package/dist/src/components/chatbot/storage/storage-implementations.js +179 -0
- package/dist/src/components/chatbot/templates/artifact-panel.template.d.ts +22 -0
- package/dist/src/components/chatbot/templates/artifact-panel.template.js +81 -0
- package/dist/src/components/chatbot/templates/chatbot-main.template.d.ts +49 -0
- package/dist/src/components/chatbot/templates/chatbot-main.template.js +115 -0
- package/dist/src/components/chatbot/templates/file-preview-modal.template.d.ts +19 -0
- package/dist/src/components/chatbot/templates/file-preview-modal.template.js +74 -0
- package/dist/src/components/chatbot/templates/file-upload-area.template.d.ts +19 -0
- package/dist/src/components/chatbot/templates/file-upload-area.template.js +29 -0
- package/dist/src/components/chatbot/templates/index.d.ts +15 -0
- package/dist/src/components/chatbot/templates/index.js +15 -0
- package/dist/src/components/chatbot/templates/input-box.template.d.ts +49 -0
- package/dist/src/components/chatbot/templates/input-box.template.js +317 -0
- package/dist/src/components/chatbot/templates/message.template.d.ts +31 -0
- package/dist/src/components/chatbot/templates/message.template.js +214 -0
- package/dist/src/components/chatbot/templates/suggestion.template.d.ts +20 -0
- package/dist/src/components/chatbot/templates/suggestion.template.js +40 -0
- package/dist/src/components/chatbot/templates/thread-sidebar.template.d.ts +24 -0
- package/dist/src/components/chatbot/templates/thread-sidebar.template.js +160 -0
- package/dist/src/components/chatbot/templates/url-modal.template.d.ts +25 -0
- package/dist/src/components/chatbot/templates/url-modal.template.js +100 -0
- package/dist/src/components/chatbot/utils/format.d.ts +23 -0
- package/dist/src/components/chatbot/utils/format.js +84 -0
- package/dist/src/components/chatbot/utils/index.d.ts +7 -0
- package/dist/src/components/chatbot/utils/index.js +7 -0
- package/dist/src/components/checkbox/mixins/checkbox-event-mixin.d.ts +87 -0
- package/dist/src/components/checkbox/mixins/checkbox-event-mixin.js +94 -0
- package/dist/src/components/checkbox/mixins/checkbox-focus-mixin.d.ts +55 -0
- package/dist/src/components/checkbox/mixins/checkbox-focus-mixin.js +57 -0
- package/dist/src/components/checkbox/mixins/index.d.ts +10 -0
- package/dist/src/components/checkbox/mixins/index.js +8 -0
- package/dist/src/components/checkbox/test/checkbox_test.d.ts +2 -0
- package/dist/src/components/checkbox/test/checkbox_test.js +88 -0
- package/dist/src/components/collapse/controllers/accordion.controller.d.ts +60 -0
- package/dist/src/components/collapse/controllers/accordion.controller.js +132 -0
- package/dist/src/components/collapse/controllers/animation.controller.d.ts +40 -0
- package/dist/src/components/collapse/controllers/animation.controller.js +125 -0
- package/dist/src/components/collapse/controllers/base.controller.d.ts +48 -0
- package/dist/src/components/collapse/controllers/base.controller.js +69 -0
- package/dist/src/components/collapse/controllers/index.d.ts +12 -0
- package/dist/src/components/collapse/controllers/index.js +11 -0
- package/dist/src/components/collapse/controllers/keyboard.controller.d.ts +73 -0
- package/dist/src/components/collapse/controllers/keyboard.controller.js +186 -0
- package/dist/src/components/colorpicker/controllers/base.controller.d.ts +14 -0
- package/dist/src/components/colorpicker/controllers/base.controller.js +15 -0
- package/dist/src/components/colorpicker/controllers/dropdown.controller.d.ts +60 -0
- package/dist/src/components/colorpicker/controllers/dropdown.controller.js +243 -0
- package/dist/src/components/colorpicker/controllers/event.controller.d.ts +46 -0
- package/dist/src/components/colorpicker/controllers/event.controller.js +130 -0
- package/dist/src/components/colorpicker/controllers/index.d.ts +4 -0
- package/dist/src/components/colorpicker/controllers/index.js +4 -0
- package/dist/src/components/colorpicker/interfaces/index.d.ts +60 -0
- package/dist/src/components/colorpicker/interfaces/index.js +2 -0
- package/dist/src/components/datepicker/controllers/calendar.controller.d.ts +78 -0
- package/dist/src/components/datepicker/controllers/calendar.controller.js +225 -0
- package/dist/src/components/datepicker/controllers/index.d.ts +11 -0
- package/dist/src/components/datepicker/controllers/index.js +11 -0
- package/dist/src/components/datepicker/controllers/keyboard.controller.d.ts +96 -0
- package/dist/src/components/datepicker/controllers/keyboard.controller.js +246 -0
- package/dist/src/components/datepicker/controllers/month-year-dropdown.controller.d.ts +48 -0
- package/dist/src/components/datepicker/controllers/month-year-dropdown.controller.js +92 -0
- package/dist/src/components/datepicker/controllers/positioning.controller.d.ts +82 -0
- package/dist/src/components/datepicker/controllers/positioning.controller.js +247 -0
- package/dist/src/components/datepicker/controllers/selection.controller.d.ts +92 -0
- package/dist/src/components/datepicker/controllers/selection.controller.js +267 -0
- package/dist/src/components/datepicker/interfaces/base-controller.interface.d.ts +40 -0
- package/dist/src/components/datepicker/interfaces/base-controller.interface.js +7 -0
- package/dist/src/components/datepicker/interfaces/datepicker-controllers.interface.d.ts +112 -0
- package/dist/src/components/datepicker/interfaces/datepicker-controllers.interface.js +7 -0
- package/dist/src/components/datepicker/interfaces/index.d.ts +8 -0
- package/dist/src/components/datepicker/interfaces/index.js +7 -0
- package/dist/src/components/datepicker/templates/days.template.d.ts +4 -0
- package/dist/src/components/datepicker/templates/days.template.js +40 -0
- package/dist/src/components/datepicker/templates/dropdown.template.d.ts +10 -0
- package/dist/src/components/datepicker/templates/dropdown.template.js +50 -0
- package/dist/src/components/datepicker/templates/headers.template.d.ts +2 -0
- package/dist/src/components/datepicker/templates/headers.template.js +5 -0
- package/dist/src/components/datepicker/templates/months.template.d.ts +6 -0
- package/dist/src/components/datepicker/templates/months.template.js +10 -0
- package/dist/src/components/datepicker/templates/years.template.d.ts +6 -0
- package/dist/src/components/datepicker/templates/years.template.js +11 -0
- package/dist/src/components/datepicker/test/datepicker_test.d.ts +2 -0
- package/dist/src/components/datepicker/test/datepicker_test.js +134 -0
- package/dist/src/components/datepicker/utils/day.helper.d.ts +5 -0
- package/dist/src/components/datepicker/utils/day.helper.js +53 -0
- package/dist/src/components/datepicker/utils/formatter.d.ts +2 -0
- package/dist/src/components/datepicker/utils/formatter.js +9 -0
- package/dist/src/components/datepicker/utils/index.d.ts +11 -0
- package/dist/src/components/datepicker/utils/index.js +11 -0
- package/dist/src/components/datepicker/utils/locale.helper.d.ts +144 -0
- package/dist/src/components/datepicker/utils/locale.helper.js +151 -0
- package/dist/src/components/datepicker/utils/month.helper.d.ts +3 -0
- package/dist/src/components/datepicker/utils/month.helper.js +24 -0
- package/dist/src/components/datepicker/utils/string.helper.d.ts +2 -0
- package/dist/src/components/datepicker/utils/string.helper.js +4 -0
- package/dist/src/components/document/demo/document-demo.d.ts +12 -0
- package/dist/src/components/document/demo/document-demo.js +40 -0
- package/dist/src/components/dropdown/controllers/base.controller.d.ts +18 -0
- package/dist/src/components/dropdown/controllers/base.controller.js +22 -0
- package/dist/src/components/dropdown/controllers/dropdown.controller.d.ts +50 -0
- package/dist/src/components/dropdown/controllers/dropdown.controller.js +408 -0
- package/dist/src/components/dropdown/controllers/index.d.ts +3 -0
- package/dist/src/components/dropdown/controllers/index.js +3 -0
- package/dist/src/components/dropdown/interfaces/controller-interfaces.d.ts +79 -0
- package/dist/src/components/dropdown/interfaces/controller-interfaces.js +2 -0
- package/dist/src/components/dropdown/interfaces/index.d.ts +2 -0
- package/dist/src/components/dropdown/interfaces/index.js +2 -0
- package/dist/src/components/dropdown/templates/nr-dropdown-item.d.ts +12 -0
- package/dist/src/components/dropdown/templates/nr-dropdown-item.js +55 -0
- package/dist/src/components/dropdown/templates/nr-dropdown-item.style.d.ts +2 -0
- package/dist/src/components/dropdown/templates/nr-dropdown-item.style.js +34 -0
- package/dist/src/components/dropdown/templates/nr-dropdown-menu.d.ts +18 -0
- package/dist/src/components/dropdown/templates/nr-dropdown-menu.js +70 -0
- package/dist/src/components/dropdown/templates/nr-dropdown-menu.style.d.ts +2 -0
- package/dist/src/components/dropdown/templates/nr-dropdown-menu.style.js +49 -0
- package/dist/src/components/file-upload/demo/file-upload-demo.d.ts +18 -0
- package/dist/src/components/file-upload/demo/file-upload-demo.js +156 -0
- package/dist/src/components/form/controllers/submission.controller.d.ts +60 -0
- package/dist/src/components/form/controllers/submission.controller.js +220 -0
- package/dist/src/components/form/controllers/validation.controller.d.ts +87 -0
- package/dist/src/components/form/controllers/validation.controller.js +236 -0
- package/dist/src/components/form/interfaces/validation.interface.d.ts +118 -0
- package/dist/src/components/form/interfaces/validation.interface.js +7 -0
- package/dist/src/components/icon/mixins/clickable-mixin.d.ts +57 -0
- package/dist/src/components/icon/mixins/clickable-mixin.js +111 -0
- package/dist/src/components/icon/mixins/index.d.ts +7 -0
- package/dist/src/components/icon/mixins/index.js +7 -0
- package/dist/src/components/iconpicker/controllers/event.controller.d.ts +38 -0
- package/dist/src/components/iconpicker/controllers/event.controller.js +68 -0
- package/dist/src/components/iconpicker/controllers/index.d.ts +9 -0
- package/dist/src/components/iconpicker/controllers/index.js +9 -0
- package/dist/src/components/iconpicker/controllers/search.controller.d.ts +34 -0
- package/dist/src/components/iconpicker/controllers/search.controller.js +55 -0
- package/dist/src/components/iconpicker/controllers/selection.controller.d.ts +27 -0
- package/dist/src/components/iconpicker/controllers/selection.controller.js +39 -0
- package/dist/src/components/iconpicker/interfaces/icon-picker.interface.d.ts +13 -0
- package/dist/src/components/iconpicker/interfaces/icon-picker.interface.js +7 -0
- package/dist/src/components/iconpicker/interfaces/index.d.ts +7 -0
- package/dist/src/components/iconpicker/interfaces/index.js +7 -0
- package/dist/src/components/iconpicker/utils/icon-filter.utils.d.ts +29 -0
- package/dist/src/components/iconpicker/utils/icon-filter.utils.js +96 -0
- package/dist/src/components/iconpicker/utils/icon-loader.utils.d.ts +39 -0
- package/dist/src/components/iconpicker/utils/icon-loader.utils.js +115 -0
- package/dist/src/components/iconpicker/utils/index.d.ts +8 -0
- package/dist/src/components/iconpicker/utils/index.js +8 -0
- package/dist/src/components/iconpicker/utils/lucide-icons.d.ts +10 -0
- package/dist/src/components/iconpicker/utils/lucide-icons.js +1624 -0
- package/dist/src/components/input/controllers/base.controller.d.ts +35 -0
- package/dist/src/components/input/controllers/base.controller.js +13 -0
- package/dist/src/components/input/controllers/event.controller.d.ts +111 -0
- package/dist/src/components/input/controllers/event.controller.js +355 -0
- package/dist/src/components/input/controllers/index.d.ts +14 -0
- package/dist/src/components/input/controllers/index.js +10 -0
- package/dist/src/components/input/controllers/state.controller.d.ts +153 -0
- package/dist/src/components/input/controllers/state.controller.js +245 -0
- package/dist/src/components/input/controllers/validation.controller.d.ts +205 -0
- package/dist/src/components/input/controllers/validation.controller.js +698 -0
- package/dist/src/components/input/mixins/focus-mixin.d.ts +60 -0
- package/dist/src/components/input/mixins/focus-mixin.js +65 -0
- package/dist/src/components/input/mixins/index.d.ts +12 -0
- package/dist/src/components/input/mixins/index.js +9 -0
- package/dist/src/components/input/mixins/number-mixin.d.ts +51 -0
- package/dist/src/components/input/mixins/number-mixin.js +128 -0
- package/dist/src/components/input/mixins/selection-mixin.d.ts +57 -0
- package/dist/src/components/input/mixins/selection-mixin.js +80 -0
- package/dist/src/components/input/test/nr-input_test.d.ts +2 -0
- package/dist/src/components/input/test/nr-input_test.js +159 -0
- package/dist/src/components/input/utils/index.d.ts +8 -0
- package/dist/src/components/input/utils/index.js +8 -0
- package/dist/src/components/input/utils/input-renderers.d.ts +54 -0
- package/dist/src/components/input/utils/input-renderers.js +178 -0
- package/dist/src/components/input/utils/input-validation.utils.d.ts +26 -0
- package/dist/src/components/input/utils/input-validation.utils.js +103 -0
- package/dist/src/components/menu/controllers/accessibility.controller.d.ts +86 -0
- package/dist/src/components/menu/controllers/accessibility.controller.js +235 -0
- package/dist/src/components/menu/controllers/base.controller.d.ts +41 -0
- package/dist/src/components/menu/controllers/base.controller.js +61 -0
- package/dist/src/components/menu/controllers/index.d.ts +10 -0
- package/dist/src/components/menu/controllers/index.js +10 -0
- package/dist/src/components/menu/controllers/keyboard.controller.d.ts +84 -0
- package/dist/src/components/menu/controllers/keyboard.controller.js +328 -0
- package/dist/src/components/menu/controllers/state.controller.d.ts +106 -0
- package/dist/src/components/menu/controllers/state.controller.js +249 -0
- package/dist/src/components/menu/interfaces/controller.interface.d.ts +51 -0
- package/dist/src/components/menu/interfaces/controller.interface.js +7 -0
- package/dist/src/components/menu/interfaces/index.d.ts +7 -0
- package/dist/src/components/menu/interfaces/index.js +7 -0
- package/dist/src/components/modal/controllers/index.d.ts +8 -0
- package/dist/src/components/modal/controllers/index.js +8 -0
- package/dist/src/components/modal/controllers/modal-drag-controller.d.ts +39 -0
- package/dist/src/components/modal/controllers/modal-drag-controller.js +108 -0
- package/dist/src/components/modal/controllers/modal-keyboard-controller.d.ts +36 -0
- package/dist/src/components/modal/controllers/modal-keyboard-controller.js +128 -0
- package/dist/src/components/panel/controllers/index.d.ts +8 -0
- package/dist/src/components/panel/controllers/index.js +8 -0
- package/dist/src/components/panel/controllers/panel-drag-controller.d.ts +40 -0
- package/dist/src/components/panel/controllers/panel-drag-controller.js +118 -0
- package/dist/src/components/panel/controllers/panel-resize-controller.d.ts +37 -0
- package/dist/src/components/panel/controllers/panel-resize-controller.js +124 -0
- package/dist/src/components/presence/bundle.js +555 -0
- package/dist/src/components/presence/bundle.js.gz +0 -0
- package/dist/src/components/presence/index.d.ts +10 -0
- package/dist/src/components/presence/index.js +10 -0
- package/dist/src/components/presence/presence-avatars.component.d.ts +40 -0
- package/dist/src/components/presence/presence-avatars.component.js +83 -0
- package/dist/src/components/presence/presence-avatars.style.d.ts +7 -0
- package/dist/src/components/presence/presence-avatars.style.js +105 -0
- package/dist/src/components/presence/presence-chat.component.d.ts +55 -0
- package/dist/src/components/presence/presence-chat.component.js +238 -0
- package/dist/src/components/presence/presence-chat.style.d.ts +7 -0
- package/dist/src/components/presence/presence-chat.style.js +248 -0
- package/dist/src/components/presence/presence.component.d.ts +95 -0
- package/dist/src/components/presence/presence.component.js +510 -0
- package/dist/src/components/presence/presence.style.d.ts +7 -0
- package/dist/src/components/presence/presence.style.js +12 -0
- package/dist/src/components/presence/presence.types.d.ts +33 -0
- package/dist/src/components/presence/presence.types.js +7 -0
- package/dist/src/components/presence/react.d.ts +24 -0
- package/dist/src/components/presence/react.js +41 -0
- package/dist/src/components/radio-group/controllers/focus.controller.d.ts +98 -0
- package/dist/src/components/radio-group/controllers/focus.controller.js +216 -0
- package/dist/src/components/radio-group/controllers/group.controller.d.ts +140 -0
- package/dist/src/components/radio-group/controllers/group.controller.js +179 -0
- package/dist/src/components/radio-group/controllers/index.d.ts +11 -0
- package/dist/src/components/radio-group/controllers/index.js +11 -0
- package/dist/src/components/radio-group/controllers/keyboard.controller.d.ts +24 -0
- package/dist/src/components/radio-group/controllers/keyboard.controller.js +93 -0
- package/dist/src/components/radio-group/controllers/ripple.controller.d.ts +59 -0
- package/dist/src/components/radio-group/controllers/ripple.controller.js +208 -0
- package/dist/src/components/radio-group/controllers/validation.controller.d.ts +73 -0
- package/dist/src/components/radio-group/controllers/validation.controller.js +108 -0
- package/dist/src/components/radio-group/interfaces/base-controller.interface.d.ts +75 -0
- package/dist/src/components/radio-group/interfaces/base-controller.interface.js +7 -0
- package/dist/src/components/radio-group/interfaces/focus-controller.interface.d.ts +40 -0
- package/dist/src/components/radio-group/interfaces/focus-controller.interface.js +7 -0
- package/dist/src/components/radio-group/interfaces/index.d.ts +11 -0
- package/dist/src/components/radio-group/interfaces/index.js +7 -0
- package/dist/src/components/radio-group/interfaces/ripple-controller.interface.d.ts +31 -0
- package/dist/src/components/radio-group/interfaces/ripple-controller.interface.js +7 -0
- package/dist/src/components/radio-group/interfaces/selection-controller.interface.d.ts +45 -0
- package/dist/src/components/radio-group/interfaces/selection-controller.interface.js +7 -0
- package/dist/src/components/radio-group/interfaces/validation-controller.interface.d.ts +48 -0
- package/dist/src/components/radio-group/interfaces/validation-controller.interface.js +7 -0
- package/dist/src/components/radio-group/test/radio_test.d.ts +2 -0
- package/dist/src/components/radio-group/test/radio_test.js +79 -0
- package/dist/src/components/select/controllers/base.controller.d.ts +10 -0
- package/dist/src/components/select/controllers/base.controller.js +8 -0
- package/dist/src/components/select/controllers/dropdown.controller.d.ts +76 -0
- package/dist/src/components/select/controllers/dropdown.controller.js +281 -0
- package/dist/src/components/select/controllers/event.controller.d.ts +54 -0
- package/dist/src/components/select/controllers/event.controller.js +113 -0
- package/dist/src/components/select/controllers/focus.controller.d.ts +79 -0
- package/dist/src/components/select/controllers/focus.controller.js +230 -0
- package/dist/src/components/select/controllers/index.d.ts +9 -0
- package/dist/src/components/select/controllers/index.js +9 -0
- package/dist/src/components/select/controllers/keyboard.controller.d.ts +75 -0
- package/dist/src/components/select/controllers/keyboard.controller.js +369 -0
- package/dist/src/components/select/controllers/search.controller.d.ts +71 -0
- package/dist/src/components/select/controllers/search.controller.js +167 -0
- package/dist/src/components/select/controllers/selection.controller.d.ts +67 -0
- package/dist/src/components/select/controllers/selection.controller.js +217 -0
- package/dist/src/components/select/controllers/validation.controller.d.ts +66 -0
- package/dist/src/components/select/controllers/validation.controller.js +189 -0
- package/dist/src/components/select/interfaces/base-controller.interface.d.ts +147 -0
- package/dist/src/components/select/interfaces/base-controller.interface.js +2 -0
- package/dist/src/components/select/interfaces/controller-interfaces.d.ts +94 -0
- package/dist/src/components/select/interfaces/controller-interfaces.js +11 -0
- package/dist/src/components/select/interfaces/index.d.ts +3 -0
- package/dist/src/components/select/interfaces/index.js +3 -0
- package/dist/src/components/slider-input/utils/debounce.d.ts +2 -0
- package/dist/src/components/slider-input/utils/debounce.js +8 -0
- package/dist/src/components/slider-input/utils/index.d.ts +2 -0
- package/dist/src/components/slider-input/utils/index.js +2 -0
- package/dist/src/components/table/controllers/base.controller.d.ts +15 -0
- package/dist/src/components/table/controllers/base.controller.js +13 -0
- package/dist/src/components/table/controllers/filter.controller.d.ts +48 -0
- package/dist/src/components/table/controllers/filter.controller.js +152 -0
- package/dist/src/components/table/controllers/index.d.ts +11 -0
- package/dist/src/components/table/controllers/index.js +11 -0
- package/dist/src/components/table/controllers/pagination.controller.d.ts +36 -0
- package/dist/src/components/table/controllers/pagination.controller.js +110 -0
- package/dist/src/components/table/controllers/selection.controller.d.ts +40 -0
- package/dist/src/components/table/controllers/selection.controller.js +120 -0
- package/dist/src/components/table/controllers/sort.controller.d.ts +32 -0
- package/dist/src/components/table/controllers/sort.controller.js +102 -0
- package/dist/src/components/table/interfaces/index.d.ts +7 -0
- package/dist/src/components/table/interfaces/index.js +7 -0
- package/dist/src/components/table/interfaces/table-host.interface.d.ts +48 -0
- package/dist/src/components/table/interfaces/table-host.interface.js +7 -0
- package/dist/src/components/table/templates/actions.template.d.ts +14 -0
- package/dist/src/components/table/templates/actions.template.js +15 -0
- package/dist/src/components/table/templates/column-filter.template.d.ts +24 -0
- package/dist/src/components/table/templates/column-filter.template.js +76 -0
- package/dist/src/components/table/templates/content.template.d.ts +37 -0
- package/dist/src/components/table/templates/content.template.js +208 -0
- package/dist/src/components/table/templates/empty.template.d.ts +8 -0
- package/dist/src/components/table/templates/empty.template.js +47 -0
- package/dist/src/components/table/templates/filter.template.d.ts +14 -0
- package/dist/src/components/table/templates/filter.template.js +28 -0
- package/dist/src/components/table/templates/index.d.ts +8 -0
- package/dist/src/components/table/templates/index.js +8 -0
- package/dist/src/components/table/templates/loading.template.d.ts +21 -0
- package/dist/src/components/table/templates/loading.template.js +51 -0
- package/dist/src/components/table/templates/pagination.template.d.ts +24 -0
- package/dist/src/components/table/templates/pagination.template.js +52 -0
- package/dist/src/components/tabs/controllers/base.controller.d.ts +49 -0
- package/dist/src/components/tabs/controllers/base.controller.js +26 -0
- package/dist/src/components/tabs/controllers/dragdrop.controller.d.ts +84 -0
- package/dist/src/components/tabs/controllers/dragdrop.controller.js +202 -0
- package/dist/src/components/tabs/controllers/editable.controller.d.ts +100 -0
- package/dist/src/components/tabs/controllers/editable.controller.js +242 -0
- package/dist/src/components/tabs/controllers/event.controller.d.ts +104 -0
- package/dist/src/components/tabs/controllers/event.controller.js +239 -0
- package/dist/src/components/tabs/controllers/index.d.ts +12 -0
- package/dist/src/components/tabs/controllers/index.js +18 -0
- package/dist/src/components/tabs/controllers/keyboard.controller.d.ts +85 -0
- package/dist/src/components/tabs/controllers/keyboard.controller.js +233 -0
- package/dist/src/components/tabs/controllers/popout.controller.d.ts +96 -0
- package/dist/src/components/tabs/controllers/popout.controller.js +441 -0
- package/dist/src/components/textarea/controllers/base.controller.d.ts +43 -0
- package/dist/src/components/textarea/controllers/base.controller.js +19 -0
- package/dist/src/components/textarea/controllers/event.controller.d.ts +169 -0
- package/dist/src/components/textarea/controllers/event.controller.js +408 -0
- package/dist/src/components/textarea/controllers/index.d.ts +9 -0
- package/dist/src/components/textarea/controllers/index.js +9 -0
- package/dist/src/components/textarea/controllers/validation.controller.d.ts +133 -0
- package/dist/src/components/textarea/controllers/validation.controller.js +315 -0
- package/dist/src/components/timepicker/controllers/formatting.controller.d.ts +93 -0
- package/dist/src/components/timepicker/controllers/formatting.controller.js +195 -0
- package/dist/src/components/timepicker/controllers/index.d.ts +9 -0
- package/dist/src/components/timepicker/controllers/index.js +9 -0
- package/dist/src/components/timepicker/controllers/selection.controller.d.ts +72 -0
- package/dist/src/components/timepicker/controllers/selection.controller.js +175 -0
- package/dist/src/components/timepicker/controllers/validation.controller.d.ts +88 -0
- package/dist/src/components/timepicker/controllers/validation.controller.js +200 -0
- package/dist/src/components/timepicker/interfaces/timepicker.interface.d.ts +103 -0
- package/dist/src/components/timepicker/interfaces/timepicker.interface.js +7 -0
- package/dist/src/components/timepicker/test/timepicker_test.d.ts +7 -0
- package/dist/src/components/timepicker/test/timepicker_test.js +218 -0
- package/dist/src/components/timepicker/utils/time.utils.d.ts +87 -0
- package/dist/src/components/timepicker/utils/time.utils.js +235 -0
- package/dist/src/components/toast/bundle.js +11 -9
- package/dist/src/components/toast/bundle.js.gz +0 -0
- package/dist/src/components/toast/controllers/base.controller.d.ts +20 -0
- package/dist/src/components/toast/controllers/base.controller.js +12 -0
- package/dist/src/components/toast/controllers/index.d.ts +8 -0
- package/dist/src/components/toast/controllers/index.js +7 -0
- package/dist/src/components/toast/toast.component.d.ts +8 -0
- package/dist/src/components/toast/toast.component.js +17 -7
- package/dist/src/components/tooltips/demo/tooltips-demo.d.ts +18 -0
- package/dist/src/components/tooltips/demo/tooltips-demo.js +132 -0
- package/dist/src/components/tooltips/test/tooltips_test.d.ts +2 -0
- package/dist/src/components/tooltips/test/tooltips_test.js +145 -0
- package/dist/src/components/video/bundle.js +13 -12
- package/dist/src/components/video/bundle.js.gz +0 -0
- package/dist/src/components/video/video.component.d.ts +15 -1
- package/dist/src/components/video/video.component.js +131 -3
- package/package.json +31 -10
- package/packages/common/dist/VERSIONS.md +1 -1
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2024 Nuraly, Laabidi Aymen
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import { BaseCanvasController } from './base.controller.js';
|
|
7
|
+
/**
|
|
8
|
+
* Controller for managing edge connections
|
|
9
|
+
*/
|
|
10
|
+
export class ConnectionController extends BaseCanvasController {
|
|
11
|
+
constructor(host) {
|
|
12
|
+
super(host);
|
|
13
|
+
this.undoController = null;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Set the undo controller (called after initialization)
|
|
17
|
+
*/
|
|
18
|
+
setUndoController(controller) {
|
|
19
|
+
this.undoController = controller;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Start creating a connection from a port
|
|
23
|
+
*/
|
|
24
|
+
startConnection(node, port, isInput, event) {
|
|
25
|
+
const pos = this.clientToCanvas(event.clientX, event.clientY);
|
|
26
|
+
this._host.connectionState = {
|
|
27
|
+
sourceNodeId: node.id,
|
|
28
|
+
sourcePortId: port.id,
|
|
29
|
+
sourceIsInput: isInput,
|
|
30
|
+
mouseX: pos.x,
|
|
31
|
+
mouseY: pos.y,
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Update the connection line position during drag
|
|
36
|
+
*/
|
|
37
|
+
updateConnectionPosition(event) {
|
|
38
|
+
if (!this._host.connectionState)
|
|
39
|
+
return;
|
|
40
|
+
const pos = this.clientToCanvas(event.clientX, event.clientY);
|
|
41
|
+
this._host.connectionState = Object.assign(Object.assign({}, this._host.connectionState), { mouseX: pos.x, mouseY: pos.y });
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Complete the connection when released on a valid port
|
|
45
|
+
*/
|
|
46
|
+
completeConnection(node, port, isInput) {
|
|
47
|
+
const state = this._host.connectionState;
|
|
48
|
+
if (!state)
|
|
49
|
+
return false;
|
|
50
|
+
// Can't connect input to input or output to output
|
|
51
|
+
if (state.sourceIsInput === isInput) {
|
|
52
|
+
this.cancelConnection();
|
|
53
|
+
return false;
|
|
54
|
+
}
|
|
55
|
+
// Can't connect to same node
|
|
56
|
+
if (state.sourceNodeId === node.id) {
|
|
57
|
+
this.cancelConnection();
|
|
58
|
+
return false;
|
|
59
|
+
}
|
|
60
|
+
// Determine source and target based on which port started the connection
|
|
61
|
+
const sourceNodeId = state.sourceIsInput ? node.id : state.sourceNodeId;
|
|
62
|
+
const sourcePortId = state.sourceIsInput ? port.id : state.sourcePortId;
|
|
63
|
+
const targetNodeId = state.sourceIsInput ? state.sourceNodeId : node.id;
|
|
64
|
+
const targetPortId = state.sourceIsInput ? state.sourcePortId : port.id;
|
|
65
|
+
// Check if edge already exists
|
|
66
|
+
const edgeExists = this._host.workflow.edges.some(edge => edge.sourceNodeId === sourceNodeId &&
|
|
67
|
+
edge.sourcePortId === sourcePortId &&
|
|
68
|
+
edge.targetNodeId === targetNodeId &&
|
|
69
|
+
edge.targetPortId === targetPortId);
|
|
70
|
+
if (!edgeExists) {
|
|
71
|
+
const newEdge = {
|
|
72
|
+
id: 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, c => { const r = (Math.random() * 16) | 0; return (c === 'x' ? r : (r & 0x3) | 0x8).toString(16); }),
|
|
73
|
+
sourceNodeId,
|
|
74
|
+
sourcePortId,
|
|
75
|
+
targetNodeId,
|
|
76
|
+
targetPortId,
|
|
77
|
+
};
|
|
78
|
+
// Record for undo before making changes
|
|
79
|
+
if (this.undoController) {
|
|
80
|
+
this.undoController.recordEdgeAdded(newEdge);
|
|
81
|
+
}
|
|
82
|
+
this._host.setWorkflow(Object.assign(Object.assign({}, this._host.workflow), { edges: [...this._host.workflow.edges, newEdge] }));
|
|
83
|
+
this._host.dispatchWorkflowChanged();
|
|
84
|
+
}
|
|
85
|
+
this.cancelConnection();
|
|
86
|
+
return !edgeExists;
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Cancel the current connection
|
|
90
|
+
*/
|
|
91
|
+
cancelConnection() {
|
|
92
|
+
this._host.connectionState = null;
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* Check if currently creating a connection
|
|
96
|
+
*/
|
|
97
|
+
isConnecting() {
|
|
98
|
+
return this._host.connectionState !== null;
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Get the current connection state
|
|
102
|
+
*/
|
|
103
|
+
getConnectionState() {
|
|
104
|
+
return this._host.connectionState;
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Get port position for a node
|
|
108
|
+
*/
|
|
109
|
+
getPortPosition(node, portId, isInput) {
|
|
110
|
+
const nodeWidth = 180;
|
|
111
|
+
// Check if this is a config port (bottom ports)
|
|
112
|
+
const configPorts = node.ports.configs || [];
|
|
113
|
+
const configIndex = configPorts.findIndex(p => p.id === portId);
|
|
114
|
+
if (configIndex !== -1) {
|
|
115
|
+
// Config ports use: left: calc(50% + offset - 5px)
|
|
116
|
+
// where offset = (index - (total - 1) / 2) * 45
|
|
117
|
+
const totalConfigs = configPorts.length;
|
|
118
|
+
const portSpacing = 45;
|
|
119
|
+
const offsetFromCenter = (configIndex - (totalConfigs - 1) / 2) * portSpacing;
|
|
120
|
+
// Estimate node height - base height + status/content
|
|
121
|
+
// When there's status shown, node is taller
|
|
122
|
+
const hasStatus = node.status && node.status !== 'IDLE';
|
|
123
|
+
const nodeHeight = hasStatus ? 110 : 85;
|
|
124
|
+
return {
|
|
125
|
+
x: node.position.x + (nodeWidth / 2) + offsetFromCenter,
|
|
126
|
+
y: node.position.y + nodeHeight, // Bottom of node (port is at bottom: -4px)
|
|
127
|
+
};
|
|
128
|
+
}
|
|
129
|
+
// Regular input/output ports
|
|
130
|
+
const portIndex = isInput
|
|
131
|
+
? node.ports.inputs.findIndex(p => p.id === portId)
|
|
132
|
+
: node.ports.outputs.findIndex(p => p.id === portId);
|
|
133
|
+
const totalPorts = isInput ? node.ports.inputs.length : node.ports.outputs.length;
|
|
134
|
+
// Match the port positioning from workflow-node.component.ts
|
|
135
|
+
const nodeHeight = 80;
|
|
136
|
+
const portSpacing = 20;
|
|
137
|
+
// Calculate vertical center position
|
|
138
|
+
const totalPortsHeight = (totalPorts - 1) * portSpacing;
|
|
139
|
+
const startY = (nodeHeight - totalPortsHeight) / 2;
|
|
140
|
+
const topOffset = startY + portIndex * portSpacing;
|
|
141
|
+
return {
|
|
142
|
+
x: node.position.x + (isInput ? 2 : nodeWidth - 2),
|
|
143
|
+
y: node.position.y + topOffset + 3,
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
/**
|
|
147
|
+
* Delete an edge by ID
|
|
148
|
+
*/
|
|
149
|
+
deleteEdge(edgeId) {
|
|
150
|
+
if (this._host.readonly)
|
|
151
|
+
return;
|
|
152
|
+
// Get the edge for undo
|
|
153
|
+
const edgeToDelete = this._host.workflow.edges.find(e => e.id === edgeId);
|
|
154
|
+
// Record for undo before making changes
|
|
155
|
+
if (this.undoController && edgeToDelete) {
|
|
156
|
+
this.undoController.recordEdgeDeleted(edgeToDelete);
|
|
157
|
+
}
|
|
158
|
+
this._host.setWorkflow(Object.assign(Object.assign({}, this._host.workflow), { edges: this._host.workflow.edges.filter(e => e.id !== edgeId) }));
|
|
159
|
+
this._host.dispatchWorkflowChanged();
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* Get edges connected to a node
|
|
163
|
+
*/
|
|
164
|
+
getNodeEdges(nodeId) {
|
|
165
|
+
return {
|
|
166
|
+
inputs: this._host.workflow.edges.filter(e => e.targetNodeId === nodeId),
|
|
167
|
+
outputs: this._host.workflow.edges.filter(e => e.sourceNodeId === nodeId),
|
|
168
|
+
};
|
|
169
|
+
}
|
|
170
|
+
/**
|
|
171
|
+
* Set hovered edge ID
|
|
172
|
+
*/
|
|
173
|
+
setHoveredEdge(edgeId) {
|
|
174
|
+
this._host.hoveredEdgeId = edgeId;
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Get hovered edge ID
|
|
178
|
+
*/
|
|
179
|
+
getHoveredEdge() {
|
|
180
|
+
return this._host.hoveredEdgeId;
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
//# sourceMappingURL=connection.controller.js.map
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2024 Nuraly, Laabidi Aymen
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import { ReactiveControllerHost } from 'lit';
|
|
7
|
+
import { BaseCanvasController } from './base.controller.js';
|
|
8
|
+
import { CanvasHost, DragState } from '../interfaces/index.js';
|
|
9
|
+
import { WorkflowNode } from '../workflow-canvas.types.js';
|
|
10
|
+
import { ViewportController } from './viewport.controller.js';
|
|
11
|
+
import type { UndoController } from './undo.controller.js';
|
|
12
|
+
import type { FrameController } from './frame.controller.js';
|
|
13
|
+
/**
|
|
14
|
+
* Controller for managing node dragging
|
|
15
|
+
*/
|
|
16
|
+
export declare class DragController extends BaseCanvasController {
|
|
17
|
+
private viewportController;
|
|
18
|
+
private undoController;
|
|
19
|
+
private frameController;
|
|
20
|
+
private dragStartPositions;
|
|
21
|
+
private frameContainedNodeIds;
|
|
22
|
+
constructor(host: CanvasHost & ReactiveControllerHost, viewportController: ViewportController);
|
|
23
|
+
/**
|
|
24
|
+
* Set the undo controller (called after initialization)
|
|
25
|
+
*/
|
|
26
|
+
setUndoController(controller: UndoController): void;
|
|
27
|
+
/**
|
|
28
|
+
* Set the frame controller (called after initialization)
|
|
29
|
+
*/
|
|
30
|
+
setFrameController(controller: FrameController): void;
|
|
31
|
+
/**
|
|
32
|
+
* Start dragging a node
|
|
33
|
+
*/
|
|
34
|
+
startDrag(node: WorkflowNode, event: MouseEvent): void;
|
|
35
|
+
/**
|
|
36
|
+
* Handle node drag movement
|
|
37
|
+
*/
|
|
38
|
+
handleDrag(event: MouseEvent): void;
|
|
39
|
+
/**
|
|
40
|
+
* Stop dragging
|
|
41
|
+
*/
|
|
42
|
+
stopDrag(): void;
|
|
43
|
+
/**
|
|
44
|
+
* Check if currently dragging
|
|
45
|
+
*/
|
|
46
|
+
isDragging(): boolean;
|
|
47
|
+
/**
|
|
48
|
+
* Get current drag state
|
|
49
|
+
*/
|
|
50
|
+
getDragState(): DragState | null;
|
|
51
|
+
/**
|
|
52
|
+
* Get the node being dragged
|
|
53
|
+
*/
|
|
54
|
+
getDraggedNodeId(): string | null;
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=drag.controller.d.ts.map
|
|
@@ -0,0 +1,195 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2024 Nuraly, Laabidi Aymen
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import { BaseCanvasController } from './base.controller.js';
|
|
7
|
+
import { WorkflowNodeType } from '../workflow-canvas.types.js';
|
|
8
|
+
/**
|
|
9
|
+
* Controller for managing node dragging
|
|
10
|
+
*/
|
|
11
|
+
export class DragController extends BaseCanvasController {
|
|
12
|
+
constructor(host, viewportController) {
|
|
13
|
+
super(host);
|
|
14
|
+
this.undoController = null;
|
|
15
|
+
this.frameController = null;
|
|
16
|
+
this.dragStartPositions = new Map();
|
|
17
|
+
// Track nodes being moved due to frame drag (contained nodes)
|
|
18
|
+
this.frameContainedNodeIds = new Set();
|
|
19
|
+
this.viewportController = viewportController;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Set the undo controller (called after initialization)
|
|
23
|
+
*/
|
|
24
|
+
setUndoController(controller) {
|
|
25
|
+
this.undoController = controller;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Set the frame controller (called after initialization)
|
|
29
|
+
*/
|
|
30
|
+
setFrameController(controller) {
|
|
31
|
+
this.frameController = controller;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Start dragging a node
|
|
35
|
+
*/
|
|
36
|
+
startDrag(node, event) {
|
|
37
|
+
const pos = this.clientToCanvas(event.clientX, event.clientY);
|
|
38
|
+
this._host.dragState = {
|
|
39
|
+
nodeId: node.id,
|
|
40
|
+
startX: node.position.x,
|
|
41
|
+
startY: node.position.y,
|
|
42
|
+
offsetX: pos.x - node.position.x,
|
|
43
|
+
offsetY: pos.y - node.position.y,
|
|
44
|
+
};
|
|
45
|
+
// Record start positions for all selected nodes
|
|
46
|
+
this.dragStartPositions.clear();
|
|
47
|
+
this.frameContainedNodeIds.clear();
|
|
48
|
+
this._host.selectedNodeIds.forEach(nodeId => {
|
|
49
|
+
const n = this._host.workflow.nodes.find(x => x.id === nodeId);
|
|
50
|
+
if (n) {
|
|
51
|
+
this.dragStartPositions.set(nodeId, Object.assign({}, n.position));
|
|
52
|
+
// If dragging a frame, also record positions of contained nodes
|
|
53
|
+
if (n.type === WorkflowNodeType.FRAME && n.containedNodeIds) {
|
|
54
|
+
for (const containedId of n.containedNodeIds) {
|
|
55
|
+
// Skip if already selected (will be moved as part of selection)
|
|
56
|
+
if (this._host.selectedNodeIds.has(containedId))
|
|
57
|
+
continue;
|
|
58
|
+
const containedNode = this._host.workflow.nodes.find(x => x.id === containedId);
|
|
59
|
+
if (containedNode) {
|
|
60
|
+
this.frameContainedNodeIds.add(containedId);
|
|
61
|
+
this.dragStartPositions.set(containedId, Object.assign({}, containedNode.position));
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Handle node drag movement
|
|
70
|
+
*/
|
|
71
|
+
handleDrag(event) {
|
|
72
|
+
const { dragState } = this._host;
|
|
73
|
+
if (!dragState)
|
|
74
|
+
return;
|
|
75
|
+
const pos = this.clientToCanvas(event.clientX, event.clientY);
|
|
76
|
+
const x = pos.x - dragState.offsetX;
|
|
77
|
+
const y = pos.y - dragState.offsetY;
|
|
78
|
+
// Snap to grid
|
|
79
|
+
const snapped = this.snapToGrid(x, y);
|
|
80
|
+
// Move all selected nodes
|
|
81
|
+
const deltaX = snapped.x - dragState.startX;
|
|
82
|
+
const deltaY = snapped.y - dragState.startY;
|
|
83
|
+
this._host.setWorkflow(Object.assign(Object.assign({}, this._host.workflow), { nodes: this._host.workflow.nodes.map(node => {
|
|
84
|
+
// Move selected nodes
|
|
85
|
+
if (this._host.selectedNodeIds.has(node.id)) {
|
|
86
|
+
if (node.id === dragState.nodeId) {
|
|
87
|
+
return Object.assign(Object.assign({}, node), { position: { x: snapped.x, y: snapped.y } });
|
|
88
|
+
}
|
|
89
|
+
return Object.assign(Object.assign({}, node), { position: {
|
|
90
|
+
x: node.position.x + deltaX,
|
|
91
|
+
y: node.position.y + deltaY,
|
|
92
|
+
} });
|
|
93
|
+
}
|
|
94
|
+
// Move contained nodes (when dragging a frame)
|
|
95
|
+
if (this.frameContainedNodeIds.has(node.id)) {
|
|
96
|
+
return Object.assign(Object.assign({}, node), { position: {
|
|
97
|
+
x: node.position.x + deltaX,
|
|
98
|
+
y: node.position.y + deltaY,
|
|
99
|
+
} });
|
|
100
|
+
}
|
|
101
|
+
return node;
|
|
102
|
+
}) }));
|
|
103
|
+
this._host.dragState = Object.assign(Object.assign({}, dragState), { startX: snapped.x, startY: snapped.y });
|
|
104
|
+
// Update config panel position if the configured node is being dragged
|
|
105
|
+
if (this._host.configuredNode &&
|
|
106
|
+
this._host.selectedNodeIds.has(this._host.configuredNode.id)) {
|
|
107
|
+
const updatedNode = this._host.workflow.nodes.find(n => n.id === this._host.configuredNode.id);
|
|
108
|
+
if (updatedNode) {
|
|
109
|
+
this._host.configuredNode = updatedNode;
|
|
110
|
+
this.viewportController.updateConfigPanelPosition();
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
// Update insert panel position if the insert panel node is being dragged
|
|
114
|
+
if (this._host.insertPanelNode &&
|
|
115
|
+
this._host.selectedNodeIds.has(this._host.insertPanelNode.id)) {
|
|
116
|
+
const updatedNode = this._host.workflow.nodes.find(n => n.id === this._host.insertPanelNode.id);
|
|
117
|
+
if (updatedNode) {
|
|
118
|
+
this._host.insertPanelNode = updatedNode;
|
|
119
|
+
this.viewportController.updateInsertPanelPosition();
|
|
120
|
+
}
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
/**
|
|
124
|
+
* Stop dragging
|
|
125
|
+
*/
|
|
126
|
+
stopDrag() {
|
|
127
|
+
if (this._host.dragState) {
|
|
128
|
+
// Record move for undo (includes selected nodes and frame contained nodes)
|
|
129
|
+
if (this.undoController && this.dragStartPositions.size > 0) {
|
|
130
|
+
const moves = [];
|
|
131
|
+
// Collect all node IDs that were moved
|
|
132
|
+
const movedNodeIds = new Set([
|
|
133
|
+
...this._host.selectedNodeIds,
|
|
134
|
+
...this.frameContainedNodeIds,
|
|
135
|
+
]);
|
|
136
|
+
movedNodeIds.forEach(nodeId => {
|
|
137
|
+
const node = this._host.workflow.nodes.find(n => n.id === nodeId);
|
|
138
|
+
const oldPos = this.dragStartPositions.get(nodeId);
|
|
139
|
+
if (node && oldPos) {
|
|
140
|
+
// Only record if position actually changed
|
|
141
|
+
if (node.position.x !== oldPos.x || node.position.y !== oldPos.y) {
|
|
142
|
+
moves.push({
|
|
143
|
+
nodeId,
|
|
144
|
+
oldPosition: oldPos,
|
|
145
|
+
newPosition: Object.assign({}, node.position),
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
}
|
|
149
|
+
});
|
|
150
|
+
if (moves.length > 0) {
|
|
151
|
+
this.undoController.recordNodesMoved(moves);
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
// Dispatch node-moved event for each moved node
|
|
155
|
+
const movedNodeIds = new Set([
|
|
156
|
+
...this._host.selectedNodeIds,
|
|
157
|
+
...this.frameContainedNodeIds,
|
|
158
|
+
]);
|
|
159
|
+
movedNodeIds.forEach(nodeId => {
|
|
160
|
+
const node = this._host.workflow.nodes.find(n => n.id === nodeId);
|
|
161
|
+
if (node) {
|
|
162
|
+
this._host.dispatchNodeMoved(node, node.position);
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
// Update frame containment for all frames after move
|
|
166
|
+
if (this.frameController) {
|
|
167
|
+
this.frameController.updateAllFrameContainments();
|
|
168
|
+
}
|
|
169
|
+
this._host.dragState = null;
|
|
170
|
+
this.dragStartPositions.clear();
|
|
171
|
+
this.frameContainedNodeIds.clear();
|
|
172
|
+
this._host.dispatchWorkflowChanged();
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* Check if currently dragging
|
|
177
|
+
*/
|
|
178
|
+
isDragging() {
|
|
179
|
+
return this._host.dragState !== null;
|
|
180
|
+
}
|
|
181
|
+
/**
|
|
182
|
+
* Get current drag state
|
|
183
|
+
*/
|
|
184
|
+
getDragState() {
|
|
185
|
+
return this._host.dragState;
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Get the node being dragged
|
|
189
|
+
*/
|
|
190
|
+
getDraggedNodeId() {
|
|
191
|
+
var _a;
|
|
192
|
+
return ((_a = this._host.dragState) === null || _a === void 0 ? void 0 : _a.nodeId) || null;
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
//# sourceMappingURL=drag.controller.js.map
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2024 Nuraly, Laabidi Aymen
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import { ReactiveControllerHost } from 'lit';
|
|
7
|
+
import { BaseCanvasController } from './base.controller.js';
|
|
8
|
+
import { CanvasHost } from '../interfaces/index.js';
|
|
9
|
+
import { WorkflowNode, ResizeHandle, AggregatedPort } from '../workflow-canvas.types.js';
|
|
10
|
+
/**
|
|
11
|
+
* Controller for frame node operations including:
|
|
12
|
+
* - Resize functionality
|
|
13
|
+
* - Containment detection
|
|
14
|
+
* - Move with contents
|
|
15
|
+
* - Collapse/expand
|
|
16
|
+
* - Aggregated ports calculation
|
|
17
|
+
*/
|
|
18
|
+
export declare class FrameController extends BaseCanvasController {
|
|
19
|
+
private resizeState;
|
|
20
|
+
private readonly MIN_FRAME_WIDTH;
|
|
21
|
+
private readonly MIN_FRAME_HEIGHT;
|
|
22
|
+
constructor(host: CanvasHost & ReactiveControllerHost);
|
|
23
|
+
/**
|
|
24
|
+
* Start resizing a frame from a specific handle
|
|
25
|
+
*/
|
|
26
|
+
startResize(event: MouseEvent, frame: WorkflowNode, handle: ResizeHandle): void;
|
|
27
|
+
private handleResizeDragWithCoords;
|
|
28
|
+
private handleResizeDrag;
|
|
29
|
+
private readonly handleResizeTouchDrag;
|
|
30
|
+
stopResize: () => void;
|
|
31
|
+
private readonly stopResizeTouch;
|
|
32
|
+
/**
|
|
33
|
+
* Check if a node's center is within a frame's bounds
|
|
34
|
+
*/
|
|
35
|
+
isNodeInFrame(node: WorkflowNode, frame: WorkflowNode): boolean;
|
|
36
|
+
/**
|
|
37
|
+
* Update frame's containedNodeIds based on current node positions
|
|
38
|
+
*/
|
|
39
|
+
updateFrameContainment(frame: WorkflowNode): void;
|
|
40
|
+
/**
|
|
41
|
+
* Update all frames' containment after node move
|
|
42
|
+
* @param triggerUpdate If true, triggers a workflow update after containment changes
|
|
43
|
+
*/
|
|
44
|
+
updateAllFrameContainments(triggerUpdate?: boolean): void;
|
|
45
|
+
/**
|
|
46
|
+
* Get all nodes contained in a frame
|
|
47
|
+
*/
|
|
48
|
+
getContainedNodes(frame: WorkflowNode): WorkflowNode[];
|
|
49
|
+
/**
|
|
50
|
+
* Move a frame and all its contained nodes by delta
|
|
51
|
+
*/
|
|
52
|
+
moveFrameWithContents(frame: WorkflowNode, deltaX: number, deltaY: number): void;
|
|
53
|
+
/**
|
|
54
|
+
* Toggle frame collapsed state
|
|
55
|
+
*/
|
|
56
|
+
toggleCollapsed(frame: WorkflowNode): void;
|
|
57
|
+
/**
|
|
58
|
+
* Set visibility of nodes contained in a frame
|
|
59
|
+
*/
|
|
60
|
+
private setContainedNodesVisibility;
|
|
61
|
+
/**
|
|
62
|
+
* Calculate aggregated ports for a collapsed frame
|
|
63
|
+
*/
|
|
64
|
+
getAggregatedPorts(frame: WorkflowNode): {
|
|
65
|
+
inputs: AggregatedPort[];
|
|
66
|
+
outputs: AggregatedPort[];
|
|
67
|
+
};
|
|
68
|
+
/**
|
|
69
|
+
* Auto-resize frame to fit its contained nodes with padding
|
|
70
|
+
*/
|
|
71
|
+
fitToContents(frame: WorkflowNode, padding?: number): void;
|
|
72
|
+
/**
|
|
73
|
+
* Create a new frame around currently selected nodes
|
|
74
|
+
*/
|
|
75
|
+
createFrameFromSelection(): WorkflowNode | null;
|
|
76
|
+
/**
|
|
77
|
+
* Delete a frame
|
|
78
|
+
* @param deleteContents If true, also delete contained nodes
|
|
79
|
+
*/
|
|
80
|
+
deleteFrame(frame: WorkflowNode, deleteContents?: boolean): void;
|
|
81
|
+
/**
|
|
82
|
+
* Check if a frame is collapsed
|
|
83
|
+
*/
|
|
84
|
+
isFrameCollapsed(frame: WorkflowNode): boolean;
|
|
85
|
+
/**
|
|
86
|
+
* Get node icons and colors for collapsed frame preview
|
|
87
|
+
*/
|
|
88
|
+
getContainedNodePreviews(frame: WorkflowNode, maxCount?: number): Array<{
|
|
89
|
+
icon: string;
|
|
90
|
+
color: string;
|
|
91
|
+
name: string;
|
|
92
|
+
}>;
|
|
93
|
+
}
|
|
94
|
+
//# sourceMappingURL=frame.controller.d.ts.map
|