@messenger-box/tailwind-ui-inbox 10.0.3-alpha.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +16 -0
- package/LICENSE +21 -0
- package/jest.config.js +9 -0
- package/lib/cdm-locales/en/translations.json +31 -0
- package/lib/cdm-locales/es/translations.json +31 -0
- package/lib/components/AIAgent/AIAgent.d.ts +32 -0
- package/lib/components/AIAgent/AIAgent.d.ts.map +1 -0
- package/lib/components/AIAgent/AIAgent.js +1135 -0
- package/lib/components/AIAgent/AIAgent.js.map +1 -0
- package/lib/components/AIAgent/InputComponent.d.ts +84 -0
- package/lib/components/AIAgent/InputComponent.d.ts.map +1 -0
- package/lib/components/AIAgent/InputComponent.js +417 -0
- package/lib/components/AIAgent/InputComponent.js.map +1 -0
- package/lib/components/AIAgent/index.d.ts +2 -0
- package/lib/components/AIAgent/index.d.ts.map +1 -0
- package/lib/components/InboxMessage/CommonMessage.d.ts +8 -0
- package/lib/components/InboxMessage/CommonMessage.d.ts.map +1 -0
- package/lib/components/InboxMessage/CommonMessage.js +35 -0
- package/lib/components/InboxMessage/CommonMessage.js.map +1 -0
- package/lib/components/InboxMessage/ConversationItem.d.ts +14 -0
- package/lib/components/InboxMessage/ConversationItem.d.ts.map +1 -0
- package/lib/components/InboxMessage/ConversationItem.js +200 -0
- package/lib/components/InboxMessage/ConversationItem.js.map +1 -0
- package/lib/components/InboxMessage/InputComponent.d.ts +20 -0
- package/lib/components/InboxMessage/InputComponent.d.ts.map +1 -0
- package/lib/components/InboxMessage/InputComponent.js +148 -0
- package/lib/components/InboxMessage/InputComponent.js.map +1 -0
- package/lib/components/InboxMessage/LeftSidebar.d.ts +20 -0
- package/lib/components/InboxMessage/LeftSidebar.d.ts.map +1 -0
- package/lib/components/InboxMessage/LeftSidebar.js +102 -0
- package/lib/components/InboxMessage/LeftSidebar.js.map +1 -0
- package/lib/components/InboxMessage/MessageInput.d.ts +9 -0
- package/lib/components/InboxMessage/MessageInput.d.ts.map +1 -0
- package/lib/components/InboxMessage/MessageInput.js +154 -0
- package/lib/components/InboxMessage/MessageInput.js.map +1 -0
- package/lib/components/InboxMessage/MessageInputComponent.d.ts +9 -0
- package/lib/components/InboxMessage/MessageInputComponent.d.ts.map +1 -0
- package/lib/components/InboxMessage/Messages.d.ts +17 -0
- package/lib/components/InboxMessage/Messages.d.ts.map +1 -0
- package/lib/components/InboxMessage/Messages.js +99 -0
- package/lib/components/InboxMessage/Messages.js.map +1 -0
- package/lib/components/InboxMessage/MessagesBuilderUi.d.ts +17 -0
- package/lib/components/InboxMessage/MessagesBuilderUi.d.ts.map +1 -0
- package/lib/components/InboxMessage/Popover.d.ts +3 -0
- package/lib/components/InboxMessage/Popover.d.ts.map +1 -0
- package/lib/components/InboxMessage/Popover.js +31 -0
- package/lib/components/InboxMessage/Popover.js.map +1 -0
- package/lib/components/InboxMessage/RightSidebar.d.ts +9 -0
- package/lib/components/InboxMessage/RightSidebar.d.ts.map +1 -0
- package/lib/components/InboxMessage/RightSidebar.js +9 -0
- package/lib/components/InboxMessage/RightSidebar.js.map +1 -0
- package/lib/components/InboxMessage/RightSidebarAi.d.ts +37 -0
- package/lib/components/InboxMessage/RightSidebarAi.d.ts.map +1 -0
- package/lib/components/InboxMessage/RightSidebarAi.js +9 -0
- package/lib/components/InboxMessage/RightSidebarAi.js.map +1 -0
- package/lib/components/InboxMessage/ServiceConversationItem.d.ts +12 -0
- package/lib/components/InboxMessage/ServiceConversationItem.d.ts.map +1 -0
- package/lib/components/InboxMessage/ServiceConversationItem.js +185 -0
- package/lib/components/InboxMessage/ServiceConversationItem.js.map +1 -0
- package/lib/components/InboxMessage/ServiceInboxItem.d.ts +12 -0
- package/lib/components/InboxMessage/ServiceInboxItem.d.ts.map +1 -0
- package/lib/components/InboxMessage/ServiceInboxItem.js +182 -0
- package/lib/components/InboxMessage/ServiceInboxItem.js.map +1 -0
- package/lib/components/InboxMessage/StreamingMessageBubble.d.ts +18 -0
- package/lib/components/InboxMessage/StreamingMessageBubble.d.ts.map +1 -0
- package/lib/components/InboxMessage/SubscriptionHandler.d.ts +19 -0
- package/lib/components/InboxMessage/SubscriptionHandler.d.ts.map +1 -0
- package/lib/components/InboxMessage/SubscriptionHandler.js +41 -0
- package/lib/components/InboxMessage/SubscriptionHandler.js.map +1 -0
- package/lib/components/InboxMessage/TypingIndicator.d.ts +11 -0
- package/lib/components/InboxMessage/TypingIndicator.d.ts.map +1 -0
- package/lib/components/InboxMessage/UploadImageButton.d.ts +7 -0
- package/lib/components/InboxMessage/UploadImageButton.d.ts.map +1 -0
- package/lib/components/InboxMessage/UploadImageButton.js +30 -0
- package/lib/components/InboxMessage/UploadImageButton.js.map +1 -0
- package/lib/components/InboxMessage/UserModalContent.d.ts +3 -0
- package/lib/components/InboxMessage/UserModalContent.d.ts.map +1 -0
- package/lib/components/InboxMessage/UserModalContent.js +60 -0
- package/lib/components/InboxMessage/UserModalContent.js.map +1 -0
- package/lib/components/InboxMessage/index.d.ts +19 -0
- package/lib/components/InboxMessage/index.d.ts.map +1 -0
- package/lib/components/InboxMessage/message-widgets/CommonMessage.d.ts +11 -0
- package/lib/components/InboxMessage/message-widgets/CommonMessage.d.ts.map +1 -0
- package/lib/components/InboxMessage/message-widgets/CommonMessage.js +44 -0
- package/lib/components/InboxMessage/message-widgets/CommonMessage.js.map +1 -0
- package/lib/components/InboxMessage/message-widgets/ErrorFixCard.d.ts +10 -0
- package/lib/components/InboxMessage/message-widgets/ErrorFixCard.d.ts.map +1 -0
- package/lib/components/InboxMessage/message-widgets/ErrorFixCard.js +194 -0
- package/lib/components/InboxMessage/message-widgets/ErrorFixCard.js.map +1 -0
- package/lib/components/InboxMessage/message-widgets/MessageCard.d.ts +8 -0
- package/lib/components/InboxMessage/message-widgets/MessageCard.d.ts.map +1 -0
- package/lib/components/InboxMessage/message-widgets/MessageSliceRenderer.d.ts +12 -0
- package/lib/components/InboxMessage/message-widgets/MessageSliceRenderer.d.ts.map +1 -0
- package/lib/components/InboxMessage/message-widgets/MessageSliceRenderer.js +37 -0
- package/lib/components/InboxMessage/message-widgets/MessageSliceRenderer.js.map +1 -0
- package/lib/components/InboxMessage/message-widgets/ModernMessageGroup.d.ts +42 -0
- package/lib/components/InboxMessage/message-widgets/ModernMessageGroup.d.ts.map +1 -0
- package/lib/components/InboxMessage/message-widgets/ModernMessageGroup.js +1339 -0
- package/lib/components/InboxMessage/message-widgets/ModernMessageGroup.js.map +1 -0
- package/lib/components/InboxMessage/message-widgets/PlainMessage.d.ts +8 -0
- package/lib/components/InboxMessage/message-widgets/PlainMessage.d.ts.map +1 -0
- package/lib/components/InboxMessage/message-widgets/PlainMessage.js +14 -0
- package/lib/components/InboxMessage/message-widgets/PlainMessage.js.map +1 -0
- package/lib/components/InboxMessage/message-widgets/PropertyMessageWidget.d.ts +9 -0
- package/lib/components/InboxMessage/message-widgets/PropertyMessageWidget.d.ts.map +1 -0
- package/lib/components/InboxMessage/message-widgets/SlackLikeMessageGroup.d.ts +14 -0
- package/lib/components/InboxMessage/message-widgets/SlackLikeMessageGroup.d.ts.map +1 -0
- package/lib/components/InboxMessage/message-widgets/SlackLikeMessageGroup.js +333 -0
- package/lib/components/InboxMessage/message-widgets/SlackLikeMessageGroup.js.map +1 -0
- package/lib/components/InboxMessage/message-widgets/index.d.ts +4 -0
- package/lib/components/InboxMessage/message-widgets/index.d.ts.map +1 -0
- package/lib/components/ModelConfigPanel.d.ts +74 -0
- package/lib/components/ModelConfigPanel.d.ts.map +1 -0
- package/lib/components/ModelConfigPanel.js +1152 -0
- package/lib/components/ModelConfigPanel.js.map +1 -0
- package/lib/components/filler-components/RightSiderBar.d.ts +3 -0
- package/lib/components/filler-components/RightSiderBar.d.ts.map +1 -0
- package/lib/components/filler-components/RightSiderBar.js +532 -0
- package/lib/components/filler-components/RightSiderBar.js.map +1 -0
- package/lib/components/inbox/FilesList.d.ts +20 -0
- package/lib/components/inbox/FilesList.d.ts.map +1 -0
- package/lib/components/inbox/FilesList.js +68 -0
- package/lib/components/inbox/FilesList.js.map +1 -0
- package/lib/components/inbox/MessageItem.d.ts +17 -0
- package/lib/components/inbox/MessageItem.d.ts.map +1 -0
- package/lib/components/inbox/MessageItem.js +50 -0
- package/lib/components/inbox/MessageItem.js.map +1 -0
- package/lib/components/inbox/ThreadItem.d.ts +11 -0
- package/lib/components/inbox/ThreadItem.d.ts.map +1 -0
- package/lib/components/inbox/ThreadItem.js +147 -0
- package/lib/components/inbox/ThreadItem.js.map +1 -0
- package/lib/components/inbox/index.d.ts +4 -0
- package/lib/components/inbox/index.d.ts.map +1 -0
- package/lib/components/index.d.ts +10 -0
- package/lib/components/index.d.ts.map +1 -0
- package/lib/components/live-code-editor/hybrid-live-editor.d.ts +20 -0
- package/lib/components/live-code-editor/hybrid-live-editor.d.ts.map +1 -0
- package/lib/components/live-code-editor/index.d.ts +4 -0
- package/lib/components/live-code-editor/index.d.ts.map +1 -0
- package/lib/components/live-code-editor/live-code-editor.d.ts +14 -0
- package/lib/components/live-code-editor/live-code-editor.d.ts.map +1 -0
- package/lib/components/messages-container-ui/MessagesContainerUI.d.ts +81 -0
- package/lib/components/messages-container-ui/MessagesContainerUI.d.ts.map +1 -0
- package/lib/components/messages-container-ui/MessagesContainerUI.js +77 -0
- package/lib/components/messages-container-ui/MessagesContainerUI.js.map +1 -0
- package/lib/components/messages-container-ui/PlanModeView.d.ts +82 -0
- package/lib/components/messages-container-ui/PlanModeView.d.ts.map +1 -0
- package/lib/components/messages-container-ui/PlanModeView.js +267 -0
- package/lib/components/messages-container-ui/PlanModeView.js.map +1 -0
- package/lib/components/messages-container-ui/index.d.ts +6 -0
- package/lib/components/messages-container-ui/index.d.ts.map +1 -0
- package/lib/components/messages-container-ui/types.d.ts +38 -0
- package/lib/components/messages-container-ui/types.d.ts.map +1 -0
- package/lib/components/slot-fill/chat-message-filler.d.ts +4 -0
- package/lib/components/slot-fill/chat-message-filler.d.ts.map +1 -0
- package/lib/components/slot-fill/chat-message-filler.js +5 -0
- package/lib/components/slot-fill/chat-message-filler.js.map +1 -0
- package/lib/components/slot-fill/chat-message-slot.d.ts +11 -0
- package/lib/components/slot-fill/chat-message-slot.d.ts.map +1 -0
- package/lib/components/slot-fill/chat-message-slot.js +6 -0
- package/lib/components/slot-fill/chat-message-slot.js.map +1 -0
- package/lib/components/slot-fill/index.d.ts +4 -0
- package/lib/components/slot-fill/index.d.ts.map +1 -0
- package/lib/components/slot-fill/right-sidebar-filler.d.ts +4 -0
- package/lib/components/slot-fill/right-sidebar-filler.d.ts.map +1 -0
- package/lib/components/slot-fill/right-sidebar-filler.js +13 -0
- package/lib/components/slot-fill/right-sidebar-filler.js.map +1 -0
- package/lib/components/ui/button.d.ts +9 -0
- package/lib/components/ui/button.d.ts.map +1 -0
- package/lib/compute.d.ts +8 -0
- package/lib/compute.d.ts.map +1 -0
- package/lib/compute.js +264 -0
- package/lib/compute.js.map +1 -0
- package/lib/config/env-config.d.ts +20 -0
- package/lib/config/env-config.d.ts.map +1 -0
- package/lib/config/env-config.js +55 -0
- package/lib/config/env-config.js.map +1 -0
- package/lib/config/index.d.ts +2 -0
- package/lib/config/index.d.ts.map +1 -0
- package/lib/constants/breakpoints.d.ts +8 -0
- package/lib/constants/breakpoints.d.ts.map +1 -0
- package/lib/constants/index.d.ts +3 -0
- package/lib/constants/index.d.ts.map +1 -0
- package/lib/container/AiInbox.d.ts +15 -0
- package/lib/container/AiInbox.d.ts.map +1 -0
- package/lib/container/AiInboxWithLoader.d.ts +36 -0
- package/lib/container/AiInboxWithLoader.d.ts.map +1 -0
- package/lib/container/AiLandingInput.d.ts +27 -0
- package/lib/container/AiLandingInput.d.ts.map +1 -0
- package/lib/container/AiLandingInput.js +149 -0
- package/lib/container/AiLandingInput.js.map +1 -0
- package/lib/container/Inbox.d.ts +15 -0
- package/lib/container/Inbox.d.ts.map +1 -0
- package/lib/container/Inbox.js +964 -0
- package/lib/container/Inbox.js.map +1 -0
- package/lib/container/InboxAiMessagesLoader.d.ts +45 -0
- package/lib/container/InboxAiMessagesLoader.d.ts.map +1 -0
- package/lib/container/InboxAiMessagesLoader.js +80 -0
- package/lib/container/InboxAiMessagesLoader.js.map +1 -0
- package/lib/container/InboxContainer.d.ts +41 -0
- package/lib/container/InboxContainer.d.ts.map +1 -0
- package/lib/container/InboxContainer.js +27 -0
- package/lib/container/InboxContainer.js.map +1 -0
- package/lib/container/InboxTemplate1.d.ts +15 -0
- package/lib/container/InboxTemplate1.d.ts.map +1 -0
- package/lib/container/InboxTemplate1WithLoader.d.ts +36 -0
- package/lib/container/InboxTemplate1WithLoader.d.ts.map +1 -0
- package/lib/container/InboxTemplate2.d.ts +15 -0
- package/lib/container/InboxTemplate2.d.ts.map +1 -0
- package/lib/container/InboxWithAiLoader.d.ts +47 -0
- package/lib/container/InboxWithAiLoader.d.ts.map +1 -0
- package/lib/container/InboxWithAiLoader.js +118 -0
- package/lib/container/InboxWithAiLoader.js.map +1 -0
- package/lib/container/InboxWithLoader.d.ts +36 -0
- package/lib/container/InboxWithLoader.d.ts.map +1 -0
- package/lib/container/InboxWithLoader.js +277 -0
- package/lib/container/InboxWithLoader.js.map +1 -0
- package/lib/container/ServiceInbox.d.ts +9 -0
- package/lib/container/ServiceInbox.d.ts.map +1 -0
- package/lib/container/ServiceInbox.js +141 -0
- package/lib/container/ServiceInbox.js.map +1 -0
- package/lib/container/TestInboxWithAiLoader.d.ts +7 -0
- package/lib/container/TestInboxWithAiLoader.d.ts.map +1 -0
- package/lib/container/TestInboxWithAiLoader.js +135 -0
- package/lib/container/TestInboxWithAiLoader.js.map +1 -0
- package/lib/container/ThreadMessages.d.ts +13 -0
- package/lib/container/ThreadMessages.d.ts.map +1 -0
- package/lib/container/ThreadMessages.js +320 -0
- package/lib/container/ThreadMessages.js.map +1 -0
- package/lib/container/ThreadMessagesInbox.d.ts +14 -0
- package/lib/container/ThreadMessagesInbox.d.ts.map +1 -0
- package/lib/container/ThreadMessagesInbox.js +347 -0
- package/lib/container/ThreadMessagesInbox.js.map +1 -0
- package/lib/container/Threads.d.ts +8 -0
- package/lib/container/Threads.d.ts.map +1 -0
- package/lib/container/Threads.js +231 -0
- package/lib/container/Threads.js.map +1 -0
- package/lib/container/ThreadsInbox.d.ts +21 -0
- package/lib/container/ThreadsInbox.d.ts.map +1 -0
- package/lib/container/ThreadsInbox.js +243 -0
- package/lib/container/ThreadsInbox.js.map +1 -0
- package/lib/container/apply-footer-styles.d.ts +2 -0
- package/lib/container/apply-footer-styles.d.ts.map +1 -0
- package/lib/container/apply-footer-styles.js +16 -0
- package/lib/container/apply-footer-styles.js.map +1 -0
- package/lib/container/index.d.ts +13 -0
- package/lib/container/index.d.ts.map +1 -0
- package/lib/enums/index.d.ts +2 -0
- package/lib/enums/index.d.ts.map +1 -0
- package/lib/enums/messenger-slot-fill-name-enum.d.ts +11 -0
- package/lib/enums/messenger-slot-fill-name-enum.d.ts.map +1 -0
- package/lib/enums/messenger-slot-fill-name-enum.js +11 -0
- package/lib/enums/messenger-slot-fill-name-enum.js.map +1 -0
- package/lib/hooks/index.d.ts +4 -0
- package/lib/hooks/index.d.ts.map +1 -0
- package/lib/hooks/usePersistentModelConfig.d.ts +33 -0
- package/lib/hooks/usePersistentModelConfig.d.ts.map +1 -0
- package/lib/hooks/usePersistentModelConfig.js +123 -0
- package/lib/hooks/usePersistentModelConfig.js.map +1 -0
- package/lib/hooks/useStreamAssembler.d.ts +8 -0
- package/lib/hooks/useStreamAssembler.d.ts.map +1 -0
- package/lib/hooks/useTemplates.d.ts +14 -0
- package/lib/hooks/useTemplates.d.ts.map +1 -0
- package/lib/hooks/useTemplates.js +59 -0
- package/lib/hooks/useTemplates.js.map +1 -0
- package/lib/index.d.ts +14 -0
- package/lib/index.d.ts.map +1 -0
- package/lib/index.js +1 -0
- package/lib/index.js.map +1 -0
- package/lib/interfaces/index.d.ts +2 -0
- package/lib/interfaces/index.d.ts.map +1 -0
- package/lib/interfaces/message-widgets.interface.d.ts +21 -0
- package/lib/interfaces/message-widgets.interface.d.ts.map +1 -0
- package/lib/machines/aiAgentMachine.d.ts +3 -0
- package/lib/machines/aiAgentMachine.d.ts.map +1 -0
- package/lib/machines/aiAgentMachine.js +1083 -0
- package/lib/machines/aiAgentMachine.js.map +1 -0
- package/lib/machines/aiAgentMachine.simple.d.ts +3 -0
- package/lib/machines/aiAgentMachine.simple.d.ts.map +1 -0
- package/lib/machines/aiAgentMachine.simple.js +108 -0
- package/lib/machines/aiAgentMachine.simple.js.map +1 -0
- package/lib/machines/index.d.ts +3 -0
- package/lib/machines/index.d.ts.map +1 -0
- package/lib/machines/types.d.ts +77 -0
- package/lib/machines/types.d.ts.map +1 -0
- package/lib/module.d.ts +7 -0
- package/lib/module.d.ts.map +1 -0
- package/lib/module.js +26 -0
- package/lib/module.js.map +1 -0
- package/lib/routes.json +251 -0
- package/lib/styles/responsive.css +76 -0
- package/lib/templates/InboxWithAi.d.ts +44 -0
- package/lib/templates/InboxWithAi.d.ts.map +1 -0
- package/lib/templates/InboxWithAi.js +651 -0
- package/lib/templates/InboxWithAi.js.map +1 -0
- package/lib/templates/InboxWithAi.tsx +844 -0
- package/lib/templates/index.d.ts +2 -0
- package/lib/templates/index.d.ts.map +1 -0
- package/lib/templates/index.ts +1 -0
- package/lib/types/templates.d.ts +35 -0
- package/lib/types/templates.d.ts.map +1 -0
- package/lib/utils/utils.d.ts +2 -0
- package/lib/utils/utils.d.ts.map +1 -0
- package/lib/xstate/index.d.ts +3 -0
- package/lib/xstate/index.d.ts.map +1 -0
- package/lib/xstate/rightSidebar.machine.d.ts +4 -0
- package/lib/xstate/rightSidebar.machine.d.ts.map +1 -0
- package/lib/xstate/rightSidebar.types.d.ts +57 -0
- package/lib/xstate/rightSidebar.types.d.ts.map +1 -0
- package/package.json +69 -0
- package/rollup.config.mjs +47 -0
- package/src/cdm-locales/en/translations.json +31 -0
- package/src/cdm-locales/es/translations.json +31 -0
- package/src/components/AIAgent/AIAgent.tsx +1468 -0
- package/src/components/AIAgent/AIAgent.tsx.bk +1365 -0
- package/src/components/AIAgent/InputComponent.tsx +608 -0
- package/src/components/AIAgent/README.md +174 -0
- package/src/components/AIAgent/index.ts +1 -0
- package/src/components/InboxMessage/CommonMessage.tsx +40 -0
- package/src/components/InboxMessage/ConversationItem.tsx +255 -0
- package/src/components/InboxMessage/InputComponent.tsx +198 -0
- package/src/components/InboxMessage/LeftSidebar.tsx +140 -0
- package/src/components/InboxMessage/MessageInput.tsx +209 -0
- package/src/components/InboxMessage/MessageInputComponent.tsx +245 -0
- package/src/components/InboxMessage/Messages.tsx +137 -0
- package/src/components/InboxMessage/MessagesBuilderUi.tsx +205 -0
- package/src/components/InboxMessage/Popover.tsx +42 -0
- package/src/components/InboxMessage/RightSidebar.tsx +22 -0
- package/src/components/InboxMessage/RightSidebarAi.tsx +47 -0
- package/src/components/InboxMessage/ServiceConversationItem.tsx +234 -0
- package/src/components/InboxMessage/ServiceInboxItem.tsx +223 -0
- package/src/components/InboxMessage/StreamingMessageBubble.tsx +270 -0
- package/src/components/InboxMessage/SubscriptionHandler.tsx +55 -0
- package/src/components/InboxMessage/TypingIndicator.tsx +38 -0
- package/src/components/InboxMessage/UploadImageButton.tsx +46 -0
- package/src/components/InboxMessage/UserModalContent.tsx +60 -0
- package/src/components/InboxMessage/index.ts +18 -0
- package/src/components/InboxMessage/message-widgets/CommonMessage.tsx +69 -0
- package/src/components/InboxMessage/message-widgets/ErrorFixCard.tsx +239 -0
- package/src/components/InboxMessage/message-widgets/MessageCard.tsx +127 -0
- package/src/components/InboxMessage/message-widgets/MessageSliceRenderer.tsx +40 -0
- package/src/components/InboxMessage/message-widgets/ModernMessageGroup.tsx +1733 -0
- package/src/components/InboxMessage/message-widgets/PlainMessage.tsx +18 -0
- package/src/components/InboxMessage/message-widgets/PropertyMessageWidget.tsx +29 -0
- package/src/components/InboxMessage/message-widgets/SlackLikeMessageGroup.tsx +492 -0
- package/src/components/InboxMessage/message-widgets/index.ts +8 -0
- package/src/components/ModelConfigPanel.tsx +1357 -0
- package/src/components/filler-components/RightSiderBar.tsx +572 -0
- package/src/components/inbox/FilesList.tsx +89 -0
- package/src/components/inbox/MessageItem.tsx +50 -0
- package/src/components/inbox/ThreadItem.tsx +295 -0
- package/src/components/inbox/index.ts +3 -0
- package/src/components/index.ts +29 -0
- package/src/components/live-code-editor/hybrid-live-editor.tsx +105 -0
- package/src/components/live-code-editor/index.ts +3 -0
- package/src/components/live-code-editor/live-code-editor.tsx +257 -0
- package/src/components/messages-container-ui/MessagesContainerUI.tsx +151 -0
- package/src/components/messages-container-ui/PlanModeView.tsx +426 -0
- package/src/components/messages-container-ui/README.md +91 -0
- package/src/components/messages-container-ui/index.ts +5 -0
- package/src/components/messages-container-ui/types.ts +40 -0
- package/src/components/slot-fill/chat-message-filler.tsx +18 -0
- package/src/components/slot-fill/chat-message-slot.tsx +18 -0
- package/src/components/slot-fill/index.ts +3 -0
- package/src/components/slot-fill/right-sidebar-filler.tsx +48 -0
- package/src/components/ui/button.tsx +32 -0
- package/src/compute.ts +271 -0
- package/src/config/env-config.ts +24 -0
- package/src/config/index.ts +1 -0
- package/src/constants/breakpoints.ts +7 -0
- package/src/constants/index.ts +5 -0
- package/src/container/AiInbox.tsx +1879 -0
- package/src/container/AiInboxWithLoader.tsx +356 -0
- package/src/container/AiLandingInput.tsx +200 -0
- package/src/container/Inbox.tsx +1095 -0
- package/src/container/InboxAiMessagesLoader.tsx +129 -0
- package/src/container/InboxContainer.tsx +61 -0
- package/src/container/InboxTemplate1.tsx +1553 -0
- package/src/container/InboxTemplate1WithLoader.tsx +338 -0
- package/src/container/InboxTemplate2.tsx +1617 -0
- package/src/container/InboxWithAiLoader.tsx +177 -0
- package/src/container/InboxWithLoader.tsx +341 -0
- package/src/container/ServiceInbox.tsx +188 -0
- package/src/container/TestInboxWithAiLoader.tsx +147 -0
- package/src/container/ThreadMessages.tsx +378 -0
- package/src/container/ThreadMessagesInbox.tsx +457 -0
- package/src/container/Threads.tsx +270 -0
- package/src/container/ThreadsInbox.tsx +351 -0
- package/src/container/apply-footer-styles.ts +17 -0
- package/src/container/index.ts +31 -0
- package/src/enums/index.ts +1 -0
- package/src/enums/messenger-slot-fill-name-enum.ts +10 -0
- package/src/hooks/index.ts +3 -0
- package/src/hooks/usePersistentModelConfig.ts +166 -0
- package/src/hooks/useStreamAssembler.ts +7 -0
- package/src/hooks/useTemplates.ts +75 -0
- package/src/index.ts +49 -0
- package/src/interfaces/index.ts +1 -0
- package/src/interfaces/message-widgets.interface.ts +21 -0
- package/src/machines/aiAgentMachine.simple.ts +89 -0
- package/src/machines/aiAgentMachine.ts +1296 -0
- package/src/machines/aiAgentMachine.ts.bk +1296 -0
- package/src/machines/index.ts +2 -0
- package/src/machines/types.ts +59 -0
- package/src/module.tsx +32 -0
- package/src/styles/responsive.css +76 -0
- package/src/templates/InboxWithAi.tsx +844 -0
- package/src/templates/index.ts +1 -0
- package/src/types/templates.ts +35 -0
- package/src/utils/utils.ts +3 -0
- package/src/xstate/index.ts +2 -0
- package/src/xstate/rightSidebar.machine.ts +304 -0
- package/src/xstate/rightSidebar.types.ts +58 -0
- package/tsconfig.json +14 -0
- package/webpack.config.js +92 -0
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
interface ConversationItemProps {
|
|
3
|
+
showBorder: boolean;
|
|
4
|
+
currentUser: any;
|
|
5
|
+
filter: string;
|
|
6
|
+
channel: any;
|
|
7
|
+
handleSelectChannel: (channelId: string) => void;
|
|
8
|
+
users: any[];
|
|
9
|
+
selectedChannelId: string;
|
|
10
|
+
messagesQuery: any;
|
|
11
|
+
}
|
|
12
|
+
export declare const ConversationItem: React.MemoExoticComponent<({ showBorder, currentUser, filter, channel, handleSelectChannel, users, selectedChannelId, messagesQuery: messagesQueryProp, }: ConversationItemProps) => React.JSX.Element>;
|
|
13
|
+
export {};
|
|
14
|
+
//# sourceMappingURL=ConversationItem.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConversationItem.d.ts","sourceRoot":"","sources":["../../../src/components/InboxMessage/ConversationItem.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAoD,MAAM,OAAO,CAAC;AAqBzE,UAAU,qBAAqB;IAC3B,UAAU,EAAE,OAAO,CAAC;IACpB,WAAW,EAAE,GAAG,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,GAAG,CAAC;IACb,mBAAmB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IACjD,KAAK,EAAE,GAAG,EAAE,CAAC;IACb,iBAAiB,EAAE,MAAM,CAAC;IAC1B,aAAa,EAAE,GAAG,CAAC;CACtB;AAED,eAAO,MAAM,gBAAgB,6JAUtB,qBAAqB,uBAuL3B,CAAC"}
|
|
@@ -0,0 +1,200 @@
|
|
|
1
|
+
import {useMessagesQuery,OnChatMessageAddedDocument}from'common/graphql';import {isToday,isYesterday,format}from'date-fns';import React__default,{useState,useMemo}from'react';import {SubscriptionHandler}from'./SubscriptionHandler.js';const createdAtText = value => {
|
|
2
|
+
if (!value) return '';
|
|
3
|
+
let date = new Date(value);
|
|
4
|
+
if (isToday(date)) return 'Today';
|
|
5
|
+
if (isYesterday(date)) return 'Yesterday';
|
|
6
|
+
return format(new Date(value), 'MMM dd, yyyy');
|
|
7
|
+
};
|
|
8
|
+
// Custom Skeleton component for loading state
|
|
9
|
+
const Skeleton = ({
|
|
10
|
+
className = ''
|
|
11
|
+
}) => {
|
|
12
|
+
return React__default.createElement("div", {
|
|
13
|
+
className: `animate-pulse bg-gray-300 dark:bg-gray-600 rounded ${className}`
|
|
14
|
+
}, React__default.createElement("div", {
|
|
15
|
+
className: "h-4 bg-gray-300 dark:bg-gray-600 rounded w-3/4 mb-2"
|
|
16
|
+
}), React__default.createElement("div", {
|
|
17
|
+
className: "h-4 bg-gray-300 dark:bg-gray-600 rounded w-1/2"
|
|
18
|
+
}));
|
|
19
|
+
};
|
|
20
|
+
const ConversationItem = React__default.memo(({
|
|
21
|
+
showBorder,
|
|
22
|
+
currentUser,
|
|
23
|
+
filter,
|
|
24
|
+
channel,
|
|
25
|
+
handleSelectChannel,
|
|
26
|
+
users,
|
|
27
|
+
selectedChannelId,
|
|
28
|
+
messagesQuery: messagesQueryProp
|
|
29
|
+
}) => {
|
|
30
|
+
// const {
|
|
31
|
+
// data: messagesQuery,
|
|
32
|
+
// loading: messageLoading,
|
|
33
|
+
// } = useMessagesQuery({
|
|
34
|
+
// variables: {
|
|
35
|
+
// channelId: channel.id?.toString(),
|
|
36
|
+
// limit: 1,
|
|
37
|
+
// },
|
|
38
|
+
// fetchPolicy: 'cache-and-network',
|
|
39
|
+
// });
|
|
40
|
+
const [messages, setMessages] = useState([]);
|
|
41
|
+
const {
|
|
42
|
+
data: messagesQuery,
|
|
43
|
+
loading: messageLoading,
|
|
44
|
+
refetch: refetchMessages,
|
|
45
|
+
subscribeToMore
|
|
46
|
+
} = useMessagesQuery({
|
|
47
|
+
variables: {
|
|
48
|
+
channelId: channel?.id?.toString(),
|
|
49
|
+
parentId: null,
|
|
50
|
+
limit: 10
|
|
51
|
+
// sort: {
|
|
52
|
+
// key: 'updatedAt',
|
|
53
|
+
// value: SortEnum.Desc,
|
|
54
|
+
// },
|
|
55
|
+
},
|
|
56
|
+
fetchPolicy: 'cache-and-network',
|
|
57
|
+
refetchWritePolicy: 'merge'
|
|
58
|
+
});
|
|
59
|
+
// const {
|
|
60
|
+
// data: newMessage,
|
|
61
|
+
// loading: newMsgLoading,
|
|
62
|
+
// error: newMsgError,
|
|
63
|
+
// }: any = useOnChatMessageAddedSubscription({
|
|
64
|
+
// variables: {
|
|
65
|
+
// channelId: channel?.id?.toString(),
|
|
66
|
+
// },
|
|
67
|
+
// });
|
|
68
|
+
React__default.useEffect(() => {
|
|
69
|
+
if (channel?.id) {
|
|
70
|
+
refetchMessages({
|
|
71
|
+
channelId: channel?.id?.toString(),
|
|
72
|
+
parentId: null,
|
|
73
|
+
limit: 10
|
|
74
|
+
// sort: {
|
|
75
|
+
// key: 'updatedAt',
|
|
76
|
+
// value: SortEnum.Desc,
|
|
77
|
+
// },
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
}, [channel?.id, refetchMessages]);
|
|
81
|
+
React__default.useEffect(() => {
|
|
82
|
+
if (messagesQuery?.messages?.data?.length) {
|
|
83
|
+
setMessages(messagesQuery.messages.data);
|
|
84
|
+
}
|
|
85
|
+
}, [messagesQuery?.messages?.data]);
|
|
86
|
+
const chatUser = useMemo(() => users?.find(({
|
|
87
|
+
id
|
|
88
|
+
}) => {
|
|
89
|
+
const isNotCurrentUser = id !== currentUser?.id;
|
|
90
|
+
if (isNotCurrentUser) {
|
|
91
|
+
return channel?.members?.find(({
|
|
92
|
+
user
|
|
93
|
+
}) => user.id === id);
|
|
94
|
+
}
|
|
95
|
+
if (channel?.members?.length === 1 && channel?.members?.[0]?.user?.id === currentUser?.id) {
|
|
96
|
+
return currentUser;
|
|
97
|
+
}
|
|
98
|
+
return isNotCurrentUser;
|
|
99
|
+
}), [users, currentUser, channel]);
|
|
100
|
+
// Last Message
|
|
101
|
+
// const lastMessage = useMemo(() => {
|
|
102
|
+
// if (!messagesQuery?.messages?.data?.length) {
|
|
103
|
+
// return null;
|
|
104
|
+
// }
|
|
105
|
+
// const { data } = messagesQuery.messages;
|
|
106
|
+
// return data[data.length - 1];
|
|
107
|
+
// }, [messagesQuery]);
|
|
108
|
+
const lastMessage = useMemo(() => {
|
|
109
|
+
if (!messages?.length) {
|
|
110
|
+
return null;
|
|
111
|
+
}
|
|
112
|
+
const data = messages;
|
|
113
|
+
const filteredData = data?.filter(p => p?.message !== '');
|
|
114
|
+
//return filteredData[0];
|
|
115
|
+
let filteredLastMessage = filteredData && filteredData?.length ? filteredData?.reduce((a, b) => {
|
|
116
|
+
return new Date(a?.updatedAt) > new Date(b?.updatedAt) ? a : b;
|
|
117
|
+
}, []) ?? null : null;
|
|
118
|
+
return filteredLastMessage;
|
|
119
|
+
// //return data[data.length - 1];
|
|
120
|
+
}, [messages]);
|
|
121
|
+
const channelType = useMemo(() => {
|
|
122
|
+
return channel?.type;
|
|
123
|
+
}, [channel]);
|
|
124
|
+
if (filter && !chatUser?.username?.toLowerCase().includes(filter.toLowerCase()) && !lastMessage?.message?.toLowerCase().includes(filter.toLowerCase())) {
|
|
125
|
+
return null;
|
|
126
|
+
}
|
|
127
|
+
return React__default.createElement("div", {
|
|
128
|
+
key: `conv_channel_${channel.id}`,
|
|
129
|
+
className: `cursor-pointer flex items-center p-3 border-b ${showBorder ? 'border-gray-300' : 'border-transparent'} ${channel.id == selectedChannelId ? 'bg-gray-300 dark:bg-gray-500' : 'hover:bg-gray-50 dark:hover:bg-gray-700'}`,
|
|
130
|
+
onClick: () => channel.id !== selectedChannelId && handleSelectChannel(channel.id)
|
|
131
|
+
}, React__default.createElement("img", {
|
|
132
|
+
className: "w-10 h-10 rounded-full bg-gray-400 object-cover flex-shrink-0",
|
|
133
|
+
src: chatUser?.picture || '/default-avatar.svg',
|
|
134
|
+
alt: chatUser?.givenName || 'User avatar',
|
|
135
|
+
onError: e => {
|
|
136
|
+
// Prevent infinite loop by checking if we're already showing the fallback
|
|
137
|
+
if (e.currentTarget.src.includes('default-avatar.svg')) {
|
|
138
|
+
// If SVG also fails, use a data URL fallback
|
|
139
|
+
e.currentTarget.src = 'data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iNDAiIGhlaWdodD0iNDAiIHZpZXdCb3g9IjAgMCA0MCA0MCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8Y2lyY2xlIGN4PSIyMCIgY3k9IjIwIiByPSIyMCIgZmlsbD0iI0U1RTdFQiIvPgogIDxjaXJjbGUgY3g9IjIwIiBjeT0iMTYiIHI9IjYiIGZpbGw9IiM5Q0EzQUYiLz4KICA8cGF0aCBkPSJNOCAzMmMwLTYuNjI3IDUuMzczLTEyIDEyLTEyczEyIDUuMzczIDEyIDEyIiBmaWxsPSIjOUNBM0FGIi8+Cjwvc3ZnPgo=';
|
|
140
|
+
} else {
|
|
141
|
+
e.currentTarget.src = '/default-avatar.svg';
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
}), React__default.createElement("div", {
|
|
145
|
+
className: "ml-2 flex-grow min-w-10 max-w-96"
|
|
146
|
+
}, messageLoading && React__default.createElement(Skeleton, {
|
|
147
|
+
className: "w-full h-16"
|
|
148
|
+
}), !messageLoading && React__default.createElement(React__default.Fragment, null, React__default.createElement(LastMessageComponent, {
|
|
149
|
+
lastMessage: lastMessage,
|
|
150
|
+
channelType: channelType,
|
|
151
|
+
chatUser: chatUser
|
|
152
|
+
}), React__default.createElement(SubscriptionHandler, {
|
|
153
|
+
subscribeToMore: subscribeToMore,
|
|
154
|
+
document: OnChatMessageAddedDocument,
|
|
155
|
+
variables: {
|
|
156
|
+
channelId: channel?.id?.toString()
|
|
157
|
+
},
|
|
158
|
+
enabled: !!channel?.id && !!subscribeToMore,
|
|
159
|
+
updateQuery: (prev, {
|
|
160
|
+
subscriptionData
|
|
161
|
+
}) => {
|
|
162
|
+
if (!subscriptionData.data) return prev;
|
|
163
|
+
const newMessage = subscriptionData?.data?.chatMessageAdded;
|
|
164
|
+
console.log('ConversationItem: New message received via subscription:', newMessage);
|
|
165
|
+
const previousData = prev?.messages?.data ? [...prev.messages.data, newMessage] : [];
|
|
166
|
+
const totalMsgCount = prev?.messages?.totalCount + 1;
|
|
167
|
+
const merged = {
|
|
168
|
+
...prev,
|
|
169
|
+
messages: {
|
|
170
|
+
...prev?.messages,
|
|
171
|
+
data: previousData,
|
|
172
|
+
totalCount: totalMsgCount
|
|
173
|
+
}
|
|
174
|
+
};
|
|
175
|
+
return merged;
|
|
176
|
+
},
|
|
177
|
+
onError: error => {
|
|
178
|
+
console.error('ConversationItem: Subscription error:', error);
|
|
179
|
+
}
|
|
180
|
+
}))));
|
|
181
|
+
});
|
|
182
|
+
const LastMessageComponent = React__default.memo(({
|
|
183
|
+
lastMessage,
|
|
184
|
+
channelType,
|
|
185
|
+
chatUser
|
|
186
|
+
}) => {
|
|
187
|
+
return React__default.createElement("div", {
|
|
188
|
+
className: "flex flex-col w-full"
|
|
189
|
+
}, React__default.createElement("div", {
|
|
190
|
+
className: "w-full flex justify-between items-center"
|
|
191
|
+
}, React__default.createElement("span", {
|
|
192
|
+
className: "text-xs text-green-500 truncate"
|
|
193
|
+
}, channelType), React__default.createElement("span", {
|
|
194
|
+
className: "text-xs text-gray-500"
|
|
195
|
+
}, lastMessage ? createdAtText(lastMessage?.createdAt) : '')), React__default.createElement("p", {
|
|
196
|
+
className: "text-sm text-gray-600 dark:text-gray-300 font-bold mt-1"
|
|
197
|
+
}, chatUser?.givenName + ' ' + chatUser?.familyName), React__default.createElement("p", {
|
|
198
|
+
className: "text-sm text-gray-600 dark:text-gray-400 truncate w-4/5 mt-1 line-clamp-1"
|
|
199
|
+
}, lastMessage?.message && lastMessage.message.length > 30 ? lastMessage.message.slice(0, 30) + '…' : lastMessage?.message));
|
|
200
|
+
});export{ConversationItem};//# sourceMappingURL=ConversationItem.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConversationItem.js","sources":["../../../src/components/InboxMessage/ConversationItem.tsx"],"sourcesContent":[null],"names":["React","CHAT_MESSAGE_ADDED"],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { ModelConfig } from '../../hooks/usePersistentModelConfig';
|
|
3
|
+
type MessageInputProps = {
|
|
4
|
+
channelId?: string;
|
|
5
|
+
handleSend?: (message: string, files: File[]) => Promise<void>;
|
|
6
|
+
placeholder?: string;
|
|
7
|
+
modelConfig?: ModelConfig;
|
|
8
|
+
onModelConfigChange?: (config: ModelConfig) => void;
|
|
9
|
+
textareaClassName?: string;
|
|
10
|
+
textareaStyles?: React.CSSProperties;
|
|
11
|
+
toolBarParentClassName?: string;
|
|
12
|
+
showModelToolbarProjectSettings?: boolean;
|
|
13
|
+
isShowMeta?: boolean;
|
|
14
|
+
showModeSelector?: boolean;
|
|
15
|
+
showStopButton?: boolean;
|
|
16
|
+
onStop?: () => void;
|
|
17
|
+
};
|
|
18
|
+
export declare const InputComponent: ({ handleSend: handleSendProp, placeholder, modelConfig, onModelConfigChange, textareaClassName, toolBarParentClassName, textareaStyles, showModelToolbarProjectSettings, isShowMeta, showModeSelector, showStopButton, onStop, }: MessageInputProps) => React.JSX.Element;
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=InputComponent.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InputComponent.d.ts","sourceRoot":"","sources":["../../../src/components/InboxMessage/InputComponent.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA4D,MAAM,OAAO,CAAC;AAKjF,OAAO,EAAE,WAAW,EAAE,MAAM,sCAAsC,CAAC;AAEnE,KAAK,iBAAiB,GAAG;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/D,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,mBAAmB,CAAC,EAAE,CAAC,MAAM,EAAE,WAAW,KAAK,IAAI,CAAC;IACpD,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,cAAc,CAAC,EAAE,KAAK,CAAC,aAAa,CAAC;IACrC,sBAAsB,CAAC,EAAE,MAAM,CAAC;IAChC,+BAA+B,CAAC,EAAE,OAAO,CAAC;IAC1C,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;CACvB,CAAC;AAEF,eAAO,MAAM,cAAc,GAAI,kOAa5B,iBAAiB,sBAiKnB,CAAC"}
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
import React__default,{useState,useRef,useEffect,useCallback,useMemo}from'react';import {useTranslation}from'react-i18next';import {config}from'../../config/env-config.js';import {FilesList}from'../inbox/FilesList.js';import'../inbox/MessageItem.js';import'../inbox/ThreadItem.js';import {ModelToolbar}from'../ModelConfigPanel.js';const InputComponent = ({
|
|
2
|
+
handleSend: handleSendProp,
|
|
3
|
+
placeholder,
|
|
4
|
+
modelConfig,
|
|
5
|
+
onModelConfigChange,
|
|
6
|
+
textareaClassName,
|
|
7
|
+
toolBarParentClassName,
|
|
8
|
+
textareaStyles,
|
|
9
|
+
showModelToolbarProjectSettings = false,
|
|
10
|
+
isShowMeta = false,
|
|
11
|
+
showModeSelector = false,
|
|
12
|
+
showStopButton = false,
|
|
13
|
+
onStop
|
|
14
|
+
}) => {
|
|
15
|
+
const [message, setMessage] = useState('');
|
|
16
|
+
const [sending, setSending] = useState(false);
|
|
17
|
+
const [files, setFiles] = useState([]);
|
|
18
|
+
const [showToast, setShowToast] = useState(false);
|
|
19
|
+
const [toastMessage, setToastMessage] = useState('');
|
|
20
|
+
const [isFocused, setIsFocused] = useState(false);
|
|
21
|
+
const textareaRef = useRef(null);
|
|
22
|
+
const {
|
|
23
|
+
t
|
|
24
|
+
} = useTranslation('translations');
|
|
25
|
+
// Auto-focus the textarea when component mounts
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
if (textareaRef.current) {
|
|
28
|
+
textareaRef.current.focus();
|
|
29
|
+
}
|
|
30
|
+
}, []);
|
|
31
|
+
// Ensure default template is set to 'vite-react' if missing
|
|
32
|
+
useEffect(() => {
|
|
33
|
+
if (modelConfig && !modelConfig.template && onModelConfigChange) {
|
|
34
|
+
onModelConfigChange({
|
|
35
|
+
...modelConfig,
|
|
36
|
+
template: 'vite-react'
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}, [modelConfig, onModelConfigChange]);
|
|
40
|
+
// no dropdowns managed here; toolbar handles its own
|
|
41
|
+
const showToastMessage = useCallback(message => {
|
|
42
|
+
setToastMessage(message);
|
|
43
|
+
setShowToast(true);
|
|
44
|
+
setTimeout(() => setShowToast(false), 3000);
|
|
45
|
+
}, []);
|
|
46
|
+
const handleSend = useCallback(() => {
|
|
47
|
+
if (!message.trim() && files.length === 0) return;
|
|
48
|
+
setSending(true);
|
|
49
|
+
handleSendProp(message, files).then(() => {
|
|
50
|
+
setMessage('');
|
|
51
|
+
setFiles([]);
|
|
52
|
+
// Auto-focus the textarea after sending a message
|
|
53
|
+
setTimeout(() => {
|
|
54
|
+
if (textareaRef.current) {
|
|
55
|
+
textareaRef.current.focus();
|
|
56
|
+
}
|
|
57
|
+
}, 100);
|
|
58
|
+
}).finally(() => setSending(false));
|
|
59
|
+
}, [files, handleSendProp, message]);
|
|
60
|
+
const handleKeyDown = useCallback(e => {
|
|
61
|
+
const keyCode = e.which || e.keyCode;
|
|
62
|
+
if (keyCode == 13 && !e.shiftKey) {
|
|
63
|
+
e.preventDefault();
|
|
64
|
+
handleSend();
|
|
65
|
+
}
|
|
66
|
+
}, [handleSend]);
|
|
67
|
+
const inputHeight = useMemo(() => {
|
|
68
|
+
const lines = message.split('\n').length;
|
|
69
|
+
return Math.max(120, Math.min(200, 120 + (lines - 1) * 20));
|
|
70
|
+
}, [message]);
|
|
71
|
+
const onUploadImageChange = useCallback(({
|
|
72
|
+
target
|
|
73
|
+
}) => {
|
|
74
|
+
let fileList = [];
|
|
75
|
+
let index = 0;
|
|
76
|
+
if (files.length + target.files.length > config.FILES_PER_MESSAGE) {
|
|
77
|
+
showToastMessage(t('tailwind_ui_inbox.you_can_not_upload_more_than_files', {
|
|
78
|
+
files_per_message: config.FILES_PER_MESSAGE
|
|
79
|
+
}));
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
while (target.files[index]) {
|
|
83
|
+
fileList.push(target.files[index]);
|
|
84
|
+
index += 1;
|
|
85
|
+
}
|
|
86
|
+
setFiles(oldFiles => [...oldFiles, ...fileList]);
|
|
87
|
+
}, [setFiles, files, showToastMessage, t]);
|
|
88
|
+
const canSend = message.trim() || files.length > 0;
|
|
89
|
+
message.trim().length > 0;
|
|
90
|
+
// toolbar now owns model/template selections
|
|
91
|
+
return (
|
|
92
|
+
// <div className="bg-gray-50 border-t border-gray-200">
|
|
93
|
+
React__default.createElement("div", {
|
|
94
|
+
className: "bg-white "
|
|
95
|
+
}, showToast && React__default.createElement("div", {
|
|
96
|
+
className: "fixed top-4 right-4 z-50 bg-orange-50 border border-orange-200 text-orange-800 px-4 py-3 rounded-lg shadow-lg animate-bounce"
|
|
97
|
+
}, React__default.createElement("div", {
|
|
98
|
+
className: "flex items-center"
|
|
99
|
+
}, React__default.createElement("svg", {
|
|
100
|
+
className: "w-5 h-5 mr-2",
|
|
101
|
+
fill: "currentColor",
|
|
102
|
+
viewBox: "0 0 20 20"
|
|
103
|
+
}, React__default.createElement("path", {
|
|
104
|
+
fillRule: "evenodd",
|
|
105
|
+
d: "M8.257 3.099c.765-1.36 2.722-1.36 3.486 0l5.58 9.92c.75 1.334-.213 2.98-1.742 2.98H4.42c-1.53 0-2.493-1.646-1.743-2.98l5.58-9.92zM11 13a1 1 0 11-2 0 1 1 0 012 0zm-1-8a1 1 0 00-1 1v3a1 1 0 002 0V6a1 1 0 00-1-1z",
|
|
106
|
+
clipRule: "evenodd"
|
|
107
|
+
})), toastMessage)), files?.length > 0 && !sending && React__default.createElement("div", {
|
|
108
|
+
className: "px-4 py-3 border-b border-gray-200"
|
|
109
|
+
}, React__default.createElement(FilesList, {
|
|
110
|
+
files: files
|
|
111
|
+
})), React__default.createElement("div", {
|
|
112
|
+
className: "px-4 py-3"
|
|
113
|
+
}, React__default.createElement("div", {
|
|
114
|
+
className: "relative mb-3"
|
|
115
|
+
}, React__default.createElement("textarea", {
|
|
116
|
+
ref: textareaRef,
|
|
117
|
+
className: `w-full text-base bg-white border border-gray-300 rounded-2xl pl-4 pr-4 py-3 resize-none focus:border-gray-300 focus:outline-none placeholder-gray-500 transition-all duration-200 ${isFocused ? 'border-gray-400 ring-2 ring-gray-300 focus:ring-gray-300' : 'border-gray-300'} ${textareaClassName}`,
|
|
118
|
+
style: {
|
|
119
|
+
height: `${inputHeight}px`,
|
|
120
|
+
minHeight: '120px',
|
|
121
|
+
maxHeight: '200px',
|
|
122
|
+
...textareaStyles
|
|
123
|
+
},
|
|
124
|
+
placeholder: placeholder || 'Message',
|
|
125
|
+
value: sending ? '' : message,
|
|
126
|
+
onKeyDown: handleKeyDown,
|
|
127
|
+
onChange: e => setMessage(e.target.value),
|
|
128
|
+
onFocus: () => setIsFocused(true),
|
|
129
|
+
onBlur: () => setIsFocused(false),
|
|
130
|
+
disabled: sending,
|
|
131
|
+
rows: 1
|
|
132
|
+
})), React__default.createElement("div", {
|
|
133
|
+
className: `${toolBarParentClassName}`
|
|
134
|
+
}, React__default.createElement(ModelToolbar, {
|
|
135
|
+
modelConfig: modelConfig,
|
|
136
|
+
onModelConfigChange: onModelConfigChange,
|
|
137
|
+
sending: sending,
|
|
138
|
+
canSend: !!canSend,
|
|
139
|
+
onSend: handleSend,
|
|
140
|
+
onUploadImageChange: onUploadImageChange,
|
|
141
|
+
showProjectSettings: showModelToolbarProjectSettings,
|
|
142
|
+
isShowMeta: isShowMeta,
|
|
143
|
+
showModeSelector: showModeSelector,
|
|
144
|
+
showStopButton: showStopButton,
|
|
145
|
+
onStop: onStop
|
|
146
|
+
}))))
|
|
147
|
+
);
|
|
148
|
+
};export{InputComponent};//# sourceMappingURL=InputComponent.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InputComponent.js","sources":["../../../src/components/InboxMessage/InputComponent.tsx"],"sourcesContent":[null],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
type LeftSidebarProps = {
|
|
3
|
+
userChannels: any;
|
|
4
|
+
userChannelsLoading: boolean;
|
|
5
|
+
currentUser: any;
|
|
6
|
+
users?: any[];
|
|
7
|
+
handleSelectChannel: (channel: any, postId?: any) => void;
|
|
8
|
+
clearMessages?: () => void;
|
|
9
|
+
selectedChannelId?: any;
|
|
10
|
+
channelToTop: number;
|
|
11
|
+
getChannelsRefetch: any;
|
|
12
|
+
supportServices?: any;
|
|
13
|
+
role?: any;
|
|
14
|
+
messagesQuery?: any;
|
|
15
|
+
windowHeight?: number;
|
|
16
|
+
windowWidth?: number;
|
|
17
|
+
};
|
|
18
|
+
export declare const LeftSidebar: React.MemoExoticComponent<(props: LeftSidebarProps) => React.JSX.Element>;
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=LeftSidebar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LeftSidebar.d.ts","sourceRoot":"","sources":["../../../src/components/InboxMessage/LeftSidebar.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAuC,MAAM,OAAO,CAAC;AAO5D,KAAK,gBAAgB,GAAG;IACpB,YAAY,EAAE,GAAG,CAAC;IAClB,mBAAmB,EAAE,OAAO,CAAC;IAC7B,WAAW,EAAE,GAAG,CAAC;IACjB,KAAK,CAAC,EAAE,GAAG,EAAE,CAAC;IACd,mBAAmB,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE,MAAM,CAAC,EAAE,GAAG,KAAK,IAAI,CAAC;IAC1D,aAAa,CAAC,EAAE,MAAM,IAAI,CAAC;IAC3B,iBAAiB,CAAC,EAAE,GAAG,CAAC;IACxB,YAAY,EAAE,MAAM,CAAC;IACrB,kBAAkB,EAAE,GAAG,CAAC;IACxB,eAAe,CAAC,EAAE,GAAG,CAAC;IACtB,IAAI,CAAC,EAAE,GAAG,CAAC;IACX,aAAa,CAAC,EAAE,GAAG,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,eAAO,MAAM,WAAW,oCAAsB,gBAAgB,uBA6F5D,CAAC"}
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import {GoSearch}from'@react-icons/all-files/go/GoSearch.js';import React__default,{useState,useMemo}from'react';import {useTranslation}from'react-i18next';import {orderBy,uniqBy}from'lodash-es';import {ConversationItem}from'./ConversationItem.js';import {ServiceConversationItem}from'./ServiceConversationItem.js';import {RoomType}from'common';const LeftSidebar = React__default.memo(props => {
|
|
2
|
+
const {
|
|
3
|
+
currentUser,
|
|
4
|
+
handleSelectChannel,
|
|
5
|
+
users,
|
|
6
|
+
userChannels,
|
|
7
|
+
userChannelsLoading,
|
|
8
|
+
selectedChannelId,
|
|
9
|
+
supportServices,
|
|
10
|
+
role,
|
|
11
|
+
messagesQuery,
|
|
12
|
+
windowHeight = 768,
|
|
13
|
+
windowWidth = 1024
|
|
14
|
+
} = props;
|
|
15
|
+
const [keyword, setKeyword] = useState('');
|
|
16
|
+
const {
|
|
17
|
+
t
|
|
18
|
+
} = useTranslation('translations');
|
|
19
|
+
// Memoize the sorted channels to prevent unnecessary re-renders
|
|
20
|
+
const sortedChannels = useMemo(() => {
|
|
21
|
+
if (!userChannels?.length) return [];
|
|
22
|
+
return orderBy(uniqBy([...userChannels], ({
|
|
23
|
+
id
|
|
24
|
+
}) => id), ['updatedAt'], ['desc']);
|
|
25
|
+
}, [userChannels]);
|
|
26
|
+
if (userChannelsLoading) {
|
|
27
|
+
return React__default.createElement("div", {
|
|
28
|
+
className: "space-y-4"
|
|
29
|
+
}, Array(10).fill(1).map((x, y) => React__default.createElement("div", {
|
|
30
|
+
key: y,
|
|
31
|
+
className: "h-10 bg-gray-200 rounded animate-pulse"
|
|
32
|
+
})));
|
|
33
|
+
}
|
|
34
|
+
return React__default.createElement("div", {
|
|
35
|
+
className: "w-full flex flex-col bg-white",
|
|
36
|
+
style: {
|
|
37
|
+
height: `${windowHeight}px`,
|
|
38
|
+
maxHeight: '100vh'
|
|
39
|
+
}
|
|
40
|
+
}, React__default.createElement("div", {
|
|
41
|
+
className: "flex-shrink-0 p-3 sm:p-4 border-b border-gray-200"
|
|
42
|
+
}, React__default.createElement(SearchInput, {
|
|
43
|
+
keyword: keyword,
|
|
44
|
+
setKeyword: setKeyword
|
|
45
|
+
})), React__default.createElement("div", {
|
|
46
|
+
className: "flex-1 min-h-0 overflow-hidden"
|
|
47
|
+
}, React__default.createElement("div", {
|
|
48
|
+
className: "overflow-y-auto p-2 sm:p-4 space-y-1",
|
|
49
|
+
style: {
|
|
50
|
+
height: `${windowHeight - 80}px`,
|
|
51
|
+
// Subtract header height
|
|
52
|
+
minHeight: 0
|
|
53
|
+
}
|
|
54
|
+
}, React__default.createElement(React__default.Fragment, null, supportServices ? supportServices : React__default.createElement(React__default.Fragment, null), sortedChannels.length > 0 ? sortedChannels.map((channel, index) => channel?.type === RoomType.Service ? React__default.createElement(ServiceConversationItem, {
|
|
55
|
+
key: `service_channel_${channel.id}`,
|
|
56
|
+
filter: keyword,
|
|
57
|
+
channel: channel,
|
|
58
|
+
currentUser: currentUser,
|
|
59
|
+
handleSelectChannel: handleSelectChannel,
|
|
60
|
+
users: users,
|
|
61
|
+
selectedChannelId: selectedChannelId,
|
|
62
|
+
showBorder: index != sortedChannels.length - 1,
|
|
63
|
+
role: role || null
|
|
64
|
+
}) : React__default.createElement(ConversationItem, {
|
|
65
|
+
key: `conv_channel_${channel.id}`,
|
|
66
|
+
filter: keyword,
|
|
67
|
+
channel: channel,
|
|
68
|
+
currentUser: currentUser,
|
|
69
|
+
handleSelectChannel: handleSelectChannel,
|
|
70
|
+
users: users,
|
|
71
|
+
selectedChannelId: selectedChannelId,
|
|
72
|
+
showBorder: index != sortedChannels.length - 1,
|
|
73
|
+
messagesQuery: messagesQuery
|
|
74
|
+
})) : React__default.createElement("div", {
|
|
75
|
+
className: "text-center py-8 text-gray-500"
|
|
76
|
+
}, React__default.createElement("div", {
|
|
77
|
+
className: "text-3xl mb-2"
|
|
78
|
+
}, "\uD83D\uDCAC"), React__default.createElement("p", null, "No conversations yet"))))));
|
|
79
|
+
});
|
|
80
|
+
const SearchInput = ({
|
|
81
|
+
keyword,
|
|
82
|
+
setKeyword
|
|
83
|
+
}) => {
|
|
84
|
+
const {
|
|
85
|
+
t
|
|
86
|
+
} = useTranslation('translations');
|
|
87
|
+
return React__default.createElement("div", {
|
|
88
|
+
className: "w-full"
|
|
89
|
+
}, React__default.createElement("div", {
|
|
90
|
+
className: "relative"
|
|
91
|
+
}, React__default.createElement("input", {
|
|
92
|
+
type: "text",
|
|
93
|
+
placeholder: t('tailwind_ui_inbox.search_inbox') || 'Search Inbox',
|
|
94
|
+
className: "w-full pl-10 sm:pl-12 pr-4 py-2 sm:py-2.5 bg-gray-50 border border-gray-200 rounded-lg text-gray-900 placeholder-gray-400 focus:outline-none focus:ring-1 focus:ring-blue-400 focus:border-blue-400 focus:bg-white transition-all duration-200 text-sm",
|
|
95
|
+
value: keyword,
|
|
96
|
+
onChange: e => setKeyword(e.target.value)
|
|
97
|
+
}), React__default.createElement("div", {
|
|
98
|
+
className: "absolute left-3 sm:left-4 top-1/2 transform -translate-y-1/2"
|
|
99
|
+
}, React__default.createElement(GoSearch, {
|
|
100
|
+
className: "w-4 h-4 text-gray-400"
|
|
101
|
+
}))));
|
|
102
|
+
};export{LeftSidebar};//# sourceMappingURL=LeftSidebar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LeftSidebar.js","sources":["../../../src/components/InboxMessage/LeftSidebar.tsx"],"sourcesContent":[null],"names":["React"],"mappings":"yVA0BO,MAAM,WAAW,GAAGA,cAAK,CAAC,IAAI,CAAC,KAAC,IAAyB;AAC5D,EAAA,MAAA;IAaA,WAAO;IACP;IAEA,KAAA;AACA,IAAA,YAAM;uBACG;AAAsB,IAAA,iBAAS;mBAC7B;AAKX,IAAA,IAAI;IAEJ,aAAI;gBAEI;eAES,GAAK;;QAMrB,CAAA,OAAA,EAAA,UAAA,CAAA,GAAA,QAAA,CAAA,EAAA,CAAA;AACD,EAAA,MAAA;;oBAGY,CAAA,cAAC,CAAA;;AAGD,EAAA,MAAA,cAAA,GAAA,OAAA,CAAA,MAAA;AAGQ,IAAA,IAAA,CAAA,YAAA,EAAA,MAAQ,EAAG,OAAA,EAAA;AACX,IAAA,OAAA,OAAA,CAAA,MAAA,CAAA,CAAA,eAAY,CAAA,EAAA,CAAA;AACf,MAAA;AAED,KAAA,KAAA,EAAA,CAAA,EAAA,CAAA,WAAA,CAAA,EAAA,CAAA,MAAA,CAAA,CAAA;AACK,EAAA,CAAA,EAAA,CAAA,YAAA,CAAA,CAAA;AAEA,EAAA,IAAA,mBAAA,EAAA;uCA8BO,CAAA,KAAA,EAAA;AACA,MAAA,SAAA,EAAA;AAQhC,KAAG,EAAA,KAAA,CAAA,EAAA,CAAA,CAAA,IAAA,CAAA,CAAA,CAAA,CAAA,GAAA,CAAA,CAAA,CAAA,EAAA,CAAA,KAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAEH,MAAM,GAAA,EAAA,CAAA;MACF,SAAW,EAAA;AACX,KAAA,CAAA,CAAA,CAAA;;AAGY,EAAA,OAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;aAOA,EAAA,+BAAK;;AAMrB,MAAE,MAAA,EAAA,CAAA,EAAA,YAAA,CAAA,EAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
type MessageInputProps = {
|
|
3
|
+
channelId?: string;
|
|
4
|
+
handleSend: (message: string, files: File[]) => Promise<void>;
|
|
5
|
+
placeholder?: string;
|
|
6
|
+
};
|
|
7
|
+
export declare const MessageInput: ({ handleSend: handleSendProp, placeholder }: MessageInputProps) => React.JSX.Element;
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=MessageInput.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"MessageInput.d.ts","sourceRoot":"","sources":["../../../src/components/InboxMessage/MessageInput.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA4D,MAAM,OAAO,CAAC;AAMjF,KAAK,iBAAiB,GAAG;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,EAAE,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC9D,WAAW,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,eAAO,MAAM,YAAY,GAAI,6CAA6C,iBAAiB,sBAoM1F,CAAC"}
|