@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,83 @@
|
|
|
1
|
+
import { Vector3, MathUtils } from 'three';
|
|
2
|
+
import { AVATAR_POSITION, AVATAR_POSITION_ZOOMED } from '../../constants';
|
|
3
|
+
|
|
4
|
+
export class AvatarPositionController {
|
|
5
|
+
private currentScale: Vector3;
|
|
6
|
+
private targetScale: Vector3;
|
|
7
|
+
private currentPosition: Vector3;
|
|
8
|
+
private basePosition: Vector3;
|
|
9
|
+
private defaultPosition: Vector3;
|
|
10
|
+
private zoomedPosition: Vector3;
|
|
11
|
+
private initialCameraPosition: Vector3;
|
|
12
|
+
|
|
13
|
+
constructor(
|
|
14
|
+
defaultPosition: Vector3 = AVATAR_POSITION.clone(),
|
|
15
|
+
zoomedPosition: Vector3 = AVATAR_POSITION_ZOOMED.clone(),
|
|
16
|
+
initialCameraZ: number = 0.6
|
|
17
|
+
) {
|
|
18
|
+
this.defaultPosition = defaultPosition;
|
|
19
|
+
this.zoomedPosition = zoomedPosition;
|
|
20
|
+
this.currentScale = new Vector3(1, 1, 1);
|
|
21
|
+
this.targetScale = new Vector3(1, 1, 1);
|
|
22
|
+
this.currentPosition = defaultPosition.clone();
|
|
23
|
+
this.basePosition = defaultPosition.clone();
|
|
24
|
+
this.initialCameraPosition = new Vector3(0, 0, initialCameraZ);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
// Map height slider value (0 to 100) to scale (0.8 to 1.2)
|
|
28
|
+
private mapHeightToScale(sliderValue: number, isHalfBody: boolean): number {
|
|
29
|
+
// Convert slider value to scale factor
|
|
30
|
+
if (isHalfBody) {
|
|
31
|
+
return MathUtils.lerp(1.4, 2.1, sliderValue / 100);
|
|
32
|
+
} else {
|
|
33
|
+
return MathUtils.lerp(0.5, 1.5, sliderValue / 100);
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
// Map depth slider value (0 to 100) to camera Z position
|
|
38
|
+
private mapDepthToCamera(depthValue: number, isHalfBody: boolean): number {
|
|
39
|
+
const baseZ = this.initialCameraPosition.z;
|
|
40
|
+
if (isHalfBody) {
|
|
41
|
+
return MathUtils.lerp(baseZ, baseZ + 3, depthValue / 100);
|
|
42
|
+
} else {
|
|
43
|
+
return MathUtils.lerp(baseZ, baseZ + 3, depthValue / 100);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
// Update height from GUI control (0-100)
|
|
48
|
+
updateHeight(heightValue: number, isHalfBody: boolean): void {
|
|
49
|
+
const heightScale = this.mapHeightToScale(heightValue, isHalfBody);
|
|
50
|
+
this.targetScale.set(heightScale, heightScale, heightScale);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
// Update depth and return new camera Z position
|
|
54
|
+
updateDepth(depthValue: number, isHalfBody: boolean): number {
|
|
55
|
+
return this.mapDepthToCamera(depthValue, isHalfBody);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
// Update base position for zooming
|
|
59
|
+
updateBasePosition(isZoomed: boolean): void {
|
|
60
|
+
const newPosition = isZoomed ? this.zoomedPosition : this.defaultPosition;
|
|
61
|
+
this.basePosition.copy(newPosition);
|
|
62
|
+
this.currentPosition.copy(newPosition);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
// Smoothly interpolate current scale to target scale
|
|
66
|
+
updateScale(lerpFactor: number): Vector3 {
|
|
67
|
+
this.currentScale.lerp(this.targetScale, lerpFactor);
|
|
68
|
+
return this.currentScale;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
// Get current position
|
|
72
|
+
getPosition(): Vector3 {
|
|
73
|
+
return this.currentPosition;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
// Reset to default values
|
|
77
|
+
reset(): void {
|
|
78
|
+
this.currentScale.set(1, 1, 1);
|
|
79
|
+
this.targetScale.set(1, 1, 1);
|
|
80
|
+
this.currentPosition.copy(this.defaultPosition);
|
|
81
|
+
this.basePosition.copy(this.defaultPosition);
|
|
82
|
+
}
|
|
83
|
+
}
|
|
@@ -0,0 +1,301 @@
|
|
|
1
|
+
import { SkinnedMesh } from 'three';
|
|
2
|
+
import { MathUtils } from 'three';
|
|
3
|
+
import {
|
|
4
|
+
EMOTION_SMOOTHING,
|
|
5
|
+
VISEME_SMOOTHING,
|
|
6
|
+
BLINK_CONFIG,
|
|
7
|
+
MAPPING_EMOTIONS_ITALIAN_TO_ENGLISH,
|
|
8
|
+
MAPPING_BLEND_SHAPE_TO_EMOTION_RPM,
|
|
9
|
+
EmotionMapping,
|
|
10
|
+
BlendShapeMap,
|
|
11
|
+
} from '../../constants';
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Controller class for handling morph target animations including emotions, visemes and blinking
|
|
15
|
+
*/
|
|
16
|
+
export class MorphTargetController {
|
|
17
|
+
private headMesh: SkinnedMesh;
|
|
18
|
+
private currentEmotionValues: Record<string, number> = {};
|
|
19
|
+
private previousEmotionKeys: Set<string> = new Set();
|
|
20
|
+
private isRPM: boolean = false;
|
|
21
|
+
|
|
22
|
+
// Default RPM blend shape mappings
|
|
23
|
+
private rpmBlendShapes: BlendShapeMap =
|
|
24
|
+
MAPPING_BLEND_SHAPE_TO_EMOTION_RPM as BlendShapeMap;
|
|
25
|
+
|
|
26
|
+
// Default custom GLB emotion mappings
|
|
27
|
+
private customGlbMapping: EmotionMapping =
|
|
28
|
+
MAPPING_EMOTIONS_ITALIAN_TO_ENGLISH as EmotionMapping;
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Constructor for MorphTargetController
|
|
32
|
+
* @param headMesh SkinnedMesh representing the head
|
|
33
|
+
* @param rpmBlendShapes Optional custom RPM blend shapes
|
|
34
|
+
* @param customGlbMapping Optional custom GLB emotion mapping
|
|
35
|
+
*/
|
|
36
|
+
constructor(
|
|
37
|
+
headMesh: SkinnedMesh,
|
|
38
|
+
rpmBlendShapes?: BlendShapeMap,
|
|
39
|
+
customGlbMapping?: EmotionMapping
|
|
40
|
+
) {
|
|
41
|
+
this.headMesh = headMesh;
|
|
42
|
+
|
|
43
|
+
// Detect if this is an RPM avatar based on mesh name
|
|
44
|
+
this.isRPM = headMesh.name !== 'GBNL__Head';
|
|
45
|
+
|
|
46
|
+
// Override default maps if provided
|
|
47
|
+
if (rpmBlendShapes) {
|
|
48
|
+
this.rpmBlendShapes = rpmBlendShapes;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
if (customGlbMapping) {
|
|
52
|
+
this.customGlbMapping = customGlbMapping;
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* Process chat emission to extract emotion data
|
|
58
|
+
* @param chatEmission Chat emission text
|
|
59
|
+
* @param isLoading Loading state
|
|
60
|
+
* @returns Object with emotion morph targets
|
|
61
|
+
*/
|
|
62
|
+
processChatEmission(
|
|
63
|
+
chatEmission: any,
|
|
64
|
+
isLoading: boolean
|
|
65
|
+
): Record<string, number> {
|
|
66
|
+
// Default empty emotion targets
|
|
67
|
+
const defaultEmotions = this.getDefaultEmotionMorphTargets();
|
|
68
|
+
|
|
69
|
+
// If loading or no chat emission, return default emotions
|
|
70
|
+
if (isLoading || !chatEmission) {
|
|
71
|
+
return defaultEmotions;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
// Check if chat emission contains emotion tag
|
|
75
|
+
const hasOutputTagEmotion = chatEmission?.includes(
|
|
76
|
+
'<output class="memori-emotion">'
|
|
77
|
+
);
|
|
78
|
+
|
|
79
|
+
if (!hasOutputTagEmotion) {
|
|
80
|
+
return defaultEmotions;
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
// Extract emotion name
|
|
84
|
+
const outputContentEmotion = chatEmission
|
|
85
|
+
?.split('<output class="memori-emotion">')[1]
|
|
86
|
+
?.split('</output>')[0]
|
|
87
|
+
?.trim();
|
|
88
|
+
|
|
89
|
+
if (!outputContentEmotion) {
|
|
90
|
+
return defaultEmotions;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
// Process emotion based on avatar type
|
|
94
|
+
return this.processEmotion(outputContentEmotion);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
/**
|
|
98
|
+
* Process an emotion name into morph target values
|
|
99
|
+
* @param emotionName Emotion name (in Italian or English)
|
|
100
|
+
* @returns Object with morph target values
|
|
101
|
+
*/
|
|
102
|
+
private processEmotion(emotionName: string): Record<string, number> {
|
|
103
|
+
// Get default empty emotion targets
|
|
104
|
+
const defaultEmotions = this.getDefaultEmotionMorphTargets();
|
|
105
|
+
|
|
106
|
+
// First, try to find the emotion regardless of language
|
|
107
|
+
if (this.isRPM) {
|
|
108
|
+
// For RPM avatars, find the matching emotion in the rpmBlendShapes array
|
|
109
|
+
const foundEmotion = this.rpmBlendShapes.find(
|
|
110
|
+
item =>
|
|
111
|
+
item.emotion.italian.toLowerCase() === emotionName.toLowerCase() ||
|
|
112
|
+
item.emotion.english.toLowerCase() === emotionName.toLowerCase()
|
|
113
|
+
);
|
|
114
|
+
|
|
115
|
+
if (foundEmotion) {
|
|
116
|
+
return { ...defaultEmotions, ...foundEmotion.blendShapes };
|
|
117
|
+
}
|
|
118
|
+
} else {
|
|
119
|
+
// For custom GLB, find the matching emotion in the customGlbMapping array
|
|
120
|
+
const foundEmotion = this.customGlbMapping.find(
|
|
121
|
+
item =>
|
|
122
|
+
item.italian.toLowerCase() === emotionName.toLowerCase() ||
|
|
123
|
+
item.english.toLowerCase() === emotionName.toLowerCase()
|
|
124
|
+
);
|
|
125
|
+
|
|
126
|
+
if (foundEmotion) {
|
|
127
|
+
return { ...defaultEmotions, [foundEmotion.english]: 1 };
|
|
128
|
+
}
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
console.log('[MorphTargetController] No emotion found:', emotionName);
|
|
132
|
+
return defaultEmotions;
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
/**
|
|
136
|
+
* Get default emotion morph targets (all set to 0)
|
|
137
|
+
*/
|
|
138
|
+
private getDefaultEmotionMorphTargets(): Record<string, number> {
|
|
139
|
+
// For RPM, collect all blend shape keys
|
|
140
|
+
if (this.isRPM) {
|
|
141
|
+
const allBlendShapeKeys = new Set<string>();
|
|
142
|
+
|
|
143
|
+
this.rpmBlendShapes.forEach(item => {
|
|
144
|
+
Object.keys(item.blendShapes).forEach(key =>
|
|
145
|
+
allBlendShapeKeys.add(key)
|
|
146
|
+
);
|
|
147
|
+
});
|
|
148
|
+
|
|
149
|
+
return Array.from(allBlendShapeKeys).reduce(
|
|
150
|
+
(acc, key) => ({ ...acc, [key]: 0 }),
|
|
151
|
+
{}
|
|
152
|
+
);
|
|
153
|
+
}
|
|
154
|
+
// For custom GLB, use English emotion names
|
|
155
|
+
else {
|
|
156
|
+
return this.customGlbMapping.reduce(
|
|
157
|
+
(acc, emotion) => ({ ...acc, [emotion.english]: 0 }),
|
|
158
|
+
{}
|
|
159
|
+
);
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
/**
|
|
163
|
+
* Updates the morph target influences for emotions, visemes and blinking
|
|
164
|
+
*/
|
|
165
|
+
updateMorphTargets(
|
|
166
|
+
currentTime: number,
|
|
167
|
+
chatEmission: any,
|
|
168
|
+
isLoading: boolean,
|
|
169
|
+
currentViseme: { name: string; weight: number } | null,
|
|
170
|
+
eyeBlink: boolean,
|
|
171
|
+
blinkState: {
|
|
172
|
+
isBlinking: boolean;
|
|
173
|
+
lastBlinkTime: number;
|
|
174
|
+
nextBlinkTime: number;
|
|
175
|
+
blinkStartTime: number;
|
|
176
|
+
}
|
|
177
|
+
) {
|
|
178
|
+
// Validate required mesh properties exist
|
|
179
|
+
if (
|
|
180
|
+
!this.headMesh.morphTargetDictionary ||
|
|
181
|
+
!this.headMesh.morphTargetInfluences
|
|
182
|
+
) {
|
|
183
|
+
console.error(
|
|
184
|
+
'[MorphTargetController] Missing morphTargetDictionary or morphTargetInfluences'
|
|
185
|
+
);
|
|
186
|
+
return;
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
// Process chat emission to get emotion morph targets
|
|
190
|
+
const emotionMorphTargets = this.processChatEmission(
|
|
191
|
+
chatEmission,
|
|
192
|
+
isLoading
|
|
193
|
+
);
|
|
194
|
+
|
|
195
|
+
// Calculate blink value for this frame
|
|
196
|
+
const blinkValue = this.calculateBlinkValue(
|
|
197
|
+
currentTime,
|
|
198
|
+
blinkState,
|
|
199
|
+
eyeBlink
|
|
200
|
+
);
|
|
201
|
+
|
|
202
|
+
const currentEmotionKeys = new Set(Object.keys(emotionMorphTargets));
|
|
203
|
+
|
|
204
|
+
// Process each morph target
|
|
205
|
+
Object.entries(this.headMesh.morphTargetDictionary).forEach(
|
|
206
|
+
([key, index]) => {
|
|
207
|
+
if (typeof index !== 'number') return;
|
|
208
|
+
|
|
209
|
+
let targetValue = 0;
|
|
210
|
+
|
|
211
|
+
// Handle emotion morphs with smoothing
|
|
212
|
+
if (currentEmotionKeys.has(key)) {
|
|
213
|
+
// console.log('[MorphTargetController] Processing morph target:', key);
|
|
214
|
+
const targetEmotionValue = emotionMorphTargets[key];
|
|
215
|
+
const currentEmotionValue = this.currentEmotionValues[key] || 0;
|
|
216
|
+
const newEmotionValue = MathUtils.lerp(
|
|
217
|
+
currentEmotionValue,
|
|
218
|
+
targetEmotionValue * 3, // Amplify emotion by 3x
|
|
219
|
+
EMOTION_SMOOTHING
|
|
220
|
+
);
|
|
221
|
+
this.currentEmotionValues[key] = newEmotionValue;
|
|
222
|
+
targetValue += newEmotionValue;
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
// Add viseme influence if active
|
|
226
|
+
if (currentViseme && key === currentViseme.name) {
|
|
227
|
+
targetValue += currentViseme.weight;
|
|
228
|
+
}
|
|
229
|
+
|
|
230
|
+
// Add blink influence if active
|
|
231
|
+
if (key === 'eyesClosed' && eyeBlink) {
|
|
232
|
+
targetValue += blinkValue;
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
// Clamp and smooth final value
|
|
236
|
+
targetValue = MathUtils.clamp(targetValue, 0, 1);
|
|
237
|
+
if (this.headMesh.morphTargetInfluences) {
|
|
238
|
+
const finalValue = MathUtils.lerp(
|
|
239
|
+
this.headMesh.morphTargetInfluences[index] || 0,
|
|
240
|
+
targetValue,
|
|
241
|
+
VISEME_SMOOTHING
|
|
242
|
+
);
|
|
243
|
+
this.headMesh.morphTargetInfluences[index] = finalValue;
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
);
|
|
247
|
+
|
|
248
|
+
this.previousEmotionKeys = currentEmotionKeys;
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
/**
|
|
252
|
+
* Calculates the blink value based on timing and state
|
|
253
|
+
*/
|
|
254
|
+
private calculateBlinkValue(
|
|
255
|
+
currentTime: number,
|
|
256
|
+
blinkState: {
|
|
257
|
+
isBlinking: boolean;
|
|
258
|
+
lastBlinkTime: number;
|
|
259
|
+
nextBlinkTime: number;
|
|
260
|
+
blinkStartTime: number;
|
|
261
|
+
},
|
|
262
|
+
eyeBlink: boolean
|
|
263
|
+
): number {
|
|
264
|
+
if (!eyeBlink) return 0;
|
|
265
|
+
|
|
266
|
+
let blinkValue = 0;
|
|
267
|
+
|
|
268
|
+
// Start new blink if it's time
|
|
269
|
+
if (currentTime >= blinkState.nextBlinkTime && !blinkState.isBlinking) {
|
|
270
|
+
blinkState.isBlinking = true;
|
|
271
|
+
blinkState.blinkStartTime = currentTime;
|
|
272
|
+
blinkState.lastBlinkTime = currentTime;
|
|
273
|
+
blinkState.nextBlinkTime =
|
|
274
|
+
currentTime +
|
|
275
|
+
Math.random() * (BLINK_CONFIG.maxInterval - BLINK_CONFIG.minInterval) +
|
|
276
|
+
BLINK_CONFIG.minInterval;
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
// Calculate blink animation progress
|
|
280
|
+
if (blinkState.isBlinking) {
|
|
281
|
+
const blinkProgress =
|
|
282
|
+
(currentTime - blinkState.blinkStartTime) / BLINK_CONFIG.blinkDuration;
|
|
283
|
+
|
|
284
|
+
// First half of blink - closing eyes
|
|
285
|
+
if (blinkProgress <= 0.5) {
|
|
286
|
+
blinkValue = blinkProgress * 2;
|
|
287
|
+
}
|
|
288
|
+
// Second half of blink - opening eyes
|
|
289
|
+
else if (blinkProgress <= 1) {
|
|
290
|
+
blinkValue = 2 - blinkProgress * 2;
|
|
291
|
+
}
|
|
292
|
+
// Blink complete
|
|
293
|
+
else {
|
|
294
|
+
blinkState.isBlinking = false;
|
|
295
|
+
blinkValue = 0;
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
|
|
299
|
+
return blinkValue;
|
|
300
|
+
}
|
|
301
|
+
}
|
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import React, { useEffect, useRef, useState } from 'react';
|
|
2
|
+
import GUI from 'lil-gui';
|
|
3
|
+
|
|
4
|
+
interface BaseAction {
|
|
5
|
+
weight: number;
|
|
6
|
+
action?: string;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
interface AdditiveAction {
|
|
10
|
+
weight: number;
|
|
11
|
+
action?: string;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
export interface AnimationControlPanelProps {
|
|
15
|
+
baseActions: Record<string, BaseAction>;
|
|
16
|
+
onBaseActionChange: (action: string, outputContent: string) => void;
|
|
17
|
+
currentBaseAction: {
|
|
18
|
+
action: string;
|
|
19
|
+
weight: number;
|
|
20
|
+
};
|
|
21
|
+
onMorphTargetInfluencesChange: (influences: { [key: string]: number }) => void;
|
|
22
|
+
onMorphTargetDictionaryChange: (dictionary: { [key: string]: number }) => void;
|
|
23
|
+
morphTargetDictionary: { [key: string]: number };
|
|
24
|
+
modifyTimeScale: (value: number) => void;
|
|
25
|
+
timeScale: number;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
const AnimationControlPanel: React.FC<AnimationControlPanelProps> = ({
|
|
29
|
+
onBaseActionChange,
|
|
30
|
+
baseActions,
|
|
31
|
+
modifyTimeScale,
|
|
32
|
+
onMorphTargetInfluencesChange,
|
|
33
|
+
onMorphTargetDictionaryChange,
|
|
34
|
+
morphTargetDictionary,
|
|
35
|
+
timeScale,
|
|
36
|
+
}) => {
|
|
37
|
+
const guiRef = useRef<GUI | null>(null);
|
|
38
|
+
const panelSettingsRef = useRef<Record<string, any>>({
|
|
39
|
+
'modify time scale': timeScale,
|
|
40
|
+
});
|
|
41
|
+
const crossFadeControlsRef = useRef<any[]>([]);
|
|
42
|
+
|
|
43
|
+
useEffect(() => {
|
|
44
|
+
|
|
45
|
+
const gui = new GUI({ width: 310 });
|
|
46
|
+
guiRef.current = gui;
|
|
47
|
+
|
|
48
|
+
const folder1 = gui.addFolder('Base Actions');
|
|
49
|
+
const folder2 = gui.addFolder('Additive Action Weights');
|
|
50
|
+
const folder3 = gui.addFolder('General Speed');
|
|
51
|
+
|
|
52
|
+
const baseNames = ['None', ...Object.keys(baseActions)];
|
|
53
|
+
|
|
54
|
+
baseNames.forEach(name => {
|
|
55
|
+
const settings = baseActions[name];
|
|
56
|
+
panelSettingsRef.current[name] = () => {
|
|
57
|
+
onBaseActionChange(name, '');
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
const control = folder1.add(panelSettingsRef.current, name);
|
|
61
|
+
crossFadeControlsRef.current.push(control);
|
|
62
|
+
});
|
|
63
|
+
|
|
64
|
+
Object.entries(morphTargetDictionary).forEach(([name, settings]) => {
|
|
65
|
+
panelSettingsRef.current[name] = settings/100;
|
|
66
|
+
folder2
|
|
67
|
+
.add(panelSettingsRef.current, name, -1.0, 1.0, 0.01)
|
|
68
|
+
.listen()
|
|
69
|
+
.onChange((weight: number) => {
|
|
70
|
+
onMorphTargetInfluencesChange({ [name]: weight });
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
folder3
|
|
75
|
+
.add(panelSettingsRef.current, 'modify time scale', 0.0, 1.5, 0.01)
|
|
76
|
+
.onChange((value: number) => {
|
|
77
|
+
modifyTimeScale(value);
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
folder1.open();
|
|
81
|
+
folder2.open();
|
|
82
|
+
folder3.open();
|
|
83
|
+
|
|
84
|
+
return () => {
|
|
85
|
+
gui.destroy();
|
|
86
|
+
};
|
|
87
|
+
}, [
|
|
88
|
+
onBaseActionChange,
|
|
89
|
+
onMorphTargetInfluencesChange,
|
|
90
|
+
onMorphTargetDictionaryChange,
|
|
91
|
+
modifyTimeScale,
|
|
92
|
+
baseActions,
|
|
93
|
+
morphTargetDictionary,
|
|
94
|
+
timeScale
|
|
95
|
+
]);
|
|
96
|
+
|
|
97
|
+
return null; // This component doesn't render anything itself
|
|
98
|
+
};
|
|
99
|
+
|
|
100
|
+
export default AnimationControlPanel;
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import { useEffect, useMemo, useRef } from 'react';
|
|
2
|
+
import { Object3D, SkinnedMesh } from 'three';
|
|
3
|
+
import { useGLTF } from '@react-three/drei';
|
|
4
|
+
import { useGraph, useFrame, useThree } from '@react-three/fiber';
|
|
5
|
+
import { correctMaterials, isSkinnedMesh } from '../../../../../helpers/utils';
|
|
6
|
+
import { MorphTargetController } from './controllers/MorphTargetController';
|
|
7
|
+
import { AvatarPositionController } from './controllers/AvatarPositionController';
|
|
8
|
+
import {
|
|
9
|
+
AVATAR_POSITION,
|
|
10
|
+
SCALE_LERP_FACTOR,
|
|
11
|
+
AVATAR_POSITION_ZOOMED,
|
|
12
|
+
} from '../constants';
|
|
13
|
+
import { hideHands } from '../../utils/utils';
|
|
14
|
+
import useHeadMovement from '../../utils/useHeadMovement';
|
|
15
|
+
|
|
16
|
+
interface HalfBodyAvatarProps {
|
|
17
|
+
url: string;
|
|
18
|
+
updateCurrentViseme: (currentTime: number) => any;
|
|
19
|
+
eyeBlink?: boolean;
|
|
20
|
+
avatarHeight: number;
|
|
21
|
+
avatarDepth: number;
|
|
22
|
+
onLoaded?: () => void;
|
|
23
|
+
onCameraZChange: (value: number) => void;
|
|
24
|
+
headMovement?: boolean;
|
|
25
|
+
chatEmission?: any;
|
|
26
|
+
loading?: boolean;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export default function HalfBodyAvatar({
|
|
30
|
+
url,
|
|
31
|
+
updateCurrentViseme,
|
|
32
|
+
eyeBlink = false,
|
|
33
|
+
avatarHeight = 50,
|
|
34
|
+
avatarDepth = 0,
|
|
35
|
+
headMovement = false,
|
|
36
|
+
onLoaded,
|
|
37
|
+
onCameraZChange,
|
|
38
|
+
chatEmission,
|
|
39
|
+
loading = false,
|
|
40
|
+
}: HalfBodyAvatarProps) {
|
|
41
|
+
const { scene } = useGLTF(url);
|
|
42
|
+
const { nodes, materials } = useGraph(scene);
|
|
43
|
+
const { camera } = useThree();
|
|
44
|
+
|
|
45
|
+
const morphTargetControllerRef = useRef<MorphTargetController | null>(null);
|
|
46
|
+
const positionControllerRef = useRef<AvatarPositionController | null>(null);
|
|
47
|
+
const targetCameraZRef = useRef(camera.position.z);
|
|
48
|
+
|
|
49
|
+
// Apply head movement if enabled
|
|
50
|
+
useHeadMovement(headMovement, nodes);
|
|
51
|
+
|
|
52
|
+
|
|
53
|
+
// Eye blinking state
|
|
54
|
+
const blinkStateRef = useRef({
|
|
55
|
+
isBlinking: false,
|
|
56
|
+
lastBlinkTime: 0,
|
|
57
|
+
nextBlinkTime: 0,
|
|
58
|
+
blinkStartTime: 0,
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
// Find head mesh
|
|
62
|
+
const headMesh = useMemo(() => {
|
|
63
|
+
let foundMesh: SkinnedMesh | undefined;
|
|
64
|
+
scene?.traverse((object: Object3D) => {
|
|
65
|
+
if (
|
|
66
|
+
object instanceof SkinnedMesh &&
|
|
67
|
+
(object.name === 'GBNL__Head' || object.name === 'Wolf3D_Avatar' || object.name === 'Wolf3D_Avatar006_1')
|
|
68
|
+
) {
|
|
69
|
+
foundMesh = object;
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
return foundMesh;
|
|
73
|
+
}, [scene]);
|
|
74
|
+
|
|
75
|
+
// Initialize controllers
|
|
76
|
+
useEffect(() => {
|
|
77
|
+
if (!positionControllerRef.current) {
|
|
78
|
+
positionControllerRef.current = new AvatarPositionController(
|
|
79
|
+
AVATAR_POSITION,
|
|
80
|
+
AVATAR_POSITION_ZOOMED,
|
|
81
|
+
);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
// Initialize MorphTargetController if head mesh exists
|
|
85
|
+
if (headMesh) {
|
|
86
|
+
morphTargetControllerRef.current = new MorphTargetController(headMesh);
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
// Correct materials and perform other initialization tasks
|
|
90
|
+
correctMaterials(materials);
|
|
91
|
+
onLoaded?.();
|
|
92
|
+
hideHands(nodes);
|
|
93
|
+
|
|
94
|
+
// Cleanup on unmount
|
|
95
|
+
return () => {
|
|
96
|
+
Object.values(materials).forEach(material => material.dispose());
|
|
97
|
+
Object.values(nodes)
|
|
98
|
+
.filter(isSkinnedMesh)
|
|
99
|
+
.forEach(mesh => mesh.geometry.dispose());
|
|
100
|
+
};
|
|
101
|
+
}, [materials, nodes, url, onLoaded, scene, headMesh]);
|
|
102
|
+
|
|
103
|
+
// Handle avatar height changes
|
|
104
|
+
useEffect(() => {
|
|
105
|
+
if (positionControllerRef.current) {
|
|
106
|
+
positionControllerRef.current.updateHeight(avatarHeight, true);
|
|
107
|
+
}
|
|
108
|
+
}, [avatarHeight]);
|
|
109
|
+
|
|
110
|
+
// Handle avatar depth changes
|
|
111
|
+
useEffect(() => {
|
|
112
|
+
if (positionControllerRef.current && onCameraZChange) {
|
|
113
|
+
const newCameraZ = positionControllerRef.current.updateDepth(avatarDepth, true);
|
|
114
|
+
onCameraZChange(newCameraZ);
|
|
115
|
+
}
|
|
116
|
+
}, [avatarDepth, onCameraZChange]);
|
|
117
|
+
|
|
118
|
+
// Animation and morphing update loop
|
|
119
|
+
useFrame((state) => {
|
|
120
|
+
const currentTime = state.clock.elapsedTime * 1000;
|
|
121
|
+
|
|
122
|
+
// Update morph targets
|
|
123
|
+
if (morphTargetControllerRef.current) {
|
|
124
|
+
const currentViseme = updateCurrentViseme(currentTime / 1000);
|
|
125
|
+
|
|
126
|
+
// Use the updated MorphTargetController that handles chat emission directly
|
|
127
|
+
morphTargetControllerRef.current.updateMorphTargets(
|
|
128
|
+
currentTime,
|
|
129
|
+
chatEmission,
|
|
130
|
+
loading,
|
|
131
|
+
currentViseme,
|
|
132
|
+
eyeBlink,
|
|
133
|
+
blinkStateRef.current,
|
|
134
|
+
);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
// Update scale with smooth transition
|
|
138
|
+
if (scene && positionControllerRef.current) {
|
|
139
|
+
const newScale = positionControllerRef.current.updateScale(SCALE_LERP_FACTOR);
|
|
140
|
+
scene.scale.copy(newScale);
|
|
141
|
+
}
|
|
142
|
+
});
|
|
143
|
+
|
|
144
|
+
// Get current position from controller
|
|
145
|
+
const position = positionControllerRef.current?.getPosition() || AVATAR_POSITION;
|
|
146
|
+
|
|
147
|
+
return (
|
|
148
|
+
<group position={position}>
|
|
149
|
+
<primitive object={scene} />
|
|
150
|
+
</group>
|
|
151
|
+
);
|
|
152
|
+
}
|