@memori.ai/memori-react 6.8.1 → 6.8.4
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 +1918 -0
- package/README.md +89 -48
- package/dist/I18nWrapper.js +3 -47
- package/dist/I18nWrapper.js.map +1 -1
- package/dist/components/AccountForm/AccountForm.d.ts +4 -2
- package/dist/components/AccountForm/AccountForm.js +2 -4
- package/dist/components/AccountForm/AccountForm.js.map +1 -1
- package/dist/components/AgeVerificationModal/AgeVerificationModal.css +1 -1
- package/dist/components/AgeVerificationModal/AgeVerificationModal.d.ts +1 -0
- package/dist/components/AgeVerificationModal/AgeVerificationModal.js +1 -1
- package/dist/components/AgeVerificationModal/AgeVerificationModal.js.map +1 -1
- package/dist/components/AttachmentLinkModal/AttachmentLinkModal.d.ts +1 -0
- package/dist/components/Auth/Auth.d.ts +1 -0
- package/dist/components/Avatar/Avatar.css +2 -2
- package/dist/components/Avatar/Avatar.d.ts +7 -0
- package/dist/components/Avatar/Avatar.js +70 -60
- package/dist/components/Avatar/Avatar.js.map +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.d.ts +7 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.js +62 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.js.map +1 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/avatarComponent.d.ts +22 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/avatarComponent.js +41 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/avatarComponent.js.map +1 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/fullbodyAvatar.d.ts +18 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/fullbodyAvatar.js +185 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/fullbodyAvatar.js.map +1 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/types.d.ts +39 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/types.js +10 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/types.js.map +1 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarAnimator.d.ts +65 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarAnimator.js +747 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarAnimator.js.map +1 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarPositionController.d.ts +19 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarPositionController.js +60 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarPositionController.js.map +1 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controllers/MorphTargetController.d.ts +24 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controllers/MorphTargetController.js +133 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controllers/MorphTargetController.js.map +1 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controls.d.ts +26 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controls.js +59 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/controls.js.map +1 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/halfbodyAvatar.d.ts +15 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/halfbodyAvatar.js +83 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/halfbodyAvatar.js.map +1 -0
- package/dist/components/{AvatarView → Avatar/AvatarView/AvatarComponent}/components/loader.d.ts +1 -0
- package/dist/components/{AvatarView → Avatar/AvatarView/AvatarComponent}/components/loader.js +1 -1
- package/dist/components/Avatar/AvatarView/AvatarComponent/components/loader.js.map +1 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/constants.d.ts +35 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/constants.js +99 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/constants.js.map +1 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/lights/Lights.d.ts +27 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/lights/Lights.js +52 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/lights/Lights.js.map +1 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.css +111 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.d.ts +11 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.js +110 -0
- package/dist/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.js.map +1 -0
- package/dist/components/Avatar/AvatarView/index.d.ts +30 -0
- package/dist/components/Avatar/AvatarView/index.js +68 -0
- package/dist/components/Avatar/AvatarView/index.js.map +1 -0
- package/dist/components/Avatar/AvatarView/utils/hideHands.d.ts +2 -0
- package/dist/components/Avatar/AvatarView/utils/hideHands.js +14 -0
- package/dist/components/Avatar/AvatarView/utils/hideHands.js.map +1 -0
- package/dist/components/Avatar/AvatarView/utils/useEyeBlink.d.ts +16 -0
- package/dist/components/Avatar/AvatarView/utils/useEyeBlink.js +71 -0
- package/dist/components/Avatar/AvatarView/utils/useEyeBlink.js.map +1 -0
- package/dist/components/Avatar/AvatarView/utils/useHeadMovement.js.map +1 -0
- package/dist/components/Avatar/AvatarView/utils/useLoadingMorphAnim.js.map +1 -0
- package/dist/components/Avatar/AvatarView/utils/useMouthAnimation.d.ts +16 -0
- package/dist/components/Avatar/AvatarView/utils/useMouthAnimation.js +59 -0
- package/dist/components/Avatar/AvatarView/utils/useMouthAnimation.js.map +1 -0
- package/dist/components/Avatar/AvatarView/utils/useSmile.js +28 -0
- package/dist/components/Avatar/AvatarView/utils/useSmile.js.map +1 -0
- package/dist/components/Avatar/AvatarView/utils/utils.js.map +1 -0
- package/dist/components/Blob/Blob.d.ts +1 -0
- package/dist/components/BlockedMemoriBadge/BlockedMemoriBadge.d.ts +1 -0
- package/dist/components/Chat/Chat.d.ts +15 -7
- package/dist/components/Chat/Chat.js +49 -30
- package/dist/components/Chat/Chat.js.map +1 -1
- package/dist/components/ChatBubble/ChatBubble.css +91 -14
- package/dist/components/ChatBubble/ChatBubble.d.ts +14 -0
- package/dist/components/ChatBubble/ChatBubble.js +92 -67
- package/dist/components/ChatBubble/ChatBubble.js.map +1 -1
- package/dist/components/ChatHistoryDrawer/ChatHistory.css +414 -0
- package/dist/components/ChatHistoryDrawer/ChatHistory.d.ts +20 -0
- package/dist/components/ChatHistoryDrawer/ChatHistory.js +630 -0
- package/dist/components/ChatHistoryDrawer/ChatHistory.js.map +1 -0
- package/dist/components/ChatInputs/ChatInputs.d.ts +9 -3
- package/dist/components/ChatInputs/ChatInputs.js +47 -6
- package/dist/components/ChatInputs/ChatInputs.js.map +1 -1
- package/dist/components/ChatTextArea/ChatTextArea.css +9 -5
- package/dist/components/ChatTextArea/ChatTextArea.js +1 -1
- package/dist/components/ChatTextArea/ChatTextArea.js.map +1 -1
- package/dist/components/CompletionProviderStatus/CompletionProviderStatus.css +35 -17
- package/dist/components/CompletionProviderStatus/CompletionProviderStatus.d.ts +5 -3
- package/dist/components/CompletionProviderStatus/CompletionProviderStatus.js +142 -28
- package/dist/components/CompletionProviderStatus/CompletionProviderStatus.js.map +1 -1
- package/dist/components/CustomGLBModelViewer/ModelViewer.d.ts +1 -0
- package/dist/components/ExpertsDrawer/ExpertsDrawer.d.ts +1 -0
- package/dist/components/ExpertsDrawer/ExpertsDrawer.js +2 -2
- package/dist/components/ExpertsDrawer/ExpertsDrawer.js.map +1 -1
- package/dist/components/FeedbackButtons/FeedbackButtons.d.ts +1 -0
- package/dist/components/FilePreview/FilePreview.css +184 -0
- package/dist/components/FilePreview/FilePreview.d.ts +9 -0
- package/dist/components/FilePreview/FilePreview.js +74 -0
- package/dist/components/FilePreview/FilePreview.js.map +1 -0
- package/dist/components/Header/Header.css +3 -3
- package/dist/components/Header/Header.d.ts +5 -1
- package/dist/components/Header/Header.js +27 -13
- package/dist/components/Header/Header.js.map +1 -1
- package/dist/components/KnownFacts/KnownFacts.d.ts +4 -2
- package/dist/components/KnownFacts/KnownFacts.js +3 -5
- package/dist/components/KnownFacts/KnownFacts.js.map +1 -1
- package/dist/components/LoginDrawer/LoginDrawer.css +302 -0
- package/dist/components/LoginDrawer/LoginDrawer.d.ts +4 -2
- package/dist/components/LoginDrawer/LoginDrawer.js +9 -11
- package/dist/components/LoginDrawer/LoginDrawer.js.map +1 -1
- package/dist/components/MediaWidget/LinkItemWidget.css +10 -0
- package/dist/components/MediaWidget/LinkItemWidget.d.ts +1 -0
- package/dist/components/MediaWidget/LinkItemWidget.js +5 -2
- package/dist/components/MediaWidget/LinkItemWidget.js.map +1 -1
- package/dist/components/MediaWidget/MediaItemWidget.css +153 -3
- package/dist/components/MediaWidget/MediaItemWidget.d.ts +7 -2
- package/dist/components/MediaWidget/MediaItemWidget.js +89 -37
- package/dist/components/MediaWidget/MediaItemWidget.js.map +1 -1
- package/dist/components/MediaWidget/MediaWidget.d.ts +4 -1
- package/dist/components/MediaWidget/MediaWidget.js +2 -2
- package/dist/components/MediaWidget/MediaWidget.js.map +1 -1
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.css +163 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.d.ts +12 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.js +133 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.js.map +1 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyButtonWithDropdown.d.ts +4 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyButtonWithDropdown.js +286 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyButtonWithDropdown.js.map +1 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyMenuItem.d.ts +6 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyMenuItem.js +40 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyMenuItem.js.map +1 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/hooks/useCopyArtifact.d.ts +6 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/hooks/useCopyArtifact.js +492 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/hooks/useCopyArtifact.js.map +1 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/index.d.ts +5 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/index.js +14 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/index.js.map +1 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/styles.css +489 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/test/CopyButtonTest.d.ts +3 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/test/CopyButtonTest.js +64 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/test/CopyButtonTest.js.map +1 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/types.d.ts +61 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/types.js +3 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/types.js.map +1 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/utils/PDFExporter.d.ts +15 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/utils/PDFExporter.js +352 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactActions/utils/PDFExporter.js.map +1 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.css +1059 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.d.ts +5 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.js +167 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.js.map +1 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.css +150 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.d.ts +9 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.js +35 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.js.map +1 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.css +253 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.d.ts +8 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.js +104 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.js.map +1 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.css +346 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.d.ts +7 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.js +89 -0
- package/dist/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.js.map +1 -0
- package/dist/components/MemoriArtifactSystem/context/ArtifactContext.d.ts +13 -0
- package/dist/components/MemoriArtifactSystem/context/ArtifactContext.js +55 -0
- package/dist/components/MemoriArtifactSystem/context/ArtifactContext.js.map +1 -0
- package/dist/components/MemoriArtifactSystem/types/artifact.types.d.ts +14 -0
- package/dist/components/MemoriArtifactSystem/types/artifact.types.js +3 -0
- package/dist/components/MemoriArtifactSystem/types/artifact.types.js.map +1 -0
- package/dist/components/MemoriWidget/MemoriWidget.css +10 -4
- package/dist/components/MemoriWidget/MemoriWidget.d.ts +29 -11
- package/dist/components/MemoriWidget/MemoriWidget.js +763 -1051
- package/dist/components/MemoriWidget/MemoriWidget.js.map +1 -1
- package/dist/components/MicrophoneButton/MicrophoneButton.d.ts +1 -0
- package/dist/components/MicrophoneButton/MicrophoneButton.js +1 -1
- package/dist/components/MicrophoneButton/MicrophoneButton.js.map +1 -1
- package/dist/components/PositionDrawer/PositionDrawer.d.ts +1 -0
- package/dist/components/PoweredBy/PoweredBy.d.ts +1 -0
- package/dist/components/SendOnEnterMenu/SendOnEnterMenu.css +3 -3
- package/dist/components/SettingsDrawer/SettingsDrawer.css +9 -2
- package/dist/components/SettingsDrawer/SettingsDrawer.d.ts +8 -1
- package/dist/components/SettingsDrawer/SettingsDrawer.js +15 -6
- package/dist/components/SettingsDrawer/SettingsDrawer.js.map +1 -1
- package/dist/components/ShareButton/ShareButton.css +6 -0
- package/dist/components/ShareButton/ShareButton.d.ts +3 -1
- package/dist/components/ShareButton/ShareButton.js +14 -3
- package/dist/components/ShareButton/ShareButton.js.map +1 -1
- package/dist/components/SignupForm/SignupForm.d.ts +4 -2
- package/dist/components/SignupForm/SignupForm.js +6 -8
- package/dist/components/SignupForm/SignupForm.js.map +1 -1
- package/dist/components/Snippet/Snippet.d.ts +2 -2
- package/dist/components/Snippet/Snippet.js +36 -25
- package/dist/components/Snippet/Snippet.js.map +1 -1
- package/dist/components/StartPanel/StartPanel.css +34 -8
- package/dist/components/StartPanel/StartPanel.d.ts +8 -3
- package/dist/components/StartPanel/StartPanel.js +26 -15
- package/dist/components/StartPanel/StartPanel.js.map +1 -1
- package/dist/components/Typing/Typing.d.ts +1 -0
- package/dist/components/Typing/Typing.js +49 -47
- package/dist/components/Typing/Typing.js.map +1 -1
- package/dist/components/UploadButton/UploadButton.css +544 -0
- package/dist/components/UploadButton/UploadButton.d.ts +19 -0
- package/dist/components/UploadButton/UploadButton.js +226 -0
- package/dist/components/UploadButton/UploadButton.js.map +1 -0
- package/dist/components/UploadButton/UploadDocuments/UploadDocuments.d.ts +31 -0
- package/dist/components/UploadButton/UploadDocuments/UploadDocuments.js +244 -0
- package/dist/components/UploadButton/UploadDocuments/UploadDocuments.js.map +1 -0
- package/dist/components/UploadButton/UploadImages/UploadImages.d.ts +20 -0
- package/dist/components/UploadButton/UploadImages/UploadImages.js +172 -0
- package/dist/components/UploadButton/UploadImages/UploadImages.js.map +1 -0
- package/dist/components/UploadMenu/UploadMenu.css +3 -3
- package/dist/components/VenueWidget/VenueWidget.css +7 -0
- package/dist/components/VenueWidget/VenueWidget.d.ts +1 -0
- package/dist/components/VenueWidget/VenueWidget.js +1 -1
- package/dist/components/VenueWidget/VenueWidget.js.map +1 -1
- package/dist/components/WhyThisAnswer/WhyThisAnswer.css +43 -0
- package/dist/components/WhyThisAnswer/WhyThisAnswer.d.ts +4 -2
- package/dist/components/WhyThisAnswer/WhyThisAnswer.js +5 -6
- package/dist/components/WhyThisAnswer/WhyThisAnswer.js.map +1 -1
- package/dist/components/icons/AI.d.ts +1 -0
- package/dist/components/icons/Alert.d.ts +6 -0
- package/dist/components/icons/Alert.js +6 -0
- package/dist/components/icons/Alert.js.map +1 -0
- package/dist/components/icons/ArrowUp.d.ts +6 -0
- package/dist/components/icons/ArrowUp.js +6 -0
- package/dist/components/icons/ArrowUp.js.map +1 -0
- package/dist/components/icons/Bug.d.ts +6 -0
- package/dist/components/icons/Bug.js +6 -0
- package/dist/components/icons/Bug.js.map +1 -0
- package/dist/components/icons/Chat.d.ts +6 -0
- package/dist/components/icons/Chat.js +6 -0
- package/dist/components/icons/Chat.js.map +1 -0
- package/dist/components/icons/ChevronDown.d.ts +6 -0
- package/dist/components/icons/ChevronDown.js +6 -0
- package/dist/components/icons/ChevronDown.js.map +1 -0
- package/dist/components/icons/ChevronLeft.d.ts +1 -0
- package/dist/components/icons/ChevronRight.d.ts +1 -0
- package/dist/components/icons/ChevronUp.d.ts +6 -0
- package/dist/components/icons/ChevronUp.js +6 -0
- package/dist/components/icons/ChevronUp.js.map +1 -0
- package/dist/components/icons/Clear.d.ts +1 -0
- package/dist/components/icons/Close.d.ts +3 -1
- package/dist/components/icons/Close.js +1 -1
- package/dist/components/icons/Close.js.map +1 -1
- package/dist/components/icons/Code.d.ts +6 -0
- package/dist/components/icons/Code.js +6 -0
- package/dist/components/icons/Code.js.map +1 -0
- package/dist/components/icons/Copy.d.ts +1 -0
- package/dist/components/icons/Copy.js +1 -1
- package/dist/components/icons/Copy.js.map +1 -1
- package/dist/components/icons/DeepThought.d.ts +1 -0
- package/dist/components/icons/Delete.d.ts +1 -0
- package/dist/components/icons/Document.d.ts +5 -0
- package/dist/components/icons/Document.js +10 -0
- package/dist/components/icons/Document.js.map +1 -0
- package/dist/components/icons/Download.d.ts +1 -0
- package/dist/components/icons/Edit.d.ts +1 -0
- package/dist/components/icons/Expand.d.ts +1 -0
- package/dist/components/icons/Eye.d.ts +1 -0
- package/dist/components/icons/EyeInvisible.d.ts +1 -0
- package/dist/components/icons/Facebook.d.ts +1 -0
- package/dist/components/icons/Feedback.d.ts +1 -0
- package/dist/components/icons/File.d.ts +1 -0
- package/dist/components/icons/FileExcel.d.ts +1 -0
- package/dist/components/icons/FilePdf.d.ts +1 -0
- package/dist/components/icons/FileWord.d.ts +1 -0
- package/dist/components/icons/Fullscreen.d.ts +1 -0
- package/dist/components/icons/FullscreenExit.d.ts +1 -0
- package/dist/components/icons/Group.d.ts +1 -0
- package/dist/components/icons/History.d.ts +7 -0
- package/dist/components/icons/History.js +6 -0
- package/dist/components/icons/History.js.map +1 -0
- package/dist/components/icons/Image.d.ts +4 -0
- package/dist/components/icons/Image.js +9 -0
- package/dist/components/icons/Image.js.map +1 -0
- package/dist/components/icons/Info.d.ts +6 -0
- package/dist/components/icons/Info.js +6 -0
- package/dist/components/icons/Info.js.map +1 -0
- package/dist/components/icons/Link.d.ts +1 -0
- package/dist/components/icons/Linkedin.d.ts +1 -0
- package/dist/components/icons/Loading.d.ts +1 -0
- package/dist/components/icons/Mail.d.ts +1 -0
- package/dist/components/icons/MapMarker.d.ts +1 -0
- package/dist/components/icons/MenuHorizontal.d.ts +7 -0
- package/dist/components/icons/MenuHorizontal.js +6 -0
- package/dist/components/icons/MenuHorizontal.js.map +1 -0
- package/dist/components/icons/MenuVertical.d.ts +7 -0
- package/dist/components/icons/MenuVertical.js +6 -0
- package/dist/components/icons/MenuVertical.js.map +1 -0
- package/dist/components/icons/Message.d.ts +1 -0
- package/dist/components/icons/Microphone.d.ts +1 -0
- package/dist/components/icons/Minus.d.ts +1 -0
- package/dist/components/icons/MinusCircle.d.ts +1 -0
- package/dist/components/icons/PaperClip.d.ts +1 -0
- package/dist/components/icons/Picture.d.ts +1 -0
- package/dist/components/icons/Plus.d.ts +1 -0
- package/dist/components/icons/Preview.d.ts +4 -0
- package/dist/components/icons/Preview.js +9 -0
- package/dist/components/icons/Preview.js.map +1 -0
- package/dist/components/icons/Print.d.ts +6 -0
- package/dist/components/icons/Print.js +6 -0
- package/dist/components/icons/Print.js.map +1 -0
- package/dist/components/icons/QuestionHelp.d.ts +1 -0
- package/dist/components/icons/Refresh.d.ts +1 -0
- package/dist/components/icons/SelectIcon.d.ts +1 -0
- package/dist/components/icons/Send.d.ts +1 -0
- package/dist/components/icons/Setting.d.ts +1 -0
- package/dist/components/icons/Share.d.ts +1 -0
- package/dist/components/icons/Sound.d.ts +1 -0
- package/dist/components/icons/SoundDeactivated.d.ts +1 -0
- package/dist/components/icons/Telegram.d.ts +1 -0
- package/dist/components/icons/ThumbDown.d.ts +1 -0
- package/dist/components/icons/ThumbUp.d.ts +1 -0
- package/dist/components/icons/Translation.d.ts +1 -0
- package/dist/components/icons/Twitter.d.ts +1 -0
- package/dist/components/icons/Upload.d.ts +4 -0
- package/dist/components/icons/Upload.js +9 -0
- package/dist/components/icons/Upload.js.map +1 -0
- package/dist/components/icons/User.d.ts +1 -0
- package/dist/components/icons/Warning.d.ts +1 -0
- package/dist/components/icons/Warning.js +1 -1
- package/dist/components/icons/Warning.js.map +1 -1
- package/dist/components/icons/WhatsApp.d.ts +1 -0
- package/dist/components/layouts/Chat.js +9 -1
- package/dist/components/layouts/Chat.js.map +1 -1
- package/dist/components/layouts/FullPage.js +10 -1
- package/dist/components/layouts/FullPage.js.map +1 -1
- package/dist/components/layouts/HiddenChat.d.ts +4 -0
- package/dist/components/layouts/HiddenChat.js +147 -0
- package/dist/components/layouts/HiddenChat.js.map +1 -0
- package/dist/components/layouts/Totem.js +1 -1
- package/dist/components/layouts/Totem.js.map +1 -1
- package/dist/components/layouts/WebsiteAssistant.js +2 -2
- package/dist/components/layouts/WebsiteAssistant.js.map +1 -1
- package/dist/components/layouts/ZoomedFullBody.d.ts +4 -0
- package/dist/components/layouts/ZoomedFullBody.js +17 -0
- package/dist/components/layouts/ZoomedFullBody.js.map +1 -0
- package/dist/components/layouts/chat.css +358 -19
- package/dist/components/layouts/hidden-chat.css +254 -0
- package/dist/components/layouts/totem.css +19 -10
- package/dist/components/layouts/website-assistant.css +2 -2
- package/dist/components/layouts/zoomed-full-body.css +18 -0
- package/dist/components/ui/Alert.css +93 -0
- package/dist/components/ui/Alert.d.ts +18 -0
- package/dist/components/ui/Alert.js +42 -0
- package/dist/components/ui/Alert.js.map +1 -0
- package/dist/components/ui/Button.css +8 -2
- package/dist/components/ui/Button.d.ts +1 -0
- package/dist/components/ui/Button.js +2 -1
- package/dist/components/ui/Button.js.map +1 -1
- package/dist/components/ui/Card.css +5 -0
- package/dist/components/ui/Card.d.ts +1 -0
- package/dist/components/ui/Card.js +2 -1
- package/dist/components/ui/Card.js.map +1 -1
- package/dist/components/ui/ConfirmDialog.css +42 -0
- package/dist/components/ui/ConfirmDialog.d.ts +11 -0
- package/dist/components/ui/ConfirmDialog.js +12 -0
- package/dist/components/ui/ConfirmDialog.js.map +1 -0
- package/dist/components/ui/Drawer.css +121 -96
- package/dist/components/ui/Drawer.d.ts +17 -6
- package/dist/components/ui/Drawer.js +44 -13
- package/dist/components/ui/Drawer.js.map +1 -1
- package/dist/components/ui/Expandable.d.ts +3 -2
- package/dist/components/ui/Expandable.js +35 -20
- package/dist/components/ui/Expandable.js.map +1 -1
- package/dist/components/ui/Select.d.ts +1 -0
- package/dist/components/ui/Slider.css +192 -0
- package/dist/components/ui/Slider.d.ts +12 -0
- package/dist/components/ui/Slider.js +78 -0
- package/dist/components/ui/Slider.js.map +1 -0
- package/dist/components/ui/Table.css +15 -2
- package/dist/context/visemeContext.d.ts +24 -0
- package/dist/context/visemeContext.js +192 -0
- package/dist/context/visemeContext.js.map +1 -0
- package/dist/helpers/configuration.js +0 -1
- package/dist/helpers/configuration.js.map +1 -1
- package/dist/helpers/constants.d.ts +6 -0
- package/dist/helpers/constants.js +7 -1
- package/dist/helpers/constants.js.map +1 -1
- package/dist/helpers/error.js +53 -6
- package/dist/helpers/error.js.map +1 -1
- package/dist/helpers/markedExtendedTables.js +1 -1
- package/dist/helpers/markedExtendedTables.js.map +1 -1
- package/dist/helpers/message.d.ts +5 -0
- package/dist/helpers/message.js +98 -0
- package/dist/helpers/message.js.map +1 -0
- package/dist/helpers/sanitizer.d.ts +1 -0
- package/dist/helpers/sanitizer.js +9 -0
- package/dist/helpers/sanitizer.js.map +1 -0
- package/dist/helpers/statistics.d.ts +1 -12
- package/dist/helpers/statistics.js +1 -165
- package/dist/helpers/statistics.js.map +1 -1
- package/dist/helpers/stt/useSTT.d.ts +40 -0
- package/dist/helpers/stt/useSTT.js +527 -0
- package/dist/helpers/stt/useSTT.js.map +1 -0
- package/dist/helpers/translations.js +23 -4
- package/dist/helpers/translations.js.map +1 -1
- package/dist/helpers/tts/ttsVoiceUtility.d.ts +158 -0
- package/dist/helpers/tts/ttsVoiceUtility.js +192 -0
- package/dist/helpers/tts/ttsVoiceUtility.js.map +1 -0
- package/dist/helpers/tts/useTTS.d.ts +27 -0
- package/dist/helpers/tts/useTTS.js +297 -0
- package/dist/helpers/tts/useTTS.js.map +1 -0
- package/dist/helpers/utils.d.ts +40 -0
- package/dist/helpers/utils.js +157 -1
- package/dist/helpers/utils.js.map +1 -1
- package/dist/i18n.js +13 -1
- package/dist/i18n.js.map +1 -1
- package/dist/index.d.ts +14 -4
- package/dist/index.js +136 -84
- package/dist/index.js.map +1 -1
- package/dist/locales/de.json +593 -0
- package/dist/locales/en.json +250 -40
- package/dist/locales/es.json +593 -0
- package/dist/locales/fr.json +603 -0
- package/dist/locales/it.json +260 -48
- package/dist/styles.css +18 -2
- package/esm/I18nWrapper.js +4 -48
- package/esm/I18nWrapper.js.map +1 -1
- package/esm/components/AccountForm/AccountForm.d.ts +4 -2
- package/esm/components/AccountForm/AccountForm.js +2 -4
- package/esm/components/AccountForm/AccountForm.js.map +1 -1
- package/esm/components/AgeVerificationModal/AgeVerificationModal.css +1 -1
- package/esm/components/AgeVerificationModal/AgeVerificationModal.d.ts +1 -0
- package/esm/components/AgeVerificationModal/AgeVerificationModal.js +1 -1
- package/esm/components/AgeVerificationModal/AgeVerificationModal.js.map +1 -1
- package/esm/components/AttachmentLinkModal/AttachmentLinkModal.d.ts +1 -0
- package/esm/components/Auth/Auth.d.ts +1 -0
- package/esm/components/Avatar/Avatar.css +2 -2
- package/esm/components/Avatar/Avatar.d.ts +7 -0
- package/esm/components/Avatar/Avatar.js +72 -62
- package/esm/components/Avatar/Avatar.js.map +1 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.d.ts +7 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.js +60 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.js.map +1 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/avatarComponent.d.ts +22 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/avatarComponent.js +36 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/avatarComponent.js.map +1 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/fullbodyAvatar.d.ts +18 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/fullbodyAvatar.js +180 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/fullbodyAvatar.js.map +1 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/types.d.ts +39 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/types.js +7 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/types.js.map +1 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarAnimator.d.ts +65 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarAnimator.js +743 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarAnimator.js.map +1 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarPositionController.d.ts +19 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarPositionController.js +56 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarPositionController.js.map +1 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controllers/MorphTargetController.d.ts +24 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controllers/MorphTargetController.js +129 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controllers/MorphTargetController.js.map +1 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controls.d.ts +26 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controls.js +56 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/controls.js.map +1 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/halfbodyAvatar.d.ts +15 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/halfbodyAvatar.js +79 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/halfbodyAvatar.js.map +1 -0
- package/esm/components/{AvatarView → Avatar/AvatarView/AvatarComponent}/components/loader.d.ts +1 -0
- package/esm/components/{AvatarView → Avatar/AvatarView/AvatarComponent}/components/loader.js +1 -1
- package/esm/components/Avatar/AvatarView/AvatarComponent/components/loader.js.map +1 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/constants.d.ts +35 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/constants.js +96 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/constants.js.map +1 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/lights/Lights.d.ts +27 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/lights/Lights.js +48 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/lights/Lights.js.map +1 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.css +111 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.d.ts +11 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.js +107 -0
- package/esm/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.js.map +1 -0
- package/esm/components/Avatar/AvatarView/index.d.ts +30 -0
- package/esm/components/Avatar/AvatarView/index.js +64 -0
- package/esm/components/Avatar/AvatarView/index.js.map +1 -0
- package/esm/components/Avatar/AvatarView/utils/hideHands.d.ts +2 -0
- package/esm/components/Avatar/AvatarView/utils/hideHands.js +10 -0
- package/esm/components/Avatar/AvatarView/utils/hideHands.js.map +1 -0
- package/esm/components/Avatar/AvatarView/utils/useEyeBlink.d.ts +16 -0
- package/esm/components/Avatar/AvatarView/utils/useEyeBlink.js +67 -0
- package/esm/components/Avatar/AvatarView/utils/useEyeBlink.js.map +1 -0
- package/esm/components/Avatar/AvatarView/utils/useHeadMovement.js.map +1 -0
- package/esm/components/Avatar/AvatarView/utils/useLoadingMorphAnim.js.map +1 -0
- package/esm/components/Avatar/AvatarView/utils/useMouthAnimation.d.ts +16 -0
- package/esm/components/Avatar/AvatarView/utils/useMouthAnimation.js +55 -0
- package/esm/components/Avatar/AvatarView/utils/useMouthAnimation.js.map +1 -0
- package/esm/components/Avatar/AvatarView/utils/useSmile.js +25 -0
- package/esm/components/Avatar/AvatarView/utils/useSmile.js.map +1 -0
- package/esm/components/Avatar/AvatarView/utils/utils.js.map +1 -0
- package/esm/components/Blob/Blob.d.ts +1 -0
- package/esm/components/BlockedMemoriBadge/BlockedMemoriBadge.d.ts +1 -0
- package/esm/components/Chat/Chat.d.ts +15 -7
- package/esm/components/Chat/Chat.js +49 -30
- package/esm/components/Chat/Chat.js.map +1 -1
- package/esm/components/ChatBubble/ChatBubble.css +91 -14
- package/esm/components/ChatBubble/ChatBubble.d.ts +14 -0
- package/esm/components/ChatBubble/ChatBubble.js +93 -68
- package/esm/components/ChatBubble/ChatBubble.js.map +1 -1
- package/esm/components/ChatHistoryDrawer/ChatHistory.css +414 -0
- package/esm/components/ChatHistoryDrawer/ChatHistory.d.ts +20 -0
- package/esm/components/ChatHistoryDrawer/ChatHistory.js +627 -0
- package/esm/components/ChatHistoryDrawer/ChatHistory.js.map +1 -0
- package/esm/components/ChatInputs/ChatInputs.d.ts +9 -3
- package/esm/components/ChatInputs/ChatInputs.js +48 -7
- package/esm/components/ChatInputs/ChatInputs.js.map +1 -1
- package/esm/components/ChatTextArea/ChatTextArea.css +9 -5
- package/esm/components/ChatTextArea/ChatTextArea.js +1 -1
- package/esm/components/ChatTextArea/ChatTextArea.js.map +1 -1
- package/esm/components/CompletionProviderStatus/CompletionProviderStatus.css +35 -17
- package/esm/components/CompletionProviderStatus/CompletionProviderStatus.d.ts +5 -3
- package/esm/components/CompletionProviderStatus/CompletionProviderStatus.js +143 -29
- package/esm/components/CompletionProviderStatus/CompletionProviderStatus.js.map +1 -1
- package/esm/components/CustomGLBModelViewer/ModelViewer.d.ts +1 -0
- package/esm/components/ExpertsDrawer/ExpertsDrawer.d.ts +1 -0
- package/esm/components/ExpertsDrawer/ExpertsDrawer.js +2 -2
- package/esm/components/ExpertsDrawer/ExpertsDrawer.js.map +1 -1
- package/esm/components/FeedbackButtons/FeedbackButtons.d.ts +1 -0
- package/esm/components/FilePreview/FilePreview.css +184 -0
- package/esm/components/FilePreview/FilePreview.d.ts +9 -0
- package/esm/components/FilePreview/FilePreview.js +71 -0
- package/esm/components/FilePreview/FilePreview.js.map +1 -0
- package/esm/components/Header/Header.css +3 -3
- package/esm/components/Header/Header.d.ts +5 -1
- package/esm/components/Header/Header.js +27 -13
- package/esm/components/Header/Header.js.map +1 -1
- package/esm/components/KnownFacts/KnownFacts.d.ts +4 -2
- package/esm/components/KnownFacts/KnownFacts.js +3 -5
- package/esm/components/KnownFacts/KnownFacts.js.map +1 -1
- package/esm/components/LoginDrawer/LoginDrawer.css +302 -0
- package/esm/components/LoginDrawer/LoginDrawer.d.ts +4 -2
- package/esm/components/LoginDrawer/LoginDrawer.js +9 -11
- package/esm/components/LoginDrawer/LoginDrawer.js.map +1 -1
- package/esm/components/MediaWidget/LinkItemWidget.css +10 -0
- package/esm/components/MediaWidget/LinkItemWidget.d.ts +1 -0
- package/esm/components/MediaWidget/LinkItemWidget.js +5 -2
- package/esm/components/MediaWidget/LinkItemWidget.js.map +1 -1
- package/esm/components/MediaWidget/MediaItemWidget.css +153 -3
- package/esm/components/MediaWidget/MediaItemWidget.d.ts +7 -2
- package/esm/components/MediaWidget/MediaItemWidget.js +90 -38
- package/esm/components/MediaWidget/MediaItemWidget.js.map +1 -1
- package/esm/components/MediaWidget/MediaWidget.d.ts +4 -1
- package/esm/components/MediaWidget/MediaWidget.js +2 -2
- package/esm/components/MediaWidget/MediaWidget.js.map +1 -1
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.css +163 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.d.ts +12 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.js +130 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.js.map +1 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyButtonWithDropdown.d.ts +4 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyButtonWithDropdown.js +283 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyButtonWithDropdown.js.map +1 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyMenuItem.d.ts +6 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyMenuItem.js +37 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyMenuItem.js.map +1 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/hooks/useCopyArtifact.d.ts +6 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/hooks/useCopyArtifact.js +487 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/hooks/useCopyArtifact.js.map +1 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/index.d.ts +5 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/index.js +6 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/index.js.map +1 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/styles.css +489 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/test/CopyButtonTest.d.ts +3 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/test/CopyButtonTest.js +62 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/test/CopyButtonTest.js.map +1 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/types.d.ts +61 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/types.js +2 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/types.js.map +1 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/utils/PDFExporter.d.ts +15 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/utils/PDFExporter.js +348 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactActions/utils/PDFExporter.js.map +1 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.css +1059 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.d.ts +5 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.js +164 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.js.map +1 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.css +150 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.d.ts +9 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.js +32 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.js.map +1 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.css +253 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.d.ts +8 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.js +101 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.js.map +1 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.css +346 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.d.ts +7 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.js +86 -0
- package/esm/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.js.map +1 -0
- package/esm/components/MemoriArtifactSystem/context/ArtifactContext.d.ts +13 -0
- package/esm/components/MemoriArtifactSystem/context/ArtifactContext.js +50 -0
- package/esm/components/MemoriArtifactSystem/context/ArtifactContext.js.map +1 -0
- package/esm/components/MemoriArtifactSystem/types/artifact.types.d.ts +14 -0
- package/esm/components/MemoriArtifactSystem/types/artifact.types.js +2 -0
- package/esm/components/MemoriArtifactSystem/types/artifact.types.js.map +1 -0
- package/esm/components/MemoriWidget/MemoriWidget.css +10 -4
- package/esm/components/MemoriWidget/MemoriWidget.d.ts +29 -11
- package/esm/components/MemoriWidget/MemoriWidget.js +766 -1054
- package/esm/components/MemoriWidget/MemoriWidget.js.map +1 -1
- package/esm/components/MicrophoneButton/MicrophoneButton.d.ts +1 -0
- package/esm/components/MicrophoneButton/MicrophoneButton.js +1 -1
- package/esm/components/MicrophoneButton/MicrophoneButton.js.map +1 -1
- package/esm/components/PositionDrawer/PositionDrawer.d.ts +1 -0
- package/esm/components/PoweredBy/PoweredBy.d.ts +1 -0
- package/esm/components/SendOnEnterMenu/SendOnEnterMenu.css +3 -3
- package/esm/components/SettingsDrawer/SettingsDrawer.css +9 -2
- package/esm/components/SettingsDrawer/SettingsDrawer.d.ts +8 -1
- package/esm/components/SettingsDrawer/SettingsDrawer.js +15 -6
- package/esm/components/SettingsDrawer/SettingsDrawer.js.map +1 -1
- package/esm/components/ShareButton/ShareButton.css +6 -0
- package/esm/components/ShareButton/ShareButton.d.ts +3 -1
- package/esm/components/ShareButton/ShareButton.js +14 -3
- package/esm/components/ShareButton/ShareButton.js.map +1 -1
- package/esm/components/SignupForm/SignupForm.d.ts +4 -2
- package/esm/components/SignupForm/SignupForm.js +6 -8
- package/esm/components/SignupForm/SignupForm.js.map +1 -1
- package/esm/components/Snippet/Snippet.d.ts +2 -2
- package/esm/components/Snippet/Snippet.js +36 -25
- package/esm/components/Snippet/Snippet.js.map +1 -1
- package/esm/components/StartPanel/StartPanel.css +34 -8
- package/esm/components/StartPanel/StartPanel.d.ts +8 -3
- package/esm/components/StartPanel/StartPanel.js +26 -15
- package/esm/components/StartPanel/StartPanel.js.map +1 -1
- package/esm/components/Typing/Typing.d.ts +1 -0
- package/esm/components/Typing/Typing.js +49 -47
- package/esm/components/Typing/Typing.js.map +1 -1
- package/esm/components/UploadButton/UploadButton.css +544 -0
- package/esm/components/UploadButton/UploadButton.d.ts +19 -0
- package/esm/components/UploadButton/UploadButton.js +223 -0
- package/esm/components/UploadButton/UploadButton.js.map +1 -0
- package/esm/components/UploadButton/UploadDocuments/UploadDocuments.d.ts +31 -0
- package/esm/components/UploadButton/UploadDocuments/UploadDocuments.js +241 -0
- package/esm/components/UploadButton/UploadDocuments/UploadDocuments.js.map +1 -0
- package/esm/components/UploadButton/UploadImages/UploadImages.d.ts +20 -0
- package/esm/components/UploadButton/UploadImages/UploadImages.js +169 -0
- package/esm/components/UploadButton/UploadImages/UploadImages.js.map +1 -0
- package/esm/components/UploadMenu/UploadMenu.css +3 -3
- package/esm/components/VenueWidget/VenueWidget.css +7 -0
- package/esm/components/VenueWidget/VenueWidget.d.ts +1 -0
- package/esm/components/VenueWidget/VenueWidget.js +1 -1
- package/esm/components/VenueWidget/VenueWidget.js.map +1 -1
- package/esm/components/WhyThisAnswer/WhyThisAnswer.css +43 -0
- package/esm/components/WhyThisAnswer/WhyThisAnswer.d.ts +4 -2
- package/esm/components/WhyThisAnswer/WhyThisAnswer.js +5 -6
- package/esm/components/WhyThisAnswer/WhyThisAnswer.js.map +1 -1
- package/esm/components/icons/AI.d.ts +1 -0
- package/esm/components/icons/Alert.d.ts +6 -0
- package/esm/components/icons/Alert.js +4 -0
- package/esm/components/icons/Alert.js.map +1 -0
- package/esm/components/icons/ArrowUp.d.ts +6 -0
- package/esm/components/icons/ArrowUp.js +4 -0
- package/esm/components/icons/ArrowUp.js.map +1 -0
- package/esm/components/icons/Bug.d.ts +6 -0
- package/esm/components/icons/Bug.js +4 -0
- package/esm/components/icons/Bug.js.map +1 -0
- package/esm/components/icons/Chat.d.ts +6 -0
- package/esm/components/icons/Chat.js +4 -0
- package/esm/components/icons/Chat.js.map +1 -0
- package/esm/components/icons/ChevronDown.d.ts +6 -0
- package/esm/components/icons/ChevronDown.js +4 -0
- package/esm/components/icons/ChevronDown.js.map +1 -0
- package/esm/components/icons/ChevronLeft.d.ts +1 -0
- package/esm/components/icons/ChevronRight.d.ts +1 -0
- package/esm/components/icons/ChevronUp.d.ts +6 -0
- package/esm/components/icons/ChevronUp.js +4 -0
- package/esm/components/icons/ChevronUp.js.map +1 -0
- package/esm/components/icons/Clear.d.ts +1 -0
- package/esm/components/icons/Close.d.ts +3 -1
- package/esm/components/icons/Close.js +1 -1
- package/esm/components/icons/Close.js.map +1 -1
- package/esm/components/icons/Code.d.ts +6 -0
- package/esm/components/icons/Code.js +4 -0
- package/esm/components/icons/Code.js.map +1 -0
- package/esm/components/icons/Copy.d.ts +1 -0
- package/esm/components/icons/Copy.js +2 -2
- package/esm/components/icons/Copy.js.map +1 -1
- package/esm/components/icons/DeepThought.d.ts +1 -0
- package/esm/components/icons/Delete.d.ts +1 -0
- package/esm/components/icons/Document.d.ts +5 -0
- package/esm/components/icons/Document.js +6 -0
- package/esm/components/icons/Document.js.map +1 -0
- package/esm/components/icons/Download.d.ts +1 -0
- package/esm/components/icons/Edit.d.ts +1 -0
- package/esm/components/icons/Expand.d.ts +1 -0
- package/esm/components/icons/Eye.d.ts +1 -0
- package/esm/components/icons/EyeInvisible.d.ts +1 -0
- package/esm/components/icons/Facebook.d.ts +1 -0
- package/esm/components/icons/Feedback.d.ts +1 -0
- package/esm/components/icons/File.d.ts +1 -0
- package/esm/components/icons/FileExcel.d.ts +1 -0
- package/esm/components/icons/FilePdf.d.ts +1 -0
- package/esm/components/icons/FileWord.d.ts +1 -0
- package/esm/components/icons/Fullscreen.d.ts +1 -0
- package/esm/components/icons/FullscreenExit.d.ts +1 -0
- package/esm/components/icons/Group.d.ts +1 -0
- package/esm/components/icons/History.d.ts +7 -0
- package/esm/components/icons/History.js +4 -0
- package/esm/components/icons/History.js.map +1 -0
- package/esm/components/icons/Image.d.ts +4 -0
- package/esm/components/icons/Image.js +5 -0
- package/esm/components/icons/Image.js.map +1 -0
- package/esm/components/icons/Info.d.ts +6 -0
- package/esm/components/icons/Info.js +4 -0
- package/esm/components/icons/Info.js.map +1 -0
- package/esm/components/icons/Link.d.ts +1 -0
- package/esm/components/icons/Linkedin.d.ts +1 -0
- package/esm/components/icons/Loading.d.ts +1 -0
- package/esm/components/icons/Mail.d.ts +1 -0
- package/esm/components/icons/MapMarker.d.ts +1 -0
- package/esm/components/icons/MenuHorizontal.d.ts +7 -0
- package/esm/components/icons/MenuHorizontal.js +4 -0
- package/esm/components/icons/MenuHorizontal.js.map +1 -0
- package/esm/components/icons/MenuVertical.d.ts +7 -0
- package/esm/components/icons/MenuVertical.js +4 -0
- package/esm/components/icons/MenuVertical.js.map +1 -0
- package/esm/components/icons/Message.d.ts +1 -0
- package/esm/components/icons/Microphone.d.ts +1 -0
- package/esm/components/icons/Minus.d.ts +1 -0
- package/esm/components/icons/MinusCircle.d.ts +1 -0
- package/esm/components/icons/PaperClip.d.ts +1 -0
- package/esm/components/icons/Picture.d.ts +1 -0
- package/esm/components/icons/Plus.d.ts +1 -0
- package/esm/components/icons/Preview.d.ts +4 -0
- package/esm/components/icons/Preview.js +5 -0
- package/esm/components/icons/Preview.js.map +1 -0
- package/esm/components/icons/Print.d.ts +6 -0
- package/esm/components/icons/Print.js +4 -0
- package/esm/components/icons/Print.js.map +1 -0
- package/esm/components/icons/QuestionHelp.d.ts +1 -0
- package/esm/components/icons/Refresh.d.ts +1 -0
- package/esm/components/icons/SelectIcon.d.ts +1 -0
- package/esm/components/icons/Send.d.ts +1 -0
- package/esm/components/icons/Setting.d.ts +1 -0
- package/esm/components/icons/Share.d.ts +1 -0
- package/esm/components/icons/Sound.d.ts +1 -0
- package/esm/components/icons/SoundDeactivated.d.ts +1 -0
- package/esm/components/icons/Telegram.d.ts +1 -0
- package/esm/components/icons/ThumbDown.d.ts +1 -0
- package/esm/components/icons/ThumbUp.d.ts +1 -0
- package/esm/components/icons/Translation.d.ts +1 -0
- package/esm/components/icons/Twitter.d.ts +1 -0
- package/esm/components/icons/Upload.d.ts +4 -0
- package/esm/components/icons/Upload.js +5 -0
- package/esm/components/icons/Upload.js.map +1 -0
- package/esm/components/icons/User.d.ts +1 -0
- package/esm/components/icons/Warning.d.ts +1 -0
- package/esm/components/icons/Warning.js +1 -1
- package/esm/components/icons/Warning.js.map +1 -1
- package/esm/components/icons/WhatsApp.d.ts +1 -0
- package/esm/components/layouts/Chat.js +9 -1
- package/esm/components/layouts/Chat.js.map +1 -1
- package/esm/components/layouts/FullPage.js +10 -1
- package/esm/components/layouts/FullPage.js.map +1 -1
- package/esm/components/layouts/HiddenChat.d.ts +4 -0
- package/esm/components/layouts/HiddenChat.js +144 -0
- package/esm/components/layouts/HiddenChat.js.map +1 -0
- package/esm/components/layouts/Totem.js +1 -1
- package/esm/components/layouts/Totem.js.map +1 -1
- package/esm/components/layouts/WebsiteAssistant.js +2 -2
- package/esm/components/layouts/WebsiteAssistant.js.map +1 -1
- package/esm/components/layouts/ZoomedFullBody.d.ts +4 -0
- package/esm/components/layouts/ZoomedFullBody.js +14 -0
- package/esm/components/layouts/ZoomedFullBody.js.map +1 -0
- package/esm/components/layouts/chat.css +358 -19
- package/esm/components/layouts/hidden-chat.css +254 -0
- package/esm/components/layouts/totem.css +19 -10
- package/esm/components/layouts/website-assistant.css +2 -2
- package/esm/components/layouts/zoomed-full-body.css +18 -0
- package/esm/components/ui/Alert.css +93 -0
- package/esm/components/ui/Alert.d.ts +18 -0
- package/esm/components/ui/Alert.js +39 -0
- package/esm/components/ui/Alert.js.map +1 -0
- package/esm/components/ui/Button.css +8 -2
- package/esm/components/ui/Button.d.ts +1 -0
- package/esm/components/ui/Button.js +2 -1
- package/esm/components/ui/Button.js.map +1 -1
- package/esm/components/ui/Card.css +5 -0
- package/esm/components/ui/Card.d.ts +1 -0
- package/esm/components/ui/Card.js +2 -1
- package/esm/components/ui/Card.js.map +1 -1
- package/esm/components/ui/ConfirmDialog.css +42 -0
- package/esm/components/ui/ConfirmDialog.d.ts +11 -0
- package/esm/components/ui/ConfirmDialog.js +9 -0
- package/esm/components/ui/ConfirmDialog.js.map +1 -0
- package/esm/components/ui/Drawer.css +121 -96
- package/esm/components/ui/Drawer.d.ts +17 -6
- package/esm/components/ui/Drawer.js +45 -14
- package/esm/components/ui/Drawer.js.map +1 -1
- package/esm/components/ui/Expandable.d.ts +3 -2
- package/esm/components/ui/Expandable.js +35 -20
- package/esm/components/ui/Expandable.js.map +1 -1
- package/esm/components/ui/Select.d.ts +1 -0
- package/esm/components/ui/Slider.css +192 -0
- package/esm/components/ui/Slider.d.ts +12 -0
- package/esm/components/ui/Slider.js +75 -0
- package/esm/components/ui/Slider.js.map +1 -0
- package/esm/components/ui/Table.css +15 -2
- package/esm/context/visemeContext.d.ts +24 -0
- package/esm/context/visemeContext.js +187 -0
- package/esm/context/visemeContext.js.map +1 -0
- package/esm/helpers/configuration.js +0 -1
- package/esm/helpers/configuration.js.map +1 -1
- package/esm/helpers/constants.d.ts +6 -0
- package/esm/helpers/constants.js +6 -0
- package/esm/helpers/constants.js.map +1 -1
- package/esm/helpers/error.js +53 -6
- package/esm/helpers/error.js.map +1 -1
- package/esm/helpers/markedExtendedTables.js +1 -1
- package/esm/helpers/markedExtendedTables.js.map +1 -1
- package/esm/helpers/message.d.ts +5 -0
- package/esm/helpers/message.js +91 -0
- package/esm/helpers/message.js.map +1 -0
- package/esm/helpers/sanitizer.d.ts +1 -0
- package/esm/helpers/sanitizer.js +5 -0
- package/esm/helpers/sanitizer.js.map +1 -0
- package/esm/helpers/statistics.d.ts +1 -12
- package/esm/helpers/statistics.js +0 -156
- package/esm/helpers/statistics.js.map +1 -1
- package/esm/helpers/stt/useSTT.d.ts +40 -0
- package/esm/helpers/stt/useSTT.js +523 -0
- package/esm/helpers/stt/useSTT.js.map +1 -0
- package/esm/helpers/translations.js +23 -4
- package/esm/helpers/translations.js.map +1 -1
- package/esm/helpers/tts/ttsVoiceUtility.d.ts +158 -0
- package/esm/helpers/tts/ttsVoiceUtility.js +182 -0
- package/esm/helpers/tts/ttsVoiceUtility.js.map +1 -0
- package/esm/helpers/tts/useTTS.d.ts +27 -0
- package/esm/helpers/tts/useTTS.js +293 -0
- package/esm/helpers/tts/useTTS.js.map +1 -0
- package/esm/helpers/utils.d.ts +40 -0
- package/esm/helpers/utils.js +143 -0
- package/esm/helpers/utils.js.map +1 -1
- package/esm/i18n.js +13 -1
- package/esm/i18n.js.map +1 -1
- package/esm/index.d.ts +14 -4
- package/esm/index.js +137 -85
- package/esm/index.js.map +1 -1
- package/esm/locales/de.json +593 -0
- package/esm/locales/en.json +250 -40
- package/esm/locales/es.json +593 -0
- package/esm/locales/fr.json +603 -0
- package/esm/locales/it.json +260 -48
- package/esm/styles.css +18 -2
- package/package.json +12 -13
- package/src/I18nWrapper.tsx +3 -60
- package/src/__snapshots__/index.test.tsx.snap +60 -0
- package/src/components/AccountForm/AccountForm.test.tsx +2 -1
- package/src/components/AccountForm/AccountForm.tsx +3 -5
- package/src/components/AgeVerificationModal/AgeVerificationModal.css +1 -1
- package/src/components/AgeVerificationModal/AgeVerificationModal.tsx +1 -1
- package/src/components/Avatar/Avatar.css +2 -2
- package/src/components/Avatar/Avatar.test.tsx +39 -20
- package/src/components/Avatar/Avatar.tsx +175 -145
- package/src/components/Avatar/AvatarView/AvatarComponent/Shadow/DynamicShadow.tsx +103 -0
- package/src/components/Avatar/AvatarView/AvatarComponent/avatarComponent.tsx +106 -0
- package/src/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/fullbodyAvatar.tsx +348 -0
- package/src/components/Avatar/AvatarView/AvatarComponent/components/FullbodyAvatar/types.ts +44 -0
- package/src/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarAnimator.ts +1250 -0
- package/src/components/Avatar/AvatarView/AvatarComponent/components/controllers/AvatarPositionController.ts +83 -0
- package/src/components/Avatar/AvatarView/AvatarComponent/components/controllers/MorphTargetController.ts +301 -0
- package/src/components/Avatar/AvatarView/AvatarComponent/components/controls.tsx +100 -0
- package/src/components/Avatar/AvatarView/AvatarComponent/components/halfbodyAvatar.tsx +152 -0
- package/src/components/{AvatarView → Avatar/AvatarView/AvatarComponent}/components/loader.tsx +1 -1
- package/src/components/Avatar/AvatarView/AvatarComponent/constants.ts +128 -0
- package/src/components/Avatar/AvatarView/AvatarComponent/lights/Lights.tsx +145 -0
- package/src/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.css +111 -0
- package/src/components/Avatar/AvatarView/AvatarComponent/positionControls/positionControls.tsx +201 -0
- package/src/components/{AvatarView → Avatar/AvatarView}/AvatarView.stories.tsx +41 -7
- package/src/components/Avatar/AvatarView/index.tsx +194 -0
- package/src/components/Avatar/AvatarView/utils/hideHands.ts +11 -0
- package/src/components/Avatar/AvatarView/utils/useEyeBlink.ts +100 -0
- package/src/components/Avatar/AvatarView/utils/useMouthAnimation.ts +93 -0
- package/src/components/Avatar/AvatarView/utils/useSmile.ts +39 -0
- package/src/components/Avatar/__snapshots__/Avatar.test.tsx.snap +32 -93
- package/src/components/BlockedMemoriBadge/__snapshots__/BlockedMemoriBadge.test.tsx.snap +10 -0
- package/src/components/Chat/Chat.stories.tsx +498 -2
- package/src/components/Chat/Chat.test.tsx +241 -301
- package/src/components/Chat/Chat.tsx +120 -58
- package/src/components/Chat/__snapshots__/Chat.test.tsx.snap +1756 -1222
- package/src/components/ChatBubble/ChatBubble.css +91 -14
- package/src/components/ChatBubble/ChatBubble.stories.tsx +759 -16
- package/src/components/ChatBubble/ChatBubble.test.tsx +217 -2
- package/src/components/ChatBubble/ChatBubble.tsx +242 -90
- package/src/components/ChatBubble/__snapshots__/ChatBubble.test.tsx.snap +7728 -254
- package/src/components/ChatHistoryDrawer/ChatHistory.css +414 -0
- package/src/components/ChatHistoryDrawer/ChatHistory.stories.tsx +361 -0
- package/src/components/ChatHistoryDrawer/ChatHistory.test.tsx +107 -0
- package/src/components/ChatHistoryDrawer/ChatHistory.tsx +1191 -0
- package/src/components/ChatHistoryDrawer/__snapshots__/ChatHistory.test.tsx.snap +27 -0
- package/src/components/ChatInputs/ChatInputs.stories.tsx +5 -0
- package/src/components/ChatInputs/ChatInputs.test.tsx +0 -6
- package/src/components/ChatInputs/ChatInputs.tsx +136 -25
- package/src/components/ChatInputs/__snapshots__/ChatInputs.test.tsx.snap +6 -138
- package/src/components/ChatTextArea/ChatTextArea.css +9 -5
- package/src/components/ChatTextArea/ChatTextArea.tsx +1 -0
- package/src/components/ChatTextArea/__snapshots__/ChatTextArea.test.tsx.snap +3 -0
- package/src/components/CompletionProviderStatus/CompletionProviderStatus.css +35 -17
- package/src/components/CompletionProviderStatus/CompletionProviderStatus.stories.tsx +275 -22
- package/src/components/CompletionProviderStatus/CompletionProviderStatus.test.tsx +6 -4
- package/src/components/CompletionProviderStatus/CompletionProviderStatus.tsx +192 -39
- package/src/components/CompletionProviderStatus/__snapshots__/CompletionProviderStatus.test.tsx.snap +83 -15
- package/src/components/ExpertsDrawer/ExpertsDrawer.tsx +4 -2
- package/src/components/FilePreview/FilePreview.css +184 -0
- package/src/components/FilePreview/FilePreview.stories.tsx +66 -0
- package/src/components/FilePreview/FilePreview.test.tsx +26 -0
- package/src/components/FilePreview/FilePreview.tsx +177 -0
- package/src/components/FilePreview/__snapshots__/FilePreview.test.tsx.snap +275 -0
- package/src/components/Header/Header.css +3 -3
- package/src/components/Header/Header.stories.tsx +21 -1
- package/src/components/Header/Header.test.tsx +38 -1
- package/src/components/Header/Header.tsx +56 -16
- package/src/components/Header/__snapshots__/Header.test.tsx.snap +127 -375
- package/src/components/KnownFacts/KnownFacts.stories.tsx +5 -4
- package/src/components/KnownFacts/KnownFacts.test.tsx +6 -3
- package/src/components/KnownFacts/KnownFacts.tsx +4 -5
- package/src/components/LoginDrawer/LoginDrawer.css +302 -0
- package/src/components/LoginDrawer/LoginDrawer.stories.tsx +27 -1
- package/src/components/LoginDrawer/LoginDrawer.test.tsx +65 -8
- package/src/components/LoginDrawer/LoginDrawer.tsx +12 -13
- package/src/components/LoginDrawer/__snapshots__/LoginDrawer.test.tsx.snap +32 -0
- package/src/components/MediaWidget/LinkItemWidget.css +10 -0
- package/src/components/MediaWidget/LinkItemWidget.tsx +6 -1
- package/src/components/MediaWidget/MediaItemWidget.css +153 -3
- package/src/components/MediaWidget/MediaItemWidget.stories.tsx +6 -0
- package/src/components/MediaWidget/MediaItemWidget.tsx +229 -161
- package/src/components/MediaWidget/MediaWidget.test.tsx +2 -1
- package/src/components/MediaWidget/MediaWidget.tsx +5 -2
- package/src/components/MediaWidget/__snapshots__/LinkItemWidget.test.tsx.snap +4 -4
- package/src/components/MediaWidget/__snapshots__/MediaItemWidget.test.tsx.snap +150 -249
- package/src/components/MediaWidget/__snapshots__/MediaWidget.test.tsx.snap +2 -2
- package/src/components/MemoriArtifactSystem/ArtifactDrawer.stories.tsx +755 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.css +163 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/ArtifactActions.tsx +250 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/CopyButton.stories.tsx +30 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyButtonWithDropdown.tsx +467 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/components/CopyMenuItem.tsx +86 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/hooks/useCopyArtifact.ts +619 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/index.ts +9 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/styles.css +489 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/test/CopyButtonTest.tsx +90 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/types.ts +73 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactActions/utils/PDFExporter.ts +454 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.css +1059 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactDrawer/ArtifactDrawer.tsx +428 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.css +150 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactDrawer/components/TabSwitch.tsx +79 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.css +253 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactHandler/ArtifactHandler.tsx +169 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.css +346 -0
- package/src/components/MemoriArtifactSystem/components/ArtifactPreview/ArtifactPreview.tsx +165 -0
- package/src/components/MemoriArtifactSystem/context/ArtifactContext.tsx +69 -0
- package/src/components/MemoriArtifactSystem/types/artifact.types.ts +16 -0
- package/src/components/MemoriWidget/MemoriWidget.css +10 -4
- package/src/components/MemoriWidget/MemoriWidget.stories.tsx +70 -11
- package/src/components/MemoriWidget/MemoriWidget.tsx +1344 -1349
- package/src/components/MicrophoneButton/MicrophoneButton.tsx +0 -1
- package/src/components/SendOnEnterMenu/SendOnEnterMenu.css +3 -3
- package/src/components/SettingsDrawer/SettingsDrawer.css +9 -2
- package/src/components/SettingsDrawer/SettingsDrawer.test.tsx +24 -0
- package/src/components/SettingsDrawer/SettingsDrawer.tsx +104 -14
- package/src/components/ShareButton/ShareButton.css +6 -0
- package/src/components/ShareButton/ShareButton.stories.tsx +18 -1
- package/src/components/ShareButton/ShareButton.test.tsx +8 -1
- package/src/components/ShareButton/ShareButton.tsx +49 -2
- package/src/components/ShareButton/__snapshots__/ShareButton.test.tsx.snap +35 -0
- package/src/components/SignupForm/SignupForm.test.tsx +3 -2
- package/src/components/SignupForm/SignupForm.tsx +8 -9
- package/src/components/Snippet/Snippet.stories.tsx +0 -8
- package/src/components/Snippet/Snippet.test.tsx +0 -1
- package/src/components/Snippet/Snippet.tsx +55 -36
- package/src/components/Snippet/__snapshots__/Snippet.test.tsx.snap +186 -2560
- package/src/components/StartPanel/StartPanel.css +34 -8
- package/src/components/StartPanel/StartPanel.stories.tsx +58 -23
- package/src/components/StartPanel/StartPanel.test.tsx +50 -17
- package/src/components/StartPanel/StartPanel.tsx +218 -152
- package/src/components/StartPanel/__snapshots__/StartPanel.test.tsx.snap +1340 -171
- package/src/components/Typing/Typing.tsx +52 -47
- package/src/components/UploadButton/UploadButton.css +544 -0
- package/src/components/UploadButton/UploadButton.stories.tsx +164 -0
- package/src/components/UploadButton/UploadButton.test.tsx +11 -0
- package/src/components/UploadButton/UploadButton.tsx +490 -0
- package/src/components/UploadButton/UploadDocuments/UploadDocuments.tsx +422 -0
- package/src/components/UploadButton/UploadImages/UploadImages.tsx +362 -0
- package/src/components/UploadButton/__snapshots__/UploadButton.test.tsx.snap +156 -0
- package/src/components/UploadMenu/UploadMenu.css +3 -3
- package/src/components/VenueWidget/VenueWidget.css +7 -0
- package/src/components/VenueWidget/VenueWidget.tsx +4 -4
- package/src/components/WhyThisAnswer/WhyThisAnswer.css +43 -0
- package/src/components/WhyThisAnswer/WhyThisAnswer.stories.tsx +46 -4
- package/src/components/WhyThisAnswer/WhyThisAnswer.test.tsx +132 -11
- package/src/components/WhyThisAnswer/WhyThisAnswer.tsx +36 -10
- package/src/components/WhyThisAnswer/__snapshots__/WhyThisAnswer.test.tsx.snap +15 -1
- package/src/components/icons/Alert.tsx +31 -0
- package/src/components/icons/ArrowUp.tsx +28 -0
- package/src/components/icons/Bug.tsx +81 -0
- package/src/components/icons/Chat.tsx +30 -0
- package/src/components/icons/ChevronDown.tsx +26 -0
- package/src/components/icons/ChevronUp.tsx +24 -0
- package/src/components/icons/Close.tsx +8 -1
- package/src/components/icons/Code.tsx +24 -0
- package/src/components/icons/Copy.tsx +8 -2
- package/src/components/icons/Document.tsx +50 -0
- package/src/components/icons/History.tsx +33 -0
- package/src/components/icons/Image.tsx +37 -0
- package/src/components/icons/Info.tsx +31 -0
- package/src/components/icons/MenuHorizontal.tsx +29 -0
- package/src/components/icons/MenuVertical.tsx +29 -0
- package/src/components/icons/Preview.tsx +29 -0
- package/src/components/icons/Print.tsx +34 -0
- package/src/components/icons/Upload.tsx +34 -0
- package/src/components/icons/Warning.tsx +2 -1
- package/src/components/icons/icons.stories.tsx +14 -6
- package/src/components/layouts/Chat.test.tsx +18 -10
- package/src/components/layouts/Chat.tsx +51 -31
- package/src/components/layouts/FullPage.test.tsx +42 -9
- package/src/components/layouts/FullPage.tsx +55 -30
- package/src/components/layouts/HiddenChat.test.tsx +40 -0
- package/src/components/layouts/HiddenChat.tsx +252 -0
- package/src/components/layouts/Totem.test.tsx +18 -10
- package/src/components/layouts/Totem.tsx +1 -7
- package/src/components/layouts/WebsiteAssistant.test.tsx +18 -10
- package/src/components/layouts/WebsiteAssistant.tsx +0 -7
- package/src/components/layouts/ZoomedFullBody.test.tsx +40 -0
- package/src/components/layouts/ZoomedFullBody.tsx +81 -0
- package/src/components/layouts/__snapshots__/Chat.test.tsx.snap +287 -197
- package/src/components/layouts/__snapshots__/FullPage.test.tsx.snap +827 -201
- package/src/components/layouts/__snapshots__/HiddenChat.test.tsx.snap +470 -0
- package/src/components/layouts/__snapshots__/Totem.test.tsx.snap +122 -36
- package/src/components/layouts/__snapshots__/WebsiteAssistant.test.tsx.snap +1 -1
- package/src/components/layouts/__snapshots__/ZoomedFullBody.test.tsx.snap +533 -0
- package/src/components/layouts/chat.css +358 -19
- package/src/components/layouts/hidden-chat.css +254 -0
- package/src/components/layouts/layouts.stories.tsx +257 -57
- package/src/components/layouts/totem.css +19 -10
- package/src/components/layouts/website-assistant.css +2 -2
- package/src/components/layouts/zoomed-full-body.css +18 -0
- package/src/components/ui/Alert.css +93 -0
- package/src/components/ui/Alert.stories.tsx +137 -0
- package/src/components/ui/Alert.test.tsx +129 -0
- package/src/components/ui/Alert.tsx +123 -0
- package/src/components/ui/Button.css +8 -2
- package/src/components/ui/Button.tsx +3 -0
- package/src/components/ui/Card.css +5 -0
- package/src/components/ui/Card.tsx +4 -0
- package/src/components/ui/ConfirmDialog.css +42 -0
- package/src/components/ui/ConfirmDialog.stories.tsx +216 -0
- package/src/components/ui/ConfirmDialog.test.tsx +124 -0
- package/src/components/ui/ConfirmDialog.tsx +58 -0
- package/src/components/ui/Drawer.css +121 -96
- package/src/components/ui/Drawer.stories.tsx +152 -67
- package/src/components/ui/Drawer.test.tsx +6 -2
- package/src/components/ui/Drawer.tsx +202 -90
- package/src/components/ui/Expandable.stories.tsx +128 -1
- package/src/components/ui/Expandable.tsx +44 -22
- package/src/components/ui/Slider.css +192 -0
- package/src/components/ui/Slider.stories.tsx +63 -0
- package/src/components/ui/Slider.tsx +142 -0
- package/src/components/ui/Table.css +15 -2
- package/src/components/ui/__snapshots__/Alert.test.tsx.snap +59 -0
- package/src/components/ui/__snapshots__/ConfirmDialog.test.tsx.snap +35 -0
- package/src/context/visemeContext.tsx +391 -0
- package/src/helpers/configuration.ts +0 -1
- package/src/helpers/constants.ts +10 -0
- package/src/helpers/error.ts +58 -6
- package/src/helpers/markedExtendedTables.js +1 -1
- package/src/helpers/message.ts +148 -0
- package/src/helpers/sanitizer.ts +17 -0
- package/src/helpers/statistics.ts +1 -195
- package/src/helpers/stt/useSTT.ts +774 -0
- package/src/helpers/translations.ts +29 -7
- package/src/helpers/tts/ttsVoiceUtility.ts +275 -0
- package/src/helpers/tts/useTTS.ts +464 -0
- package/src/helpers/utils.test.ts +38 -1
- package/src/helpers/utils.ts +200 -0
- package/src/i18n.ts +13 -1
- package/src/index.stories.tsx +266 -23
- package/src/index.test.tsx +130 -0
- package/src/index.tsx +245 -153
- package/src/locales/de.json +621 -0
- package/src/locales/en.json +251 -40
- package/src/locales/es.json +593 -0
- package/src/locales/fr.json +603 -0
- package/src/locales/it.json +262 -48
- package/src/mocks/data.ts +272 -9
- package/src/styles.css +18 -2
- package/dist/components/AttachmentMediaModal/AttachmentMediaModal.d.ts +0 -14
- package/dist/components/AttachmentMediaModal/AttachmentMediaModal.js +0 -66
- package/dist/components/AttachmentMediaModal/AttachmentMediaModal.js.map +0 -1
- package/dist/components/AvatarView/components/avatar.d.ts +0 -9
- package/dist/components/AvatarView/components/avatar.js +0 -35
- package/dist/components/AvatarView/components/avatar.js.map +0 -1
- package/dist/components/AvatarView/components/fullbodyAvatar.d.ts +0 -10
- package/dist/components/AvatarView/components/fullbodyAvatar.js +0 -62
- package/dist/components/AvatarView/components/fullbodyAvatar.js.map +0 -1
- package/dist/components/AvatarView/components/loader.js.map +0 -1
- package/dist/components/AvatarView/index.d.ts +0 -17
- package/dist/components/AvatarView/index.js +0 -35
- package/dist/components/AvatarView/index.js.map +0 -1
- package/dist/components/AvatarView/utils/useEyeBlink.d.ts +0 -2
- package/dist/components/AvatarView/utils/useEyeBlink.js +0 -40
- package/dist/components/AvatarView/utils/useEyeBlink.js.map +0 -1
- package/dist/components/AvatarView/utils/useHeadMovement.js.map +0 -1
- package/dist/components/AvatarView/utils/useLoadingMorphAnim.js.map +0 -1
- package/dist/components/AvatarView/utils/useMouthSpeaking.d.ts +0 -2
- package/dist/components/AvatarView/utils/useMouthSpeaking.js +0 -60
- package/dist/components/AvatarView/utils/useMouthSpeaking.js.map +0 -1
- package/dist/components/AvatarView/utils/useSmile.js +0 -30
- package/dist/components/AvatarView/utils/useSmile.js.map +0 -1
- package/dist/components/AvatarView/utils/utils.js.map +0 -1
- package/dist/components/ExportHistoryButton/ExportHistoryButton.d.ts +0 -14
- package/dist/components/ExportHistoryButton/ExportHistoryButton.js +0 -38
- package/dist/components/ExportHistoryButton/ExportHistoryButton.js.map +0 -1
- package/dist/components/ImageUpload/ImageUpload.css +0 -168
- package/dist/components/ImageUpload/ImageUpload.d.ts +0 -28
- package/dist/components/ImageUpload/ImageUpload.js +0 -163
- package/dist/components/ImageUpload/ImageUpload.js.map +0 -1
- package/dist/components/layouts/Default.d.ts +0 -17
- package/dist/components/layouts/Default.js +0 -8
- package/dist/components/layouts/Default.js.map +0 -1
- package/dist/components/ui/Message.d.ts +0 -17
- package/dist/components/ui/Message.js +0 -13
- package/dist/components/ui/Message.js.map +0 -1
- package/dist/helpers/tenant.d.ts +0 -2
- package/dist/helpers/tenant.js +0 -40
- package/dist/helpers/tenant.js.map +0 -1
- package/esm/components/AttachmentMediaModal/AttachmentMediaModal.d.ts +0 -14
- package/esm/components/AttachmentMediaModal/AttachmentMediaModal.js +0 -63
- package/esm/components/AttachmentMediaModal/AttachmentMediaModal.js.map +0 -1
- package/esm/components/AvatarView/components/avatar.d.ts +0 -9
- package/esm/components/AvatarView/components/avatar.js +0 -31
- package/esm/components/AvatarView/components/avatar.js.map +0 -1
- package/esm/components/AvatarView/components/fullbodyAvatar.d.ts +0 -10
- package/esm/components/AvatarView/components/fullbodyAvatar.js +0 -58
- package/esm/components/AvatarView/components/fullbodyAvatar.js.map +0 -1
- package/esm/components/AvatarView/components/loader.js.map +0 -1
- package/esm/components/AvatarView/index.d.ts +0 -17
- package/esm/components/AvatarView/index.js +0 -31
- package/esm/components/AvatarView/index.js.map +0 -1
- package/esm/components/AvatarView/utils/useEyeBlink.d.ts +0 -2
- package/esm/components/AvatarView/utils/useEyeBlink.js +0 -37
- package/esm/components/AvatarView/utils/useEyeBlink.js.map +0 -1
- package/esm/components/AvatarView/utils/useHeadMovement.js.map +0 -1
- package/esm/components/AvatarView/utils/useLoadingMorphAnim.js.map +0 -1
- package/esm/components/AvatarView/utils/useMouthSpeaking.d.ts +0 -2
- package/esm/components/AvatarView/utils/useMouthSpeaking.js +0 -57
- package/esm/components/AvatarView/utils/useMouthSpeaking.js.map +0 -1
- package/esm/components/AvatarView/utils/useSmile.js +0 -27
- package/esm/components/AvatarView/utils/useSmile.js.map +0 -1
- package/esm/components/AvatarView/utils/utils.js.map +0 -1
- package/esm/components/ExportHistoryButton/ExportHistoryButton.d.ts +0 -14
- package/esm/components/ExportHistoryButton/ExportHistoryButton.js +0 -35
- package/esm/components/ExportHistoryButton/ExportHistoryButton.js.map +0 -1
- package/esm/components/ImageUpload/ImageUpload.css +0 -168
- package/esm/components/ImageUpload/ImageUpload.d.ts +0 -28
- package/esm/components/ImageUpload/ImageUpload.js +0 -160
- package/esm/components/ImageUpload/ImageUpload.js.map +0 -1
- package/esm/components/layouts/Default.d.ts +0 -17
- package/esm/components/layouts/Default.js +0 -5
- package/esm/components/layouts/Default.js.map +0 -1
- package/esm/components/ui/Message.d.ts +0 -17
- package/esm/components/ui/Message.js +0 -10
- package/esm/components/ui/Message.js.map +0 -1
- package/esm/helpers/tenant.d.ts +0 -2
- package/esm/helpers/tenant.js +0 -36
- package/esm/helpers/tenant.js.map +0 -1
- package/src/components/AvatarView/components/avatar.tsx +0 -57
- package/src/components/AvatarView/components/fullbodyAvatar.tsx +0 -99
- package/src/components/AvatarView/index.tsx +0 -101
- package/src/components/AvatarView/utils/useEyeBlink.ts +0 -48
- package/src/components/AvatarView/utils/useMouthSpeaking.ts +0 -70
- package/src/components/AvatarView/utils/useSmile.ts +0 -31
- package/src/components/ExportHistoryButton/ExportHistoryButton.stories.tsx +0 -73
- package/src/components/ExportHistoryButton/ExportHistoryButton.test.tsx +0 -69
- package/src/components/ExportHistoryButton/ExportHistoryButton.tsx +0 -103
- package/src/components/ExportHistoryButton/__snapshots__/ExportHistoryButton.test.tsx.snap +0 -239
- package/src/helpers/statistics.test.ts +0 -213
- package/src/helpers/tenant.ts +0 -47
- /package/dist/components/{AvatarView → Avatar/AvatarView}/utils/useHeadMovement.d.ts +0 -0
- /package/dist/components/{AvatarView → Avatar/AvatarView}/utils/useHeadMovement.js +0 -0
- /package/dist/components/{AvatarView → Avatar/AvatarView}/utils/useLoadingMorphAnim.d.ts +0 -0
- /package/dist/components/{AvatarView → Avatar/AvatarView}/utils/useLoadingMorphAnim.js +0 -0
- /package/dist/components/{AvatarView → Avatar/AvatarView}/utils/useSmile.d.ts +0 -0
- /package/dist/components/{AvatarView → Avatar/AvatarView}/utils/utils.d.ts +0 -0
- /package/dist/components/{AvatarView → Avatar/AvatarView}/utils/utils.js +0 -0
- /package/esm/components/{AvatarView → Avatar/AvatarView}/utils/useHeadMovement.d.ts +0 -0
- /package/esm/components/{AvatarView → Avatar/AvatarView}/utils/useHeadMovement.js +0 -0
- /package/esm/components/{AvatarView → Avatar/AvatarView}/utils/useLoadingMorphAnim.d.ts +0 -0
- /package/esm/components/{AvatarView → Avatar/AvatarView}/utils/useLoadingMorphAnim.js +0 -0
- /package/esm/components/{AvatarView → Avatar/AvatarView}/utils/useSmile.d.ts +0 -0
- /package/esm/components/{AvatarView → Avatar/AvatarView}/utils/utils.d.ts +0 -0
- /package/esm/components/{AvatarView → Avatar/AvatarView}/utils/utils.js +0 -0
- /package/src/components/{AvatarView → Avatar/AvatarView}/utils/useHeadMovement.ts +0 -0
- /package/src/components/{AvatarView → Avatar/AvatarView}/utils/useLoadingMorphAnim.ts +0 -0
- /package/src/components/{AvatarView → Avatar/AvatarView}/utils/utils.ts +0 -0
|
@@ -0,0 +1,774 @@
|
|
|
1
|
+
// hooks/useSTT.ts - Modified version for Azure WAV support
|
|
2
|
+
// Audio format compatibility:
|
|
3
|
+
// - MediaRecorder supports: webm, mp4, ogg formats
|
|
4
|
+
// - Azure STT supported formats:
|
|
5
|
+
// * WAV format (required for Azure Speech SDK)
|
|
6
|
+
// * webm-16khz-16bit-mono-opus (for REST API)
|
|
7
|
+
// * webm-24khz-16bit-24kbps-mono-opus
|
|
8
|
+
// * webm-24khz-16bit-mono-opus
|
|
9
|
+
// - OpenAI: Supports multiple formats including webm, mp4, ogg
|
|
10
|
+
import { useState, useCallback, useRef, useEffect } from 'react';
|
|
11
|
+
import { getLocalConfig } from '../configuration';
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Configuration for STT
|
|
15
|
+
*/
|
|
16
|
+
export interface STTConfig {
|
|
17
|
+
provider: 'azure' | 'openai';
|
|
18
|
+
language?: string;
|
|
19
|
+
model?: string;
|
|
20
|
+
region?: string; // required for Azure
|
|
21
|
+
tenant?: string; // Tenant identifier for multi-tenant applications
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* Result from STT transcription
|
|
26
|
+
*/
|
|
27
|
+
export interface STTResult {
|
|
28
|
+
text: string;
|
|
29
|
+
confidence?: number;
|
|
30
|
+
language?: string;
|
|
31
|
+
duration?: number;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Options for the useSTT hook
|
|
36
|
+
*/
|
|
37
|
+
export interface UseSTTOptions {
|
|
38
|
+
apiUrl?: string;
|
|
39
|
+
onTranscriptionComplete?: (result: STTResult) => void;
|
|
40
|
+
onError?: (error: Error) => void;
|
|
41
|
+
continuousRecording?: boolean;
|
|
42
|
+
autoStart?: boolean;
|
|
43
|
+
processSpeechAndSendMessage?: (text: string) => void;
|
|
44
|
+
silenceTimeout?: number; // Timeout in milliseconds for silence detection
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* Recording states
|
|
49
|
+
*/
|
|
50
|
+
export type RecordingState = 'idle' | 'recording' | 'processing' | 'error';
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* Convert audio blob to WAV format
|
|
54
|
+
*/
|
|
55
|
+
async function convertToWav(audioBlob: Blob): Promise<Blob> {
|
|
56
|
+
return new Promise((resolve, reject) => {
|
|
57
|
+
// Safari compatibility: check for AudioContext support
|
|
58
|
+
const AudioContextClass = window.AudioContext || (window as any).webkitAudioContext;
|
|
59
|
+
if (!AudioContextClass) {
|
|
60
|
+
reject(new Error('AudioContext not supported in this browser'));
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
const audioContext = new AudioContextClass();
|
|
65
|
+
const fileReader = new FileReader();
|
|
66
|
+
|
|
67
|
+
fileReader.onload = async () => {
|
|
68
|
+
try {
|
|
69
|
+
const arrayBuffer = fileReader.result as ArrayBuffer;
|
|
70
|
+
|
|
71
|
+
// Resume context if suspended (required for Safari)
|
|
72
|
+
if (audioContext.state === 'suspended') {
|
|
73
|
+
await audioContext.resume();
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
const audioBuffer = await audioContext.decodeAudioData(arrayBuffer);
|
|
77
|
+
|
|
78
|
+
// Convert to WAV format
|
|
79
|
+
const wavBlob = audioBufferToWav(audioBuffer);
|
|
80
|
+
|
|
81
|
+
// Close the audio context to free resources
|
|
82
|
+
await audioContext.close();
|
|
83
|
+
|
|
84
|
+
resolve(wavBlob);
|
|
85
|
+
} catch (error) {
|
|
86
|
+
console.error('Error converting audio to WAV:', error);
|
|
87
|
+
reject(error);
|
|
88
|
+
}
|
|
89
|
+
};
|
|
90
|
+
|
|
91
|
+
fileReader.onerror = () => {
|
|
92
|
+
console.error('Failed to read audio file');
|
|
93
|
+
reject(new Error('Failed to read audio file'));
|
|
94
|
+
};
|
|
95
|
+
|
|
96
|
+
fileReader.readAsArrayBuffer(audioBlob);
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
/**
|
|
101
|
+
* Convert AudioBuffer to WAV Blob
|
|
102
|
+
*/
|
|
103
|
+
function audioBufferToWav(buffer: AudioBuffer): Blob {
|
|
104
|
+
const length = buffer.length;
|
|
105
|
+
const sampleRate = buffer.sampleRate;
|
|
106
|
+
const numberOfChannels = buffer.numberOfChannels;
|
|
107
|
+
const arrayBuffer = new ArrayBuffer(44 + length * numberOfChannels * 2);
|
|
108
|
+
const view = new DataView(arrayBuffer);
|
|
109
|
+
|
|
110
|
+
// WAV header
|
|
111
|
+
const writeString = (offset: number, string: string) => {
|
|
112
|
+
for (let i = 0; i < string.length; i++) {
|
|
113
|
+
view.setUint8(offset + i, string.charCodeAt(i));
|
|
114
|
+
}
|
|
115
|
+
};
|
|
116
|
+
|
|
117
|
+
writeString(0, 'RIFF');
|
|
118
|
+
view.setUint32(4, 36 + length * numberOfChannels * 2, true);
|
|
119
|
+
writeString(8, 'WAVE');
|
|
120
|
+
writeString(12, 'fmt ');
|
|
121
|
+
view.setUint32(16, 16, true);
|
|
122
|
+
view.setUint16(20, 1, true);
|
|
123
|
+
view.setUint16(22, numberOfChannels, true);
|
|
124
|
+
view.setUint32(24, sampleRate, true);
|
|
125
|
+
view.setUint32(28, sampleRate * numberOfChannels * 2, true);
|
|
126
|
+
view.setUint16(32, numberOfChannels * 2, true);
|
|
127
|
+
view.setUint16(34, 16, true);
|
|
128
|
+
writeString(36, 'data');
|
|
129
|
+
view.setUint32(40, length * numberOfChannels * 2, true);
|
|
130
|
+
|
|
131
|
+
// Convert audio data
|
|
132
|
+
let offset = 44;
|
|
133
|
+
for (let i = 0; i < length; i++) {
|
|
134
|
+
for (let channel = 0; channel < numberOfChannels; channel++) {
|
|
135
|
+
const sample = Math.max(-1, Math.min(1, buffer.getChannelData(channel)[i]));
|
|
136
|
+
view.setInt16(offset, sample < 0 ? sample * 0x8000 : sample * 0x7FFF, true);
|
|
137
|
+
offset += 2;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
return new Blob([arrayBuffer], { type: 'audio/wav' });
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
/**
|
|
145
|
+
* Unified hook for handling Speech-to-Text functionality
|
|
146
|
+
*/
|
|
147
|
+
export function useSTT(
|
|
148
|
+
config: STTConfig,
|
|
149
|
+
processSpeechAndSendMessage: (text: string) => void,
|
|
150
|
+
options: UseSTTOptions = {},
|
|
151
|
+
defaultEnableAudio: boolean = true
|
|
152
|
+
) {
|
|
153
|
+
// Local state
|
|
154
|
+
const [recordingState, setRecordingState] = useState<RecordingState>('idle');
|
|
155
|
+
const [microphoneMuted, setMicrophoneMuted] = useState(
|
|
156
|
+
getLocalConfig('muteMicrophone', !defaultEnableAudio)
|
|
157
|
+
);
|
|
158
|
+
const [hasUserActivatedRecord, setHasUserActivatedRecord] = useState(false);
|
|
159
|
+
const [error, setError] = useState<Error | null>(null);
|
|
160
|
+
const [lastTranscription, setLastTranscription] = useState<STTResult | null>(
|
|
161
|
+
null
|
|
162
|
+
);
|
|
163
|
+
const [isListening, setIsListening] = useState(false);
|
|
164
|
+
|
|
165
|
+
// References
|
|
166
|
+
const mediaRecorderRef = useRef<MediaRecorder | null>(null);
|
|
167
|
+
const audioStreamRef = useRef<MediaStream | null>(null);
|
|
168
|
+
const chunksRef = useRef<Blob[]>([]);
|
|
169
|
+
const isRecordingRef = useRef<boolean>(false);
|
|
170
|
+
const isMountedRef = useRef<boolean>(true);
|
|
171
|
+
const silenceTimeoutRef = useRef<NodeJS.Timeout | null>(null);
|
|
172
|
+
const audioContextRef = useRef<AudioContext | null>(null);
|
|
173
|
+
const analyserRef = useRef<AnalyserNode | null>(null);
|
|
174
|
+
const dataArrayRef = useRef<Uint8Array | null>(null);
|
|
175
|
+
const backgroundNoiseRef = useRef<number>(0);
|
|
176
|
+
const audioActivityHistoryRef = useRef<number[]>([]);
|
|
177
|
+
const lastStopTimeRef = useRef<number>(0); // Track when recording was last stopped
|
|
178
|
+
const apiUrl = options.apiUrl || '/api/stt';
|
|
179
|
+
const silenceTimeout = options.silenceTimeout || 3; // Increased default to 3 seconds
|
|
180
|
+
|
|
181
|
+
const initializeRecording = useCallback(async (): Promise<boolean> => {
|
|
182
|
+
try {
|
|
183
|
+
|
|
184
|
+
if (!navigator.mediaDevices || !navigator.mediaDevices.getUserMedia) {
|
|
185
|
+
throw new Error('Media recording is not supported in this browser');
|
|
186
|
+
}
|
|
187
|
+
|
|
188
|
+
const stream = await navigator.mediaDevices.getUserMedia({
|
|
189
|
+
audio: {
|
|
190
|
+
echoCancellation: true,
|
|
191
|
+
noiseSuppression: true,
|
|
192
|
+
autoGainControl: true,
|
|
193
|
+
sampleRate: 16000, // Optimal for speech recognition
|
|
194
|
+
},
|
|
195
|
+
});
|
|
196
|
+
|
|
197
|
+
audioStreamRef.current = stream;
|
|
198
|
+
|
|
199
|
+
// Initialize audio context for silence detection only if continuous recording is enabled
|
|
200
|
+
if (options.continuousRecording) {
|
|
201
|
+
try {
|
|
202
|
+
// Safari compatibility: check for AudioContext support
|
|
203
|
+
const AudioContextClass = window.AudioContext || (window as any).webkitAudioContext;
|
|
204
|
+
if (AudioContextClass) {
|
|
205
|
+
audioContextRef.current = new AudioContextClass({
|
|
206
|
+
sampleRate: 16000, // Match the audio input sample rate
|
|
207
|
+
latencyHint: 'interactive' // Better for real-time analysis
|
|
208
|
+
});
|
|
209
|
+
|
|
210
|
+
|
|
211
|
+
// Resume context if suspended (required for Safari)
|
|
212
|
+
if (audioContextRef.current.state === 'suspended') {
|
|
213
|
+
await audioContextRef.current.resume();
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
// Wait a bit for Safari to stabilize the AudioContext
|
|
217
|
+
await new Promise(resolve => setTimeout(resolve, 100));
|
|
218
|
+
|
|
219
|
+
analyserRef.current = audioContextRef.current.createAnalyser();
|
|
220
|
+
analyserRef.current.fftSize = 512; // Increased for better frequency resolution
|
|
221
|
+
analyserRef.current.smoothingTimeConstant = 0.3; // Reduced for more responsive detection
|
|
222
|
+
analyserRef.current.minDecibels = -90;
|
|
223
|
+
analyserRef.current.maxDecibels = -10;
|
|
224
|
+
|
|
225
|
+
const bufferLength = analyserRef.current.frequencyBinCount;
|
|
226
|
+
dataArrayRef.current = new Uint8Array(bufferLength);
|
|
227
|
+
|
|
228
|
+
const source = audioContextRef.current.createMediaStreamSource(stream);
|
|
229
|
+
source.connect(analyserRef.current);
|
|
230
|
+
|
|
231
|
+
// Initialize audio analysis state
|
|
232
|
+
backgroundNoiseRef.current = 0;
|
|
233
|
+
audioActivityHistoryRef.current = [];
|
|
234
|
+
|
|
235
|
+
} else {
|
|
236
|
+
console.warn('🎤 [INIT] AudioContext not supported in this browser');
|
|
237
|
+
}
|
|
238
|
+
} catch (err) {
|
|
239
|
+
// Silence detection initialization failed but we can continue
|
|
240
|
+
console.error('🎤 [INIT] Silence detection initialization failed:', err);
|
|
241
|
+
}
|
|
242
|
+
} else {
|
|
243
|
+
console.log('🎤 [INIT] Continuous recording disabled, skipping silence detection setup');
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
// Format selection based on provider with Safari compatibility
|
|
247
|
+
let mimeType = '';
|
|
248
|
+
|
|
249
|
+
// Safari compatibility: prefer formats that work well on Safari
|
|
250
|
+
const supportedFormats = [
|
|
251
|
+
'audio/mp4', // Best Safari support
|
|
252
|
+
'audio/webm;codecs=opus',
|
|
253
|
+
'audio/webm',
|
|
254
|
+
'audio/ogg;codecs=opus',
|
|
255
|
+
'audio/wav' // Fallback
|
|
256
|
+
];
|
|
257
|
+
|
|
258
|
+
for (const format of supportedFormats) {
|
|
259
|
+
if (MediaRecorder.isTypeSupported(format)) {
|
|
260
|
+
mimeType = format;
|
|
261
|
+
break;
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
|
|
266
|
+
const mediaRecorder = new MediaRecorder(
|
|
267
|
+
stream,
|
|
268
|
+
mimeType ? { mimeType } : {}
|
|
269
|
+
);
|
|
270
|
+
|
|
271
|
+
mediaRecorder.ondataavailable = (event: BlobEvent) => {
|
|
272
|
+
if (event.data.size > 0) {
|
|
273
|
+
chunksRef.current.push(event.data);
|
|
274
|
+
}
|
|
275
|
+
};
|
|
276
|
+
|
|
277
|
+
mediaRecorder.onstop = async () => {
|
|
278
|
+
|
|
279
|
+
// Immediately set processing state to prevent ghost messages
|
|
280
|
+
setRecordingState('processing');
|
|
281
|
+
setIsListening(false);
|
|
282
|
+
|
|
283
|
+
try {
|
|
284
|
+
if (chunksRef.current.length === 0) {
|
|
285
|
+
throw new Error('No audio data recorded');
|
|
286
|
+
}
|
|
287
|
+
|
|
288
|
+
let audioBlob = new Blob(chunksRef.current, {
|
|
289
|
+
type: mediaRecorder.mimeType,
|
|
290
|
+
});
|
|
291
|
+
|
|
292
|
+
if (audioBlob.size === 0) {
|
|
293
|
+
throw new Error('Recorded audio is empty');
|
|
294
|
+
}
|
|
295
|
+
|
|
296
|
+
|
|
297
|
+
// Convert to WAV if using Azure
|
|
298
|
+
if (config.provider === 'azure') {
|
|
299
|
+
try {
|
|
300
|
+
audioBlob = await convertToWav(audioBlob);
|
|
301
|
+
} catch (conversionError) {
|
|
302
|
+
throw new Error('Failed to convert audio to WAV format for Azure');
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
|
|
306
|
+
const result = await transcribeAudio(audioBlob);
|
|
307
|
+
|
|
308
|
+
// Only process if we have meaningful text
|
|
309
|
+
if (result.text && result.text.trim().length > 0) {
|
|
310
|
+
if (processSpeechAndSendMessage) {
|
|
311
|
+
processSpeechAndSendMessage(result.text);
|
|
312
|
+
}
|
|
313
|
+
|
|
314
|
+
setLastTranscription(result);
|
|
315
|
+
|
|
316
|
+
if (options.onTranscriptionComplete) {
|
|
317
|
+
options.onTranscriptionComplete(result);
|
|
318
|
+
}
|
|
319
|
+
} else {
|
|
320
|
+
console.log('No meaningful text transcribed, skipping message processing');
|
|
321
|
+
}
|
|
322
|
+
|
|
323
|
+
setRecordingState('idle');
|
|
324
|
+
} catch (err) {
|
|
325
|
+
const errorMsg = err instanceof Error ? err : new Error(String(err));
|
|
326
|
+
setError(errorMsg);
|
|
327
|
+
setRecordingState('error');
|
|
328
|
+
|
|
329
|
+
if (options.onError) {
|
|
330
|
+
options.onError(errorMsg);
|
|
331
|
+
}
|
|
332
|
+
} finally {
|
|
333
|
+
chunksRef.current = [];
|
|
334
|
+
isRecordingRef.current = false;
|
|
335
|
+
}
|
|
336
|
+
};
|
|
337
|
+
|
|
338
|
+
mediaRecorder.onerror = () => {
|
|
339
|
+
const errorMsg = new Error('Recording failed');
|
|
340
|
+
setError(errorMsg);
|
|
341
|
+
setRecordingState('error');
|
|
342
|
+
isRecordingRef.current = false;
|
|
343
|
+
|
|
344
|
+
if (options.onError) {
|
|
345
|
+
options.onError(errorMsg);
|
|
346
|
+
}
|
|
347
|
+
};
|
|
348
|
+
|
|
349
|
+
mediaRecorderRef.current = mediaRecorder;
|
|
350
|
+
return true;
|
|
351
|
+
} catch (err) {
|
|
352
|
+
const errorMsg =
|
|
353
|
+
err instanceof Error ? err : new Error('Failed to access microphone');
|
|
354
|
+
setError(errorMsg);
|
|
355
|
+
setRecordingState('error');
|
|
356
|
+
|
|
357
|
+
if (options.onError) {
|
|
358
|
+
options.onError(errorMsg);
|
|
359
|
+
}
|
|
360
|
+
|
|
361
|
+
return false;
|
|
362
|
+
}
|
|
363
|
+
}, [config.provider, options, silenceTimeout]);
|
|
364
|
+
|
|
365
|
+
/**
|
|
366
|
+
* Detect if there's audio activity (not silence)
|
|
367
|
+
* Only works when continuous recording is enabled
|
|
368
|
+
*/
|
|
369
|
+
const detectAudioActivity = useCallback((): boolean => {
|
|
370
|
+
if (!options.continuousRecording) {
|
|
371
|
+
return false;
|
|
372
|
+
}
|
|
373
|
+
|
|
374
|
+
if (!analyserRef.current || !dataArrayRef.current) {
|
|
375
|
+
return false;
|
|
376
|
+
}
|
|
377
|
+
|
|
378
|
+
try {
|
|
379
|
+
analyserRef.current.getByteFrequencyData(dataArrayRef.current);
|
|
380
|
+
|
|
381
|
+
// Calculate simple average volume
|
|
382
|
+
let sum = 0;
|
|
383
|
+
for (let i = 0; i < dataArrayRef.current.length; i++) {
|
|
384
|
+
sum += dataArrayRef.current[i];
|
|
385
|
+
}
|
|
386
|
+
const averageVolume = sum / dataArrayRef.current.length;
|
|
387
|
+
|
|
388
|
+
// Simple threshold - if volume is above 20, consider it activity
|
|
389
|
+
const hasActivity = averageVolume > 20;
|
|
390
|
+
|
|
391
|
+
|
|
392
|
+
return hasActivity;
|
|
393
|
+
} catch (error) {
|
|
394
|
+
return false;
|
|
395
|
+
}
|
|
396
|
+
}, [options.continuousRecording]);
|
|
397
|
+
|
|
398
|
+
/**
|
|
399
|
+
* Start silence detection monitoring
|
|
400
|
+
* Only works when continuous recording is enabled
|
|
401
|
+
*/
|
|
402
|
+
const startSilenceDetection = useCallback(() => {
|
|
403
|
+
if (!options.continuousRecording || !analyserRef.current) {
|
|
404
|
+
return;
|
|
405
|
+
}
|
|
406
|
+
|
|
407
|
+
let silenceCount = 0;
|
|
408
|
+
const maxSilenceCount = 30; // 3 seconds of silence (30 * 100ms)
|
|
409
|
+
|
|
410
|
+
const checkAudioActivity = () => {
|
|
411
|
+
if (!isRecordingRef.current || !isMountedRef.current) {
|
|
412
|
+
return;
|
|
413
|
+
}
|
|
414
|
+
|
|
415
|
+
const hasActivity = detectAudioActivity();
|
|
416
|
+
|
|
417
|
+
if (hasActivity) {
|
|
418
|
+
// Reset silence counter when activity is detected
|
|
419
|
+
silenceCount = 0;
|
|
420
|
+
} else {
|
|
421
|
+
// Increment silence counter
|
|
422
|
+
silenceCount++;
|
|
423
|
+
|
|
424
|
+
// Stop recording after 3 seconds of silence
|
|
425
|
+
if (silenceCount >= maxSilenceCount) {
|
|
426
|
+
isRecordingRef.current = false;
|
|
427
|
+
if (mediaRecorderRef.current && mediaRecorderRef.current.state === 'recording') {
|
|
428
|
+
mediaRecorderRef.current.stop();
|
|
429
|
+
}
|
|
430
|
+
return;
|
|
431
|
+
}
|
|
432
|
+
}
|
|
433
|
+
};
|
|
434
|
+
|
|
435
|
+
// Check audio activity every 100ms
|
|
436
|
+
const intervalId = setInterval(checkAudioActivity, 100);
|
|
437
|
+
(window as any).memoriSilenceDetectionInterval = intervalId;
|
|
438
|
+
}, [options.continuousRecording, detectAudioActivity]);
|
|
439
|
+
|
|
440
|
+
/**
|
|
441
|
+
* Stop silence detection monitoring
|
|
442
|
+
* Only works when continuous recording is enabled
|
|
443
|
+
*/
|
|
444
|
+
const stopSilenceDetection = useCallback(() => {
|
|
445
|
+
if ((window as any).memoriSilenceDetectionInterval) {
|
|
446
|
+
clearInterval((window as any).memoriSilenceDetectionInterval);
|
|
447
|
+
(window as any).memoriSilenceDetectionInterval = null;
|
|
448
|
+
}
|
|
449
|
+
}, []);
|
|
450
|
+
|
|
451
|
+
/**
|
|
452
|
+
* Transcribe audio blob using the API
|
|
453
|
+
*/
|
|
454
|
+
const transcribeAudio = useCallback(
|
|
455
|
+
async (audioBlob: Blob): Promise<STTResult> => {
|
|
456
|
+
const formData = new FormData();
|
|
457
|
+
let fileExtension = 'webm'; // default fallback
|
|
458
|
+
|
|
459
|
+
// Determine file extension based on provider and blob type
|
|
460
|
+
if (config.provider === 'azure') {
|
|
461
|
+
fileExtension = 'wav'; // We convert to WAV for Azure
|
|
462
|
+
} else if (mediaRecorderRef.current?.mimeType) {
|
|
463
|
+
if (mediaRecorderRef.current.mimeType.includes('webm')) {
|
|
464
|
+
fileExtension = 'webm';
|
|
465
|
+
} else if (mediaRecorderRef.current.mimeType.includes('mp4')) {
|
|
466
|
+
fileExtension = 'mp4';
|
|
467
|
+
} else if (mediaRecorderRef.current.mimeType.includes('ogg')) {
|
|
468
|
+
fileExtension = 'ogg';
|
|
469
|
+
}
|
|
470
|
+
}
|
|
471
|
+
|
|
472
|
+
formData.append('audio', audioBlob, `recording.${fileExtension}`);
|
|
473
|
+
formData.append('provider', config.provider);
|
|
474
|
+
formData.append('tenant', config.tenant || 'www.aisuru.com');
|
|
475
|
+
|
|
476
|
+
if (config.language) {
|
|
477
|
+
formData.append('language', config.language);
|
|
478
|
+
}
|
|
479
|
+
|
|
480
|
+
if (config.model) {
|
|
481
|
+
formData.append('model', config.model);
|
|
482
|
+
}
|
|
483
|
+
|
|
484
|
+
if (config.region) {
|
|
485
|
+
formData.append('region', config.region);
|
|
486
|
+
}
|
|
487
|
+
|
|
488
|
+
const response = await fetch(apiUrl, {
|
|
489
|
+
method: 'POST',
|
|
490
|
+
body: formData,
|
|
491
|
+
});
|
|
492
|
+
|
|
493
|
+
if (!response.ok) {
|
|
494
|
+
const errorData = await response.json().catch(() => ({}));
|
|
495
|
+
throw new Error(errorData.error || `API error: ${response.status}`);
|
|
496
|
+
}
|
|
497
|
+
|
|
498
|
+
const data = await response.json();
|
|
499
|
+
|
|
500
|
+
if (!data.success || !data.result) {
|
|
501
|
+
throw new Error('Invalid response from transcription service');
|
|
502
|
+
}
|
|
503
|
+
|
|
504
|
+
return data.result;
|
|
505
|
+
},
|
|
506
|
+
[config, apiUrl]
|
|
507
|
+
);
|
|
508
|
+
|
|
509
|
+
/**
|
|
510
|
+
* Start recording audio
|
|
511
|
+
*/
|
|
512
|
+
const startRecording = useCallback(async (): Promise<void> => {
|
|
513
|
+
console.log('🎤 [START] Starting recording...');
|
|
514
|
+
console.log('🎤 [START] Mounted:', isMountedRef.current, 'Muted:', microphoneMuted, 'State:', recordingState);
|
|
515
|
+
|
|
516
|
+
// Prevent immediate restart after stopping (cooldown period)
|
|
517
|
+
const timeSinceLastStop = Date.now() - lastStopTimeRef.current;
|
|
518
|
+
if (timeSinceLastStop < 1000) { // 1 second cooldown
|
|
519
|
+
console.log('🎤 [START] Too soon after last stop, waiting...', timeSinceLastStop + 'ms');
|
|
520
|
+
return;
|
|
521
|
+
}
|
|
522
|
+
|
|
523
|
+
if (
|
|
524
|
+
microphoneMuted ||
|
|
525
|
+
recordingState === 'recording'
|
|
526
|
+
) {
|
|
527
|
+
console.log('🎤 [START] Cannot start recording - conditions not met');
|
|
528
|
+
return;
|
|
529
|
+
}
|
|
530
|
+
|
|
531
|
+
if (!hasUserActivatedRecord) {
|
|
532
|
+
console.log('🎤 [START] Setting user activated record flag');
|
|
533
|
+
setHasUserActivatedRecord(true);
|
|
534
|
+
}
|
|
535
|
+
|
|
536
|
+
try {
|
|
537
|
+
setError(null);
|
|
538
|
+
setRecordingState('recording');
|
|
539
|
+
console.log('🎤 [START] Recording state set to recording');
|
|
540
|
+
|
|
541
|
+
// Initialize recording if needed
|
|
542
|
+
if (!mediaRecorderRef.current) {
|
|
543
|
+
console.log('🎤 [START] MediaRecorder not initialized, initializing...');
|
|
544
|
+
const initialized = await initializeRecording();
|
|
545
|
+
if (!initialized) {
|
|
546
|
+
console.error('🎤 [START] Failed to initialize recording');
|
|
547
|
+
return;
|
|
548
|
+
}
|
|
549
|
+
console.log('🎤 [START] Recording initialized successfully');
|
|
550
|
+
}
|
|
551
|
+
|
|
552
|
+
// Reset chunks and start recording
|
|
553
|
+
chunksRef.current = [];
|
|
554
|
+
isRecordingRef.current = true;
|
|
555
|
+
console.log('🎤 [START] Reset chunks and set recording flag');
|
|
556
|
+
|
|
557
|
+
if (
|
|
558
|
+
mediaRecorderRef.current &&
|
|
559
|
+
mediaRecorderRef.current.state === 'inactive'
|
|
560
|
+
) {
|
|
561
|
+
// Use different timeslice based on recording mode and browser
|
|
562
|
+
// For Safari, use longer timeslice to avoid issues with short recordings
|
|
563
|
+
// For other browsers, use shorter timeslice for real-time analysis
|
|
564
|
+
const isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent);
|
|
565
|
+
const timeslice = isSafari ? 500 : 100; // 500ms for Safari, 100ms for others
|
|
566
|
+
|
|
567
|
+
console.log(`🎤 [START] Starting MediaRecorder with ${timeslice}ms timeslice (Safari: ${isSafari})`);
|
|
568
|
+
console.log('🎤 [START] Continuous recording enabled:', options.continuousRecording);
|
|
569
|
+
|
|
570
|
+
mediaRecorderRef.current.start(timeslice);
|
|
571
|
+
setIsListening(true);
|
|
572
|
+
console.log('🎤 [START] MediaRecorder started, listening state set to true');
|
|
573
|
+
|
|
574
|
+
// Start silence detection if continuous recording is enabled
|
|
575
|
+
if (options.continuousRecording) {
|
|
576
|
+
console.log('🎤 [START] Starting silence detection for continuous recording');
|
|
577
|
+
startSilenceDetection();
|
|
578
|
+
} else {
|
|
579
|
+
console.log('🎤 [START] Continuous recording disabled, skipping silence detection');
|
|
580
|
+
}
|
|
581
|
+
} else {
|
|
582
|
+
console.log('🎤 [START] MediaRecorder not available or not inactive, state:', mediaRecorderRef.current?.state);
|
|
583
|
+
}
|
|
584
|
+
} catch (err) {
|
|
585
|
+
const errorMsg =
|
|
586
|
+
err instanceof Error ? err : new Error('Failed to start recording');
|
|
587
|
+
console.error('🎤 [START] Error starting recording:', errorMsg);
|
|
588
|
+
setError(errorMsg);
|
|
589
|
+
setRecordingState('error');
|
|
590
|
+
isRecordingRef.current = false;
|
|
591
|
+
|
|
592
|
+
if (options.onError) {
|
|
593
|
+
options.onError(errorMsg);
|
|
594
|
+
}
|
|
595
|
+
}
|
|
596
|
+
}, [
|
|
597
|
+
microphoneMuted,
|
|
598
|
+
recordingState,
|
|
599
|
+
hasUserActivatedRecord,
|
|
600
|
+
initializeRecording,
|
|
601
|
+
options,
|
|
602
|
+
startSilenceDetection,
|
|
603
|
+
]);
|
|
604
|
+
|
|
605
|
+
/**
|
|
606
|
+
* Stop recording audio
|
|
607
|
+
*/
|
|
608
|
+
const stopRecording = useCallback((): void => {
|
|
609
|
+
console.log('🛑 [STOP] Stop recording called');
|
|
610
|
+
console.log('🛑 [STOP] isRecordingRef:', isRecordingRef.current, 'continuousRecording:', options.continuousRecording);
|
|
611
|
+
|
|
612
|
+
if (!isRecordingRef.current) {
|
|
613
|
+
console.log('🛑 [STOP] Not currently recording, ignoring stop request');
|
|
614
|
+
return;
|
|
615
|
+
}
|
|
616
|
+
|
|
617
|
+
try {
|
|
618
|
+
console.log('🛑 [STOP] Setting listening to false');
|
|
619
|
+
setIsListening(false);
|
|
620
|
+
|
|
621
|
+
// Record the stop time for cooldown
|
|
622
|
+
lastStopTimeRef.current = Date.now();
|
|
623
|
+
|
|
624
|
+
// Stop silence detection only if continuous recording was enabled
|
|
625
|
+
if (options.continuousRecording) {
|
|
626
|
+
console.log('🛑 [STOP] Stopping silence detection for continuous recording');
|
|
627
|
+
stopSilenceDetection();
|
|
628
|
+
} else {
|
|
629
|
+
console.log('🛑 [STOP] Continuous recording disabled, skipping silence detection stop');
|
|
630
|
+
}
|
|
631
|
+
|
|
632
|
+
if (
|
|
633
|
+
mediaRecorderRef.current &&
|
|
634
|
+
mediaRecorderRef.current.state === 'recording'
|
|
635
|
+
) {
|
|
636
|
+
console.log('🛑 [STOP] Stopping MediaRecorder');
|
|
637
|
+
mediaRecorderRef.current.stop();
|
|
638
|
+
} else {
|
|
639
|
+
console.log('🛑 [STOP] MediaRecorder not available or not recording, state:', mediaRecorderRef.current?.state);
|
|
640
|
+
}
|
|
641
|
+
|
|
642
|
+
console.log('🛑 [STOP] Recording stop completed');
|
|
643
|
+
} catch (err) {
|
|
644
|
+
const errorMsg =
|
|
645
|
+
err instanceof Error ? err : new Error('Failed to stop recording');
|
|
646
|
+
console.error('🛑 [STOP] Error stopping recording:', errorMsg);
|
|
647
|
+
setError(errorMsg);
|
|
648
|
+
setRecordingState('error');
|
|
649
|
+
isRecordingRef.current = false;
|
|
650
|
+
|
|
651
|
+
if (options.onError) {
|
|
652
|
+
options.onError(errorMsg);
|
|
653
|
+
}
|
|
654
|
+
}
|
|
655
|
+
}, [recordingState, options, stopSilenceDetection]);
|
|
656
|
+
|
|
657
|
+
/**
|
|
658
|
+
* Toggle recording state
|
|
659
|
+
*/
|
|
660
|
+
const toggleRecording = useCallback(async (): Promise<void> => {
|
|
661
|
+
console.log('🔄 [TOGGLE] Toggle recording called, current state:', recordingState);
|
|
662
|
+
|
|
663
|
+
if (recordingState === 'recording') {
|
|
664
|
+
console.log('🔄 [TOGGLE] Currently recording, stopping...');
|
|
665
|
+
stopRecording();
|
|
666
|
+
} else if (recordingState === 'idle') {
|
|
667
|
+
console.log('🔄 [TOGGLE] Currently idle, starting recording...');
|
|
668
|
+
await startRecording();
|
|
669
|
+
} else {
|
|
670
|
+
console.log('🔄 [TOGGLE] Cannot toggle from state:', recordingState);
|
|
671
|
+
}
|
|
672
|
+
}, [recordingState, startRecording, stopRecording]);
|
|
673
|
+
|
|
674
|
+
/**
|
|
675
|
+
* Toggle microphone mute state
|
|
676
|
+
*/
|
|
677
|
+
const toggleMute = useCallback(
|
|
678
|
+
(mute?: boolean): void => {
|
|
679
|
+
const newMuteState = mute !== undefined ? mute : !microphoneMuted;
|
|
680
|
+
setMicrophoneMuted(newMuteState);
|
|
681
|
+
|
|
682
|
+
if (newMuteState && recordingState === 'recording') {
|
|
683
|
+
stopRecording();
|
|
684
|
+
}
|
|
685
|
+
},
|
|
686
|
+
[microphoneMuted, recordingState, stopRecording]
|
|
687
|
+
);
|
|
688
|
+
|
|
689
|
+
/**
|
|
690
|
+
* Clean up resources
|
|
691
|
+
*/
|
|
692
|
+
const cleanup = useCallback((): void => {
|
|
693
|
+
isRecordingRef.current = false;
|
|
694
|
+
|
|
695
|
+
if (mediaRecorderRef.current) {
|
|
696
|
+
if (mediaRecorderRef.current.state === 'recording') {
|
|
697
|
+
mediaRecorderRef.current.stop();
|
|
698
|
+
}
|
|
699
|
+
mediaRecorderRef.current = null;
|
|
700
|
+
}
|
|
701
|
+
|
|
702
|
+
if (audioStreamRef.current) {
|
|
703
|
+
audioStreamRef.current.getTracks().forEach(track => track.stop());
|
|
704
|
+
audioStreamRef.current = null;
|
|
705
|
+
}
|
|
706
|
+
|
|
707
|
+
// Clean up audio context only if continuous recording was enabled
|
|
708
|
+
if (options.continuousRecording && audioContextRef.current) {
|
|
709
|
+
try {
|
|
710
|
+
// Check if AudioContext is still valid before closing
|
|
711
|
+
if (audioContextRef.current.state !== 'closed') {
|
|
712
|
+
audioContextRef.current.close();
|
|
713
|
+
}
|
|
714
|
+
} catch (error) {
|
|
715
|
+
console.warn('Error closing AudioContext:', error);
|
|
716
|
+
}
|
|
717
|
+
audioContextRef.current = null;
|
|
718
|
+
}
|
|
719
|
+
|
|
720
|
+
// Stop silence detection only if continuous recording was enabled
|
|
721
|
+
if (options.continuousRecording) {
|
|
722
|
+
stopSilenceDetection();
|
|
723
|
+
}
|
|
724
|
+
|
|
725
|
+
// Reset audio analysis state
|
|
726
|
+
analyserRef.current = null;
|
|
727
|
+
dataArrayRef.current = null;
|
|
728
|
+
|
|
729
|
+
chunksRef.current = [];
|
|
730
|
+
setIsListening(false);
|
|
731
|
+
setRecordingState('idle');
|
|
732
|
+
}, [options.continuousRecording, stopSilenceDetection]);
|
|
733
|
+
|
|
734
|
+
/**
|
|
735
|
+
* Cleanup on unmount
|
|
736
|
+
*/
|
|
737
|
+
useEffect(() => {
|
|
738
|
+
return () => {
|
|
739
|
+
isMountedRef.current = false;
|
|
740
|
+
cleanup();
|
|
741
|
+
};
|
|
742
|
+
}, [cleanup]);
|
|
743
|
+
|
|
744
|
+
/**
|
|
745
|
+
* Update global variables
|
|
746
|
+
*/
|
|
747
|
+
useEffect(() => {
|
|
748
|
+
if (typeof window !== 'undefined') {
|
|
749
|
+
(window as any).memoriListening = isListening;
|
|
750
|
+
}
|
|
751
|
+
}, [isListening]);
|
|
752
|
+
|
|
753
|
+
return {
|
|
754
|
+
// State
|
|
755
|
+
recordingState,
|
|
756
|
+
microphoneMuted,
|
|
757
|
+
hasUserActivatedRecord,
|
|
758
|
+
error,
|
|
759
|
+
lastTranscription,
|
|
760
|
+
isListening,
|
|
761
|
+
|
|
762
|
+
// Actions
|
|
763
|
+
startRecording,
|
|
764
|
+
stopRecording,
|
|
765
|
+
toggleRecording,
|
|
766
|
+
toggleMute,
|
|
767
|
+
transcribeAudio,
|
|
768
|
+
setHasUserActivatedRecord,
|
|
769
|
+
setError,
|
|
770
|
+
|
|
771
|
+
// Utils
|
|
772
|
+
cleanup,
|
|
773
|
+
};
|
|
774
|
+
}
|