@memori.ai/memori-react 8.38.5 → 9.0.0-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 +1824 -0
- package/dist/components/AgeVerificationModal/AgeVerificationModal.css +35 -12
- package/dist/components/AgeVerificationModal/AgeVerificationModal.d.ts +0 -1
- package/dist/components/AgeVerificationModal/AgeVerificationModal.js +22 -10
- package/dist/components/AgeVerificationModal/AgeVerificationModal.js.map +1 -1
- package/dist/components/Auth/Auth.css +13 -9
- package/dist/components/Auth/Auth.d.ts +0 -1
- package/dist/components/Auth/Auth.js +14 -10
- package/dist/components/Auth/Auth.js.map +1 -1
- package/dist/components/Avatar/Avatar.css +2 -2
- package/dist/components/Avatar/Avatar.js +7 -7
- package/dist/components/Avatar/Avatar.js.map +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.d.ts +0 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.js +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.js.map +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/avatarComponent.d.ts +0 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/avatarComponent.js.map +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/fullbodyAvatar.d.ts +0 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/fullbodyAvatar.js +1 -2
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/fullbodyAvatar.js.map +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/types.js +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/types.js.map +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarAnimator.js.map +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarPositionController.js.map +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controllers/MorphTargetController.js.map +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/halfbodyAvatar.d.ts +0 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/halfbodyAvatar.js +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/halfbodyAvatar.js.map +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/loader.d.ts +0 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/loader.js +2 -3
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/loader.js.map +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.css +21 -21
- package/dist/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.d.ts +0 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.js +8 -10
- package/dist/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.js.map +1 -1
- package/dist/components/Avatar/AvatarView/index.js +1 -1
- package/dist/components/Avatar/AvatarView/index.js.map +1 -1
- package/dist/components/Avatar/AvatarView/utils/hideHands.js.map +1 -1
- package/dist/components/Avatar/AvatarView/utils/useEyeBlink.js +1 -2
- package/dist/components/Avatar/AvatarView/utils/useEyeBlink.js.map +1 -1
- package/dist/components/Avatar/AvatarView/utils/useHeadMovement.js +1 -1
- package/dist/components/Avatar/AvatarView/utils/useHeadMovement.js.map +1 -1
- package/dist/components/Avatar/AvatarView/utils/useLoadingMorphAnim.js +1 -1
- package/dist/components/Avatar/AvatarView/utils/useLoadingMorphAnim.js.map +1 -1
- package/dist/components/Avatar/AvatarView/utils/useMouthAnimation.js +1 -2
- package/dist/components/Avatar/AvatarView/utils/useMouthAnimation.js.map +1 -1
- package/dist/components/Avatar/AvatarView/utils/useSmile.js +1 -1
- package/dist/components/Avatar/AvatarView/utils/useSmile.js.map +1 -1
- package/dist/components/Avatar/AvatarView/utils/utils.js.map +1 -1
- package/dist/components/Blob/Blob.css +14 -12
- package/dist/components/Blob/Blob.d.ts +0 -1
- package/dist/components/BlockedMemoriBadge/BlockedMemoriBadge.css +4 -4
- package/dist/components/BlockedMemoriBadge/BlockedMemoriBadge.d.ts +0 -1
- package/dist/components/BlockedMemoriBadge/BlockedMemoriBadge.js +4 -5
- package/dist/components/BlockedMemoriBadge/BlockedMemoriBadge.js.map +1 -1
- package/dist/components/ChangeMode/ChangeMode.css +4 -2
- package/dist/components/ChangeMode/ChangeMode.js +8 -3
- package/dist/components/ChangeMode/ChangeMode.js.map +1 -1
- package/dist/components/Chat/Chat.css +114 -38
- package/dist/components/Chat/Chat.js +39 -53
- package/dist/components/Chat/Chat.js.map +1 -1
- package/dist/components/ChatBubble/ChatBubble.css +206 -68
- package/dist/components/ChatBubble/ChatBubble.d.ts +5 -0
- package/dist/components/ChatBubble/ChatBubble.js +223 -164
- package/dist/components/ChatBubble/ChatBubble.js.map +1 -1
- package/dist/components/ChatHistoryDrawer/ChatHistory.css +417 -156
- package/dist/components/ChatHistoryDrawer/ChatHistory.d.ts +0 -1
- package/dist/components/ChatHistoryDrawer/ChatHistory.js +252 -151
- package/dist/components/ChatHistoryDrawer/ChatHistory.js.map +1 -1
- package/dist/components/ChatHistoryDrawer/ChatResumeDrawer.css +1 -1
- package/dist/components/ChatInputs/ChatInputs.css +68 -51
- package/dist/components/ChatInputs/ChatInputs.d.ts +1 -0
- package/dist/components/ChatInputs/ChatInputs.js +51 -28
- package/dist/components/ChatInputs/ChatInputs.js.map +1 -1
- package/dist/components/ChatTextArea/ChatTextArea.css +38 -12
- package/dist/components/ChatTextArea/ChatTextArea.js +1 -1
- package/dist/components/ChatTextArea/ChatTextArea.js.map +1 -1
- package/dist/components/CompletionProviderStatus/CompletionProviderStatus.css +5 -5
- package/dist/components/CompletionProviderStatus/CompletionProviderStatus.d.ts +0 -1
- package/dist/components/CompletionProviderStatus/CompletionProviderStatus.js +8 -11
- package/dist/components/CompletionProviderStatus/CompletionProviderStatus.js.map +1 -1
- package/dist/components/ContentPreviewModal/ContentPreviewModal.css +129 -84
- package/dist/components/ContentPreviewModal/ContentPreviewModal.js +5 -4
- package/dist/components/ContentPreviewModal/ContentPreviewModal.js.map +1 -1
- package/dist/components/ContentPreviewModal/index.js +2 -4
- package/dist/components/ContentPreviewModal/index.js.map +1 -1
- package/dist/components/CustomGLBModelViewer/ModelViewer.d.ts +0 -1
- package/dist/components/DateSelector/DateSelector.css +22 -24
- package/dist/components/DateSelector/DateSelector.d.ts +0 -1
- package/dist/components/DateSelector/DateSelector.js +2 -2
- package/dist/components/DateSelector/DateSelector.js.map +1 -1
- package/dist/components/ErrorBoundary/ErrorBoundary.js +3 -4
- package/dist/components/ErrorBoundary/ErrorBoundary.js.map +1 -1
- package/dist/components/ExpertsDrawer/ExpertsDrawer.css +6 -9
- package/dist/components/ExpertsDrawer/ExpertsDrawer.d.ts +0 -1
- package/dist/components/ExpertsDrawer/ExpertsDrawer.js +2 -3
- package/dist/components/ExpertsDrawer/ExpertsDrawer.js.map +1 -1
- package/dist/components/ExportHistoryButton/ExportHistoryButton.css +3 -3
- package/dist/components/FeedbackButtons/FeedbackButtons.css +17 -15
- package/dist/components/FeedbackButtons/FeedbackButtons.d.ts +0 -1
- package/dist/components/FeedbackButtons/FeedbackButtons.js +32 -12
- package/dist/components/FeedbackButtons/FeedbackButtons.js.map +1 -1
- package/dist/components/FilePreview/FilePreview.css +56 -40
- package/dist/components/FilePreview/FilePreview.d.ts +0 -1
- package/dist/components/FilePreview/FilePreview.js +11 -12
- package/dist/components/FilePreview/FilePreview.js.map +1 -1
- package/dist/components/Header/ChatConsumptionDropdown.d.ts +10 -2
- package/dist/components/Header/ChatConsumptionDropdown.js +36 -10
- package/dist/components/Header/ChatConsumptionDropdown.js.map +1 -1
- package/dist/components/Header/Header.css +525 -62
- package/dist/components/Header/Header.d.ts +7 -1
- package/dist/components/Header/Header.js +357 -69
- package/dist/components/Header/Header.js.map +1 -1
- package/dist/components/KnownFacts/KnownFacts.css +52 -13
- package/dist/components/KnownFacts/KnownFacts.d.ts +2 -2
- package/dist/components/KnownFacts/KnownFacts.js +183 -128
- package/dist/components/KnownFacts/KnownFacts.js.map +1 -1
- package/dist/components/LoginDrawer/LoginDrawer.css +377 -252
- package/dist/components/LoginDrawer/LoginDrawer.d.ts +1 -2
- package/dist/components/LoginDrawer/LoginDrawer.js +140 -32
- package/dist/components/LoginDrawer/LoginDrawer.js.map +1 -1
- package/dist/components/MediaWidget/DocumentCard.js +1 -2
- package/dist/components/MediaWidget/DocumentCard.js.map +1 -1
- package/dist/components/MediaWidget/MediaItemWidget.css +222 -176
- package/dist/components/MediaWidget/MediaItemWidget.js +23 -26
- package/dist/components/MediaWidget/MediaItemWidget.js.map +1 -1
- package/dist/components/MediaWidget/MediaItemWidget.types.d.ts +0 -1
- package/dist/components/MediaWidget/MediaItemWidget.utils.js +11 -11
- package/dist/components/MediaWidget/MediaItemWidget.utils.js.map +1 -1
- package/dist/components/MediaWidget/MediaPreviewModal.d.ts +1 -1
- package/dist/components/MediaWidget/MediaPreviewModal.js +2 -3
- package/dist/components/MediaWidget/MediaPreviewModal.js.map +1 -1
- package/dist/components/MediaWidget/MediaWidget.css +5 -5
- package/dist/components/MediaWidget/MediaWidget.js +3 -4
- package/dist/components/MediaWidget/MediaWidget.js.map +1 -1
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.css +83 -87
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.js +4 -9
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.js.map +1 -1
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyButtonWithDropdown.js +25 -28
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyButtonWithDropdown.js.map +1 -1
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyMenuItem.js +5 -8
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyMenuItem.js.map +1 -1
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/hooks/useCopyArtifact.js +8 -7
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/hooks/useCopyArtifact.js.map +1 -1
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/styles.css +287 -277
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/utils/PDFExporter.js +5 -5
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/utils/PDFExporter.js.map +1 -1
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.css +117 -142
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.js +47 -45
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.js.map +1 -1
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.css +4 -134
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.js +10 -16
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.js.map +1 -1
- package/dist/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.css +196 -166
- package/dist/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.js +41 -29
- package/dist/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.js.map +1 -1
- package/dist/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.css +204 -205
- package/dist/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.js.map +1 -1
- package/dist/components/MemoriArtifactSystem/context/ArtifactContext.d.ts +4 -1
- package/dist/components/MemoriArtifactSystem/context/ArtifactContext.js +5 -1
- package/dist/components/MemoriArtifactSystem/context/ArtifactContext.js.map +1 -1
- package/dist/components/MemoriArtifactSystem/types/artifact.types.d.ts +1 -0
- package/dist/components/MemoriArtifactSystem/utils/ArtifactAPI.js +15 -4
- package/dist/components/MemoriArtifactSystem/utils/ArtifactAPI.js.map +1 -1
- package/dist/components/MemoriWidget/MemoriWidget.css +16 -71
- package/dist/components/MemoriWidget/MemoriWidget.d.ts +16 -10
- package/dist/components/MemoriWidget/MemoriWidget.js +198 -105
- package/dist/components/MemoriWidget/MemoriWidget.js.map +1 -1
- package/dist/components/MicrophoneButton/MicrophoneButton.css +25 -5
- package/dist/components/MicrophoneButton/MicrophoneButton.d.ts +2 -2
- package/dist/components/MicrophoneButton/MicrophoneButton.js +16 -13
- package/dist/components/MicrophoneButton/MicrophoneButton.js.map +1 -1
- package/dist/components/MobileSessionPanel/MobileSessionPanel.css +30 -4
- package/dist/components/MobileSessionPanel/MobileSessionPanel.js +13 -10
- package/dist/components/MobileSessionPanel/MobileSessionPanel.js.map +1 -1
- package/dist/components/PoweredBy/PoweredBy.css +29 -27
- package/dist/components/PoweredBy/PoweredBy.d.ts +1 -2
- package/dist/components/PoweredBy/PoweredBy.js +5 -7
- package/dist/components/PoweredBy/PoweredBy.js.map +1 -1
- package/dist/components/SendOnEnterMenu/SendOnEnterMenu.css +3 -3
- package/dist/components/SendOnEnterMenu/SendOnEnterMenu.js +3 -9
- package/dist/components/SendOnEnterMenu/SendOnEnterMenu.js.map +1 -1
- package/dist/components/SettingsDrawer/SettingsDrawer.css +2 -2
- package/dist/components/SettingsDrawer/SettingsDrawer.d.ts +0 -1
- package/dist/components/SettingsDrawer/SettingsDrawer.js +19 -17
- package/dist/components/SettingsDrawer/SettingsDrawer.js.map +1 -1
- package/dist/components/ShareButton/ShareButton.css +254 -8
- package/dist/components/ShareButton/ShareButton.d.ts +6 -1
- package/dist/components/ShareButton/ShareButton.js +199 -41
- package/dist/components/ShareButton/ShareButton.js.map +1 -1
- package/dist/components/Snippet/Snippet.css +53 -17
- package/dist/components/Snippet/Snippet.d.ts +0 -1
- package/dist/components/Snippet/Snippet.js +3 -3
- package/dist/components/Snippet/Snippet.js.map +1 -1
- package/dist/components/StartPanel/StartPanel.css +733 -110
- package/dist/components/StartPanel/StartPanel.d.ts +5 -1
- package/dist/components/StartPanel/StartPanel.js +152 -64
- package/dist/components/StartPanel/StartPanel.js.map +1 -1
- package/dist/components/Typing/Typing.d.ts +8 -2
- package/dist/components/Typing/Typing.js +41 -2
- package/dist/components/Typing/Typing.js.map +1 -1
- package/dist/components/UploadButton/UploadButton.css +357 -326
- package/dist/components/UploadButton/UploadButton.d.ts +1 -0
- package/dist/components/UploadButton/UploadButton.js +46 -28
- package/dist/components/UploadButton/UploadButton.js.map +1 -1
- package/dist/components/UploadButton/UploadDocuments/UploadDocuments.js +5 -5
- package/dist/components/UploadButton/UploadDocuments/UploadDocuments.js.map +1 -1
- package/dist/components/UploadButton/UploadImages/UploadImages.js +22 -16
- package/dist/components/UploadButton/UploadImages/UploadImages.js.map +1 -1
- package/dist/components/VenueWidget/VenueWidget.css +101 -41
- package/dist/components/VenueWidget/VenueWidget.d.ts +19 -1
- package/dist/components/VenueWidget/VenueWidget.js +140 -59
- package/dist/components/VenueWidget/VenueWidget.js.map +1 -1
- package/dist/components/WhyThisAnswer/WhyThisAnswer.css +20 -20
- package/dist/components/WhyThisAnswer/WhyThisAnswer.d.ts +0 -1
- package/dist/components/WhyThisAnswer/WhyThisAnswer.js +11 -8
- package/dist/components/WhyThisAnswer/WhyThisAnswer.js.map +1 -1
- package/dist/components/icons/GasStation.d.ts +2 -3
- package/dist/components/layouts/Chat.js +194 -4
- package/dist/components/layouts/Chat.js.map +1 -1
- package/dist/components/layouts/FullPage.js +186 -4
- package/dist/components/layouts/FullPage.js.map +1 -1
- package/dist/components/layouts/HiddenChat.js +289 -12
- package/dist/components/layouts/HiddenChat.js.map +1 -1
- package/dist/components/layouts/Totem.js +2 -3
- package/dist/components/layouts/Totem.js.map +1 -1
- package/dist/components/layouts/ZoomedFullBody.js +185 -3
- package/dist/components/layouts/ZoomedFullBody.js.map +1 -1
- package/dist/components/layouts/chat.css +273 -71
- package/dist/components/layouts/hidden-chat.css +329 -84
- package/dist/components/layouts/totem.css +23 -15
- package/dist/components/layouts/zoomed-full-body.css +144 -6
- package/dist/context/visemeContext.js.map +1 -1
- package/dist/helpers/chatPdfExport.js +15 -12
- package/dist/helpers/chatPdfExport.js.map +1 -1
- package/dist/helpers/configuration.js.map +1 -1
- package/dist/helpers/constants.js +25 -25
- package/dist/helpers/constants.js.map +1 -1
- package/dist/helpers/credits.d.ts +3 -3
- package/dist/helpers/credits.js.map +1 -1
- package/dist/helpers/error.js.map +1 -1
- package/dist/helpers/imageCompression.js.map +1 -1
- package/dist/helpers/llmUsage.js.map +1 -1
- package/dist/helpers/markedExtendedTables.js +1 -1
- package/dist/helpers/markedExtendedTables.js.map +1 -1
- package/dist/helpers/media.js.map +1 -1
- package/dist/helpers/message.js.map +1 -1
- package/dist/helpers/piiDetection.js +1 -2
- package/dist/helpers/piiDetection.js.map +1 -1
- package/dist/helpers/sanitizer.js +1 -2
- package/dist/helpers/sanitizer.js.map +1 -1
- package/dist/helpers/statistics.js.map +1 -1
- package/dist/helpers/stt/useSTT.d.ts +0 -1
- package/dist/helpers/stt/useSTT.js +1 -2
- package/dist/helpers/stt/useSTT.js.map +1 -1
- package/dist/helpers/tts/ttsVoiceUtility.js +8 -8
- package/dist/helpers/tts/ttsVoiceUtility.js.map +1 -1
- package/dist/helpers/tts/useTTS.d.ts +0 -1
- package/dist/helpers/tts/useTTS.js +1 -2
- package/dist/helpers/tts/useTTS.js.map +1 -1
- package/dist/helpers/utils.d.ts +2 -1
- package/dist/helpers/utils.js +8 -7
- package/dist/helpers/utils.js.map +1 -1
- package/dist/i18n.js +2 -0
- package/dist/i18n.js.map +1 -1
- package/dist/index.js +17 -17
- package/dist/index.js.map +1 -1
- package/dist/locales/de.json +67 -6
- package/dist/locales/en.json +67 -6
- package/dist/locales/es.json +67 -7
- package/dist/locales/fr.json +68 -7
- package/dist/locales/it.json +68 -7
- package/dist/styles.css +87 -52
- package/dist/version.d.ts +1 -1
- package/dist/version.js +1 -1
- package/dist/version.js.map +1 -1
- package/esm/components/AgeVerificationModal/AgeVerificationModal.css +35 -12
- package/esm/components/AgeVerificationModal/AgeVerificationModal.d.ts +0 -1
- package/esm/components/AgeVerificationModal/AgeVerificationModal.js +22 -10
- package/esm/components/AgeVerificationModal/AgeVerificationModal.js.map +1 -1
- package/esm/components/Auth/Auth.css +13 -9
- package/esm/components/Auth/Auth.d.ts +0 -1
- package/esm/components/Auth/Auth.js +14 -9
- package/esm/components/Auth/Auth.js.map +1 -1
- package/esm/components/Avatar/Avatar.css +2 -2
- package/esm/components/Avatar/Avatar.js +7 -7
- package/esm/components/Avatar/Avatar.js.map +1 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.d.ts +0 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.js +1 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.js.map +1 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/avatarComponent.d.ts +0 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/avatarComponent.js.map +1 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/fullbodyAvatar.d.ts +0 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/fullbodyAvatar.js.map +1 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarAnimator.js.map +1 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarPositionController.js.map +1 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controllers/MorphTargetController.js.map +1 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/halfbodyAvatar.d.ts +0 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/halfbodyAvatar.js.map +1 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/loader.d.ts +0 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/loader.js +1 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/loader.js.map +1 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.css +21 -21
- package/esm/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.d.ts +0 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.js +8 -9
- package/esm/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.js.map +1 -1
- package/esm/components/Avatar/AvatarView/index.js.map +1 -1
- package/esm/components/Avatar/AvatarView/utils/hideHands.js.map +1 -1
- package/esm/components/Avatar/AvatarView/utils/useEyeBlink.js.map +1 -1
- package/esm/components/Avatar/AvatarView/utils/useHeadMovement.js.map +1 -1
- package/esm/components/Avatar/AvatarView/utils/useLoadingMorphAnim.js.map +1 -1
- package/esm/components/Avatar/AvatarView/utils/useMouthAnimation.js.map +1 -1
- package/esm/components/Avatar/AvatarView/utils/useSmile.js.map +1 -1
- package/esm/components/Avatar/AvatarView/utils/utils.js.map +1 -1
- package/esm/components/Blob/Blob.css +14 -12
- package/esm/components/Blob/Blob.d.ts +0 -1
- package/esm/components/BlockedMemoriBadge/BlockedMemoriBadge.css +4 -4
- package/esm/components/BlockedMemoriBadge/BlockedMemoriBadge.d.ts +0 -1
- package/esm/components/BlockedMemoriBadge/BlockedMemoriBadge.js +3 -3
- package/esm/components/BlockedMemoriBadge/BlockedMemoriBadge.js.map +1 -1
- package/esm/components/ChangeMode/ChangeMode.css +4 -2
- package/esm/components/ChangeMode/ChangeMode.js +8 -3
- package/esm/components/ChangeMode/ChangeMode.js.map +1 -1
- package/esm/components/Chat/Chat.css +114 -38
- package/esm/components/Chat/Chat.js +35 -49
- package/esm/components/Chat/Chat.js.map +1 -1
- package/esm/components/ChatBubble/ChatBubble.css +206 -68
- package/esm/components/ChatBubble/ChatBubble.d.ts +5 -0
- package/esm/components/ChatBubble/ChatBubble.js +223 -164
- package/esm/components/ChatBubble/ChatBubble.js.map +1 -1
- package/esm/components/ChatHistoryDrawer/ChatHistory.css +417 -156
- package/esm/components/ChatHistoryDrawer/ChatHistory.d.ts +0 -1
- package/esm/components/ChatHistoryDrawer/ChatHistory.js +252 -151
- package/esm/components/ChatHistoryDrawer/ChatHistory.js.map +1 -1
- package/esm/components/ChatHistoryDrawer/ChatResumeDrawer.css +1 -1
- package/esm/components/ChatInputs/ChatInputs.css +68 -51
- package/esm/components/ChatInputs/ChatInputs.d.ts +1 -0
- package/esm/components/ChatInputs/ChatInputs.js +51 -28
- package/esm/components/ChatInputs/ChatInputs.js.map +1 -1
- package/esm/components/ChatTextArea/ChatTextArea.css +38 -12
- package/esm/components/ChatTextArea/ChatTextArea.js +1 -1
- package/esm/components/ChatTextArea/ChatTextArea.js.map +1 -1
- package/esm/components/CompletionProviderStatus/CompletionProviderStatus.css +5 -5
- package/esm/components/CompletionProviderStatus/CompletionProviderStatus.d.ts +0 -1
- package/esm/components/CompletionProviderStatus/CompletionProviderStatus.js +5 -7
- package/esm/components/CompletionProviderStatus/CompletionProviderStatus.js.map +1 -1
- package/esm/components/ContentPreviewModal/ContentPreviewModal.css +129 -84
- package/esm/components/ContentPreviewModal/ContentPreviewModal.js +5 -4
- package/esm/components/ContentPreviewModal/ContentPreviewModal.js.map +1 -1
- package/esm/components/CustomGLBModelViewer/ModelViewer.d.ts +0 -1
- package/esm/components/DateSelector/DateSelector.css +22 -24
- package/esm/components/DateSelector/DateSelector.d.ts +0 -1
- package/esm/components/DateSelector/DateSelector.js +2 -2
- package/esm/components/DateSelector/DateSelector.js.map +1 -1
- package/esm/components/ErrorBoundary/ErrorBoundary.js +3 -3
- package/esm/components/ErrorBoundary/ErrorBoundary.js.map +1 -1
- package/esm/components/ExpertsDrawer/ExpertsDrawer.css +6 -9
- package/esm/components/ExpertsDrawer/ExpertsDrawer.d.ts +0 -1
- package/esm/components/ExpertsDrawer/ExpertsDrawer.js +1 -1
- package/esm/components/ExpertsDrawer/ExpertsDrawer.js.map +1 -1
- package/esm/components/ExportHistoryButton/ExportHistoryButton.css +3 -3
- package/esm/components/FeedbackButtons/FeedbackButtons.css +17 -15
- package/esm/components/FeedbackButtons/FeedbackButtons.d.ts +0 -1
- package/esm/components/FeedbackButtons/FeedbackButtons.js +32 -11
- package/esm/components/FeedbackButtons/FeedbackButtons.js.map +1 -1
- package/esm/components/FilePreview/FilePreview.css +56 -40
- package/esm/components/FilePreview/FilePreview.d.ts +0 -1
- package/esm/components/FilePreview/FilePreview.js +11 -12
- package/esm/components/FilePreview/FilePreview.js.map +1 -1
- package/esm/components/Header/ChatConsumptionDropdown.d.ts +10 -2
- package/esm/components/Header/ChatConsumptionDropdown.js +34 -10
- package/esm/components/Header/ChatConsumptionDropdown.js.map +1 -1
- package/esm/components/Header/Header.css +525 -62
- package/esm/components/Header/Header.d.ts +7 -1
- package/esm/components/Header/Header.js +359 -71
- package/esm/components/Header/Header.js.map +1 -1
- package/esm/components/KnownFacts/KnownFacts.css +52 -13
- package/esm/components/KnownFacts/KnownFacts.d.ts +2 -2
- package/esm/components/KnownFacts/KnownFacts.js +185 -129
- package/esm/components/KnownFacts/KnownFacts.js.map +1 -1
- package/esm/components/LoginDrawer/LoginDrawer.css +377 -252
- package/esm/components/LoginDrawer/LoginDrawer.d.ts +1 -2
- package/esm/components/LoginDrawer/LoginDrawer.js +140 -32
- package/esm/components/LoginDrawer/LoginDrawer.js.map +1 -1
- package/esm/components/MediaWidget/MediaItemWidget.css +222 -176
- package/esm/components/MediaWidget/MediaItemWidget.js +14 -17
- package/esm/components/MediaWidget/MediaItemWidget.js.map +1 -1
- package/esm/components/MediaWidget/MediaItemWidget.types.d.ts +0 -1
- package/esm/components/MediaWidget/MediaItemWidget.utils.js.map +1 -1
- package/esm/components/MediaWidget/MediaPreviewModal.d.ts +1 -1
- package/esm/components/MediaWidget/MediaPreviewModal.js +1 -1
- package/esm/components/MediaWidget/MediaPreviewModal.js.map +1 -1
- package/esm/components/MediaWidget/MediaWidget.css +5 -5
- package/esm/components/MediaWidget/MediaWidget.js +2 -3
- package/esm/components/MediaWidget/MediaWidget.js.map +1 -1
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.css +83 -87
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.js +4 -8
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.js.map +1 -1
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyButtonWithDropdown.js +23 -26
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyButtonWithDropdown.js.map +1 -1
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyMenuItem.js +3 -6
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyMenuItem.js.map +1 -1
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/hooks/useCopyArtifact.js +8 -7
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/hooks/useCopyArtifact.js.map +1 -1
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/styles.css +287 -277
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/utils/PDFExporter.js +5 -5
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/utils/PDFExporter.js.map +1 -1
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.css +117 -142
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.js +47 -45
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.js.map +1 -1
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.css +4 -134
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.js +9 -14
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.js.map +1 -1
- package/esm/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.css +196 -166
- package/esm/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.js +41 -29
- package/esm/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.js.map +1 -1
- package/esm/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.css +204 -205
- package/esm/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.js.map +1 -1
- package/esm/components/MemoriArtifactSystem/context/ArtifactContext.d.ts +4 -1
- package/esm/components/MemoriArtifactSystem/context/ArtifactContext.js +5 -1
- package/esm/components/MemoriArtifactSystem/context/ArtifactContext.js.map +1 -1
- package/esm/components/MemoriArtifactSystem/types/artifact.types.d.ts +1 -0
- package/esm/components/MemoriArtifactSystem/utils/ArtifactAPI.js +15 -4
- package/esm/components/MemoriArtifactSystem/utils/ArtifactAPI.js.map +1 -1
- package/esm/components/MemoriWidget/MemoriWidget.css +16 -71
- package/esm/components/MemoriWidget/MemoriWidget.d.ts +16 -10
- package/esm/components/MemoriWidget/MemoriWidget.js +197 -105
- package/esm/components/MemoriWidget/MemoriWidget.js.map +1 -1
- package/esm/components/MicrophoneButton/MicrophoneButton.css +25 -5
- package/esm/components/MicrophoneButton/MicrophoneButton.d.ts +2 -2
- package/esm/components/MicrophoneButton/MicrophoneButton.js +16 -12
- package/esm/components/MicrophoneButton/MicrophoneButton.js.map +1 -1
- package/esm/components/MobileSessionPanel/MobileSessionPanel.css +30 -4
- package/esm/components/MobileSessionPanel/MobileSessionPanel.js +14 -11
- package/esm/components/MobileSessionPanel/MobileSessionPanel.js.map +1 -1
- package/esm/components/PoweredBy/PoweredBy.css +29 -27
- package/esm/components/PoweredBy/PoweredBy.d.ts +1 -2
- package/esm/components/PoweredBy/PoweredBy.js +4 -7
- package/esm/components/PoweredBy/PoweredBy.js.map +1 -1
- package/esm/components/SendOnEnterMenu/SendOnEnterMenu.css +3 -3
- package/esm/components/SendOnEnterMenu/SendOnEnterMenu.js +3 -8
- package/esm/components/SendOnEnterMenu/SendOnEnterMenu.js.map +1 -1
- package/esm/components/SettingsDrawer/SettingsDrawer.css +2 -2
- package/esm/components/SettingsDrawer/SettingsDrawer.d.ts +0 -1
- package/esm/components/SettingsDrawer/SettingsDrawer.js +19 -16
- package/esm/components/SettingsDrawer/SettingsDrawer.js.map +1 -1
- package/esm/components/ShareButton/ShareButton.css +254 -8
- package/esm/components/ShareButton/ShareButton.d.ts +6 -1
- package/esm/components/ShareButton/ShareButton.js +200 -42
- package/esm/components/ShareButton/ShareButton.js.map +1 -1
- package/esm/components/Snippet/Snippet.css +53 -17
- package/esm/components/Snippet/Snippet.d.ts +0 -1
- package/esm/components/Snippet/Snippet.js +3 -3
- package/esm/components/Snippet/Snippet.js.map +1 -1
- package/esm/components/StartPanel/StartPanel.css +733 -110
- package/esm/components/StartPanel/StartPanel.d.ts +5 -1
- package/esm/components/StartPanel/StartPanel.js +154 -66
- package/esm/components/StartPanel/StartPanel.js.map +1 -1
- package/esm/components/Typing/Typing.d.ts +8 -2
- package/esm/components/Typing/Typing.js +41 -2
- package/esm/components/Typing/Typing.js.map +1 -1
- package/esm/components/UploadButton/UploadButton.css +357 -326
- package/esm/components/UploadButton/UploadButton.d.ts +1 -0
- package/esm/components/UploadButton/UploadButton.js +47 -29
- package/esm/components/UploadButton/UploadButton.js.map +1 -1
- package/esm/components/UploadButton/UploadDocuments/UploadDocuments.js +5 -5
- package/esm/components/UploadButton/UploadDocuments/UploadDocuments.js.map +1 -1
- package/esm/components/UploadButton/UploadImages/UploadImages.js +22 -16
- package/esm/components/UploadButton/UploadImages/UploadImages.js.map +1 -1
- package/esm/components/VenueWidget/VenueWidget.css +101 -41
- package/esm/components/VenueWidget/VenueWidget.d.ts +19 -1
- package/esm/components/VenueWidget/VenueWidget.js +138 -61
- package/esm/components/VenueWidget/VenueWidget.js.map +1 -1
- package/esm/components/WhyThisAnswer/WhyThisAnswer.css +20 -20
- package/esm/components/WhyThisAnswer/WhyThisAnswer.d.ts +0 -1
- package/esm/components/WhyThisAnswer/WhyThisAnswer.js +10 -7
- package/esm/components/WhyThisAnswer/WhyThisAnswer.js.map +1 -1
- package/esm/components/icons/GasStation.d.ts +2 -3
- package/esm/components/layouts/Chat.js +194 -4
- package/esm/components/layouts/Chat.js.map +1 -1
- package/esm/components/layouts/FullPage.js +186 -4
- package/esm/components/layouts/FullPage.js.map +1 -1
- package/esm/components/layouts/HiddenChat.js +290 -13
- package/esm/components/layouts/HiddenChat.js.map +1 -1
- package/esm/components/layouts/Totem.js +2 -2
- package/esm/components/layouts/Totem.js.map +1 -1
- package/esm/components/layouts/ZoomedFullBody.js +185 -3
- package/esm/components/layouts/ZoomedFullBody.js.map +1 -1
- package/esm/components/layouts/chat.css +273 -71
- package/esm/components/layouts/hidden-chat.css +329 -84
- package/esm/components/layouts/totem.css +23 -15
- package/esm/components/layouts/zoomed-full-body.css +144 -6
- package/esm/context/visemeContext.js.map +1 -1
- package/esm/helpers/chatPdfExport.js +15 -12
- package/esm/helpers/chatPdfExport.js.map +1 -1
- package/esm/helpers/configuration.js.map +1 -1
- package/esm/helpers/constants.js +25 -25
- package/esm/helpers/constants.js.map +1 -1
- package/esm/helpers/credits.d.ts +3 -3
- package/esm/helpers/credits.js.map +1 -1
- package/esm/helpers/error.js.map +1 -1
- package/esm/helpers/imageCompression.js.map +1 -1
- package/esm/helpers/llmUsage.js.map +1 -1
- package/esm/helpers/markedExtendedTables.js.map +1 -1
- package/esm/helpers/media.js.map +1 -1
- package/esm/helpers/message.js.map +1 -1
- package/esm/helpers/piiDetection.js.map +1 -1
- package/esm/helpers/statistics.js.map +1 -1
- package/esm/helpers/stt/useSTT.d.ts +0 -1
- package/esm/helpers/stt/useSTT.js.map +1 -1
- package/esm/helpers/tts/ttsVoiceUtility.js.map +1 -1
- package/esm/helpers/tts/useTTS.d.ts +0 -1
- package/esm/helpers/tts/useTTS.js.map +1 -1
- package/esm/helpers/utils.d.ts +2 -1
- package/esm/helpers/utils.js +1 -0
- package/esm/helpers/utils.js.map +1 -1
- package/esm/i18n.js +2 -0
- package/esm/i18n.js.map +1 -1
- package/esm/index.js +17 -17
- package/esm/index.js.map +1 -1
- package/esm/locales/de.json +67 -6
- package/esm/locales/en.json +67 -6
- package/esm/locales/es.json +67 -7
- package/esm/locales/fr.json +68 -7
- package/esm/locales/it.json +68 -7
- package/esm/styles.css +87 -52
- package/esm/version.d.ts +1 -1
- package/esm/version.js +1 -1
- package/esm/version.js.map +1 -1
- package/package.json +15 -11
- package/src/Showcase.stories.tsx +641 -0
- package/src/__snapshots__/index.test.tsx.snap +40 -10
- package/src/components/AgeVerificationModal/AgeVerificationModal.css +35 -12
- package/src/components/AgeVerificationModal/AgeVerificationModal.stories.tsx +4 -1
- package/src/components/AgeVerificationModal/AgeVerificationModal.test.tsx +2 -1
- package/src/components/AgeVerificationModal/AgeVerificationModal.tsx +59 -39
- package/src/components/AgeVerificationModal/__snapshots__/AgeVerificationModal.test.tsx.snap +27 -3
- package/src/components/Auth/Auth.css +13 -9
- package/src/components/Auth/Auth.tsx +30 -18
- package/src/components/Auth/__snapshots__/Auth.test.tsx.snap +91 -35
- package/src/components/Avatar/Avatar.css +2 -2
- package/src/components/Avatar/Avatar.tsx +11 -8
- package/src/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.tsx +1 -1
- package/src/components/Avatar/AvatarView/AvatarComponent/components/loader.tsx +1 -1
- package/src/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.css +21 -21
- package/src/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.tsx +12 -14
- package/src/components/Blob/Blob.css +14 -12
- package/src/components/BlockedMemoriBadge/BlockedMemoriBadge.css +4 -4
- package/src/components/BlockedMemoriBadge/BlockedMemoriBadge.tsx +3 -3
- package/src/components/BlockedMemoriBadge/__snapshots__/BlockedMemoriBadge.test.tsx.snap +115 -70
- package/src/components/ChangeMode/ChangeMode.css +4 -2
- package/src/components/ChangeMode/ChangeMode.tsx +29 -28
- package/src/components/ChangeMode/__snapshots__/ChangeMode.test.tsx.snap +50 -80
- package/src/components/Chat/Chat.css +114 -38
- package/src/components/Chat/Chat.stories.tsx +15 -12
- package/src/components/Chat/Chat.test.tsx +11 -2
- package/src/components/Chat/Chat.tsx +136 -173
- package/src/components/Chat/__snapshots__/Chat.test.tsx.snap +8260 -4942
- package/src/components/ChatBubble/ChatBubble.css +206 -68
- package/src/components/ChatBubble/ChatBubble.stories.tsx +13 -20
- package/src/components/ChatBubble/ChatBubble.test.tsx +5 -0
- package/src/components/ChatBubble/ChatBubble.tsx +505 -401
- package/src/components/ChatBubble/__snapshots__/ChatBubble.test.tsx.snap +7753 -6638
- package/src/components/ChatHistoryDrawer/ChatHistory.css +417 -156
- package/src/components/ChatHistoryDrawer/ChatHistory.stories.tsx +121 -82
- package/src/components/ChatHistoryDrawer/ChatHistory.test.tsx +65 -56
- package/src/components/ChatHistoryDrawer/ChatHistory.tsx +507 -513
- package/src/components/ChatHistoryDrawer/ChatResumeDrawer.css +367 -0
- package/src/components/ChatHistoryDrawer/ChatResumeDrawer.tsx +296 -0
- package/src/components/ChatHistoryDrawer/__snapshots__/ChatHistory.test.tsx.snap +12 -15
- package/src/components/ChatInputs/ChatInputs.css +68 -51
- package/src/components/ChatInputs/ChatInputs.stories.tsx +13 -10
- package/src/components/ChatInputs/ChatInputs.tsx +80 -54
- package/src/components/ChatTextArea/ChatTextArea.css +38 -12
- package/src/components/ChatTextArea/ChatTextArea.tsx +7 -3
- package/src/components/ChatTextArea/__snapshots__/ChatTextArea.test.tsx.snap +6 -0
- package/src/components/CompletionProviderStatus/CompletionProviderStatus.css +5 -5
- package/src/components/CompletionProviderStatus/CompletionProviderStatus.tsx +5 -7
- package/src/components/CompletionProviderStatus/__snapshots__/CompletionProviderStatus.test.tsx.snap +63 -48
- package/src/components/ContentPreviewModal/ContentPreviewModal.css +129 -84
- package/src/components/ContentPreviewModal/ContentPreviewModal.tsx +4 -3
- package/src/components/DateSelector/DateSelector.css +22 -24
- package/src/components/DateSelector/DateSelector.tsx +11 -4
- package/src/components/DrawerFooter/DrawerFooter.css +62 -0
- package/src/components/DrawerFooter/DrawerFooter.tsx +58 -0
- package/src/components/ErrorBoundary/ErrorBoundary.tsx +3 -3
- package/src/components/ExpertsDrawer/ExpertsDrawer.css +6 -9
- package/src/components/ExpertsDrawer/ExpertsDrawer.tsx +1 -1
- package/src/components/ExpertsDrawer/__snapshots__/ExpertsDrawer.test.tsx.snap +4 -5
- package/src/components/ExportHistoryButton/ExportHistoryButton.css +3 -3
- package/src/components/FeedbackButtons/FeedbackButtons.css +17 -15
- package/src/components/FeedbackButtons/FeedbackButtons.stories.tsx +4 -1
- package/src/components/FeedbackButtons/FeedbackButtons.test.tsx +1 -1
- package/src/components/FeedbackButtons/FeedbackButtons.tsx +104 -77
- package/src/components/FeedbackButtons/__snapshots__/FeedbackButtons.test.tsx.snap +30 -17
- package/src/components/FilePreview/FilePreview.css +56 -40
- package/src/components/FilePreview/FilePreview.tsx +36 -27
- package/src/components/FilePreview/__snapshots__/FilePreview.test.tsx.snap +165 -96
- package/src/components/Header/ChatConsumptionDropdown.test.tsx +41 -4
- package/src/components/Header/ChatConsumptionDropdown.tsx +190 -123
- package/src/components/Header/Header.css +525 -62
- package/src/components/Header/Header.stories.tsx +123 -57
- package/src/components/Header/Header.test.tsx +43 -15
- package/src/components/Header/Header.tsx +1037 -250
- package/src/components/Header/__snapshots__/Header.test.tsx.snap +1752 -700
- package/src/components/KnownFacts/KnownFacts.css +52 -13
- package/src/components/KnownFacts/KnownFacts.stories.tsx +11 -8
- package/src/components/KnownFacts/KnownFacts.test.tsx +1 -1
- package/src/components/KnownFacts/KnownFacts.tsx +327 -316
- package/src/components/KnownFacts/__snapshots__/KnownFacts.test.tsx.snap +27 -3
- package/src/components/LoginDrawer/LoginDrawer.css +377 -252
- package/src/components/LoginDrawer/LoginDrawer.stories.tsx +3 -0
- package/src/components/LoginDrawer/LoginDrawer.test.tsx +1 -1
- package/src/components/LoginDrawer/LoginDrawer.tsx +301 -123
- package/src/components/LoginDrawer/__snapshots__/LoginDrawer.test.tsx.snap +90 -12
- package/src/components/MediaWidget/DocumentCard.test.tsx +1 -1
- package/src/components/MediaWidget/MediaItemWidget.css +222 -176
- package/src/components/MediaWidget/MediaItemWidget.tsx +17 -31
- package/src/components/MediaWidget/MediaPreviewModal.test.tsx +1 -1
- package/src/components/MediaWidget/MediaPreviewModal.tsx +1 -1
- package/src/components/MediaWidget/MediaWidget.css +5 -5
- package/src/components/MediaWidget/MediaWidget.tsx +6 -16
- package/src/components/MediaWidget/__snapshots__/MediaItemWidget.test.tsx.snap +280 -463
- package/src/components/MediaWidget/__snapshots__/MediaWidget.test.tsx.snap +31 -45
- package/src/components/MemoriArtifactSystem/ArtifactDrawer.stories.tsx +17 -17
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.css +83 -87
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.tsx +32 -42
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyButtonWithDropdown.tsx +81 -84
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyMenuItem.tsx +8 -6
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/hooks/useCopyArtifact.ts +8 -7
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/styles.css +287 -277
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/utils/PDFExporter.ts +5 -5
- package/src/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.css +117 -142
- package/src/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.tsx +144 -155
- package/src/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.css +4 -134
- package/src/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.tsx +29 -45
- package/src/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.css +196 -166
- package/src/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.tsx +53 -27
- package/src/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.css +204 -205
- package/src/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.tsx +2 -3
- package/src/components/MemoriArtifactSystem/context/ArtifactContext.tsx +21 -10
- package/src/components/MemoriArtifactSystem/types/artifact.types.ts +2 -0
- package/src/components/MemoriArtifactSystem/utils/ArtifactAPI.test.tsx +2 -1
- package/src/components/MemoriArtifactSystem/utils/ArtifactAPI.tsx +15 -4
- package/src/components/MemoriWidget/MemoriWidget.css +16 -71
- package/src/components/MemoriWidget/MemoriWidget.stories.tsx +29 -8
- package/src/components/MemoriWidget/MemoriWidget.tsx +247 -131
- package/src/components/MicrophoneButton/MicrophoneButton.css +25 -5
- package/src/components/MicrophoneButton/MicrophoneButton.tsx +31 -24
- package/src/components/MobileSessionPanel/MobileSessionPanel.css +437 -0
- package/src/components/MobileSessionPanel/MobileSessionPanel.tsx +795 -0
- package/src/components/PositionPopover/PositionPopover.css +219 -0
- package/src/components/PositionPopover/PositionPopover.stories.tsx +37 -0
- package/src/components/PositionPopover/PositionPopover.tsx +367 -0
- package/src/components/PoweredBy/PoweredBy.css +29 -27
- package/src/components/PoweredBy/PoweredBy.tsx +11 -19
- package/src/components/PoweredBy/__snapshots__/PoweredBy.test.tsx.snap +248 -16
- package/src/components/SendOnEnterMenu/SendOnEnterMenu.css +3 -3
- package/src/components/SendOnEnterMenu/SendOnEnterMenu.tsx +30 -64
- package/src/components/SendOnEnterMenu/__snapshots__/SendOnEnterMenu.test.tsx.snap +74 -26
- package/src/components/SettingsDrawer/SettingsDrawer.css +2 -2
- package/src/components/SettingsDrawer/SettingsDrawer.tsx +54 -65
- package/src/components/SettingsDrawer/__snapshots__/SettingsDrawer.test.tsx.snap +28 -35
- package/src/components/ShareButton/ShareButton.css +254 -8
- package/src/components/ShareButton/ShareButton.stories.tsx +9 -4
- package/src/components/ShareButton/ShareButton.test.tsx +1 -1
- package/src/components/ShareButton/ShareButton.tsx +496 -142
- package/src/components/ShareButton/__snapshots__/ShareButton.test.tsx.snap +639 -216
- package/src/components/Snippet/Snippet.css +53 -17
- package/src/components/Snippet/Snippet.tsx +5 -5
- package/src/components/Snippet/__snapshots__/Snippet.test.tsx.snap +64 -48
- package/src/components/StartPanel/StartPanel.css +733 -110
- package/src/components/StartPanel/StartPanel.stories.tsx +54 -65
- package/src/components/StartPanel/StartPanel.test.tsx +26 -13
- package/src/components/StartPanel/StartPanel.tsx +555 -262
- package/src/components/StartPanel/__snapshots__/StartPanel.test.tsx.snap +2602 -1346
- package/src/components/Typing/Typing.tsx +85 -7
- package/src/components/Typing/__snapshots__/Typing.test.tsx.snap +102 -62
- package/src/components/UploadButton/UploadButton.css +357 -326
- package/src/components/UploadButton/UploadButton.stories.tsx +221 -87
- package/src/components/UploadButton/UploadButton.test.tsx +4 -1
- package/src/components/UploadButton/UploadButton.tsx +99 -81
- package/src/components/UploadButton/UploadDocuments/UploadDocuments.tsx +8 -5
- package/src/components/UploadButton/UploadImages/UploadImages.tsx +76 -63
- package/src/components/UploadButton/__snapshots__/UploadButton.test.tsx.snap +70 -75
- package/src/components/VenueWidget/VenueWidget.css +101 -41
- package/src/components/VenueWidget/VenueWidget.stories.tsx +4 -1
- package/src/components/VenueWidget/VenueWidget.test.tsx +1 -1
- package/src/components/VenueWidget/VenueWidget.tsx +311 -191
- package/src/components/VenueWidget/__snapshots__/VenueWidget.test.tsx.snap +498 -92
- package/src/components/WhyThisAnswer/WhyThisAnswer.css +20 -20
- package/src/components/WhyThisAnswer/WhyThisAnswer.stories.tsx +21 -18
- package/src/components/WhyThisAnswer/WhyThisAnswer.test.tsx +1 -1
- package/src/components/WhyThisAnswer/WhyThisAnswer.tsx +20 -11
- package/src/components/WhyThisAnswer/__snapshots__/WhyThisAnswer.test.tsx.snap +34 -4
- package/src/components/layouts/Chat.test.tsx +2 -1
- package/src/components/layouts/Chat.tsx +379 -17
- package/src/components/layouts/FullPage.test.tsx +2 -1
- package/src/components/layouts/FullPage.tsx +307 -14
- package/src/components/layouts/HiddenChat.test.tsx +2 -1
- package/src/components/layouts/HiddenChat.tsx +569 -44
- package/src/components/layouts/Totem.test.tsx +2 -1
- package/src/components/layouts/Totem.tsx +7 -3
- package/src/components/layouts/WebsiteAssistant/WebsiteAssistant.stories.tsx +115 -0
- package/src/components/layouts/WebsiteAssistant/WebsiteAssistant.test.tsx +43 -0
- package/src/components/layouts/{WebsiteAssistant.tsx → WebsiteAssistant/WebsiteAssistant.tsx} +29 -23
- package/src/components/layouts/WebsiteAssistant/__snapshots__/WebsiteAssistant.test.tsx.snap +76 -0
- package/src/components/layouts/{website-assistant.css → WebsiteAssistant/website-assistant.css} +74 -58
- package/src/components/layouts/ZoomedFullBody.test.tsx +2 -1
- package/src/components/layouts/ZoomedFullBody.tsx +304 -14
- package/src/components/layouts/__snapshots__/Chat.test.tsx.snap +663 -365
- package/src/components/layouts/__snapshots__/FullPage.test.tsx.snap +1170 -740
- package/src/components/layouts/__snapshots__/HiddenChat.test.tsx.snap +476 -339
- package/src/components/layouts/__snapshots__/Totem.test.tsx.snap +624 -392
- package/src/components/layouts/__snapshots__/ZoomedFullBody.test.tsx.snap +571 -356
- package/src/components/layouts/chat.css +273 -71
- package/src/components/layouts/fullpage.css +362 -0
- package/src/components/layouts/hidden-chat.css +329 -84
- package/src/components/layouts/layouts.stories.tsx +14 -146
- package/src/components/layouts/totem.css +23 -15
- package/src/components/layouts/zoomed-full-body.css +144 -6
- package/src/helpers/chatPdfExport.ts +15 -12
- package/src/helpers/constants.ts +28 -27
- package/src/helpers/utils.ts +2 -0
- package/src/i18n.ts +2 -0
- package/src/icons/FacebookIcon.tsx +23 -0
- package/src/icons/LinkedinIcon.tsx +23 -0
- package/src/icons/MemoriIcon.tsx +80 -0
- package/src/icons/TelegramIcon.tsx +19 -0
- package/src/icons/TwitterIcon.tsx +8 -0
- package/src/icons/WhatsappIcon.tsx +23 -0
- package/src/icons/artifacts/DocumentIcon.tsx +19 -0
- package/src/icons/artifacts/HtmlIcon.tsx +38 -0
- package/src/icons/artifacts/JavascriptIcon.tsx +19 -0
- package/src/icons/artifacts/MarkdownIcon.tsx +19 -0
- package/src/icons/artifacts/PythonIcon.tsx +17 -0
- package/src/icons/artifacts/SvgIcon.tsx +34 -0
- package/src/icons/artifacts/XmlIcon.tsx +34 -0
- package/src/icons/artifacts/cssIcon.tsx +34 -0
- package/src/index.stories.tsx +11 -5
- package/src/index.tsx +75 -72
- package/src/locales/de.json +67 -6
- package/src/locales/en.json +67 -6
- package/src/locales/es.json +67 -7
- package/src/locales/fr.json +68 -7
- package/src/locales/it.json +68 -7
- package/src/mocks/data.ts +5 -5
- package/src/styles.css +87 -52
- package/src/testUtils.tsx +42 -0
- package/src/version.ts +1 -1
- package/src/components/PositionDrawer/PositionDrawer.stories.tsx +0 -51
- package/src/components/PositionDrawer/PositionDrawer.test.tsx +0 -39
- package/src/components/PositionDrawer/PositionDrawer.tsx +0 -50
- package/src/components/PositionDrawer/__snapshots__/PositionDrawer.test.tsx.snap +0 -17
- package/src/components/icons/AI.tsx +0 -34
- package/src/components/icons/Alert.tsx +0 -31
- package/src/components/icons/ArrowUp.tsx +0 -28
- package/src/components/icons/Bug.tsx +0 -81
- package/src/components/icons/Chat.tsx +0 -30
- package/src/components/icons/ChevronDown.tsx +0 -26
- package/src/components/icons/ChevronLeft.tsx +0 -28
- package/src/components/icons/ChevronRight.tsx +0 -28
- package/src/components/icons/ChevronUp.tsx +0 -24
- package/src/components/icons/Clear.tsx +0 -23
- package/src/components/icons/Close.tsx +0 -30
- package/src/components/icons/Code.tsx +0 -24
- package/src/components/icons/Copy.tsx +0 -23
- package/src/components/icons/DeepThought.tsx +0 -38
- package/src/components/icons/Delete.tsx +0 -23
- package/src/components/icons/Document.tsx +0 -50
- package/src/components/icons/Download.tsx +0 -23
- package/src/components/icons/Edit.tsx +0 -17
- package/src/components/icons/Expand.tsx +0 -23
- package/src/components/icons/Eye.tsx +0 -17
- package/src/components/icons/EyeInvisible.tsx +0 -24
- package/src/components/icons/Facebook.tsx +0 -23
- package/src/components/icons/Feedback.tsx +0 -24
- package/src/components/icons/File.tsx +0 -17
- package/src/components/icons/FileExcel.tsx +0 -23
- package/src/components/icons/FilePdf.tsx +0 -23
- package/src/components/icons/FileWord.tsx +0 -23
- package/src/components/icons/Fullscreen.tsx +0 -23
- package/src/components/icons/FullscreenExit.tsx +0 -23
- package/src/components/icons/Group.tsx +0 -30
- package/src/components/icons/History.tsx +0 -33
- package/src/components/icons/Image.tsx +0 -37
- package/src/components/icons/Info.tsx +0 -31
- package/src/components/icons/Link.tsx +0 -17
- package/src/components/icons/Linkedin.tsx +0 -23
- package/src/components/icons/Loading.tsx +0 -28
- package/src/components/icons/Logout.tsx +0 -27
- package/src/components/icons/Mail.tsx +0 -17
- package/src/components/icons/MapMarker.tsx +0 -26
- package/src/components/icons/MenuHorizontal.tsx +0 -29
- package/src/components/icons/MenuVertical.tsx +0 -29
- package/src/components/icons/Message.tsx +0 -23
- package/src/components/icons/Microphone.tsx +0 -23
- package/src/components/icons/Minus.tsx +0 -23
- package/src/components/icons/MinusCircle.tsx +0 -24
- package/src/components/icons/PaperClip.tsx +0 -23
- package/src/components/icons/Picture.tsx +0 -23
- package/src/components/icons/Plus.tsx +0 -18
- package/src/components/icons/Preview.tsx +0 -29
- package/src/components/icons/Print.tsx +0 -34
- package/src/components/icons/QuestionHelp.tsx +0 -30
- package/src/components/icons/Refresh.tsx +0 -30
- package/src/components/icons/SelectIcon.tsx +0 -28
- package/src/components/icons/Send.tsx +0 -17
- package/src/components/icons/Setting.tsx +0 -23
- package/src/components/icons/Share.tsx +0 -23
- package/src/components/icons/Sound.tsx +0 -23
- package/src/components/icons/SoundDeactivated.tsx +0 -27
- package/src/components/icons/Telegram.tsx +0 -26
- package/src/components/icons/ThumbDown.tsx +0 -29
- package/src/components/icons/ThumbUp.tsx +0 -29
- package/src/components/icons/Translation.tsx +0 -24
- package/src/components/icons/Twitter.tsx +0 -23
- package/src/components/icons/Upload.tsx +0 -34
- package/src/components/icons/User.tsx +0 -17
- package/src/components/icons/Warning.tsx +0 -24
- package/src/components/icons/WhatsApp.tsx +0 -24
- package/src/components/icons/icons.stories.css +0 -5
- package/src/components/icons/icons.stories.tsx +0 -81
- package/src/components/icons/loading.css +0 -14
- package/src/components/layouts/WebsiteAssistant.test.tsx +0 -40
- package/src/components/layouts/__snapshots__/WebsiteAssistant.test.tsx.snap +0 -59
- package/src/components/ui/Alert.css +0 -93
- package/src/components/ui/Alert.stories.tsx +0 -137
- package/src/components/ui/Alert.test.tsx +0 -129
- package/src/components/ui/Alert.tsx +0 -123
- package/src/components/ui/Button.css +0 -167
- package/src/components/ui/Button.stories.tsx +0 -156
- package/src/components/ui/Button.test.tsx +0 -74
- package/src/components/ui/Button.tsx +0 -107
- package/src/components/ui/Card.css +0 -65
- package/src/components/ui/Card.stories.tsx +0 -95
- package/src/components/ui/Card.test.tsx +0 -47
- package/src/components/ui/Card.tsx +0 -48
- package/src/components/ui/Checkbox.css +0 -116
- package/src/components/ui/Checkbox.stories.tsx +0 -74
- package/src/components/ui/Checkbox.test.tsx +0 -28
- package/src/components/ui/Checkbox.tsx +0 -58
- package/src/components/ui/ConfirmDialog.css +0 -42
- package/src/components/ui/ConfirmDialog.stories.tsx +0 -216
- package/src/components/ui/ConfirmDialog.test.tsx +0 -124
- package/src/components/ui/ConfirmDialog.tsx +0 -58
- package/src/components/ui/Details.css +0 -66
- package/src/components/ui/Drawer.css +0 -270
- package/src/components/ui/Drawer.stories.tsx +0 -267
- package/src/components/ui/Drawer.test.tsx +0 -130
- package/src/components/ui/Drawer.tsx +0 -293
- package/src/components/ui/Dropdown.css +0 -173
- package/src/components/ui/Dropdown.tsx +0 -63
- package/src/components/ui/Expandable.css +0 -15
- package/src/components/ui/Expandable.stories.tsx +0 -180
- package/src/components/ui/Expandable.test.tsx +0 -107
- package/src/components/ui/Expandable.tsx +0 -121
- package/src/components/ui/Modal.css +0 -98
- package/src/components/ui/Modal.stories.tsx +0 -171
- package/src/components/ui/Modal.test.tsx +0 -111
- package/src/components/ui/Modal.tsx +0 -117
- package/src/components/ui/Select.css +0 -138
- package/src/components/ui/Select.stories.tsx +0 -79
- package/src/components/ui/Select.test.tsx +0 -84
- package/src/components/ui/Select.tsx +0 -79
- package/src/components/ui/Slider.css +0 -192
- package/src/components/ui/Slider.stories.tsx +0 -63
- package/src/components/ui/Slider.tsx +0 -142
- package/src/components/ui/Spin.css +0 -31
- package/src/components/ui/Spin.stories.tsx +0 -64
- package/src/components/ui/Spin.test.tsx +0 -41
- package/src/components/ui/Spin.tsx +0 -31
- package/src/components/ui/Table.css +0 -132
- package/src/components/ui/Tooltip.css +0 -171
- package/src/components/ui/Tooltip.stories.tsx +0 -109
- package/src/components/ui/Tooltip.test.tsx +0 -102
- package/src/components/ui/Tooltip.tsx +0 -163
- package/src/components/ui/__snapshots__/Alert.test.tsx.snap +0 -59
- package/src/components/ui/__snapshots__/Button.test.tsx.snap +0 -204
- package/src/components/ui/__snapshots__/Card.test.tsx.snap +0 -321
- package/src/components/ui/__snapshots__/Checkbox.test.tsx.snap +0 -131
- package/src/components/ui/__snapshots__/ConfirmDialog.test.tsx.snap +0 -35
- package/src/components/ui/__snapshots__/Drawer.test.tsx.snap +0 -67
- package/src/components/ui/__snapshots__/Expandable.test.tsx.snap +0 -159
- package/src/components/ui/__snapshots__/Modal.test.tsx.snap +0 -59
- package/src/components/ui/__snapshots__/Select.test.tsx.snap +0 -254
- package/src/components/ui/__snapshots__/Spin.test.tsx.snap +0 -193
- package/src/components/ui/__snapshots__/Tooltip.test.tsx.snap +0 -113
- package/src/components/ui/definitions.stories.tsx +0 -139
|
@@ -1,15 +1,18 @@
|
|
|
1
|
-
import React, {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
import React, {
|
|
2
|
+
useState,
|
|
3
|
+
useRef,
|
|
4
|
+
useEffect,
|
|
5
|
+
useCallback,
|
|
6
|
+
useMemo,
|
|
7
|
+
} from 'react';
|
|
8
|
+
import { Upload as UploadIcon } from 'lucide-react';
|
|
9
|
+
import { Spin, Tooltip, useAlertManager } from '@memori.ai/ui';
|
|
7
10
|
import cx from 'classnames';
|
|
8
11
|
import UploadDocuments from './UploadDocuments/UploadDocuments';
|
|
9
12
|
import UploadImages from './UploadImages/UploadImages';
|
|
10
13
|
import { useTranslation } from 'react-i18next';
|
|
11
14
|
import memoriApiClient from '@memori.ai/memori-api-client';
|
|
12
|
-
|
|
15
|
+
|
|
13
16
|
// Props interface
|
|
14
17
|
interface UploadManagerProps {
|
|
15
18
|
authToken?: string;
|
|
@@ -33,6 +36,8 @@ interface UploadManagerProps {
|
|
|
33
36
|
maxDocumentContentLength?: number;
|
|
34
37
|
/** Called when the upload loading state changes. */
|
|
35
38
|
onUploadLoadingChange?: (loading: boolean, fileCount?: number) => void;
|
|
39
|
+
/** When true, the control does not open the file picker and ignores paste/drop for uploads. */
|
|
40
|
+
disabled?: boolean;
|
|
36
41
|
}
|
|
37
42
|
|
|
38
43
|
const UploadButton: React.FC<UploadManagerProps> = ({
|
|
@@ -47,6 +52,7 @@ const UploadButton: React.FC<UploadManagerProps> = ({
|
|
|
47
52
|
maxDocumentsPerMessage = 10,
|
|
48
53
|
maxDocumentContentLength = 300000,
|
|
49
54
|
onUploadLoadingChange,
|
|
55
|
+
disabled = false,
|
|
50
56
|
}) => {
|
|
51
57
|
// Per-document character limit for the inlined `<document_attachment>`
|
|
52
58
|
// content. Does NOT affect the full text uploaded as an asset.
|
|
@@ -59,11 +65,9 @@ const UploadButton: React.FC<UploadManagerProps> = ({
|
|
|
59
65
|
const [docUploadingCount, setDocUploadingCount] = useState(0);
|
|
60
66
|
const [imgUploadingCount, setImgUploadingCount] = useState(0);
|
|
61
67
|
const uploadingFileCount = docUploadingCount + imgUploadingCount;
|
|
62
|
-
const [errors, setErrors] = useState<
|
|
63
|
-
{ message: string; severity: 'error' | 'warning' | 'info' }[]
|
|
64
|
-
>([]);
|
|
65
68
|
const [isDragging, setIsDragging] = useState(false);
|
|
66
|
-
const { t
|
|
69
|
+
const { t } = useTranslation();
|
|
70
|
+
const alertManager = useAlertManager();
|
|
67
71
|
|
|
68
72
|
// Refs
|
|
69
73
|
const buttonRef = useRef<HTMLButtonElement>(null);
|
|
@@ -77,18 +81,22 @@ const UploadButton: React.FC<UploadManagerProps> = ({
|
|
|
77
81
|
const remainingSlots = maxDocumentsPerMessage - currentMediaCount;
|
|
78
82
|
const hasReachedMediaLimit = remainingSlots <= 0;
|
|
79
83
|
|
|
80
|
-
// Error handling
|
|
81
|
-
const
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
84
|
+
// Error handling - show alerts via toast manager
|
|
85
|
+
const addError = useCallback(
|
|
86
|
+
(error: { message: string; severity: 'error' | 'warning' | 'info' }) => {
|
|
87
|
+
alertManager.add({
|
|
88
|
+
id: `upload-notification-${Date.now()}`,
|
|
89
|
+
title: 'Upload notification',
|
|
90
|
+
description: error.message,
|
|
91
|
+
data: {
|
|
92
|
+
severity: error.severity,
|
|
93
|
+
closable: true,
|
|
94
|
+
style: { zIndex: 10002, top: 30, right: 30, position: 'fixed' },
|
|
95
|
+
},
|
|
96
|
+
});
|
|
97
|
+
},
|
|
98
|
+
[alertManager]
|
|
99
|
+
);
|
|
92
100
|
|
|
93
101
|
// Check if file is an image
|
|
94
102
|
const isImageFile = (file: File): boolean => {
|
|
@@ -246,6 +254,7 @@ const UploadButton: React.FC<UploadManagerProps> = ({
|
|
|
246
254
|
|
|
247
255
|
// Handle button click - open file chooser directly
|
|
248
256
|
const handleButtonClick = () => {
|
|
257
|
+
if (disabled) return;
|
|
249
258
|
if (unifiedInputRef.current) {
|
|
250
259
|
unifiedInputRef.current.click();
|
|
251
260
|
}
|
|
@@ -266,6 +275,7 @@ const UploadButton: React.FC<UploadManagerProps> = ({
|
|
|
266
275
|
// Paste handler for files
|
|
267
276
|
useEffect(() => {
|
|
268
277
|
const handlePaste = (e: ClipboardEvent) => {
|
|
278
|
+
if (disabled) return;
|
|
269
279
|
const clipboardData = e.clipboardData;
|
|
270
280
|
if (!clipboardData) {
|
|
271
281
|
return;
|
|
@@ -320,7 +330,7 @@ const UploadButton: React.FC<UploadManagerProps> = ({
|
|
|
320
330
|
return () => {
|
|
321
331
|
document.removeEventListener('paste', handlePaste);
|
|
322
332
|
};
|
|
323
|
-
}, [handleUnifiedFileSelection]);
|
|
333
|
+
}, [handleUnifiedFileSelection, disabled]);
|
|
324
334
|
|
|
325
335
|
// Drag and drop handlers
|
|
326
336
|
useEffect(() => {
|
|
@@ -329,6 +339,7 @@ const UploadButton: React.FC<UploadManagerProps> = ({
|
|
|
329
339
|
const handleDragEnter = (e: DragEvent) => {
|
|
330
340
|
e.preventDefault();
|
|
331
341
|
e.stopPropagation();
|
|
342
|
+
if (disabled) return;
|
|
332
343
|
dragCounter++;
|
|
333
344
|
if (dragCounter === 1) {
|
|
334
345
|
setIsDragging(true);
|
|
@@ -355,6 +366,8 @@ const UploadButton: React.FC<UploadManagerProps> = ({
|
|
|
355
366
|
dragCounter = 0;
|
|
356
367
|
setIsDragging(false);
|
|
357
368
|
|
|
369
|
+
if (disabled) return;
|
|
370
|
+
|
|
358
371
|
const files = e.dataTransfer?.files;
|
|
359
372
|
if (files && files.length > 0) {
|
|
360
373
|
handleUnifiedFileSelection(files);
|
|
@@ -373,7 +386,7 @@ const UploadButton: React.FC<UploadManagerProps> = ({
|
|
|
373
386
|
document.removeEventListener('dragover', handleDragOver);
|
|
374
387
|
document.removeEventListener('drop', handleDrop);
|
|
375
388
|
};
|
|
376
|
-
}, [handleUnifiedFileSelection]);
|
|
389
|
+
}, [handleUnifiedFileSelection, disabled]);
|
|
377
390
|
|
|
378
391
|
// Handler for document files - now supports multiple documents
|
|
379
392
|
const handleDocumentFiles = (
|
|
@@ -400,16 +413,12 @@ const UploadButton: React.FC<UploadManagerProps> = ({
|
|
|
400
413
|
// Process each document file
|
|
401
414
|
const processedDocuments = files.map(file => {
|
|
402
415
|
const escapedFileName = escapeAttributeValue(file.name);
|
|
403
|
-
|
|
404
|
-
//
|
|
405
|
-
// <document_attachment> tag. The full text is still available via
|
|
406
|
-
// textAssetUrl as an uploaded asset.
|
|
416
|
+
// Truncate the inlined content to the per-document character limit.
|
|
417
|
+
// The full text remains available via the uploaded asset link.
|
|
407
418
|
const inlinedContent =
|
|
408
419
|
file.content.length > effectivePerDocumentLimit
|
|
409
|
-
? file.content.
|
|
410
|
-
'\n\n[Content truncated due to size limits]'
|
|
420
|
+
? file.content.slice(0, effectivePerDocumentLimit)
|
|
411
421
|
: file.content;
|
|
412
|
-
|
|
413
422
|
const formattedContent = `<document_attachment filename="${escapedFileName}" type="${
|
|
414
423
|
file.mimeType
|
|
415
424
|
}">
|
|
@@ -551,10 +560,46 @@ ${file.textAssetUrl || ''}
|
|
|
551
560
|
onUploadLoadingChange?.(isLoading, isLoading ? uploadingFileCount : 0);
|
|
552
561
|
}, [isLoading, uploadingFileCount, onUploadLoadingChange]);
|
|
553
562
|
|
|
563
|
+
const uploadTooltipTitle = useMemo(() => {
|
|
564
|
+
if (hasReachedMediaLimit) {
|
|
565
|
+
return t('upload.maxReached') ?? 'Max limit reached';
|
|
566
|
+
}
|
|
567
|
+
|
|
568
|
+
return t('upload.uploadFilesOrImages') ?? 'Upload files or images';
|
|
569
|
+
}, [hasReachedMediaLimit, t]);
|
|
570
|
+
|
|
571
|
+
const isUploadDisabled = disabled || isLoading || hasReachedMediaLimit;
|
|
572
|
+
|
|
573
|
+
const uploadButton = (
|
|
574
|
+
<button
|
|
575
|
+
ref={buttonRef}
|
|
576
|
+
type="button"
|
|
577
|
+
className={cx(
|
|
578
|
+
'memori-button',
|
|
579
|
+
'memori-button--circle',
|
|
580
|
+
'memori-button--icon-only',
|
|
581
|
+
'memori-share-button--button',
|
|
582
|
+
'memori--conversation-button',
|
|
583
|
+
'memori--unified-upload-button'
|
|
584
|
+
)}
|
|
585
|
+
onClick={handleButtonClick}
|
|
586
|
+
disabled={isUploadDisabled}
|
|
587
|
+
tabIndex={isUploadDisabled ? -1 : undefined}
|
|
588
|
+
aria-label={uploadTooltipTitle}
|
|
589
|
+
>
|
|
590
|
+
{isLoading ? (
|
|
591
|
+
<Spin spinning className="memori--upload-icon" />
|
|
592
|
+
) : (
|
|
593
|
+
<UploadIcon className="memori--upload-icon" />
|
|
594
|
+
)}
|
|
595
|
+
</button>
|
|
596
|
+
);
|
|
597
|
+
|
|
554
598
|
return (
|
|
555
599
|
<div
|
|
556
600
|
className={cx('memori--unified-upload-wrapper', {
|
|
557
|
-
'memori--dragging': isDragging,
|
|
601
|
+
'memori--dragging': isDragging && !disabled,
|
|
602
|
+
'memori--upload-disabled': disabled,
|
|
558
603
|
})}
|
|
559
604
|
ref={wrapperRef}
|
|
560
605
|
>
|
|
@@ -569,36 +614,27 @@ ${file.textAssetUrl || ''}
|
|
|
569
614
|
style={{ display: 'none' }}
|
|
570
615
|
/>
|
|
571
616
|
|
|
572
|
-
{/* Main upload button */}
|
|
573
|
-
<
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
/Mac|iPhone|iPod|iPad/i.test(navigator.platform) ||
|
|
590
|
-
navigator.userAgent.includes('Mac')
|
|
591
|
-
? 'Cmd'
|
|
592
|
-
: 'Ctrl',
|
|
593
|
-
}) ?? 'Upload files (drag & drop)'
|
|
594
|
-
}
|
|
595
|
-
>
|
|
596
|
-
{isLoading ? (
|
|
597
|
-
<Spin spinning className="memori--upload-icon" />
|
|
617
|
+
{/* Main upload button — direct child of Tooltip so Tab reaches the button (no extra span wrapper) */}
|
|
618
|
+
<Tooltip placement="top" title={uploadTooltipTitle}>
|
|
619
|
+
{isUploadDisabled ? (
|
|
620
|
+
<span
|
|
621
|
+
className="memori--unified-upload-button-tooltip-trigger"
|
|
622
|
+
tabIndex={0}
|
|
623
|
+
role="button"
|
|
624
|
+
aria-disabled="true"
|
|
625
|
+
aria-label={uploadTooltipTitle}
|
|
626
|
+
onKeyDown={event => {
|
|
627
|
+
if (event.key === 'Enter' || event.key === ' ') {
|
|
628
|
+
event.preventDefault();
|
|
629
|
+
}
|
|
630
|
+
}}
|
|
631
|
+
>
|
|
632
|
+
{uploadButton}
|
|
633
|
+
</span>
|
|
598
634
|
) : (
|
|
599
|
-
|
|
635
|
+
uploadButton
|
|
600
636
|
)}
|
|
601
|
-
</
|
|
637
|
+
</Tooltip>
|
|
602
638
|
|
|
603
639
|
{/* Media count indicator */}
|
|
604
640
|
{currentMediaCount > 0 && (
|
|
@@ -612,7 +648,7 @@ ${file.textAssetUrl || ''}
|
|
|
612
648
|
)}
|
|
613
649
|
|
|
614
650
|
{/* Hidden components */}
|
|
615
|
-
<div className="memori--hidden-uploader" ref={documentRef}>
|
|
651
|
+
<div className="memori--hidden-uploader" ref={documentRef} aria-hidden>
|
|
616
652
|
<UploadDocuments
|
|
617
653
|
setDocumentPreviewFiles={handleDocumentFiles}
|
|
618
654
|
authToken={authToken}
|
|
@@ -628,7 +664,7 @@ ${file.textAssetUrl || ''}
|
|
|
628
664
|
/>
|
|
629
665
|
</div>
|
|
630
666
|
|
|
631
|
-
<div className="memori--hidden-uploader" ref={imageRef}>
|
|
667
|
+
<div className="memori--hidden-uploader" ref={imageRef} aria-hidden>
|
|
632
668
|
<UploadImages
|
|
633
669
|
authToken={authToken}
|
|
634
670
|
client={client}
|
|
@@ -643,24 +679,6 @@ ${file.textAssetUrl || ''}
|
|
|
643
679
|
onValidateImageFile={validateImageFile}
|
|
644
680
|
/>
|
|
645
681
|
</div>
|
|
646
|
-
|
|
647
|
-
{/* Error messages container */}
|
|
648
|
-
<div className="memori--error-message-container">
|
|
649
|
-
{errors.map((error, index) => (
|
|
650
|
-
<Alert
|
|
651
|
-
className="memori--error-message-alert"
|
|
652
|
-
key={`${error.message}-${index}`}
|
|
653
|
-
open={true}
|
|
654
|
-
type={error.severity}
|
|
655
|
-
title={t('upload.uploadNotification', {
|
|
656
|
-
defaultValue: 'Upload notification',
|
|
657
|
-
})}
|
|
658
|
-
description={error.message}
|
|
659
|
-
onClose={() => removeError(error.message)}
|
|
660
|
-
width="350px"
|
|
661
|
-
/>
|
|
662
|
-
))}
|
|
663
|
-
</div>
|
|
664
682
|
</div>
|
|
665
683
|
);
|
|
666
684
|
};
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import React, { useState, useRef } from 'react';
|
|
2
2
|
import cx from 'classnames';
|
|
3
|
-
import Spin from '
|
|
4
|
-
import { DocumentIcon } from '
|
|
5
|
-
import Modal from '
|
|
3
|
+
import { Spin } from '@memori.ai/ui';
|
|
4
|
+
import { FileText as DocumentIcon } from 'lucide-react';
|
|
5
|
+
import { Modal } from '@memori.ai/ui';
|
|
6
6
|
import { useTranslation } from 'react-i18next';
|
|
7
7
|
import memoriApiClient from '@memori.ai/memori-api-client';
|
|
8
8
|
// Types
|
|
@@ -437,6 +437,7 @@ const UploadDocuments: React.FC<UploadDocumentsProps> = ({
|
|
|
437
437
|
|
|
438
438
|
{/* Upload document button */}
|
|
439
439
|
<button
|
|
440
|
+
type="button"
|
|
440
441
|
className={cx(
|
|
441
442
|
'memori-button',
|
|
442
443
|
'memori-button--circle',
|
|
@@ -446,19 +447,21 @@ const UploadDocuments: React.FC<UploadDocumentsProps> = ({
|
|
|
446
447
|
'memori--document-upload-button',
|
|
447
448
|
{ 'memori--error': false } // Removed errors.length > 0
|
|
448
449
|
)}
|
|
450
|
+
aria-label={String(
|
|
451
|
+
t('upload.addDocument', { defaultValue: 'Upload document' })
|
|
452
|
+
)}
|
|
449
453
|
onClick={() => documentInputRef.current?.click()}
|
|
450
454
|
disabled={
|
|
451
455
|
isLoading ||
|
|
452
456
|
(maxDocuments && documentPreviewFiles.length >= maxDocuments) ||
|
|
453
457
|
false
|
|
454
458
|
}
|
|
455
|
-
title="Upload documents"
|
|
456
459
|
>
|
|
457
460
|
{isLoading ? (
|
|
458
461
|
<Spin spinning className="memori--upload-icon" />
|
|
459
462
|
) : (
|
|
460
463
|
<React.Fragment>
|
|
461
|
-
<DocumentIcon className="memori--upload-icon" />
|
|
464
|
+
<DocumentIcon className="memori--upload-icon" aria-hidden />
|
|
462
465
|
</React.Fragment>
|
|
463
466
|
)}
|
|
464
467
|
</button>
|
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
import React, { useState, useRef, useEffect } from 'react';
|
|
2
2
|
import cx from 'classnames';
|
|
3
|
-
import Spin from '
|
|
4
|
-
import
|
|
5
|
-
import {
|
|
6
|
-
import Modal from '../../ui/Modal';
|
|
3
|
+
import { Field, FieldGroup, Input, Spin } from '@memori.ai/ui';
|
|
4
|
+
import { Image as ImageIcon } from 'lucide-react';
|
|
5
|
+
import { Modal } from '@memori.ai/ui';
|
|
7
6
|
import memoriApiClient from '@memori.ai/memori-api-client';
|
|
8
7
|
import { Asset, Medium } from '@memori.ai/memori-api-client/dist/types';
|
|
9
8
|
import { useTranslation } from 'react-i18next';
|
|
10
|
-
import Button from '
|
|
9
|
+
import { Button } from '@memori.ai/ui';
|
|
11
10
|
import { compressImage } from '../../../helpers/imageCompression';
|
|
12
11
|
|
|
13
12
|
// Types
|
|
@@ -34,7 +33,10 @@ interface UploadImagesProps {
|
|
|
34
33
|
onLoadingChange?: (loading: boolean, fileCount?: number) => void;
|
|
35
34
|
maxImages?: number;
|
|
36
35
|
memoriID?: string;
|
|
37
|
-
onImageError?: (error: {
|
|
36
|
+
onImageError?: (error: {
|
|
37
|
+
message: string;
|
|
38
|
+
severity: 'error' | 'warning' | 'info';
|
|
39
|
+
}) => void;
|
|
38
40
|
onValidateImageFile?: (file: File) => boolean;
|
|
39
41
|
}
|
|
40
42
|
|
|
@@ -101,7 +103,8 @@ const UploadImages: React.FC<UploadImagesProps> = ({
|
|
|
101
103
|
count: skipped,
|
|
102
104
|
max: maxImages,
|
|
103
105
|
defaultValue: `${skipped} image(s) not added (maximum ${maxImages} files allowed).`,
|
|
104
|
-
}) ??
|
|
106
|
+
}) ??
|
|
107
|
+
`${skipped} image(s) not added (maximum ${maxImages} files allowed).`,
|
|
105
108
|
severity: 'warning',
|
|
106
109
|
});
|
|
107
110
|
}
|
|
@@ -133,11 +136,11 @@ const UploadImages: React.FC<UploadImagesProps> = ({
|
|
|
133
136
|
const file = validFiles[0];
|
|
134
137
|
setSelectedFile(file);
|
|
135
138
|
setFilePreview(URL.createObjectURL(file));
|
|
136
|
-
|
|
139
|
+
|
|
137
140
|
// Set initial title as filename without extension
|
|
138
141
|
const fileName = file.name.split('.').slice(0, -1).join('.');
|
|
139
142
|
setImageTitle(fileName);
|
|
140
|
-
|
|
143
|
+
|
|
141
144
|
// Show upload modal with preview
|
|
142
145
|
setShowUploadModal(true);
|
|
143
146
|
} else {
|
|
@@ -155,7 +158,7 @@ const UploadImages: React.FC<UploadImagesProps> = ({
|
|
|
155
158
|
setIsLoading(true);
|
|
156
159
|
|
|
157
160
|
try {
|
|
158
|
-
const uploadPromises = files.map(async
|
|
161
|
+
const uploadPromises = files.map(async file => {
|
|
159
162
|
// Compress image before upload
|
|
160
163
|
let fileToUpload = file;
|
|
161
164
|
try {
|
|
@@ -174,13 +177,16 @@ const UploadImages: React.FC<UploadImagesProps> = ({
|
|
|
174
177
|
mediumID: string | undefined;
|
|
175
178
|
url: string;
|
|
176
179
|
mimeType: string;
|
|
177
|
-
} | null>(
|
|
180
|
+
} | null>(resolve => {
|
|
178
181
|
const reader = new FileReader();
|
|
179
|
-
|
|
180
|
-
reader.onload = async
|
|
182
|
+
|
|
183
|
+
reader.onload = async e => {
|
|
181
184
|
const fileDataUrl = e.target?.result as string;
|
|
182
185
|
const fileId = Math.random().toString(36).substr(2, 9);
|
|
183
|
-
const fileName = fileToUpload.name
|
|
186
|
+
const fileName = fileToUpload.name
|
|
187
|
+
.split('.')
|
|
188
|
+
.slice(0, -1)
|
|
189
|
+
.join('.');
|
|
184
190
|
|
|
185
191
|
if (client) {
|
|
186
192
|
try {
|
|
@@ -193,7 +199,11 @@ const UploadImages: React.FC<UploadImagesProps> = ({
|
|
|
193
199
|
fileDataUrl,
|
|
194
200
|
authToken
|
|
195
201
|
);
|
|
196
|
-
} else if (
|
|
202
|
+
} else if (
|
|
203
|
+
memoriID &&
|
|
204
|
+
sessionID &&
|
|
205
|
+
backend?.uploadAssetUnlogged
|
|
206
|
+
) {
|
|
197
207
|
response = await backend.uploadAssetUnlogged(
|
|
198
208
|
fileToUpload.name,
|
|
199
209
|
fileDataUrl,
|
|
@@ -323,7 +333,7 @@ const UploadImages: React.FC<UploadImagesProps> = ({
|
|
|
323
333
|
response = await backend.uploadAsset(
|
|
324
334
|
fileToUpload.name,
|
|
325
335
|
fileDataUrl,
|
|
326
|
-
authToken
|
|
336
|
+
authToken
|
|
327
337
|
// memoriID
|
|
328
338
|
);
|
|
329
339
|
} else if (memoriID && sessionID && backend?.uploadAssetUnlogged) {
|
|
@@ -449,6 +459,7 @@ const UploadImages: React.FC<UploadImagesProps> = ({
|
|
|
449
459
|
|
|
450
460
|
{/* Upload image button */}
|
|
451
461
|
<button
|
|
462
|
+
type="button"
|
|
452
463
|
className={cx(
|
|
453
464
|
'memori-button',
|
|
454
465
|
'memori-button--circle',
|
|
@@ -457,6 +468,7 @@ const UploadImages: React.FC<UploadImagesProps> = ({
|
|
|
457
468
|
'memori--conversation-button',
|
|
458
469
|
'memori--image-upload-button'
|
|
459
470
|
)}
|
|
471
|
+
aria-label={String(t('upload.addImage', { defaultValue: 'Upload image' }))}
|
|
460
472
|
onClick={() => imageInputRef.current?.click()}
|
|
461
473
|
disabled={
|
|
462
474
|
isLoading || !isMediaAccepted || currentMediaCount >= maxImages
|
|
@@ -465,69 +477,70 @@ const UploadImages: React.FC<UploadImagesProps> = ({
|
|
|
465
477
|
{isLoading ? (
|
|
466
478
|
<Spin spinning className="memori--upload-icon" />
|
|
467
479
|
) : (
|
|
468
|
-
<ImageIcon className="memori--upload-icon" />
|
|
480
|
+
<ImageIcon className="memori--upload-icon" aria-hidden />
|
|
469
481
|
)}
|
|
470
482
|
</button>
|
|
471
483
|
|
|
472
484
|
{/* Upload Modal with Title Input */}
|
|
473
485
|
<Modal
|
|
474
|
-
width="80%"
|
|
475
|
-
widthMd="80%"
|
|
476
486
|
open={showUploadModal && !!selectedFile}
|
|
477
|
-
className="memori--modal-preview-file"
|
|
487
|
+
className="memori--modal-preview-file memori--upload-image-preview-modal"
|
|
478
488
|
onClose={handleCancelUpload}
|
|
489
|
+
footer={
|
|
490
|
+
<div
|
|
491
|
+
style={{
|
|
492
|
+
display: 'flex',
|
|
493
|
+
gap: 'var(--memori-spacing-sm)',
|
|
494
|
+
justifyContent: 'end',
|
|
495
|
+
alignItems: 'center',
|
|
496
|
+
borderTop: '1px solid rgba(255, 255, 255, 0.2)',
|
|
497
|
+
}}
|
|
498
|
+
>
|
|
499
|
+
<Button onClick={handleCancelUpload} variant="outline">
|
|
500
|
+
{t('cancel') ?? 'Cancel'}
|
|
501
|
+
</Button>
|
|
502
|
+
<Button
|
|
503
|
+
onClick={handleTitleSubmit}
|
|
504
|
+
disabled={!selectedFile || !imageTitle.trim()}
|
|
505
|
+
>
|
|
506
|
+
{t('confirm') ?? 'Confirm'}
|
|
507
|
+
</Button>
|
|
508
|
+
</div>
|
|
509
|
+
}
|
|
479
510
|
closable
|
|
480
511
|
// title={t('upload.titleImage', { title: imageTitle })}
|
|
481
512
|
// description={t('upload.imageTitleDescription')}
|
|
482
513
|
>
|
|
483
|
-
<div
|
|
484
|
-
className="memori--preview-content"
|
|
485
|
-
style={{
|
|
486
|
-
maxHeight: '70vh',
|
|
487
|
-
overflowY: 'auto',
|
|
488
|
-
textAlign: 'center',
|
|
489
|
-
}}
|
|
490
|
-
>
|
|
514
|
+
<div className="memori--preview-content memori--upload-image-preview-content">
|
|
491
515
|
{filePreview && (
|
|
492
|
-
<
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
}}
|
|
500
|
-
/>
|
|
516
|
+
<div className="memori--upload-image-preview-frame">
|
|
517
|
+
<img
|
|
518
|
+
src={filePreview}
|
|
519
|
+
alt={selectedFile?.name || 'Preview'}
|
|
520
|
+
className="memori--upload-image-preview"
|
|
521
|
+
/>
|
|
522
|
+
</div>
|
|
501
523
|
)}
|
|
502
524
|
|
|
503
|
-
<div
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
525
|
+
<div style={{ textAlign: 'left' }}>
|
|
526
|
+
<p
|
|
527
|
+
style={{
|
|
528
|
+
marginBottom: '10px',
|
|
529
|
+
color: 'var(--memori-text-color)',
|
|
530
|
+
}}
|
|
531
|
+
>
|
|
507
532
|
{t('upload.titleHelp')}
|
|
508
533
|
</p>
|
|
509
|
-
<
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
|
|
514
|
-
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
519
|
-
className="memori-button memori-button--outline memori--upload-image"
|
|
520
|
-
>
|
|
521
|
-
{t('cancel') ?? 'Cancel'}
|
|
522
|
-
</Button>
|
|
523
|
-
<Button
|
|
524
|
-
onClick={handleTitleSubmit}
|
|
525
|
-
disabled={!selectedFile || !imageTitle.trim()}
|
|
526
|
-
className="memori-button memori-button--primary memori-button--image-confirm memori--upload-image"
|
|
527
|
-
>
|
|
528
|
-
{t('confirm') ?? 'Confirm'}
|
|
529
|
-
</Button>
|
|
530
|
-
</div>
|
|
534
|
+
<FieldGroup
|
|
535
|
+
label={t('upload.titlePlaceholder') ?? 'Enter image title'}
|
|
536
|
+
>
|
|
537
|
+
<Input
|
|
538
|
+
value={imageTitle}
|
|
539
|
+
onChange={(e: React.ChangeEvent<HTMLInputElement>) =>
|
|
540
|
+
setImageTitle(e.target.value)
|
|
541
|
+
}
|
|
542
|
+
/>
|
|
543
|
+
</FieldGroup>
|
|
531
544
|
</div>
|
|
532
545
|
</div>
|
|
533
546
|
</Modal>
|