@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,85 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2024 Nuraly, Laabidi Aymen
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
import { LitElement } from 'lit';
|
|
7
|
+
import type { ChatMessage, ChatUser } from './chat-panel.types.js';
|
|
8
|
+
/**
|
|
9
|
+
* Shared chat panel — renders messages, input bar, reactions, context menu.
|
|
10
|
+
* Used inside both the floating presence chat and the full messages page.
|
|
11
|
+
*
|
|
12
|
+
* @fires message-send - User sends a message. Detail: `{ text, replyTo? }`
|
|
13
|
+
* @fires message-edit - User edits a message. Detail: `{ messageId, content }`
|
|
14
|
+
* @fires message-delete - User deletes a message. Detail: `{ messageId }`
|
|
15
|
+
* @fires message-react - User reacts to a message. Detail: `{ messageId, emoji }`
|
|
16
|
+
* @fires typing-start
|
|
17
|
+
* @fires typing-stop
|
|
18
|
+
* @fires file-select - User selected a file. Detail: `{ file: File, imageOnly: boolean }`
|
|
19
|
+
*/
|
|
20
|
+
export declare class NrChatPanelElement extends LitElement {
|
|
21
|
+
static styles: import("lit").CSSResult;
|
|
22
|
+
/** Messages to display */
|
|
23
|
+
messages: ChatMessage[];
|
|
24
|
+
/** Current user info */
|
|
25
|
+
currentUser: ChatUser | null;
|
|
26
|
+
/** Conversation ID */
|
|
27
|
+
conversationId: string;
|
|
28
|
+
/** Whether this is a group conversation */
|
|
29
|
+
isGroup: boolean;
|
|
30
|
+
/** Loading state */
|
|
31
|
+
loading: boolean;
|
|
32
|
+
/** Compact mode for floating panels */
|
|
33
|
+
compact: boolean;
|
|
34
|
+
/** Empty state text */
|
|
35
|
+
emptyText: string;
|
|
36
|
+
/** Hide the built-in input bar (for pages that provide their own) */
|
|
37
|
+
hideInput: boolean;
|
|
38
|
+
private _showEmoji;
|
|
39
|
+
private _contextMenu;
|
|
40
|
+
private _replyTo;
|
|
41
|
+
private _editingIdx;
|
|
42
|
+
private _typing;
|
|
43
|
+
private _typingTimer;
|
|
44
|
+
private _longPressTimer;
|
|
45
|
+
private _touchMoved;
|
|
46
|
+
updated(changed: Map<string, unknown>): void;
|
|
47
|
+
/** Add a typing indicator */
|
|
48
|
+
addTyping(userName: string): void;
|
|
49
|
+
/** Remove a typing indicator */
|
|
50
|
+
removeTyping(userName: string): void;
|
|
51
|
+
private _sendMessage;
|
|
52
|
+
private _onInputKeydown;
|
|
53
|
+
private _toggleEmoji;
|
|
54
|
+
private _insertEmoji;
|
|
55
|
+
private _menuPos;
|
|
56
|
+
private _showContextMenuHandler;
|
|
57
|
+
private _onTouchStart;
|
|
58
|
+
private _onTouchEnd;
|
|
59
|
+
private _onTouchMove;
|
|
60
|
+
private _onMsgTap;
|
|
61
|
+
private _hideContextMenu;
|
|
62
|
+
private _deleteMsg;
|
|
63
|
+
private _replyMsg;
|
|
64
|
+
private _editMsg;
|
|
65
|
+
private _confirmEdit;
|
|
66
|
+
private _onEditKeydown;
|
|
67
|
+
private _reactMsg;
|
|
68
|
+
private _toggleAudioPlay;
|
|
69
|
+
private _onAudioTimeUpdate;
|
|
70
|
+
private _onAudioEnded;
|
|
71
|
+
private _pickFile;
|
|
72
|
+
private _playSound;
|
|
73
|
+
render(): import("lit-html").TemplateResult<1>;
|
|
74
|
+
private _renderMessage;
|
|
75
|
+
private _renderAttachment;
|
|
76
|
+
private _renderContextMenu;
|
|
77
|
+
private _renderEmojiPicker;
|
|
78
|
+
private _renderInputBar;
|
|
79
|
+
}
|
|
80
|
+
declare global {
|
|
81
|
+
interface HTMLElementTagNameMap {
|
|
82
|
+
'nr-chat-panel': NrChatPanelElement;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
//# sourceMappingURL=chat-panel.component.d.ts.map
|
|
@@ -0,0 +1,510 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @license
|
|
3
|
+
* Copyright 2024 Nuraly, Laabidi Aymen
|
|
4
|
+
* SPDX-License-Identifier: MIT
|
|
5
|
+
*/
|
|
6
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
7
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
8
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
9
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
10
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
11
|
+
};
|
|
12
|
+
import { LitElement, html, nothing } from 'lit';
|
|
13
|
+
import { customElement, property, state } from 'lit/decorators.js';
|
|
14
|
+
import { chatPanelStyles } from './chat-panel.style.js';
|
|
15
|
+
const REACTIONS = [
|
|
16
|
+
{ key: '👍', label: 'Like' },
|
|
17
|
+
{ key: '❤️', label: 'Love' },
|
|
18
|
+
{ key: '😂', label: 'Haha' },
|
|
19
|
+
{ key: '😮', label: 'Wow' },
|
|
20
|
+
{ key: '😢', label: 'Sad' },
|
|
21
|
+
{ key: '🔥', label: 'Fire' },
|
|
22
|
+
];
|
|
23
|
+
const EMOJI_GRID = ['😀', '😂', '🥰', '😎', '🤔', '🎉', '✨', '🙏', '💯', '🚀', '👏', '😍', '🤣', '💪', '😊', '🥳', '😤', '💀', '🫡', '👀', '💜', '🤝', '⭐', '🙌'];
|
|
24
|
+
const svgCheck = html `<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><polyline points="20 6 9 17 4 12"/></svg>`;
|
|
25
|
+
const svgCheckDouble = html `<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><polyline points="18 6 7 17 2 12"/><polyline points="23 6 12 17" opacity="0.5"/></svg>`;
|
|
26
|
+
const svgCheckDoubleRead = html `<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="#7c3aed" stroke-width="2"><polyline points="18 6 7 17 2 12"/><polyline points="23 6 12 17"/></svg>`;
|
|
27
|
+
const svgSend = html `<svg width="18" height="18" viewBox="0 0 24 24" fill="currentColor"><path d="M2.01 21L23 12 2.01 3 2 10l15 2-15 2z"/></svg>`;
|
|
28
|
+
const svgSmile = html `<svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><circle cx="12" cy="12" r="10"/><path d="M8 14s1.5 2 4 2 4-2 4-2"/><line x1="9" y1="9" x2="9.01" y2="9"/><line x1="15" y1="9" x2="15.01" y2="9"/></svg>`;
|
|
29
|
+
const svgPlay = html `<svg width="14" height="14" viewBox="0 0 24 24" fill="currentColor"><polygon points="5 3 19 12 5 21 5 3"/></svg>`;
|
|
30
|
+
const svgFile = html `<svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M14 2H6a2 2 0 00-2 2v16a2 2 0 002 2h12a2 2 0 002-2V8z"/><polyline points="14 2 14 8 20 8"/></svg>`;
|
|
31
|
+
const svgDownload = html `<svg width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2"><path d="M21 15v4a2 2 0 01-2 2H5a2 2 0 01-2-2v-4"/><polyline points="7 10 12 15 17 10"/><line x1="12" y1="15" x2="12" y2="3"/></svg>`;
|
|
32
|
+
const svgPhone = html `<svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M22 16.92v3a2 2 0 01-2.18 2 19.79 19.79 0 01-8.63-3.07 19.5 19.5 0 01-6-6 19.79 19.79 0 01-3.07-8.67A2 2 0 014.11 2h3a2 2 0 012 1.72c.127.96.361 1.903.7 2.81a2 2 0 01-.45 2.11L8.09 9.91a16 16 0 006 6l1.27-1.27a2 2 0 012.11-.45c.907.339 1.85.573 2.81.7A2 2 0 0122 16.92z"/></svg>`;
|
|
33
|
+
const svgVideo = html `<svg width="16" height="16" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><polygon points="23 7 16 12 23 17 23 7"/><rect x="1" y="5" width="15" height="14" rx="2" ry="2"/></svg>`;
|
|
34
|
+
const svgChat = html `<svg width="36" height="36" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1"><path d="M21 15a2 2 0 0 1-2 2H7l-4 4V5a2 2 0 0 1 2-2h14a2 2 0 0 1 2 2z"/></svg>`;
|
|
35
|
+
const svgAttach = html `<svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><path d="M21.44 11.05l-9.19 9.19a6 6 0 01-8.49-8.49l9.19-9.19a4 4 0 015.66 5.66l-9.2 9.19a2 2 0 01-2.83-2.83l8.49-8.48"/></svg>`;
|
|
36
|
+
const svgImage = html `<svg width="18" height="18" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1.5"><rect x="3" y="3" width="18" height="18" rx="2" ry="2"/><circle cx="8.5" cy="8.5" r="1.5"/><polyline points="21 15 16 10 5 21"/></svg>`;
|
|
37
|
+
/**
|
|
38
|
+
* Shared chat panel — renders messages, input bar, reactions, context menu.
|
|
39
|
+
* Used inside both the floating presence chat and the full messages page.
|
|
40
|
+
*
|
|
41
|
+
* @fires message-send - User sends a message. Detail: `{ text, replyTo? }`
|
|
42
|
+
* @fires message-edit - User edits a message. Detail: `{ messageId, content }`
|
|
43
|
+
* @fires message-delete - User deletes a message. Detail: `{ messageId }`
|
|
44
|
+
* @fires message-react - User reacts to a message. Detail: `{ messageId, emoji }`
|
|
45
|
+
* @fires typing-start
|
|
46
|
+
* @fires typing-stop
|
|
47
|
+
* @fires file-select - User selected a file. Detail: `{ file: File, imageOnly: boolean }`
|
|
48
|
+
*/
|
|
49
|
+
let NrChatPanelElement = class NrChatPanelElement extends LitElement {
|
|
50
|
+
constructor() {
|
|
51
|
+
super(...arguments);
|
|
52
|
+
/** Messages to display */
|
|
53
|
+
this.messages = [];
|
|
54
|
+
/** Current user info */
|
|
55
|
+
this.currentUser = null;
|
|
56
|
+
/** Conversation ID */
|
|
57
|
+
this.conversationId = '';
|
|
58
|
+
/** Whether this is a group conversation */
|
|
59
|
+
this.isGroup = false;
|
|
60
|
+
/** Loading state */
|
|
61
|
+
this.loading = false;
|
|
62
|
+
/** Compact mode for floating panels */
|
|
63
|
+
this.compact = false;
|
|
64
|
+
/** Empty state text */
|
|
65
|
+
this.emptyText = 'No messages yet';
|
|
66
|
+
/** Hide the built-in input bar (for pages that provide their own) */
|
|
67
|
+
this.hideInput = false;
|
|
68
|
+
this._showEmoji = false;
|
|
69
|
+
this._contextMenu = null;
|
|
70
|
+
this._replyTo = null;
|
|
71
|
+
this._editingIdx = null;
|
|
72
|
+
this._typing = [];
|
|
73
|
+
this._typingTimer = null;
|
|
74
|
+
this._longPressTimer = null;
|
|
75
|
+
this._touchMoved = false;
|
|
76
|
+
}
|
|
77
|
+
updated(changed) {
|
|
78
|
+
// Auto-scroll on new messages
|
|
79
|
+
if (changed.has('messages')) {
|
|
80
|
+
requestAnimationFrame(() => {
|
|
81
|
+
var _a;
|
|
82
|
+
const el = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.chat-messages');
|
|
83
|
+
if (el)
|
|
84
|
+
el.scrollTop = el.scrollHeight;
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
// ── Public methods (called by parent for socket events) ──
|
|
89
|
+
/** Add a typing indicator */
|
|
90
|
+
addTyping(userName) {
|
|
91
|
+
if (!this._typing.includes(userName)) {
|
|
92
|
+
this._typing = [...this._typing, userName];
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
/** Remove a typing indicator */
|
|
96
|
+
removeTyping(userName) {
|
|
97
|
+
this._typing = this._typing.filter(n => n !== userName);
|
|
98
|
+
}
|
|
99
|
+
// ── Send ──
|
|
100
|
+
_sendMessage() {
|
|
101
|
+
var _a;
|
|
102
|
+
const input = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.chat-input textarea');
|
|
103
|
+
if (!(input === null || input === void 0 ? void 0 : input.value.trim()))
|
|
104
|
+
return;
|
|
105
|
+
const text = input.value.trim();
|
|
106
|
+
input.value = '';
|
|
107
|
+
input.focus();
|
|
108
|
+
this.dispatchEvent(new CustomEvent('message-send', {
|
|
109
|
+
detail: { text, replyTo: this._replyTo || undefined },
|
|
110
|
+
bubbles: true, composed: true,
|
|
111
|
+
}));
|
|
112
|
+
this._replyTo = null;
|
|
113
|
+
this._showEmoji = false;
|
|
114
|
+
this._playSound();
|
|
115
|
+
}
|
|
116
|
+
_onInputKeydown(e) {
|
|
117
|
+
if (e.key === 'Enter' && !e.shiftKey) {
|
|
118
|
+
e.preventDefault();
|
|
119
|
+
this._sendMessage();
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
this.dispatchEvent(new CustomEvent('typing-start', { bubbles: true, composed: true }));
|
|
123
|
+
clearTimeout(this._typingTimer);
|
|
124
|
+
this._typingTimer = setTimeout(() => {
|
|
125
|
+
this.dispatchEvent(new CustomEvent('typing-stop', { bubbles: true, composed: true }));
|
|
126
|
+
}, 2000);
|
|
127
|
+
}
|
|
128
|
+
// ── Emoji ──
|
|
129
|
+
_toggleEmoji() { this._showEmoji = !this._showEmoji; }
|
|
130
|
+
_insertEmoji(emoji) {
|
|
131
|
+
var _a;
|
|
132
|
+
const input = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.chat-input textarea');
|
|
133
|
+
if (input) {
|
|
134
|
+
input.value += emoji;
|
|
135
|
+
input.focus();
|
|
136
|
+
}
|
|
137
|
+
this._showEmoji = false;
|
|
138
|
+
}
|
|
139
|
+
// ── Context menu ──
|
|
140
|
+
_menuPos(target) {
|
|
141
|
+
const bubble = (target.closest('.msg-bubble') || target.closest('.msg-row'));
|
|
142
|
+
if (!bubble)
|
|
143
|
+
return { y: 0, left: 0 };
|
|
144
|
+
const rect = bubble.getBoundingClientRect();
|
|
145
|
+
const isMe = !!target.closest('.msg-row.me');
|
|
146
|
+
const menuH = isMe ? 140 : 80;
|
|
147
|
+
const y = rect.top > menuH + 12 ? rect.top - menuH - 4 : rect.bottom + 4;
|
|
148
|
+
if (isMe)
|
|
149
|
+
return { y, right: Math.max(8, window.innerWidth - rect.right) };
|
|
150
|
+
return { y, left: Math.max(8, rect.left) };
|
|
151
|
+
}
|
|
152
|
+
_showContextMenuHandler(e, msgIdx) {
|
|
153
|
+
e.preventDefault();
|
|
154
|
+
this._contextMenu = Object.assign({ msgIdx }, this._menuPos(e.target));
|
|
155
|
+
}
|
|
156
|
+
_onTouchStart(e, msgIdx) {
|
|
157
|
+
this._touchMoved = false;
|
|
158
|
+
this._longPressTimer = setTimeout(() => {
|
|
159
|
+
var _a;
|
|
160
|
+
e.preventDefault();
|
|
161
|
+
(_a = window.getSelection()) === null || _a === void 0 ? void 0 : _a.removeAllRanges();
|
|
162
|
+
this._contextMenu = Object.assign({ msgIdx }, this._menuPos(e.target));
|
|
163
|
+
this._touchMoved = true;
|
|
164
|
+
}, 500);
|
|
165
|
+
}
|
|
166
|
+
_onTouchEnd() { clearTimeout(this._longPressTimer); }
|
|
167
|
+
_onTouchMove() { this._touchMoved = true; clearTimeout(this._longPressTimer); }
|
|
168
|
+
_onMsgTap(e, msgIdx) {
|
|
169
|
+
if (!window.matchMedia('(max-width: 640px)').matches)
|
|
170
|
+
return;
|
|
171
|
+
if (this._touchMoved)
|
|
172
|
+
return;
|
|
173
|
+
const target = e.target;
|
|
174
|
+
if (target.closest('.reaction') || target.closest('.audio-play-btn') || target.closest('.file-card') || target.closest('.edit-inline'))
|
|
175
|
+
return;
|
|
176
|
+
e.stopPropagation();
|
|
177
|
+
this._contextMenu = Object.assign({ msgIdx }, this._menuPos(target));
|
|
178
|
+
}
|
|
179
|
+
_hideContextMenu() { this._contextMenu = null; }
|
|
180
|
+
// ── Message actions ──
|
|
181
|
+
_deleteMsg(idx) {
|
|
182
|
+
const msg = this.messages[idx];
|
|
183
|
+
if (msg === null || msg === void 0 ? void 0 : msg.id) {
|
|
184
|
+
this.dispatchEvent(new CustomEvent('message-delete', {
|
|
185
|
+
detail: { messageId: msg.id }, bubbles: true, composed: true,
|
|
186
|
+
}));
|
|
187
|
+
}
|
|
188
|
+
this._contextMenu = null;
|
|
189
|
+
}
|
|
190
|
+
_replyMsg(idx) {
|
|
191
|
+
var _a, _b;
|
|
192
|
+
const msg = this.messages[idx];
|
|
193
|
+
if (msg) {
|
|
194
|
+
this._replyTo = { text: msg.text, from: msg.from };
|
|
195
|
+
(_b = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.chat-input textarea')) === null || _b === void 0 ? void 0 : _b.focus();
|
|
196
|
+
}
|
|
197
|
+
this._contextMenu = null;
|
|
198
|
+
}
|
|
199
|
+
_editMsg(idx) {
|
|
200
|
+
this._editingIdx = idx;
|
|
201
|
+
this._contextMenu = null;
|
|
202
|
+
requestAnimationFrame(() => {
|
|
203
|
+
var _a;
|
|
204
|
+
const input = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.edit-input');
|
|
205
|
+
if (input) {
|
|
206
|
+
input.focus();
|
|
207
|
+
input.select();
|
|
208
|
+
}
|
|
209
|
+
});
|
|
210
|
+
}
|
|
211
|
+
_confirmEdit(idx) {
|
|
212
|
+
var _a;
|
|
213
|
+
const input = (_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.edit-input');
|
|
214
|
+
const content = input === null || input === void 0 ? void 0 : input.value.trim();
|
|
215
|
+
if (!content) {
|
|
216
|
+
this._editingIdx = null;
|
|
217
|
+
return;
|
|
218
|
+
}
|
|
219
|
+
const msg = this.messages[idx];
|
|
220
|
+
if (msg === null || msg === void 0 ? void 0 : msg.id) {
|
|
221
|
+
this.dispatchEvent(new CustomEvent('message-edit', {
|
|
222
|
+
detail: { messageId: msg.id, content }, bubbles: true, composed: true,
|
|
223
|
+
}));
|
|
224
|
+
}
|
|
225
|
+
this._editingIdx = null;
|
|
226
|
+
}
|
|
227
|
+
_onEditKeydown(e, idx) {
|
|
228
|
+
if (e.key === 'Enter' && !e.shiftKey) {
|
|
229
|
+
e.preventDefault();
|
|
230
|
+
this._confirmEdit(idx);
|
|
231
|
+
}
|
|
232
|
+
else if (e.key === 'Escape') {
|
|
233
|
+
this._editingIdx = null;
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
_reactMsg(idx, emoji) {
|
|
237
|
+
const msg = this.messages[idx];
|
|
238
|
+
if (msg === null || msg === void 0 ? void 0 : msg.id) {
|
|
239
|
+
this.dispatchEvent(new CustomEvent('message-react', {
|
|
240
|
+
detail: { messageId: msg.id, emoji }, bubbles: true, composed: true,
|
|
241
|
+
}));
|
|
242
|
+
}
|
|
243
|
+
this._contextMenu = null;
|
|
244
|
+
}
|
|
245
|
+
// ── Audio player ──
|
|
246
|
+
_toggleAudioPlay(e) {
|
|
247
|
+
var _a;
|
|
248
|
+
const btn = e.currentTarget;
|
|
249
|
+
const container = btn.closest('.audio-msg');
|
|
250
|
+
const audio = container === null || container === void 0 ? void 0 : container.querySelector('audio');
|
|
251
|
+
if (!audio)
|
|
252
|
+
return;
|
|
253
|
+
if (audio.paused) {
|
|
254
|
+
(_a = this.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelectorAll('.audio-msg audio').forEach((a) => {
|
|
255
|
+
if (a !== audio && !a.paused) {
|
|
256
|
+
a.pause();
|
|
257
|
+
a.currentTime = 0;
|
|
258
|
+
}
|
|
259
|
+
});
|
|
260
|
+
audio.play().catch(() => { });
|
|
261
|
+
}
|
|
262
|
+
else {
|
|
263
|
+
audio.pause();
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
_onAudioTimeUpdate(e) {
|
|
267
|
+
const audio = e.target;
|
|
268
|
+
const container = audio.closest('.audio-msg');
|
|
269
|
+
if (!container || !audio.duration)
|
|
270
|
+
return;
|
|
271
|
+
const bars = container.querySelectorAll('.a-bar');
|
|
272
|
+
const progress = audio.currentTime / audio.duration;
|
|
273
|
+
const filledCount = Math.floor(progress * bars.length);
|
|
274
|
+
bars.forEach((bar, idx) => bar.classList.toggle('played', idx <= filledCount));
|
|
275
|
+
}
|
|
276
|
+
_onAudioEnded(e) {
|
|
277
|
+
const audio = e.target;
|
|
278
|
+
const container = audio.closest('.audio-msg');
|
|
279
|
+
container === null || container === void 0 ? void 0 : container.querySelectorAll('.a-bar').forEach(bar => bar.classList.remove('played'));
|
|
280
|
+
}
|
|
281
|
+
// ── File picker ──
|
|
282
|
+
_pickFile(imageOnly = false) {
|
|
283
|
+
const input = document.createElement('input');
|
|
284
|
+
input.type = 'file';
|
|
285
|
+
if (imageOnly)
|
|
286
|
+
input.accept = 'image/jpeg,image/png,image/gif,image/webp,image/heic,image/heif';
|
|
287
|
+
input.style.cssText = 'position:fixed;top:-9999px;left:-9999px;opacity:0';
|
|
288
|
+
document.body.appendChild(input);
|
|
289
|
+
input.onchange = () => {
|
|
290
|
+
var _a;
|
|
291
|
+
const file = (_a = input.files) === null || _a === void 0 ? void 0 : _a[0];
|
|
292
|
+
if (file) {
|
|
293
|
+
this.dispatchEvent(new CustomEvent('file-select', {
|
|
294
|
+
detail: { file, imageOnly }, bubbles: true, composed: true,
|
|
295
|
+
}));
|
|
296
|
+
}
|
|
297
|
+
try {
|
|
298
|
+
document.body.removeChild(input);
|
|
299
|
+
}
|
|
300
|
+
catch (_b) { }
|
|
301
|
+
};
|
|
302
|
+
input.click();
|
|
303
|
+
}
|
|
304
|
+
// ── Sound ──
|
|
305
|
+
_playSound() {
|
|
306
|
+
try {
|
|
307
|
+
const ctx = new AudioContext();
|
|
308
|
+
const gain = ctx.createGain();
|
|
309
|
+
gain.connect(ctx.destination);
|
|
310
|
+
gain.gain.value = 0.12;
|
|
311
|
+
const o = ctx.createOscillator();
|
|
312
|
+
o.connect(gain);
|
|
313
|
+
o.type = 'sine';
|
|
314
|
+
o.frequency.setValueAtTime(600, ctx.currentTime);
|
|
315
|
+
o.frequency.setValueAtTime(900, ctx.currentTime + 0.08);
|
|
316
|
+
gain.gain.exponentialRampToValueAtTime(0.001, ctx.currentTime + 0.15);
|
|
317
|
+
o.start(ctx.currentTime);
|
|
318
|
+
o.stop(ctx.currentTime + 0.15);
|
|
319
|
+
setTimeout(() => ctx.close(), 500);
|
|
320
|
+
}
|
|
321
|
+
catch (_a) { }
|
|
322
|
+
}
|
|
323
|
+
// ── Render ──
|
|
324
|
+
render() {
|
|
325
|
+
if (this.loading)
|
|
326
|
+
return html `<div class="loading">Loading...</div>`;
|
|
327
|
+
return html `
|
|
328
|
+
${this.messages.length === 0
|
|
329
|
+
? html `<div class="empty-state">${svgChat}<span>${this.emptyText}</span></div>`
|
|
330
|
+
: html `
|
|
331
|
+
<div class="chat-messages" @click=${() => this._hideContextMenu()} @touchstart=${() => { if (this._contextMenu)
|
|
332
|
+
this._hideContextMenu(); }}>
|
|
333
|
+
${this.messages.map((m, i, arr) => this._renderMessage(m, i, arr))}
|
|
334
|
+
</div>
|
|
335
|
+
`}
|
|
336
|
+
|
|
337
|
+
${this._contextMenu ? this._renderContextMenu() : nothing}
|
|
338
|
+
${this._typing.length > 0 ? html `<div class="typing-indicator">${this._typing.join(', ')} typing...</div>` : nothing}
|
|
339
|
+
${this._replyTo ? html `
|
|
340
|
+
<div class="reply-bar">
|
|
341
|
+
<span class="reply-text">Replying to: ${this._replyTo.text}</span>
|
|
342
|
+
<button @click=${() => { this._replyTo = null; }}>✕</button>
|
|
343
|
+
</div>
|
|
344
|
+
` : nothing}
|
|
345
|
+
${this._showEmoji ? this._renderEmojiPicker() : nothing}
|
|
346
|
+
${this.hideInput ? nothing : this._renderInputBar()}
|
|
347
|
+
`;
|
|
348
|
+
}
|
|
349
|
+
_renderMessage(m, i, arr) {
|
|
350
|
+
var _a;
|
|
351
|
+
if (m.from === 'date')
|
|
352
|
+
return html `<div class="date-sep">${m.text}</div>`;
|
|
353
|
+
if (m.deleted)
|
|
354
|
+
return html `<div class="msg-row system"><div class="msg-bubble"><div class="msg them msg-deleted">This message was deleted</div></div></div>`;
|
|
355
|
+
const prevMsg = i > 0 ? arr[i - 1] : null;
|
|
356
|
+
const showSenderName = this.isGroup && m.from === 'them' && (!prevMsg || prevMsg.from !== 'them' || prevMsg.senderId !== m.senderId);
|
|
357
|
+
return html `
|
|
358
|
+
<div class="msg-row ${m.from}"
|
|
359
|
+
@contextmenu=${(e) => this._showContextMenuHandler(e, i)}
|
|
360
|
+
@touchstart=${(e) => this._onTouchStart(e, i)}
|
|
361
|
+
@touchend=${() => this._onTouchEnd()}
|
|
362
|
+
@touchmove=${() => this._onTouchMove()}
|
|
363
|
+
@click=${(e) => this._onMsgTap(e, i)}>
|
|
364
|
+
${m.from === 'them' ? html `<div class="msg-avatar" style="background:${m.senderColor || '#7c3aed'}">${(m.senderInitials || '?').charAt(0)}</div>` : nothing}
|
|
365
|
+
<div class="msg-bubble" @dblclick=${m.from === 'me' && !m.deleted ? () => this._editMsg(i) : undefined}>
|
|
366
|
+
${showSenderName ? html `<div class="msg-sender-name" style="color:${m.senderColor || '#7c3aed'}">${m.senderName}</div>` : nothing}
|
|
367
|
+
${m.replyTo ? html `<div class="msg-reply-quote">${m.replyTo.text}</div>` : nothing}
|
|
368
|
+
${this._renderAttachment(m)}
|
|
369
|
+
${this._editingIdx === i
|
|
370
|
+
? html `<div class="edit-inline"><input class="edit-input" type="text" .value=${m.text || ''} @keydown=${(e) => this._onEditKeydown(e, i)}><button class="edit-confirm" @click=${() => this._confirmEdit(i)}>✓</button><button class="edit-cancel" @click=${() => { this._editingIdx = null; }}>✕</button></div>`
|
|
371
|
+
: m.text ? html `<div class="msg ${m.from}">${m.text}${m.edited ? html ` <span class="msg-edited">(edited)</span>` : nothing}${m.encrypted ? html `<span class="msg-e2e" title="End-to-end encrypted">🔒</span>` : nothing}</div>` : nothing}
|
|
372
|
+
<div class="msg-footer ${m.from}">
|
|
373
|
+
<span class="msg-time">${m.time || ''}</span>
|
|
374
|
+
${m.from === 'me' ? html `<span class="msg-read">${m.status === 'read' ? svgCheckDoubleRead : m.status === 'delivered' ? svgCheckDouble : svgCheck}</span>` : nothing}
|
|
375
|
+
</div>
|
|
376
|
+
${((_a = m.reactions) === null || _a === void 0 ? void 0 : _a.length) ? html `
|
|
377
|
+
<div class="msg-reactions">
|
|
378
|
+
${m.reactions.map(r => {
|
|
379
|
+
var _a;
|
|
380
|
+
return html `
|
|
381
|
+
<span class="reaction ${((_a = r.users) === null || _a === void 0 ? void 0 : _a.includes('me')) ? 'mine' : ''}" @click=${() => this._reactMsg(i, r.emoji)}>${r.emoji} <span class="count">${r.count}</span></span>
|
|
382
|
+
`;
|
|
383
|
+
})}
|
|
384
|
+
</div>
|
|
385
|
+
` : nothing}
|
|
386
|
+
</div>
|
|
387
|
+
</div>
|
|
388
|
+
`;
|
|
389
|
+
}
|
|
390
|
+
_renderAttachment(m) {
|
|
391
|
+
var _a;
|
|
392
|
+
const a = m.attachment;
|
|
393
|
+
if (!a)
|
|
394
|
+
return nothing;
|
|
395
|
+
if (a.type === 'call') {
|
|
396
|
+
const icon = a.callType === 'video' ? svgVideo : svgPhone;
|
|
397
|
+
const color = (a.callStatus === 'missed' || a.callStatus === 'declined') ? '#ef4444' : '#22c55e';
|
|
398
|
+
return html `<div class="msg-call-log">
|
|
399
|
+
<span style="color:${color}">${icon}</span>
|
|
400
|
+
<div class="msg-call-info">
|
|
401
|
+
<div class="msg-call-type">${a.callType === 'video' ? 'Video call' : 'Voice call'}</div>
|
|
402
|
+
<div class="msg-call-status ${a.callStatus}">${a.callStatus === 'completed' ? (a.duration || 'Ended') : a.callStatus === 'declined' ? 'Declined' : 'Missed'}</div>
|
|
403
|
+
</div>
|
|
404
|
+
</div>`;
|
|
405
|
+
}
|
|
406
|
+
if (a.type === 'image') {
|
|
407
|
+
return html `<div class="msg-attachment"><img src="${a.decryptedUrl || a.url}" alt="${a.name || 'Image'}"></div>`;
|
|
408
|
+
}
|
|
409
|
+
if (a.type === 'audio') {
|
|
410
|
+
const waveform = ((_a = a.waveform) === null || _a === void 0 ? void 0 : _a.length) ? a.waveform : Array(36).fill(0.15);
|
|
411
|
+
return html `<div class="msg-attachment"><div class="audio-msg">
|
|
412
|
+
<button class="audio-play-btn" @click=${(e) => this._toggleAudioPlay(e)}>${svgPlay}</button>
|
|
413
|
+
<div class="audio-bars">${waveform.map((h) => html `<div class="a-bar" style="height:${Math.round(h * 22 + 3)}px"></div>`)}</div>
|
|
414
|
+
<span class="audio-dur">${a.duration || '0:00'}</span>
|
|
415
|
+
<audio src="${a.decryptedUrl || a.url}" preload="metadata" @timeupdate=${(e) => this._onAudioTimeUpdate(e)} @ended=${(e) => this._onAudioEnded(e)}></audio>
|
|
416
|
+
</div></div>`;
|
|
417
|
+
}
|
|
418
|
+
// Generic file
|
|
419
|
+
return html `<div class="msg-attachment"><a class="file-card" href="${a.decryptedUrl || a.url}" target="_blank" download="${a.name || 'file'}">
|
|
420
|
+
${svgFile}
|
|
421
|
+
<div style="flex:1;min-width:0"><div style="font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis">${a.name || 'File'}</div>${a.fileSize ? html `<div style="font-size:10px;color:var(--text-secondary);margin-top:1px">${(a.fileSize / 1024).toFixed(0)} KB</div>` : nothing}</div>
|
|
422
|
+
${svgDownload}
|
|
423
|
+
</a></div>`;
|
|
424
|
+
}
|
|
425
|
+
_renderContextMenu() {
|
|
426
|
+
const cm = this._contextMenu;
|
|
427
|
+
const msg = this.messages[cm.msgIdx];
|
|
428
|
+
const isMe = (msg === null || msg === void 0 ? void 0 : msg.from) === 'me';
|
|
429
|
+
return html `
|
|
430
|
+
<div class="ctx-menu" @mousedown=${(e) => e.preventDefault()} @touchstart=${(e) => e.stopPropagation()} style="top:${cm.y}px;${cm.right != null ? `right:${cm.right}px` : `left:${cm.left}px`}">
|
|
431
|
+
<div class="ctx-reactions">
|
|
432
|
+
${REACTIONS.map(r => html `<button @click=${() => this._reactMsg(cm.msgIdx, r.key)} title=${r.label}>${r.key}</button>`)}
|
|
433
|
+
</div>
|
|
434
|
+
<button @click=${() => this._replyMsg(cm.msgIdx)}>↩ Reply</button>
|
|
435
|
+
${isMe && !(msg === null || msg === void 0 ? void 0 : msg.deleted) ? html `<button @click=${() => this._editMsg(cm.msgIdx)}>✏️ Edit</button>` : nothing}
|
|
436
|
+
${isMe && !(msg === null || msg === void 0 ? void 0 : msg.deleted) ? html `<button class="danger" @click=${() => this._deleteMsg(cm.msgIdx)}>🗑 Delete</button>` : nothing}
|
|
437
|
+
</div>
|
|
438
|
+
`;
|
|
439
|
+
}
|
|
440
|
+
_renderEmojiPicker() {
|
|
441
|
+
return html `
|
|
442
|
+
<div class="emoji-picker" @mousedown=${(e) => e.preventDefault()}>
|
|
443
|
+
<div class="emoji-quick">
|
|
444
|
+
${REACTIONS.map(r => html `<button @click=${() => this._insertEmoji(r.key)} title=${r.label}>${r.key}</button>`)}
|
|
445
|
+
</div>
|
|
446
|
+
<div class="emoji-grid">
|
|
447
|
+
${EMOJI_GRID.map(e => html `<button @click=${() => this._insertEmoji(e)}>${e}</button>`)}
|
|
448
|
+
</div>
|
|
449
|
+
</div>
|
|
450
|
+
`;
|
|
451
|
+
}
|
|
452
|
+
_renderInputBar() {
|
|
453
|
+
return html `
|
|
454
|
+
<div class="chat-input">
|
|
455
|
+
<div class="input-tools">
|
|
456
|
+
<button @click=${() => this._pickFile()} title="Attach file">${svgAttach}</button>
|
|
457
|
+
<button @click=${() => this._pickFile(true)} title="Send image">${svgImage}</button>
|
|
458
|
+
<button @click=${() => this._toggleEmoji()} title="Emoji">${svgSmile}</button>
|
|
459
|
+
</div>
|
|
460
|
+
<textarea rows="1" placeholder="Type a message..." @keydown=${(e) => this._onInputKeydown(e)}></textarea>
|
|
461
|
+
<button class="send-btn" @mousedown=${(e) => e.preventDefault()} @click=${() => this._sendMessage()} title="Send">${svgSend}</button>
|
|
462
|
+
</div>
|
|
463
|
+
`;
|
|
464
|
+
}
|
|
465
|
+
};
|
|
466
|
+
NrChatPanelElement.styles = chatPanelStyles;
|
|
467
|
+
__decorate([
|
|
468
|
+
property({ type: Array })
|
|
469
|
+
], NrChatPanelElement.prototype, "messages", void 0);
|
|
470
|
+
__decorate([
|
|
471
|
+
property({ type: Object })
|
|
472
|
+
], NrChatPanelElement.prototype, "currentUser", void 0);
|
|
473
|
+
__decorate([
|
|
474
|
+
property({ type: String, attribute: 'conversation-id' })
|
|
475
|
+
], NrChatPanelElement.prototype, "conversationId", void 0);
|
|
476
|
+
__decorate([
|
|
477
|
+
property({ type: Boolean })
|
|
478
|
+
], NrChatPanelElement.prototype, "isGroup", void 0);
|
|
479
|
+
__decorate([
|
|
480
|
+
property({ type: Boolean })
|
|
481
|
+
], NrChatPanelElement.prototype, "loading", void 0);
|
|
482
|
+
__decorate([
|
|
483
|
+
property({ type: Boolean, reflect: true })
|
|
484
|
+
], NrChatPanelElement.prototype, "compact", void 0);
|
|
485
|
+
__decorate([
|
|
486
|
+
property({ type: String, attribute: 'empty-text' })
|
|
487
|
+
], NrChatPanelElement.prototype, "emptyText", void 0);
|
|
488
|
+
__decorate([
|
|
489
|
+
property({ type: Boolean, attribute: 'hide-input' })
|
|
490
|
+
], NrChatPanelElement.prototype, "hideInput", void 0);
|
|
491
|
+
__decorate([
|
|
492
|
+
state()
|
|
493
|
+
], NrChatPanelElement.prototype, "_showEmoji", void 0);
|
|
494
|
+
__decorate([
|
|
495
|
+
state()
|
|
496
|
+
], NrChatPanelElement.prototype, "_contextMenu", void 0);
|
|
497
|
+
__decorate([
|
|
498
|
+
state()
|
|
499
|
+
], NrChatPanelElement.prototype, "_replyTo", void 0);
|
|
500
|
+
__decorate([
|
|
501
|
+
state()
|
|
502
|
+
], NrChatPanelElement.prototype, "_editingIdx", void 0);
|
|
503
|
+
__decorate([
|
|
504
|
+
state()
|
|
505
|
+
], NrChatPanelElement.prototype, "_typing", void 0);
|
|
506
|
+
NrChatPanelElement = __decorate([
|
|
507
|
+
customElement('nr-chat-panel')
|
|
508
|
+
], NrChatPanelElement);
|
|
509
|
+
export { NrChatPanelElement };
|
|
510
|
+
//# sourceMappingURL=chat-panel.component.js.map
|