@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,208 @@
|
|
|
1
|
+
import { html, nothing } from 'lit';
|
|
2
|
+
import { repeat } from 'lit/directives/repeat.js';
|
|
3
|
+
import { choose } from 'lit/directives/choose.js';
|
|
4
|
+
import { renderColumnFilterTemplate, renderFilterIcon } from './column-filter.template.js';
|
|
5
|
+
import { renderLoadingTemplate } from './loading.template.js';
|
|
6
|
+
import { renderEmptyTemplate } from './empty.template.js';
|
|
7
|
+
/**
|
|
8
|
+
* Calculate cumulative left position for fixed columns
|
|
9
|
+
*/
|
|
10
|
+
function calculateFixedColumnLeft(headers, currentIndex, hasSelection) {
|
|
11
|
+
let left = 0;
|
|
12
|
+
// Add selection column width if present
|
|
13
|
+
if (hasSelection) {
|
|
14
|
+
left += 50; // Default selection column width
|
|
15
|
+
}
|
|
16
|
+
// Sum up widths of all previous fixed left columns
|
|
17
|
+
for (let i = 0; i < currentIndex; i++) {
|
|
18
|
+
if (headers[i].fixed === 'left') {
|
|
19
|
+
const width = headers[i].width;
|
|
20
|
+
left += typeof width === 'number' ? width : Number.parseInt(String(width)) || 150;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
return left;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Get CSS classes for fixed columns
|
|
27
|
+
*/
|
|
28
|
+
function getFixedColumnClasses(header) {
|
|
29
|
+
const classes = [];
|
|
30
|
+
if (header.fixed) {
|
|
31
|
+
classes.push('fixed-column');
|
|
32
|
+
classes.push(`fixed-column-${header.fixed}`);
|
|
33
|
+
}
|
|
34
|
+
return classes.join(' ');
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Renders the table content template
|
|
38
|
+
* @param data - Table content data and event handlers
|
|
39
|
+
* @returns Template for table content
|
|
40
|
+
*/
|
|
41
|
+
export function renderContentTemplate(data) {
|
|
42
|
+
// Check if any columns are fixed left
|
|
43
|
+
const hasFixedLeftColumns = data.headers.some(h => h.fixed === 'left');
|
|
44
|
+
const selectionColumnClass = hasFixedLeftColumns ? 'fixed-column fixed-column-left' : '';
|
|
45
|
+
return html `
|
|
46
|
+
<table>
|
|
47
|
+
<thead>
|
|
48
|
+
<tr>
|
|
49
|
+
${(data.expandable || data.expansionRenderer) || data.selectionMode
|
|
50
|
+
? html `<th class="${selectionColumnClass}" style="${hasFixedLeftColumns ? 'left: 0; width: 50px; min-width: 50px;' : ''}">
|
|
51
|
+
${data.selectionMode === "multiple" /* SelectionMode.Multiple */
|
|
52
|
+
? html `<nr-checkbox
|
|
53
|
+
id="global-check"
|
|
54
|
+
@nr-change=${data.onCheckAll}
|
|
55
|
+
></nr-checkbox>`
|
|
56
|
+
: nothing}
|
|
57
|
+
</th>`
|
|
58
|
+
: nothing}
|
|
59
|
+
${repeat(data.headers, (header, index) => {
|
|
60
|
+
const fixedClasses = getFixedColumnClasses(header);
|
|
61
|
+
const hasSelection = (data.expandable || data.expansionRenderer) || data.selectionMode;
|
|
62
|
+
const leftPosition = header.fixed === 'left'
|
|
63
|
+
? calculateFixedColumnLeft(data.headers, index, !!hasSelection)
|
|
64
|
+
: undefined;
|
|
65
|
+
const width = header.width
|
|
66
|
+
? typeof header.width === 'number' ? `${header.width}px` : header.width
|
|
67
|
+
: undefined;
|
|
68
|
+
return html `
|
|
69
|
+
${data.expandable !== header.key
|
|
70
|
+
? html `<th
|
|
71
|
+
class="${[header.filterable ? 'filterable' : '', fixedClasses].filter(Boolean).join(' ')}"
|
|
72
|
+
style="${leftPosition !== undefined ? `left: ${leftPosition}px;` : ''} ${width ? `width: ${width}; min-width: ${width};` : ''}">
|
|
73
|
+
<div class="th-content">
|
|
74
|
+
<span class="th-text" @click=${() => data.onUpdateSort(index)}>
|
|
75
|
+
${header.name}
|
|
76
|
+
${index === data.sortAttribute.index
|
|
77
|
+
? choose(data.sortAttribute.order, [
|
|
78
|
+
["default" /* SortOrder.Default */, () => html `<nr-icon name="arrow-up-down" size="small"></nr-icon>`],
|
|
79
|
+
["ascending" /* SortOrder.Ascending */, () => html `<nr-icon name="arrow-up" size="small"></nr-icon>`],
|
|
80
|
+
["descending" /* SortOrder.Descending */, () => html `<nr-icon name="arrow-down" size="small"></nr-icon>`],
|
|
81
|
+
])
|
|
82
|
+
: html `<nr-icon name="arrow-up-down" size="small"></nr-icon>`}
|
|
83
|
+
</span>
|
|
84
|
+
${header.filterable && header.filterConfig
|
|
85
|
+
? html `
|
|
86
|
+
<div class="filter-wrapper">
|
|
87
|
+
<button
|
|
88
|
+
class="filter-trigger"
|
|
89
|
+
@click=${(e) => {
|
|
90
|
+
e.stopPropagation();
|
|
91
|
+
data.onToggleColumnFilter(header.key);
|
|
92
|
+
}}
|
|
93
|
+
>
|
|
94
|
+
${renderFilterIcon(data.activeFilterColumn === header.key, data.columnFilters.has(header.key))}
|
|
95
|
+
</button>
|
|
96
|
+
${data.activeFilterColumn === header.key
|
|
97
|
+
? renderColumnFilterTemplate({
|
|
98
|
+
columnKey: header.key,
|
|
99
|
+
filterConfig: header.filterConfig,
|
|
100
|
+
currentValue: data.columnFilters.get(header.key),
|
|
101
|
+
isActive: true,
|
|
102
|
+
onFilterChange: (value) => data.onApplyColumnFilter(header.key, value),
|
|
103
|
+
onClearFilter: () => data.onClearColumnFilter(header.key),
|
|
104
|
+
})
|
|
105
|
+
: nothing}
|
|
106
|
+
</div>
|
|
107
|
+
`
|
|
108
|
+
: nothing}
|
|
109
|
+
</div>
|
|
110
|
+
</th>`
|
|
111
|
+
: nothing}
|
|
112
|
+
`;
|
|
113
|
+
})}
|
|
114
|
+
</tr>
|
|
115
|
+
</thead>
|
|
116
|
+
<tbody>
|
|
117
|
+
${data.loading
|
|
118
|
+
? renderLoadingTemplate(data.host, 5)
|
|
119
|
+
: data.rows.length === 0
|
|
120
|
+
? renderEmptyTemplate(data.host)
|
|
121
|
+
: repeat(data.rows, (row, index) => html `
|
|
122
|
+
<tr class="${data.clickable ? 'clickable' : ''}" @click=${() => { var _a; return (_a = data.onRowClick) === null || _a === void 0 ? void 0 : _a.call(data, row, index); }}>
|
|
123
|
+
${(data.expandable || data.expansionRenderer) && !data.selectionMode
|
|
124
|
+
? html `
|
|
125
|
+
<td
|
|
126
|
+
@click=${() => data.onShowExpandedContent(index)}
|
|
127
|
+
@keydown=${(e) => {
|
|
128
|
+
if (e.key === 'Enter' || e.key === ' ') {
|
|
129
|
+
e.preventDefault();
|
|
130
|
+
data.onShowExpandedContent(index);
|
|
131
|
+
}
|
|
132
|
+
}}
|
|
133
|
+
tabindex="0"
|
|
134
|
+
role="button"
|
|
135
|
+
aria-expanded="${data.expand[index]}"
|
|
136
|
+
aria-label="${data.expand[index] ? 'Collapse row' : 'Expand row'}"
|
|
137
|
+
class="expand-icon ${data.expand[index] ? 'expanded' : ''} ${selectionColumnClass}"
|
|
138
|
+
style="${hasFixedLeftColumns ? 'left: 0; width: 50px; min-width: 50px;' : ''}">
|
|
139
|
+
<nr-icon name="chevron-down" size="small"></nr-icon>
|
|
140
|
+
</td>
|
|
141
|
+
`
|
|
142
|
+
: data.selectionMode
|
|
143
|
+
? choose(data.selectionMode, [
|
|
144
|
+
[
|
|
145
|
+
"multiple" /* SelectionMode.Multiple */,
|
|
146
|
+
() => html `<td class="${selectionColumnClass}" style="${hasFixedLeftColumns ? 'left: 0; width: 50px; min-width: 50px;' : ''}">
|
|
147
|
+
<nr-checkbox
|
|
148
|
+
@nr-change=${(checkOneEvent) => data.onCheckOne(checkOneEvent, index)}
|
|
149
|
+
.checked=${data.selectedItems[index + (data.currentPage - 1) * data.itemPerPage]}
|
|
150
|
+
></nr-checkbox>
|
|
151
|
+
</td>`,
|
|
152
|
+
],
|
|
153
|
+
[
|
|
154
|
+
"single" /* SelectionMode.Single */,
|
|
155
|
+
() => html `<td class="${selectionColumnClass}" style="${hasFixedLeftColumns ? 'left: 0; width: 50px; min-width: 50px;' : ''}">
|
|
156
|
+
<nr-radio
|
|
157
|
+
name="table-row-selection"
|
|
158
|
+
value="${index}"
|
|
159
|
+
@nr-change=${() => data.onSelectOne(index)}
|
|
160
|
+
.checked=${data.selectedItems[index + (data.currentPage - 1) * data.itemPerPage]}
|
|
161
|
+
></nr-radio>
|
|
162
|
+
</td>`,
|
|
163
|
+
],
|
|
164
|
+
])
|
|
165
|
+
: nothing}
|
|
166
|
+
${repeat(data.headers, (header, headerIndex) => {
|
|
167
|
+
const fixedClasses = getFixedColumnClasses(header);
|
|
168
|
+
const hasSelection = (data.expandable || data.expansionRenderer) || data.selectionMode;
|
|
169
|
+
const leftPosition = header.fixed === 'left'
|
|
170
|
+
? calculateFixedColumnLeft(data.headers, headerIndex, !!hasSelection)
|
|
171
|
+
: undefined;
|
|
172
|
+
const width = header.width
|
|
173
|
+
? typeof header.width === 'number' ? `${header.width}px` : header.width
|
|
174
|
+
: undefined;
|
|
175
|
+
const cellValue = row[header.key];
|
|
176
|
+
const cellContent = header.render
|
|
177
|
+
? header.render(cellValue, row, index)
|
|
178
|
+
: cellValue;
|
|
179
|
+
return html `${data.expandable !== header.key
|
|
180
|
+
? html `<td
|
|
181
|
+
class="${fixedClasses}"
|
|
182
|
+
style="${leftPosition !== undefined ? `left: ${leftPosition}px;` : ''} ${width ? `width: ${width}; min-width: ${width};` : ''}">
|
|
183
|
+
${cellContent}
|
|
184
|
+
</td>`
|
|
185
|
+
: nothing}`;
|
|
186
|
+
})}
|
|
187
|
+
</tr>
|
|
188
|
+
${data.expand[index]
|
|
189
|
+
? html `
|
|
190
|
+
<tr class="expansion-row expanded">
|
|
191
|
+
<td colspan=${data.headers.length + ((data.expandable || data.expansionRenderer) || data.selectionMode ? 1 : 0)}>
|
|
192
|
+
<div class="expansion-content">
|
|
193
|
+
${data.expansionRenderer
|
|
194
|
+
? data.expansionRenderer(row, index)
|
|
195
|
+
: data.expandable
|
|
196
|
+
? row[data.expandable]
|
|
197
|
+
: nothing}
|
|
198
|
+
</div>
|
|
199
|
+
</td>
|
|
200
|
+
</tr>
|
|
201
|
+
`
|
|
202
|
+
: nothing}
|
|
203
|
+
`)}
|
|
204
|
+
</tbody>
|
|
205
|
+
</table>
|
|
206
|
+
`;
|
|
207
|
+
}
|
|
208
|
+
//# sourceMappingURL=content.template.js.map
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import type { TableHost } from '../interfaces/table-host.interface';
|
|
2
|
+
/**
|
|
3
|
+
* Renders the empty state template for the table when there is no data
|
|
4
|
+
* @param host - The table host component
|
|
5
|
+
* @returns Empty state template
|
|
6
|
+
*/
|
|
7
|
+
export declare function renderEmptyTemplate(host: TableHost): import("lit-html").TemplateResult<1>;
|
|
8
|
+
//# sourceMappingURL=empty.template.d.ts.map
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { html } from 'lit';
|
|
2
|
+
/**
|
|
3
|
+
* Renders the empty state template for the table when there is no data
|
|
4
|
+
* @param host - The table host component
|
|
5
|
+
* @returns Empty state template
|
|
6
|
+
*/
|
|
7
|
+
export function renderEmptyTemplate(host) {
|
|
8
|
+
// Calculate colspan: headers + selection column (if present)
|
|
9
|
+
const colspan = host.headers.length + (host.selectionMode ? 1 : 0);
|
|
10
|
+
return html `
|
|
11
|
+
<tr class="empty-row">
|
|
12
|
+
<td colspan="${colspan}" class="empty-cell">
|
|
13
|
+
<div class="empty-state">
|
|
14
|
+
${host.emptyIcon
|
|
15
|
+
? html `
|
|
16
|
+
<div class="empty-icon">
|
|
17
|
+
<nr-icon name="${host.emptyIcon}"></nr-icon>
|
|
18
|
+
</div>
|
|
19
|
+
`
|
|
20
|
+
: html `
|
|
21
|
+
<div class="empty-icon">
|
|
22
|
+
<svg
|
|
23
|
+
width="64"
|
|
24
|
+
height="64"
|
|
25
|
+
viewBox="0 0 64 64"
|
|
26
|
+
fill="none"
|
|
27
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
28
|
+
>
|
|
29
|
+
<path
|
|
30
|
+
d="M32 8C18.745 8 8 18.745 8 32s10.745 24 24 24 24-10.745 24-24S45.255 8 32 8zm0 44c-11.028 0-20-8.972-20-20s8.972-20 20-20 20 8.972 20 20-8.972 20-20 20z"
|
|
31
|
+
fill="currentColor"
|
|
32
|
+
opacity="0.3"
|
|
33
|
+
/>
|
|
34
|
+
<path
|
|
35
|
+
d="M32 20c-1.105 0-2 .895-2 2v12c0 1.105.895 2 2 2s2-.895 2-2V22c0-1.105-.895-2-2-2zm0 20c-1.105 0-2 .895-2 2s.895 2 2 2 2-.895 2-2-.895-2-2-2z"
|
|
36
|
+
fill="currentColor"
|
|
37
|
+
/>
|
|
38
|
+
</svg>
|
|
39
|
+
</div>
|
|
40
|
+
`}
|
|
41
|
+
<div class="empty-text">${host.emptyText}</div>
|
|
42
|
+
</div>
|
|
43
|
+
</td>
|
|
44
|
+
</tr>
|
|
45
|
+
`;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=empty.template.js.map
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { TemplateResult } from 'lit';
|
|
2
|
+
export interface FilterTemplateData {
|
|
3
|
+
showInput: boolean;
|
|
4
|
+
value: string;
|
|
5
|
+
onToggleInput: () => void;
|
|
6
|
+
onChange: (event: Event) => void;
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* Renders the filter/search template for the table
|
|
10
|
+
* @param data - Filter data and event handlers
|
|
11
|
+
* @returns Template for search filter
|
|
12
|
+
*/
|
|
13
|
+
export declare function renderFilterTemplate(data: FilterTemplateData): TemplateResult;
|
|
14
|
+
//# sourceMappingURL=filter.template.d.ts.map
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { html, nothing } from 'lit';
|
|
2
|
+
/**
|
|
3
|
+
* Renders the filter/search template for the table
|
|
4
|
+
* @param data - Filter data and event handlers
|
|
5
|
+
* @returns Template for search filter
|
|
6
|
+
*/
|
|
7
|
+
export function renderFilterTemplate(data) {
|
|
8
|
+
return html `
|
|
9
|
+
<div class="filter-container">
|
|
10
|
+
${data.showInput
|
|
11
|
+
? html `
|
|
12
|
+
<nr-icon name="search" size="small" class="search-icon"></nr-icon>
|
|
13
|
+
<input
|
|
14
|
+
type="text"
|
|
15
|
+
placeholder="search"
|
|
16
|
+
@blur=${!data.value.trim() ? data.onToggleInput : nothing}
|
|
17
|
+
@input=${data.onChange}
|
|
18
|
+
/>
|
|
19
|
+
`
|
|
20
|
+
: html `
|
|
21
|
+
<div class="icon-container" @click=${data.onToggleInput}>
|
|
22
|
+
<nr-icon name="search" size="small"></nr-icon>
|
|
23
|
+
</div>
|
|
24
|
+
`}
|
|
25
|
+
</div>
|
|
26
|
+
`;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=filter.template.js.map
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { renderPaginationTemplate, type PaginationTemplateData } from './pagination.template.js';
|
|
2
|
+
export { renderContentTemplate, type ContentTemplateData } from './content.template.js';
|
|
3
|
+
export { renderActionsTemplate, type ActionsTemplateData } from './actions.template.js';
|
|
4
|
+
export { renderFilterTemplate, type FilterTemplateData } from './filter.template.js';
|
|
5
|
+
export { renderColumnFilterTemplate, renderFilterIcon, type ColumnFilterTemplateData } from './column-filter.template.js';
|
|
6
|
+
export { renderLoadingTemplate, renderSpinnerLoadingTemplate } from './loading.template.js';
|
|
7
|
+
export { renderEmptyTemplate } from './empty.template.js';
|
|
8
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export { renderPaginationTemplate } from './pagination.template.js';
|
|
2
|
+
export { renderContentTemplate } from './content.template.js';
|
|
3
|
+
export { renderActionsTemplate } from './actions.template.js';
|
|
4
|
+
export { renderFilterTemplate } from './filter.template.js';
|
|
5
|
+
export { renderColumnFilterTemplate, renderFilterIcon } from './column-filter.template.js';
|
|
6
|
+
export { renderLoadingTemplate, renderSpinnerLoadingTemplate } from './loading.template.js';
|
|
7
|
+
export { renderEmptyTemplate } from './empty.template.js';
|
|
8
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2023 Nuraly, Laabidi Aymen
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import { TemplateResult } from 'lit';
|
|
7
|
+
import { TableHost } from '../interfaces/index.js';
|
|
8
|
+
/**
|
|
9
|
+
* Renders skeleton loading rows for the table
|
|
10
|
+
* @param host - The table host component
|
|
11
|
+
* @param rowCount - Number of skeleton rows to show (default: 5)
|
|
12
|
+
* @returns Template with skeleton rows
|
|
13
|
+
*/
|
|
14
|
+
export declare function renderLoadingTemplate(host: TableHost, rowCount?: number): TemplateResult;
|
|
15
|
+
/**
|
|
16
|
+
* Renders a centered spinner loading indicator
|
|
17
|
+
* @param host - The table host component
|
|
18
|
+
* @returns Template with centered spinner
|
|
19
|
+
*/
|
|
20
|
+
export declare function renderSpinnerLoadingTemplate(host: TableHost): TemplateResult;
|
|
21
|
+
//# sourceMappingURL=loading.template.d.ts.map
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2023 Nuraly, Laabidi Aymen
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import { html } from 'lit';
|
|
7
|
+
/**
|
|
8
|
+
* Renders skeleton loading rows for the table
|
|
9
|
+
* @param host - The table host component
|
|
10
|
+
* @param rowCount - Number of skeleton rows to show (default: 5)
|
|
11
|
+
* @returns Template with skeleton rows
|
|
12
|
+
*/
|
|
13
|
+
export function renderLoadingTemplate(host, rowCount = 5) {
|
|
14
|
+
const hasSelection = !!host.selectionMode;
|
|
15
|
+
return html `
|
|
16
|
+
${Array.from({ length: rowCount }, () => html `
|
|
17
|
+
<tr class="skeleton-row">
|
|
18
|
+
${hasSelection ? html `
|
|
19
|
+
<td class="skeleton-cell selection-skeleton">
|
|
20
|
+
<div class="skeleton-checkbox"></div>
|
|
21
|
+
</td>
|
|
22
|
+
` : ''}
|
|
23
|
+
${host.headers.map(() => html `
|
|
24
|
+
<td class="skeleton-cell">
|
|
25
|
+
<div class="skeleton-content"></div>
|
|
26
|
+
</td>
|
|
27
|
+
`)}
|
|
28
|
+
</tr>
|
|
29
|
+
`)}
|
|
30
|
+
`;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Renders a centered spinner loading indicator
|
|
34
|
+
* @param host - The table host component
|
|
35
|
+
* @returns Template with centered spinner
|
|
36
|
+
*/
|
|
37
|
+
export function renderSpinnerLoadingTemplate(host) {
|
|
38
|
+
const hasSelection = !!host.selectionMode;
|
|
39
|
+
const columnCount = host.headers.length + (hasSelection ? 1 : 0);
|
|
40
|
+
return html `
|
|
41
|
+
<tr class="loading-row">
|
|
42
|
+
<td colspan="${columnCount}" class="loading-cell">
|
|
43
|
+
<div class="loading-spinner-container">
|
|
44
|
+
<div class="loading-spinner"></div>
|
|
45
|
+
<p class="loading-text">Loading data...</p>
|
|
46
|
+
</div>
|
|
47
|
+
</td>
|
|
48
|
+
</tr>
|
|
49
|
+
`;
|
|
50
|
+
}
|
|
51
|
+
//# sourceMappingURL=loading.template.js.map
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { TemplateResult } from 'lit';
|
|
2
|
+
import { Sizes } from '../table.types.js';
|
|
3
|
+
export interface PaginationTemplateData {
|
|
4
|
+
numberOfItems: number;
|
|
5
|
+
itemPerPage: number[];
|
|
6
|
+
selectedItemPerPage: number;
|
|
7
|
+
currentPage: number;
|
|
8
|
+
size: Sizes;
|
|
9
|
+
numberOfPages: number;
|
|
10
|
+
fromItem: number;
|
|
11
|
+
toItem: number;
|
|
12
|
+
enableNext: boolean;
|
|
13
|
+
enablePrevious: boolean;
|
|
14
|
+
onItemPerPageChange: (event: CustomEvent) => void;
|
|
15
|
+
onNextPage: () => void;
|
|
16
|
+
onPreviousPage: () => void;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Renders the pagination template for the table
|
|
20
|
+
* @param data - Pagination data and event handlers
|
|
21
|
+
* @returns Template for pagination UI
|
|
22
|
+
*/
|
|
23
|
+
export declare function renderPaginationTemplate(data: PaginationTemplateData): TemplateResult;
|
|
24
|
+
//# sourceMappingURL=pagination.template.d.ts.map
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { html, nothing } from 'lit';
|
|
2
|
+
/**
|
|
3
|
+
* Renders the pagination template for the table
|
|
4
|
+
* @param data - Pagination data and event handlers
|
|
5
|
+
* @returns Template for pagination UI
|
|
6
|
+
*/
|
|
7
|
+
export function renderPaginationTemplate(data) {
|
|
8
|
+
const selectOptions = data.itemPerPage.map(item => ({
|
|
9
|
+
label: String(item),
|
|
10
|
+
value: String(item)
|
|
11
|
+
}));
|
|
12
|
+
return html `
|
|
13
|
+
<div class="pagination-container" data-size="${data.size}">
|
|
14
|
+
<div class="left-content">
|
|
15
|
+
<span class="select-details">
|
|
16
|
+
<label>Items per page:</label>
|
|
17
|
+
<nr-select
|
|
18
|
+
.options=${selectOptions}
|
|
19
|
+
.value=${String(data.selectedItemPerPage)}
|
|
20
|
+
size="small"
|
|
21
|
+
@nr-change=${data.onItemPerPageChange}
|
|
22
|
+
></nr-select>
|
|
23
|
+
</span>
|
|
24
|
+
<span class="items-details">
|
|
25
|
+
${data.fromItem} - ${data.toItem} of ${data.numberOfItems} items
|
|
26
|
+
</span>
|
|
27
|
+
</div>
|
|
28
|
+
|
|
29
|
+
<div class="right-content">
|
|
30
|
+
<span class="page-details">
|
|
31
|
+
${data.currentPage} of ${data.numberOfPages} pages
|
|
32
|
+
</span>
|
|
33
|
+
<span class="icon-container">
|
|
34
|
+
<nr-icon
|
|
35
|
+
class="left-arrow"
|
|
36
|
+
data-enabled=${data.enablePrevious}
|
|
37
|
+
name="chevron-left" size="small"
|
|
38
|
+
@click=${data.enablePrevious ? data.onPreviousPage : nothing}
|
|
39
|
+
></nr-icon>
|
|
40
|
+
|
|
41
|
+
<nr-icon
|
|
42
|
+
class="right-arrow"
|
|
43
|
+
data-enabled=${data.enableNext}
|
|
44
|
+
name="chevron-right" size="small"
|
|
45
|
+
@click=${data.enableNext ? data.onNextPage : nothing}
|
|
46
|
+
></nr-icon>
|
|
47
|
+
</span>
|
|
48
|
+
</div>
|
|
49
|
+
</div>
|
|
50
|
+
`;
|
|
51
|
+
}
|
|
52
|
+
//# sourceMappingURL=pagination.template.js.map
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2023 Nuraly, Laabidi Aymen
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import { ReactiveControllerHost } from 'lit';
|
|
7
|
+
import { TabItem } from '../tabs.types.js';
|
|
8
|
+
import { BaseComponentController } from '@nuralyui/common/controllers';
|
|
9
|
+
export type { ErrorHandler } from '@nuralyui/common/controllers';
|
|
10
|
+
/**
|
|
11
|
+
* Base interface for tabs host element
|
|
12
|
+
*/
|
|
13
|
+
export interface TabsHost extends EventTarget {
|
|
14
|
+
/** Currently active tab index */
|
|
15
|
+
activeTab: number;
|
|
16
|
+
/** Array of tab items */
|
|
17
|
+
tabs: TabItem[];
|
|
18
|
+
/** Whether component is disabled */
|
|
19
|
+
disabled?: boolean;
|
|
20
|
+
/** Current theme */
|
|
21
|
+
currentTheme: string;
|
|
22
|
+
/** Whether component is available */
|
|
23
|
+
isComponentAvailable(component: string): boolean;
|
|
24
|
+
/** Shadow root access */
|
|
25
|
+
shadowRoot: ShadowRoot | null;
|
|
26
|
+
/** Request update */
|
|
27
|
+
requestUpdate(): void;
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Base interface for tabs controllers
|
|
31
|
+
*/
|
|
32
|
+
export interface TabsBaseController {
|
|
33
|
+
readonly host: TabsHost;
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* Abstract base controller class that implements common functionality
|
|
37
|
+
* for all tabs component controllers
|
|
38
|
+
*/
|
|
39
|
+
export declare abstract class BaseTabsController extends BaseComponentController<TabsHost & ReactiveControllerHost> implements TabsBaseController {
|
|
40
|
+
/**
|
|
41
|
+
* Helper method to check if tab is valid
|
|
42
|
+
*/
|
|
43
|
+
protected isValidTabIndex(index: number): boolean;
|
|
44
|
+
/**
|
|
45
|
+
* Helper method to get tab element by index
|
|
46
|
+
*/
|
|
47
|
+
protected getTabElement(index: number): Element | null;
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=base.controller.d.ts.map
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2023 Nuraly, Laabidi Aymen
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import { BaseComponentController } from '@nuralyui/common/controllers';
|
|
7
|
+
/**
|
|
8
|
+
* Abstract base controller class that implements common functionality
|
|
9
|
+
* for all tabs component controllers
|
|
10
|
+
*/
|
|
11
|
+
export class BaseTabsController extends BaseComponentController {
|
|
12
|
+
/**
|
|
13
|
+
* Helper method to check if tab is valid
|
|
14
|
+
*/
|
|
15
|
+
isValidTabIndex(index) {
|
|
16
|
+
return index >= 0 && index < this.host.tabs.length;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Helper method to get tab element by index
|
|
20
|
+
*/
|
|
21
|
+
getTabElement(index) {
|
|
22
|
+
var _a;
|
|
23
|
+
return ((_a = this.host.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(`[data-index="${index}"]`)) || null;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=base.controller.js.map
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2023 Nuraly, Laabidi Aymen
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import { TabsHost, BaseTabsController } from './base.controller.js';
|
|
7
|
+
import { ReactiveControllerHost } from 'lit';
|
|
8
|
+
/**
|
|
9
|
+
* Drag and drop controller interface for tabs components
|
|
10
|
+
*/
|
|
11
|
+
export interface DragDropController {
|
|
12
|
+
handleDragStart(event: DragEvent): void;
|
|
13
|
+
handleDragOver(event: DragEvent): void;
|
|
14
|
+
handleDragEnter(event: DragEvent): void;
|
|
15
|
+
handleDragLeave(event: DragEvent): void;
|
|
16
|
+
handleDrop(event: DragEvent): void;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Enhanced tabs host interface for drag and drop functionality
|
|
20
|
+
*/
|
|
21
|
+
export interface TabsDragDropHost extends TabsHost {
|
|
22
|
+
editable?: {
|
|
23
|
+
canMove?: boolean;
|
|
24
|
+
};
|
|
25
|
+
dispatchEventWithMetadata(eventName: string, detail: any): void;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Drag and drop controller manages drag and drop functionality for tabs components
|
|
29
|
+
* Handles all drag events and tab reordering
|
|
30
|
+
*/
|
|
31
|
+
export declare class TabsDragDropController extends BaseTabsController implements DragDropController {
|
|
32
|
+
protected _host: TabsDragDropHost & ReactiveControllerHost;
|
|
33
|
+
private dragOverHandler;
|
|
34
|
+
constructor(host: TabsDragDropHost & ReactiveControllerHost);
|
|
35
|
+
get host(): TabsDragDropHost & ReactiveControllerHost;
|
|
36
|
+
hostConnected(): void;
|
|
37
|
+
hostDisconnected(): void;
|
|
38
|
+
/**
|
|
39
|
+
* Handle drag start event
|
|
40
|
+
* @param event - The drag event
|
|
41
|
+
*/
|
|
42
|
+
handleDragStart(event: DragEvent): void;
|
|
43
|
+
/**
|
|
44
|
+
* Handle drag over event
|
|
45
|
+
* @param event - The drag event
|
|
46
|
+
*/
|
|
47
|
+
handleDragOver(event: DragEvent): void;
|
|
48
|
+
/**
|
|
49
|
+
* Handle drag enter event
|
|
50
|
+
* @param event - The drag event
|
|
51
|
+
*/
|
|
52
|
+
handleDragEnter(event: DragEvent): void;
|
|
53
|
+
/**
|
|
54
|
+
* Handle drag leave event
|
|
55
|
+
* @param event - The drag event
|
|
56
|
+
*/
|
|
57
|
+
handleDragLeave(event: DragEvent): void;
|
|
58
|
+
/**
|
|
59
|
+
* Handle drop event
|
|
60
|
+
* @param event - The drag event
|
|
61
|
+
*/
|
|
62
|
+
handleDrop(event: DragEvent): void;
|
|
63
|
+
/**
|
|
64
|
+
* Check if tab can be moved (drag and drop enabled)
|
|
65
|
+
*/
|
|
66
|
+
canMoveTab(): boolean;
|
|
67
|
+
/**
|
|
68
|
+
* Validate if tab reorder is valid
|
|
69
|
+
*/
|
|
70
|
+
private isValidTabReorder;
|
|
71
|
+
/**
|
|
72
|
+
* Perform tab reordering
|
|
73
|
+
*/
|
|
74
|
+
private performTabReorder;
|
|
75
|
+
/**
|
|
76
|
+
* Clean up drag-related CSS classes
|
|
77
|
+
*/
|
|
78
|
+
private cleanupDragClasses;
|
|
79
|
+
/**
|
|
80
|
+
* Get draggable state for tab element
|
|
81
|
+
*/
|
|
82
|
+
getDraggableState(): boolean;
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=dragdrop.controller.d.ts.map
|