@memori.ai/memori-react 8.38.4 → 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 +1836 -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 +12 -3
- package/dist/components/ChatHistoryDrawer/ChatResumeDrawer.js +18 -7
- package/dist/components/ChatHistoryDrawer/ChatResumeDrawer.js.map +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/DrawerFooter/DrawerFooter.js +1 -1
- package/dist/components/DrawerFooter/DrawerFooter.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 +48 -4
- package/dist/components/MobileSessionPanel/MobileSessionPanel.d.ts +5 -1
- package/dist/components/MobileSessionPanel/MobileSessionPanel.js +177 -57
- package/dist/components/MobileSessionPanel/MobileSessionPanel.js.map +1 -1
- package/dist/components/PositionPopover/PositionPopover.js +2 -1
- package/dist/components/PositionPopover/PositionPopover.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 +60 -27
- package/dist/components/UploadButton/UploadButton.js.map +1 -1
- package/dist/components/UploadButton/UploadDocuments/UploadDocuments.d.ts +0 -2
- package/dist/components/UploadButton/UploadDocuments/UploadDocuments.js +13 -27
- 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/WebsiteAssistant/WebsiteAssistant.js +1 -1
- package/dist/components/layouts/WebsiteAssistant/WebsiteAssistant.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/fullpage.css +25 -8
- 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/components/ui/Tooltip.js +3 -3
- package/dist/components/ui/Tooltip.js.map +1 -1
- 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 +12 -3
- package/esm/components/ChatHistoryDrawer/ChatResumeDrawer.js +18 -7
- package/esm/components/ChatHistoryDrawer/ChatResumeDrawer.js.map +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/DrawerFooter/DrawerFooter.js +1 -1
- package/esm/components/DrawerFooter/DrawerFooter.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 +48 -4
- package/esm/components/MobileSessionPanel/MobileSessionPanel.d.ts +5 -1
- package/esm/components/MobileSessionPanel/MobileSessionPanel.js +178 -59
- package/esm/components/MobileSessionPanel/MobileSessionPanel.js.map +1 -1
- package/esm/components/PositionPopover/PositionPopover.js +2 -1
- package/esm/components/PositionPopover/PositionPopover.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 +61 -28
- package/esm/components/UploadButton/UploadButton.js.map +1 -1
- package/esm/components/UploadButton/UploadDocuments/UploadDocuments.d.ts +0 -2
- package/esm/components/UploadButton/UploadDocuments/UploadDocuments.js +13 -27
- 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/WebsiteAssistant/WebsiteAssistant.js +1 -1
- package/esm/components/layouts/WebsiteAssistant/WebsiteAssistant.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/fullpage.css +25 -8
- 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/components/ui/Tooltip.js +3 -3
- package/esm/components/ui/Tooltip.js.map +1 -1
- 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 +220 -167
- package/src/components/UploadButton/UploadDocuments/UploadDocuments.tsx +14 -38
- 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/dist/helpers/userMessage.d.ts +0 -2
- package/dist/helpers/userMessage.js +0 -23
- package/dist/helpers/userMessage.js.map +0 -1
- package/esm/helpers/userMessage.d.ts +0 -2
- package/esm/helpers/userMessage.js +0 -18
- package/esm/helpers/userMessage.js.map +0 -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 -162
- 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
|
@@ -0,0 +1,795 @@
|
|
|
1
|
+
import React, { useEffect, useMemo, useRef, useState } from 'react';
|
|
2
|
+
import {
|
|
3
|
+
Brain,
|
|
4
|
+
Camera,
|
|
5
|
+
ChevronLeft,
|
|
6
|
+
ChevronRight,
|
|
7
|
+
LogIn,
|
|
8
|
+
LogOut,
|
|
9
|
+
} from 'lucide-react';
|
|
10
|
+
import { Button, createAlertOptions, useAlertManager } from '@memori.ai/ui';
|
|
11
|
+
import { useTranslation } from 'react-i18next';
|
|
12
|
+
import { Message, User } from '@memori.ai/memori-api-client/dist/types';
|
|
13
|
+
import './MobileSessionPanel.css';
|
|
14
|
+
import { getErrori18nKey } from '../../helpers/error';
|
|
15
|
+
import { imgMimeTypes } from '../../helpers/utils';
|
|
16
|
+
import GasStation from '../icons/GasStation';
|
|
17
|
+
import { ChatConsumptionContent } from '../Header/ChatConsumptionDropdown';
|
|
18
|
+
type SessionAction = {
|
|
19
|
+
key: string;
|
|
20
|
+
icon: React.ReactNode;
|
|
21
|
+
title: string;
|
|
22
|
+
subtitle?: string;
|
|
23
|
+
onClick?: () => void;
|
|
24
|
+
trailing?: React.ReactNode;
|
|
25
|
+
view?: 'location' | 'knownFacts' | 'share';
|
|
26
|
+
disabled?: boolean;
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
export interface MobileSessionPanelProps {
|
|
30
|
+
open: boolean;
|
|
31
|
+
onClose: () => void;
|
|
32
|
+
presentation?: 'sheet' | 'popover';
|
|
33
|
+
title: string;
|
|
34
|
+
loginToken?: string;
|
|
35
|
+
userName: string;
|
|
36
|
+
userInitial?: string;
|
|
37
|
+
user?: User;
|
|
38
|
+
apiClient?: {
|
|
39
|
+
backend?: {
|
|
40
|
+
uploadAsset?: (
|
|
41
|
+
name: string,
|
|
42
|
+
payload: string,
|
|
43
|
+
token: string
|
|
44
|
+
) => Promise<any>;
|
|
45
|
+
pwlUpdateUser?: (
|
|
46
|
+
token: string,
|
|
47
|
+
userID: string,
|
|
48
|
+
user: Partial<User>
|
|
49
|
+
) => Promise<any>;
|
|
50
|
+
};
|
|
51
|
+
};
|
|
52
|
+
userEmail?: string;
|
|
53
|
+
birthDate?: string;
|
|
54
|
+
avatarURL?: string;
|
|
55
|
+
actions: SessionAction[];
|
|
56
|
+
logoutLabel?: string;
|
|
57
|
+
onLogout?: () => void;
|
|
58
|
+
onKnownFactsOpen?: () => void;
|
|
59
|
+
onLocationEnable?: () => void;
|
|
60
|
+
onLocationDisable?: () => void;
|
|
61
|
+
knownFactsPageTitle?: string;
|
|
62
|
+
sharePageTitle?: string;
|
|
63
|
+
locationPageTitle?: string;
|
|
64
|
+
backLabel?: string;
|
|
65
|
+
locationStatusLabel?: string;
|
|
66
|
+
locationPlace?: string;
|
|
67
|
+
locationUnknownLabel?: string;
|
|
68
|
+
locationEnableLabel?: string;
|
|
69
|
+
locationDisableLabel?: string;
|
|
70
|
+
knownFactsDescription?: string;
|
|
71
|
+
knownFactsCtaLabel?: string;
|
|
72
|
+
knownFactsCountLabel?: string;
|
|
73
|
+
shareContent?: React.ReactNode;
|
|
74
|
+
knownFactsDisabled?: boolean;
|
|
75
|
+
knownFactsHint?: string;
|
|
76
|
+
showSessionInfo?: boolean;
|
|
77
|
+
history?: Message[];
|
|
78
|
+
aiUsageTitle?: string;
|
|
79
|
+
isLoggedIn?: boolean;
|
|
80
|
+
loginLabel?: string;
|
|
81
|
+
onLogin?: () => void;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
type ImpactMetricType = 'energy' | 'co2' | 'water';
|
|
85
|
+
|
|
86
|
+
type LlmUsageEnergyImpact = {
|
|
87
|
+
energy?: number | { source?: string; parsedValue?: number };
|
|
88
|
+
gwp?: number | { source?: string; parsedValue?: number };
|
|
89
|
+
wcf?: number | { source?: string; parsedValue?: number };
|
|
90
|
+
};
|
|
91
|
+
|
|
92
|
+
const getMetricValue = (
|
|
93
|
+
metric?: number | { source?: string; parsedValue?: number }
|
|
94
|
+
): number | undefined => {
|
|
95
|
+
if (typeof metric === 'number' && Number.isFinite(metric)) return metric;
|
|
96
|
+
if (!metric || typeof metric !== 'object') return undefined;
|
|
97
|
+
if (
|
|
98
|
+
typeof metric.parsedValue === 'number' &&
|
|
99
|
+
Number.isFinite(metric.parsedValue)
|
|
100
|
+
) {
|
|
101
|
+
return metric.parsedValue;
|
|
102
|
+
}
|
|
103
|
+
if (typeof metric.source === 'string') {
|
|
104
|
+
const parsed = Number(metric.source);
|
|
105
|
+
if (Number.isFinite(parsed)) return parsed;
|
|
106
|
+
}
|
|
107
|
+
return undefined;
|
|
108
|
+
};
|
|
109
|
+
|
|
110
|
+
const formatMetricValue = (value: number, locale: string): string =>
|
|
111
|
+
new Intl.NumberFormat(locale, {
|
|
112
|
+
minimumFractionDigits: 0,
|
|
113
|
+
maximumFractionDigits: Math.abs(value) >= 1 ? 3 : 4,
|
|
114
|
+
}).format(value);
|
|
115
|
+
|
|
116
|
+
const formatImpactInReadableUnit = (
|
|
117
|
+
value: number,
|
|
118
|
+
metricType: ImpactMetricType,
|
|
119
|
+
locale: string
|
|
120
|
+
): string => {
|
|
121
|
+
const absValue = Math.abs(value);
|
|
122
|
+
|
|
123
|
+
if (metricType === 'energy') {
|
|
124
|
+
if (absValue >= 1) return `${formatMetricValue(value, locale)} kWh`;
|
|
125
|
+
const wh = value * 1000;
|
|
126
|
+
if (Math.abs(wh) >= 1) return `${formatMetricValue(wh, locale)} Wh`;
|
|
127
|
+
return `${formatMetricValue(wh * 1000, locale)} mWh`;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
if (metricType === 'co2') {
|
|
131
|
+
if (absValue >= 1) return `${formatMetricValue(value, locale)} kg`;
|
|
132
|
+
const g = value * 1000;
|
|
133
|
+
if (Math.abs(g) >= 1) return `${formatMetricValue(g, locale)} g`;
|
|
134
|
+
return `${formatMetricValue(g * 1000, locale)} mg`;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
if (absValue >= 1) return `${formatMetricValue(value, locale)} L`;
|
|
138
|
+
const ml = value * 1000;
|
|
139
|
+
if (Math.abs(ml) >= 1) return `${formatMetricValue(ml, locale)} mL`;
|
|
140
|
+
return `${formatMetricValue(ml * 1000, locale)} μL`;
|
|
141
|
+
};
|
|
142
|
+
|
|
143
|
+
const MobileSessionPanel: React.FC<MobileSessionPanelProps> = ({
|
|
144
|
+
open,
|
|
145
|
+
onClose,
|
|
146
|
+
presentation = 'sheet',
|
|
147
|
+
title,
|
|
148
|
+
loginToken,
|
|
149
|
+
userName,
|
|
150
|
+
user,
|
|
151
|
+
apiClient,
|
|
152
|
+
userEmail,
|
|
153
|
+
birthDate,
|
|
154
|
+
avatarURL,
|
|
155
|
+
actions,
|
|
156
|
+
logoutLabel = 'Log out',
|
|
157
|
+
onLogout,
|
|
158
|
+
onKnownFactsOpen,
|
|
159
|
+
onLocationEnable,
|
|
160
|
+
onLocationDisable,
|
|
161
|
+
knownFactsPageTitle = 'Known facts',
|
|
162
|
+
sharePageTitle = 'Share',
|
|
163
|
+
locationPageTitle = 'Location tracking',
|
|
164
|
+
backLabel = 'Back',
|
|
165
|
+
locationStatusLabel = 'Status',
|
|
166
|
+
locationPlace,
|
|
167
|
+
locationUnknownLabel = 'Unknown position',
|
|
168
|
+
locationEnableLabel = 'Use current position',
|
|
169
|
+
locationDisableLabel = 'Disable location sharing',
|
|
170
|
+
knownFactsDescription,
|
|
171
|
+
knownFactsCtaLabel = 'Open full known facts',
|
|
172
|
+
knownFactsCountLabel,
|
|
173
|
+
shareContent,
|
|
174
|
+
knownFactsDisabled = false,
|
|
175
|
+
knownFactsHint,
|
|
176
|
+
showSessionInfo = false,
|
|
177
|
+
history = [],
|
|
178
|
+
aiUsageTitle,
|
|
179
|
+
isLoggedIn = false,
|
|
180
|
+
loginLabel = 'Log in',
|
|
181
|
+
onLogin,
|
|
182
|
+
}) => {
|
|
183
|
+
const panelRef = useRef<HTMLElement>(null);
|
|
184
|
+
const dialogRef = useRef<HTMLDivElement>(null);
|
|
185
|
+
const panelTitleId = 'mobile-session-panel-title';
|
|
186
|
+
const touchStartYRef = useRef(0);
|
|
187
|
+
const [dragOffset, setDragOffset] = useState(0);
|
|
188
|
+
const [activeView, setActiveView] = useState<
|
|
189
|
+
'session' | 'location' | 'knownFacts' | 'share' | 'aiUsage'
|
|
190
|
+
>('session');
|
|
191
|
+
const { uploadAsset, pwlUpdateUser } = apiClient?.backend || {};
|
|
192
|
+
const { add } = useAlertManager();
|
|
193
|
+
const { t, i18n } = useTranslation();
|
|
194
|
+
const currentLocale = i18n.language || navigator.language || 'en';
|
|
195
|
+
const sustainabilityTotals = useMemo(() => {
|
|
196
|
+
const totals = { energy: 0, gwp: 0, wcf: 0 };
|
|
197
|
+
history.forEach(line => {
|
|
198
|
+
const energyImpact = (
|
|
199
|
+
line as Message & {
|
|
200
|
+
llmUsage?: { energyImpact?: LlmUsageEnergyImpact };
|
|
201
|
+
}
|
|
202
|
+
).llmUsage?.energyImpact;
|
|
203
|
+
if (!energyImpact) return;
|
|
204
|
+
totals.energy += getMetricValue(energyImpact.energy) ?? 0;
|
|
205
|
+
totals.gwp += getMetricValue(energyImpact.gwp) ?? 0;
|
|
206
|
+
totals.wcf += getMetricValue(energyImpact.wcf) ?? 0;
|
|
207
|
+
});
|
|
208
|
+
return totals;
|
|
209
|
+
}, [history]);
|
|
210
|
+
const hasSustainabilityData = useMemo(
|
|
211
|
+
() =>
|
|
212
|
+
history.some(
|
|
213
|
+
line =>
|
|
214
|
+
!!(
|
|
215
|
+
line as Message & {
|
|
216
|
+
llmUsage?: { energyImpact?: LlmUsageEnergyImpact };
|
|
217
|
+
}
|
|
218
|
+
).llmUsage?.energyImpact
|
|
219
|
+
),
|
|
220
|
+
[history]
|
|
221
|
+
);
|
|
222
|
+
const hasChatConsumptionData = useMemo(
|
|
223
|
+
() =>
|
|
224
|
+
history.some(
|
|
225
|
+
line =>
|
|
226
|
+
!!(
|
|
227
|
+
line as Message & {
|
|
228
|
+
llmUsage?: {
|
|
229
|
+
energyImpact?: LlmUsageEnergyImpact;
|
|
230
|
+
};
|
|
231
|
+
}
|
|
232
|
+
).llmUsage
|
|
233
|
+
),
|
|
234
|
+
[history]
|
|
235
|
+
);
|
|
236
|
+
const aiUsageSubtitle = hasSustainabilityData
|
|
237
|
+
? `${formatImpactInReadableUnit(
|
|
238
|
+
sustainabilityTotals.energy,
|
|
239
|
+
'energy',
|
|
240
|
+
currentLocale
|
|
241
|
+
)} • ${formatImpactInReadableUnit(
|
|
242
|
+
sustainabilityTotals.gwp,
|
|
243
|
+
'co2',
|
|
244
|
+
currentLocale
|
|
245
|
+
)}`
|
|
246
|
+
: t('widget.noData', { defaultValue: 'Nessun dato disponibile' });
|
|
247
|
+
const resolvedKnownFactsHint =
|
|
248
|
+
knownFactsHint || t('widget.knownFactsHint') || 'What I remember about you';
|
|
249
|
+
const resolvedAiUsageTitle =
|
|
250
|
+
aiUsageTitle || t('widget.aiConsumption') || 'AI usage';
|
|
251
|
+
useEffect(() => {
|
|
252
|
+
if (!open) return;
|
|
253
|
+
const onEscape = (event: KeyboardEvent) => {
|
|
254
|
+
if (event.key === 'Escape') onClose();
|
|
255
|
+
};
|
|
256
|
+
document.addEventListener('keydown', onEscape);
|
|
257
|
+
return () => document.removeEventListener('keydown', onEscape);
|
|
258
|
+
}, [open, onClose]);
|
|
259
|
+
|
|
260
|
+
useEffect(() => {
|
|
261
|
+
if (!open) return;
|
|
262
|
+
|
|
263
|
+
const previouslyFocused = document.activeElement as HTMLElement | null;
|
|
264
|
+
const root = dialogRef.current;
|
|
265
|
+
if (!root) return;
|
|
266
|
+
|
|
267
|
+
const handleKeyDown = (event: KeyboardEvent) => {
|
|
268
|
+
if (event.key !== 'Tab') return;
|
|
269
|
+
|
|
270
|
+
const focusableElements = root.querySelectorAll<HTMLElement>(
|
|
271
|
+
'button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])'
|
|
272
|
+
);
|
|
273
|
+
if (!focusableElements.length) return;
|
|
274
|
+
|
|
275
|
+
const first = focusableElements[0];
|
|
276
|
+
const last = focusableElements[focusableElements.length - 1];
|
|
277
|
+
const active = document.activeElement as HTMLElement | null;
|
|
278
|
+
|
|
279
|
+
if (event.shiftKey && active === first) {
|
|
280
|
+
event.preventDefault();
|
|
281
|
+
last.focus();
|
|
282
|
+
} else if (!event.shiftKey && active === last) {
|
|
283
|
+
event.preventDefault();
|
|
284
|
+
first.focus();
|
|
285
|
+
}
|
|
286
|
+
};
|
|
287
|
+
|
|
288
|
+
document.addEventListener('keydown', handleKeyDown);
|
|
289
|
+
panelRef.current?.focus();
|
|
290
|
+
|
|
291
|
+
return () => {
|
|
292
|
+
document.removeEventListener('keydown', handleKeyDown);
|
|
293
|
+
previouslyFocused?.focus();
|
|
294
|
+
};
|
|
295
|
+
}, [open]);
|
|
296
|
+
|
|
297
|
+
useEffect(() => {
|
|
298
|
+
if (open) setActiveView('session');
|
|
299
|
+
}, [open]);
|
|
300
|
+
|
|
301
|
+
if (!open) return null;
|
|
302
|
+
|
|
303
|
+
const updateAvatar = async (avatar: any) => {
|
|
304
|
+
if (!uploadAsset || !pwlUpdateUser) {
|
|
305
|
+
add(
|
|
306
|
+
createAlertOptions({
|
|
307
|
+
description: t('login.avatarUploadError'),
|
|
308
|
+
severity: 'error',
|
|
309
|
+
})
|
|
310
|
+
);
|
|
311
|
+
return;
|
|
312
|
+
}
|
|
313
|
+
if (avatar && loginToken) {
|
|
314
|
+
const reader = new FileReader();
|
|
315
|
+
reader.onload = async e => {
|
|
316
|
+
try {
|
|
317
|
+
const { asset: avatarAsset, ...resp } = await uploadAsset(
|
|
318
|
+
avatar.name ?? 'avatar',
|
|
319
|
+
e.target?.result as string,
|
|
320
|
+
loginToken ?? ''
|
|
321
|
+
);
|
|
322
|
+
|
|
323
|
+
if (resp.resultCode !== 0) {
|
|
324
|
+
console.error('[updateAvatar] Upload failed:', resp);
|
|
325
|
+
add(
|
|
326
|
+
createAlertOptions({
|
|
327
|
+
description: t(getErrori18nKey(resp.resultCode)),
|
|
328
|
+
severity: 'error',
|
|
329
|
+
})
|
|
330
|
+
);
|
|
331
|
+
} else if (avatarAsset) {
|
|
332
|
+
let newUser: Partial<User> = {
|
|
333
|
+
userID: user?.userID ?? '',
|
|
334
|
+
avatarURL: avatarAsset.assetURL,
|
|
335
|
+
};
|
|
336
|
+
|
|
337
|
+
const { ...updateResp } = await pwlUpdateUser(
|
|
338
|
+
loginToken ?? '',
|
|
339
|
+
user?.userID ?? '',
|
|
340
|
+
newUser
|
|
341
|
+
);
|
|
342
|
+
|
|
343
|
+
if (updateResp.resultCode !== 0) {
|
|
344
|
+
add(
|
|
345
|
+
createAlertOptions({
|
|
346
|
+
description: t(getErrori18nKey(updateResp.resultCode)),
|
|
347
|
+
severity: 'error',
|
|
348
|
+
})
|
|
349
|
+
);
|
|
350
|
+
} else {
|
|
351
|
+
add(
|
|
352
|
+
createAlertOptions({
|
|
353
|
+
description: t('login.avatarUploadSuccess'),
|
|
354
|
+
severity: 'success',
|
|
355
|
+
})
|
|
356
|
+
);
|
|
357
|
+
}
|
|
358
|
+
}
|
|
359
|
+
} catch (e) {
|
|
360
|
+
let err = e as Error;
|
|
361
|
+
console.error('[updateAvatar] Error:', err);
|
|
362
|
+
|
|
363
|
+
if (err?.message)
|
|
364
|
+
add(
|
|
365
|
+
createAlertOptions({
|
|
366
|
+
description: err.message,
|
|
367
|
+
severity: 'error',
|
|
368
|
+
})
|
|
369
|
+
);
|
|
370
|
+
}
|
|
371
|
+
};
|
|
372
|
+
reader.readAsDataURL(avatar as Blob);
|
|
373
|
+
} else {
|
|
374
|
+
console.error('[updateAvatar] Missing avatar or login token', {
|
|
375
|
+
avatar,
|
|
376
|
+
loginToken,
|
|
377
|
+
});
|
|
378
|
+
add(
|
|
379
|
+
createAlertOptions({
|
|
380
|
+
description: t('login.avatarUploadError'),
|
|
381
|
+
severity: 'error',
|
|
382
|
+
})
|
|
383
|
+
);
|
|
384
|
+
}
|
|
385
|
+
};
|
|
386
|
+
|
|
387
|
+
const isPopover = presentation === 'popover';
|
|
388
|
+
const isLocationEnabled = Boolean(
|
|
389
|
+
locationPlace &&
|
|
390
|
+
locationPlace.trim().length > 0 &&
|
|
391
|
+
locationPlace !== locationUnknownLabel
|
|
392
|
+
);
|
|
393
|
+
const visibleActions = actions.filter(action => {
|
|
394
|
+
const normalizedKey = action.key.toLowerCase();
|
|
395
|
+
const normalizedTitle = action.title.toLowerCase();
|
|
396
|
+
const isKnownFactsAction = action.view === 'knownFacts';
|
|
397
|
+
const isAudioAction =
|
|
398
|
+
normalizedKey.includes('audio') ||
|
|
399
|
+
normalizedTitle.includes('audio') ||
|
|
400
|
+
normalizedTitle.includes('sound');
|
|
401
|
+
|
|
402
|
+
return !isKnownFactsAction && !isAudioAction;
|
|
403
|
+
});
|
|
404
|
+
|
|
405
|
+
return (
|
|
406
|
+
<div
|
|
407
|
+
ref={dialogRef}
|
|
408
|
+
className={`memori-mobile-session-panel--overlay ${
|
|
409
|
+
isPopover ? 'memori-mobile-session-panel--overlay-popover' : ''
|
|
410
|
+
}`}
|
|
411
|
+
role="presentation"
|
|
412
|
+
>
|
|
413
|
+
{!isPopover && (
|
|
414
|
+
<button
|
|
415
|
+
type="button"
|
|
416
|
+
className="memori-mobile-session-panel--backdrop"
|
|
417
|
+
aria-label={String(t('close', { defaultValue: 'Close' }))}
|
|
418
|
+
onClick={onClose}
|
|
419
|
+
/>
|
|
420
|
+
)}
|
|
421
|
+
<section
|
|
422
|
+
ref={panelRef}
|
|
423
|
+
tabIndex={-1}
|
|
424
|
+
className={`memori-mobile-session-panel ${
|
|
425
|
+
isPopover ? 'memori-mobile-session-panel--popover' : ''
|
|
426
|
+
}`}
|
|
427
|
+
role="dialog"
|
|
428
|
+
aria-modal="true"
|
|
429
|
+
aria-labelledby={panelTitleId}
|
|
430
|
+
onClick={event => event.stopPropagation()}
|
|
431
|
+
onTouchStart={
|
|
432
|
+
isPopover
|
|
433
|
+
? undefined
|
|
434
|
+
: event => {
|
|
435
|
+
touchStartYRef.current = event.touches[0].clientY;
|
|
436
|
+
setDragOffset(0);
|
|
437
|
+
}
|
|
438
|
+
}
|
|
439
|
+
onTouchMove={
|
|
440
|
+
isPopover
|
|
441
|
+
? undefined
|
|
442
|
+
: event => {
|
|
443
|
+
const delta = event.touches[0].clientY - touchStartYRef.current;
|
|
444
|
+
if (delta > 0) setDragOffset(delta);
|
|
445
|
+
}
|
|
446
|
+
}
|
|
447
|
+
onTouchEnd={
|
|
448
|
+
isPopover
|
|
449
|
+
? undefined
|
|
450
|
+
: () => {
|
|
451
|
+
if (dragOffset > 90) {
|
|
452
|
+
onClose();
|
|
453
|
+
}
|
|
454
|
+
setDragOffset(0);
|
|
455
|
+
}
|
|
456
|
+
}
|
|
457
|
+
style={{
|
|
458
|
+
transform: dragOffset ? `translateY(${dragOffset}px)` : undefined,
|
|
459
|
+
}}
|
|
460
|
+
>
|
|
461
|
+
{!isPopover && <div className="memori-mobile-session-panel--handle" />}
|
|
462
|
+
{activeView === 'session' ? (
|
|
463
|
+
<>
|
|
464
|
+
{isLoggedIn && (
|
|
465
|
+
<div className="memori-mobile-session-panel--user">
|
|
466
|
+
<div className="memori-dropdown--avatar-wrap">
|
|
467
|
+
{avatarURL ? (
|
|
468
|
+
<>
|
|
469
|
+
<img
|
|
470
|
+
src={avatarURL}
|
|
471
|
+
alt={userName || userEmail}
|
|
472
|
+
className="memori-dropdown--avatar"
|
|
473
|
+
/>
|
|
474
|
+
<span
|
|
475
|
+
className="memori-dropdown--avatar-overlay"
|
|
476
|
+
aria-hidden
|
|
477
|
+
>
|
|
478
|
+
<Camera size={20} strokeWidth={2} />
|
|
479
|
+
</span>
|
|
480
|
+
<label
|
|
481
|
+
htmlFor="mobile-session-avatar-upload"
|
|
482
|
+
className="sr-only"
|
|
483
|
+
>
|
|
484
|
+
{t('login.changeAvatar', {
|
|
485
|
+
defaultValue: 'Change profile picture',
|
|
486
|
+
})}
|
|
487
|
+
</label>
|
|
488
|
+
<input
|
|
489
|
+
type="file"
|
|
490
|
+
name="avatar"
|
|
491
|
+
id="mobile-session-avatar-upload"
|
|
492
|
+
className="memori-dropdown--avatar-input"
|
|
493
|
+
onChange={e =>
|
|
494
|
+
updateAvatar(
|
|
495
|
+
e.target.files?.[0] ?? (null as unknown as Blob)
|
|
496
|
+
)
|
|
497
|
+
}
|
|
498
|
+
accept={imgMimeTypes.join(', ')}
|
|
499
|
+
/>
|
|
500
|
+
</>
|
|
501
|
+
) : (
|
|
502
|
+
<>
|
|
503
|
+
<div className="memori-dropdown--avatar-placeholder">
|
|
504
|
+
<span className="memori-dropdown--avatar-initial">
|
|
505
|
+
{(userName || userEmail || 'U')
|
|
506
|
+
.charAt(0)
|
|
507
|
+
.toUpperCase()}
|
|
508
|
+
</span>
|
|
509
|
+
<span
|
|
510
|
+
className="memori-dropdown--avatar-overlay"
|
|
511
|
+
aria-hidden
|
|
512
|
+
>
|
|
513
|
+
<Camera size={20} strokeWidth={2} />
|
|
514
|
+
</span>
|
|
515
|
+
<label
|
|
516
|
+
htmlFor="mobile-session-avatar-upload-placeholder"
|
|
517
|
+
className="sr-only"
|
|
518
|
+
>
|
|
519
|
+
{t('login.changeAvatar', {
|
|
520
|
+
defaultValue: 'Change profile picture',
|
|
521
|
+
})}
|
|
522
|
+
</label>
|
|
523
|
+
<input
|
|
524
|
+
type="file"
|
|
525
|
+
name="avatar"
|
|
526
|
+
id="mobile-session-avatar-upload-placeholder"
|
|
527
|
+
className="memori-dropdown--avatar-input"
|
|
528
|
+
onChange={e =>
|
|
529
|
+
updateAvatar(
|
|
530
|
+
e.target.files?.[0] ?? (null as unknown as Blob)
|
|
531
|
+
)
|
|
532
|
+
}
|
|
533
|
+
accept={imgMimeTypes.join(', ')}
|
|
534
|
+
/>
|
|
535
|
+
</div>
|
|
536
|
+
</>
|
|
537
|
+
)}
|
|
538
|
+
</div>
|
|
539
|
+
<div className="memori-dropdown--user-details">
|
|
540
|
+
<h3 className="memori-dropdown--user-name">{userName}</h3>
|
|
541
|
+
<p className="memori-dropdown--user-email">{userEmail}</p>
|
|
542
|
+
<div className="memori-dropdown--user-badge">
|
|
543
|
+
{birthDate
|
|
544
|
+
? new Date(birthDate).toLocaleDateString()
|
|
545
|
+
: 'Not set'}
|
|
546
|
+
</div>
|
|
547
|
+
</div>
|
|
548
|
+
</div>
|
|
549
|
+
)}
|
|
550
|
+
<h2
|
|
551
|
+
id={panelTitleId}
|
|
552
|
+
className="memori-mobile-session-panel--section-title"
|
|
553
|
+
>
|
|
554
|
+
{title}
|
|
555
|
+
</h2>
|
|
556
|
+
{showSessionInfo && (
|
|
557
|
+
<ul className="memori-mobile-session-panel--actions memori-mobile-session-panel--session-info">
|
|
558
|
+
{isLoggedIn && (
|
|
559
|
+
<li>
|
|
560
|
+
<Button
|
|
561
|
+
variant="toolbar"
|
|
562
|
+
size="sm"
|
|
563
|
+
className="memori-mobile-session-panel--action"
|
|
564
|
+
disabled={knownFactsDisabled}
|
|
565
|
+
onClick={() => {
|
|
566
|
+
if (knownFactsDisabled) return;
|
|
567
|
+
onKnownFactsOpen?.();
|
|
568
|
+
}}
|
|
569
|
+
>
|
|
570
|
+
<span className="memori-mobile-session-panel--action-icon">
|
|
571
|
+
<Brain size={18} />
|
|
572
|
+
</span>
|
|
573
|
+
<span className="memori-mobile-session-panel--action-copy">
|
|
574
|
+
<span className="memori-mobile-session-panel--action-title">
|
|
575
|
+
{knownFactsPageTitle}
|
|
576
|
+
</span>
|
|
577
|
+
<span className="memori-mobile-session-panel--action-subtitle">
|
|
578
|
+
{resolvedKnownFactsHint}
|
|
579
|
+
</span>
|
|
580
|
+
</span>
|
|
581
|
+
<span className="memori-mobile-session-panel--action-trailing">
|
|
582
|
+
<ChevronRight size={16} />
|
|
583
|
+
</span>
|
|
584
|
+
</Button>
|
|
585
|
+
</li>
|
|
586
|
+
)}
|
|
587
|
+
<li>
|
|
588
|
+
<Button
|
|
589
|
+
variant="toolbar"
|
|
590
|
+
size="sm"
|
|
591
|
+
className="memori-mobile-session-panel--action"
|
|
592
|
+
disabled={!hasChatConsumptionData}
|
|
593
|
+
onClick={() => {
|
|
594
|
+
if (!hasChatConsumptionData) return;
|
|
595
|
+
setActiveView('aiUsage');
|
|
596
|
+
}}
|
|
597
|
+
>
|
|
598
|
+
<span className="memori-mobile-session-panel--action-icon">
|
|
599
|
+
<GasStation />
|
|
600
|
+
</span>
|
|
601
|
+
<span className="memori-mobile-session-panel--action-copy">
|
|
602
|
+
<span className="memori-mobile-session-panel--action-title">
|
|
603
|
+
{resolvedAiUsageTitle}
|
|
604
|
+
</span>
|
|
605
|
+
<span className="memori-mobile-session-panel--action-subtitle">
|
|
606
|
+
{aiUsageSubtitle}
|
|
607
|
+
</span>
|
|
608
|
+
</span>
|
|
609
|
+
<span className="memori-mobile-session-panel--action-trailing">
|
|
610
|
+
<ChevronRight size={16} />
|
|
611
|
+
</span>
|
|
612
|
+
</Button>
|
|
613
|
+
</li>
|
|
614
|
+
</ul>
|
|
615
|
+
)}
|
|
616
|
+
<ul className="memori-mobile-session-panel--actions">
|
|
617
|
+
{visibleActions.map(action => (
|
|
618
|
+
<li key={action.key}>
|
|
619
|
+
{(() => {
|
|
620
|
+
const isKnownFactsAction = action.view === 'knownFacts';
|
|
621
|
+
const isShareAction = action.view === 'share';
|
|
622
|
+
const isActionDisabled =
|
|
623
|
+
action.disabled || (isKnownFactsAction && !isLoggedIn);
|
|
624
|
+
|
|
625
|
+
return (
|
|
626
|
+
<Button
|
|
627
|
+
variant="toolbar"
|
|
628
|
+
size="sm"
|
|
629
|
+
className="memori-mobile-session-panel--action"
|
|
630
|
+
disabled={isActionDisabled}
|
|
631
|
+
onClick={() => {
|
|
632
|
+
if (isActionDisabled) return;
|
|
633
|
+
if (action.view === 'knownFacts') {
|
|
634
|
+
if (onKnownFactsOpen) {
|
|
635
|
+
onKnownFactsOpen();
|
|
636
|
+
return;
|
|
637
|
+
}
|
|
638
|
+
}
|
|
639
|
+
if (action.view) {
|
|
640
|
+
setActiveView(action.view);
|
|
641
|
+
return;
|
|
642
|
+
}
|
|
643
|
+
action.onClick?.();
|
|
644
|
+
}}
|
|
645
|
+
>
|
|
646
|
+
<span className="memori-mobile-session-panel--action-icon">
|
|
647
|
+
{action.icon}
|
|
648
|
+
</span>
|
|
649
|
+
<span className="memori-mobile-session-panel--action-copy">
|
|
650
|
+
<span className="memori-mobile-session-panel--action-title">
|
|
651
|
+
{action.title}
|
|
652
|
+
</span>
|
|
653
|
+
{action.subtitle && (
|
|
654
|
+
<span className="memori-mobile-session-panel--action-subtitle">
|
|
655
|
+
{action.subtitle}
|
|
656
|
+
</span>
|
|
657
|
+
)}
|
|
658
|
+
</span>
|
|
659
|
+
{(isShareAction || action.view === 'location') && (
|
|
660
|
+
<span className="memori-mobile-session-panel--action-trailing">
|
|
661
|
+
<ChevronRight size={16} />
|
|
662
|
+
</span>
|
|
663
|
+
)}
|
|
664
|
+
</Button>
|
|
665
|
+
);
|
|
666
|
+
})()}
|
|
667
|
+
</li>
|
|
668
|
+
))}
|
|
669
|
+
</ul>
|
|
670
|
+
{isLoggedIn && (
|
|
671
|
+
<Button
|
|
672
|
+
variant="toolbar"
|
|
673
|
+
size="sm"
|
|
674
|
+
shape="default"
|
|
675
|
+
className="memori-mobile-session-panel--logout"
|
|
676
|
+
onClick={onLogout}
|
|
677
|
+
>
|
|
678
|
+
<span className="memori-mobile-session-panel--action-icon">
|
|
679
|
+
<LogOut size={18} />
|
|
680
|
+
</span>
|
|
681
|
+
<span className="memori-mobile-session-panel--logout-label">
|
|
682
|
+
{logoutLabel}
|
|
683
|
+
</span>
|
|
684
|
+
</Button>
|
|
685
|
+
)}
|
|
686
|
+
{!isLoggedIn && (
|
|
687
|
+
<div className="memori-mobile-session-panel--login-cta-wrap">
|
|
688
|
+
<Button
|
|
689
|
+
variant="toolbar"
|
|
690
|
+
size="sm"
|
|
691
|
+
className="memori-mobile-session-panel--login-cta"
|
|
692
|
+
onClick={onLogin}
|
|
693
|
+
>
|
|
694
|
+
<span className="memori-mobile-session-panel--action-icon">
|
|
695
|
+
<LogIn size={18} />
|
|
696
|
+
</span>
|
|
697
|
+
{loginLabel}
|
|
698
|
+
</Button>
|
|
699
|
+
</div>
|
|
700
|
+
)}
|
|
701
|
+
</>
|
|
702
|
+
) : (
|
|
703
|
+
<div className="memori-mobile-session-panel--page">
|
|
704
|
+
<Button
|
|
705
|
+
variant="toolbar"
|
|
706
|
+
size="sm"
|
|
707
|
+
className="memori-mobile-session-panel--back"
|
|
708
|
+
onClick={() => setActiveView('session')}
|
|
709
|
+
>
|
|
710
|
+
<ChevronLeft size={16} />
|
|
711
|
+
{backLabel}
|
|
712
|
+
</Button>
|
|
713
|
+
<h3 className="memori-mobile-session-panel--page-title">
|
|
714
|
+
{activeView === 'location'
|
|
715
|
+
? locationPageTitle
|
|
716
|
+
: activeView === 'share'
|
|
717
|
+
? sharePageTitle
|
|
718
|
+
: activeView === 'aiUsage'
|
|
719
|
+
? resolvedAiUsageTitle
|
|
720
|
+
: knownFactsPageTitle}
|
|
721
|
+
</h3>
|
|
722
|
+
{activeView === 'location' ? (
|
|
723
|
+
<div className="memori-mobile-session-panel--page-content">
|
|
724
|
+
<p className="memori-mobile-session-panel--meta-label">
|
|
725
|
+
{locationStatusLabel}
|
|
726
|
+
</p>
|
|
727
|
+
<p className="memori-mobile-session-panel--meta-value">
|
|
728
|
+
{locationPlace || locationUnknownLabel}
|
|
729
|
+
</p>
|
|
730
|
+
<div className="memori-mobile-session-panel--page-actions">
|
|
731
|
+
<Button
|
|
732
|
+
variant="toolbar"
|
|
733
|
+
size="sm"
|
|
734
|
+
className={`memori-mobile-session-panel--page-btn ${
|
|
735
|
+
isLocationEnabled
|
|
736
|
+
? 'memori-mobile-session-panel--page-btn-active'
|
|
737
|
+
: ''
|
|
738
|
+
}`}
|
|
739
|
+
onClick={onLocationEnable}
|
|
740
|
+
>
|
|
741
|
+
<span>{locationEnableLabel}</span>
|
|
742
|
+
</Button>
|
|
743
|
+
<Button
|
|
744
|
+
variant="toolbar"
|
|
745
|
+
size="sm"
|
|
746
|
+
className="memori-mobile-session-panel--page-btn memori-mobile-session-panel--page-btn-secondary"
|
|
747
|
+
onClick={onLocationDisable}
|
|
748
|
+
>
|
|
749
|
+
{locationDisableLabel}
|
|
750
|
+
</Button>
|
|
751
|
+
</div>
|
|
752
|
+
</div>
|
|
753
|
+
) : activeView === 'share' ? (
|
|
754
|
+
<div className="memori-mobile-session-panel--page-content memori-mobile-session-panel--share-content">
|
|
755
|
+
{shareContent}
|
|
756
|
+
</div>
|
|
757
|
+
) : activeView === 'aiUsage' ? (
|
|
758
|
+
<div className="memori-mobile-session-panel--page-content memori-mobile-session-panel--ai-usage-content">
|
|
759
|
+
<ChatConsumptionContent
|
|
760
|
+
history={history}
|
|
761
|
+
showTitle={false}
|
|
762
|
+
className="memori-mobile-session-panel--ai-usage"
|
|
763
|
+
/>
|
|
764
|
+
</div>
|
|
765
|
+
) : (
|
|
766
|
+
<div className="memori-mobile-session-panel--page-content">
|
|
767
|
+
{knownFactsDescription && (
|
|
768
|
+
<p className="memori-mobile-session-panel--known-facts-description">
|
|
769
|
+
{knownFactsDescription}
|
|
770
|
+
</p>
|
|
771
|
+
)}
|
|
772
|
+
{knownFactsCountLabel && (
|
|
773
|
+
<p className="memori-mobile-session-panel--known-facts-count">
|
|
774
|
+
{knownFactsCountLabel}
|
|
775
|
+
</p>
|
|
776
|
+
)}
|
|
777
|
+
<Button
|
|
778
|
+
variant="toolbar"
|
|
779
|
+
size="sm"
|
|
780
|
+
className="memori-mobile-session-panel--page-btn"
|
|
781
|
+
disabled={knownFactsDisabled}
|
|
782
|
+
onClick={onKnownFactsOpen}
|
|
783
|
+
>
|
|
784
|
+
{knownFactsCtaLabel}
|
|
785
|
+
</Button>
|
|
786
|
+
</div>
|
|
787
|
+
)}
|
|
788
|
+
</div>
|
|
789
|
+
)}
|
|
790
|
+
</section>
|
|
791
|
+
</div>
|
|
792
|
+
);
|
|
793
|
+
};
|
|
794
|
+
|
|
795
|
+
export default MobileSessionPanel;
|