@microsoft/omnichannel-chat-widget 0.1.0-main.edd8c2a → 0.1.0-main.f4c21f0
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/README.md +259 -0
- package/lib/cjs/assets/Audios.js +8 -0
- package/lib/cjs/assets/Icons.js +30 -0
- package/lib/cjs/common/Constants.js +54 -151
- package/lib/cjs/common/KeyCodes.js +3 -4
- package/lib/cjs/common/contextDataStore/DataStoreManager.js +12 -0
- package/lib/cjs/{assets/assets.d.js → common/interfaces/IContextDataStore.js} +0 -0
- package/lib/cjs/common/storage/default/defaultCacheManager.js +26 -0
- package/lib/cjs/common/storage/default/defaultClientDataStoreProvider.js +111 -0
- package/lib/cjs/common/storage/default/defaultInMemoryDataStore.js +78 -0
- package/lib/cjs/common/telemetry/TelemetryConstants.js +88 -22
- package/lib/cjs/common/telemetry/TelemetryHelper.js +39 -59
- package/lib/cjs/common/telemetry/TelemetryManager.js +25 -35
- package/lib/cjs/common/telemetry/defaultConfigs/defaultAriaConfig.js +3 -3
- package/lib/cjs/common/telemetry/defaultConfigs/defaultTelemetryConfiguration.js +4 -3
- package/lib/cjs/common/telemetry/loggers/ariaTelemetryLogger.js +59 -32
- package/lib/cjs/common/telemetry/loggers/consoleLogger.js +9 -14
- package/lib/cjs/common/utils.js +80 -80
- package/lib/cjs/components/callingcontainerstateful/CallingContainerStateful.js +21 -45
- package/lib/cjs/components/chatbuttonstateful/ChatButtonStateful.js +20 -26
- package/lib/cjs/components/chatbuttonstateful/common/styleProps/defaultOutOfOfficeChatButtonStyleProps.js +3 -0
- package/lib/cjs/components/confirmationpanestateful/ConfirmationPaneStateful.js +15 -86
- package/lib/cjs/components/dimlayer/DimLayer.js +0 -4
- package/lib/cjs/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.js +11 -39
- package/lib/cjs/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.spec.js +6 -8
- package/lib/cjs/components/footerstateful/FooterStateful.js +14 -46
- package/lib/cjs/components/footerstateful/audionotificationstateful/AudioNotificationStateful.js +0 -6
- package/lib/cjs/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.js +15 -44
- package/lib/cjs/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.spec.js +6 -8
- package/lib/cjs/components/headerstateful/HeaderStateful.js +26 -35
- package/lib/cjs/components/livechatwidget/LiveChatWidget.js +2 -14
- package/lib/cjs/components/livechatwidget/common/ActivityStreamHandler.js +39 -0
- package/lib/cjs/components/livechatwidget/common/ActivitySubscriber/DefaultActivitySubscriber.js +20 -0
- package/lib/cjs/components/livechatwidget/common/ActivitySubscriber/IActivitySubscriber.js +1 -0
- package/lib/cjs/components/livechatwidget/common/ActivitySubscriber/PauseActivitySubscriber.js +34 -0
- package/lib/cjs/components/livechatwidget/common/ChatAdapterShim.js +64 -0
- package/lib/cjs/components/livechatwidget/common/Deferred.js +37 -0
- package/lib/cjs/components/livechatwidget/common/authHelper.js +50 -0
- package/lib/cjs/components/livechatwidget/common/createAdapter.js +10 -9
- package/lib/cjs/components/livechatwidget/common/createFooter.js +4 -23
- package/lib/cjs/components/livechatwidget/common/createInternetConnectionChangeHandler.js +10 -10
- package/lib/cjs/components/livechatwidget/common/createMarkdown.js +36 -44
- package/lib/cjs/components/livechatwidget/common/defaultProps/defaultScrollBarProps.js +14 -0
- package/lib/cjs/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +146 -68
- package/lib/cjs/components/livechatwidget/common/disposeTelemetryLoggers.js +11 -0
- package/lib/cjs/components/livechatwidget/common/endChat.js +168 -54
- package/lib/cjs/components/livechatwidget/common/getGeneralStylesForButton.js +0 -6
- package/lib/cjs/components/livechatwidget/common/initCallingSdk.js +10 -14
- package/lib/cjs/components/livechatwidget/common/initConfirmationPropsComposer.js +4 -8
- package/lib/cjs/components/livechatwidget/common/initWebChatComposer.js +51 -54
- package/lib/cjs/components/livechatwidget/common/reconnectChatHelper.js +98 -66
- package/lib/cjs/components/livechatwidget/common/registerTelemetryLoggers.js +13 -22
- package/lib/cjs/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +18 -29
- package/lib/cjs/components/livechatwidget/common/shareObservable.js +41 -0
- package/lib/cjs/components/livechatwidget/common/startChat.js +310 -67
- package/lib/cjs/components/livechatwidget/common/startProactiveChat.js +3 -11
- package/lib/cjs/components/livechatwidget/common/updateSessionDataForTelemetry.js +2 -11
- package/lib/cjs/components/livechatwidget/interfaces/IScrollBarProps.js +1 -0
- package/lib/cjs/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +370 -160
- package/lib/cjs/components/loadingpanestateful/LoadingPaneStateful.js +20 -20
- package/lib/cjs/components/loadingpanestateful/common/errorUIStyleProps/errorUILoadingPaneStyleProps.js +57 -0
- package/lib/cjs/components/ooohpanestateful/OOOHPaneStateful.js +9 -14
- package/lib/cjs/components/postchatloadingpanestateful/PostChatLoadingPaneStateful.js +9 -14
- package/lib/cjs/components/postchatsurveypanestateful/PostChatSurveyPaneStateful.js +32 -23
- package/lib/cjs/components/postchatsurveypanestateful/common/defaultStyleProps/defaultgeneralPostChatSurveyPaneStyleProps.js +1 -1
- package/lib/cjs/components/postchatsurveypanestateful/enums/CustomerVoiceEvents.js +13 -0
- package/lib/cjs/components/postchatsurveypanestateful/enums/PostChatSurveyMode.js +0 -1
- package/lib/cjs/components/postchatsurveypanestateful/interfaces/IPostChatSurveyPaneStatefulProps.js +1 -0
- package/lib/cjs/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +27 -43
- package/lib/cjs/components/prechatsurveypanestateful/common/defaultStyles/defaultGeneralPreChatSurveyPaneStyleProps.js +1 -1
- package/lib/cjs/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +27 -35
- package/lib/cjs/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.js +1 -0
- package/lib/cjs/components/reconnectchatpanestateful/ReconnectChatPaneStateful.js +6 -24
- package/lib/cjs/components/webchatcontainerstateful/WebChatContainerStateful.js +94 -19
- package/lib/cjs/components/webchatcontainerstateful/common/defaultProps/defaultWebChatContainerStatefulProps.js +3 -7
- package/lib/cjs/components/webchatcontainerstateful/common/defaultProps/defaultWebChatStatefulProps.js +2 -6
- package/lib/cjs/components/webchatcontainerstateful/common/defaultStyles/defaultAdaptiveCardStyles.js +11 -0
- package/lib/cjs/components/webchatcontainerstateful/common/mockadapter.js +12 -27
- package/lib/cjs/components/webchatcontainerstateful/common/mockchatsdk.js +9 -16
- package/lib/cjs/components/webchatcontainerstateful/common/utils/BrowserInfo.js +2 -24
- package/lib/cjs/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +56 -88
- package/lib/cjs/components/webchatcontainerstateful/common/utils/isMaskingFromCustomer.js +5 -8
- package/lib/cjs/components/webchatcontainerstateful/interfaces/IAdaptiveCardStyles.js +1 -0
- package/lib/cjs/components/webchatcontainerstateful/interfaces/IBotMagicCodeConfig.js +1 -0
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/BotMagicCodeStore.js +12 -0
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/WebChatStoreLoader.js +3 -5
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/BrowserVendor.js +0 -1
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/DirectLineActivityType.js +0 -1
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/DirectLineSenderRole.js +0 -1
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/MessageType.js +0 -1
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/NotificationLevel.js +0 -1
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/NotificationScenarios.js +0 -1
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/SendStatus.js +0 -1
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/WebChatActionType.js +0 -1
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/adaptermiddlewares/formatTagsEgressMiddleware.js +0 -7
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/adaptermiddlewares/formatTagsIngressMiddleware.js +0 -5
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.js +33 -80
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityStatusMiddleware.js +10 -22
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/attachmentMiddleware.js +27 -61
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/avatarMiddleware.js +7 -15
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.js +41 -0
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.js +82 -0
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultReceivedMessageAnchorStyles.js +10 -0
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultSystemMessageBoxStyles.js +10 -0
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultTimestampFailedStyles.js +2 -3
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultTimestampRetryStyles.js +2 -3
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultUserMessageBoxStyles.js +10 -0
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/groupActivitiesMiddleware.js +3 -9
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/messageTimestampMiddleware.js +89 -0
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/DeliveredTimestamp.js +7 -18
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/NotDeliveredTimestamp.js +8 -42
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/SendingTimestamp.js +4 -22
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/typingIndicatorMiddleware.js +13 -30
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/attachmentProcessingMiddleware.js +3 -9
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/attachmentUploadValidatorMiddleware.js +6 -34
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/channelDataMiddleware.js +1 -10
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/conversationEndMiddleware.js +7 -18
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/dataMaskingMiddleware.js +17 -19
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/gifUploadMiddleware.js +1 -9
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/htmlPlayerMiddleware.js +3 -9
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/htmlTextMiddleware.js +13 -34
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/maxMessageSizeValidator.js +1 -10
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/preProcessingMiddleware.js +7 -11
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/sanitizationMiddleware.js +5 -14
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/notification/NotificationHandler.js +1 -21
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.js +33 -0
- package/lib/cjs/contexts/ChatAdapterStore.js +0 -2
- package/lib/cjs/contexts/ChatContextStore.js +0 -2
- package/lib/cjs/contexts/ChatSDKStore.js +0 -2
- package/lib/cjs/contexts/common/ConversationState.js +4 -3
- package/lib/cjs/contexts/common/LiveChatWidgetActionType.js +30 -23
- package/lib/cjs/contexts/common/LiveChatWidgetContextInitialState.js +21 -12
- package/lib/cjs/contexts/createReducer.js +181 -101
- package/lib/cjs/controller/componentController.js +5 -34
- package/lib/cjs/hooks/useChatAdapterStore.js +0 -6
- package/lib/cjs/hooks/useChatContextStore.js +0 -6
- package/lib/cjs/hooks/useChatSDKStore.js +0 -6
- package/lib/cjs/index.js +0 -5
- package/lib/cjs/plugins/newMessageEventHandler.js +82 -0
- package/lib/esm/assets/Audios.js +1 -0
- package/lib/esm/assets/Icons.js +12 -0
- package/lib/esm/common/Constants.js +49 -139
- package/lib/esm/common/KeyCodes.js +3 -3
- package/lib/esm/common/contextDataStore/DataStoreManager.js +5 -0
- package/lib/esm/common/interfaces/IContextDataStore.js +1 -0
- package/lib/esm/common/storage/default/defaultCacheManager.js +18 -0
- package/lib/esm/common/storage/default/defaultClientDataStoreProvider.js +104 -0
- package/lib/esm/common/storage/default/defaultInMemoryDataStore.js +70 -0
- package/lib/esm/common/telemetry/TelemetryConstants.js +87 -17
- package/lib/esm/common/telemetry/TelemetryHelper.js +40 -49
- package/lib/esm/common/telemetry/TelemetryManager.js +24 -27
- package/lib/esm/common/telemetry/defaultConfigs/defaultAriaConfig.js +3 -3
- package/lib/esm/common/telemetry/defaultConfigs/defaultTelemetryConfiguration.js +4 -1
- package/lib/esm/common/telemetry/loggers/ariaTelemetryLogger.js +62 -23
- package/lib/esm/common/telemetry/loggers/consoleLogger.js +9 -10
- package/lib/esm/common/utils.js +73 -45
- package/lib/esm/components/callingcontainerstateful/CallingContainerStateful.js +21 -16
- package/lib/esm/components/chatbuttonstateful/ChatButtonStateful.js +23 -13
- package/lib/esm/components/chatbuttonstateful/common/styleProps/defaultOutOfOfficeChatButtonStyleProps.js +3 -0
- package/lib/esm/components/confirmationpanestateful/ConfirmationPaneStateful.js +16 -62
- package/lib/esm/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.js +11 -18
- package/lib/esm/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.spec.js +6 -6
- package/lib/esm/components/footerstateful/FooterStateful.js +15 -26
- package/lib/esm/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.js +15 -37
- package/lib/esm/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.spec.js +6 -6
- package/lib/esm/components/headerstateful/HeaderStateful.js +27 -21
- package/lib/esm/components/livechatwidget/LiveChatWidget.js +2 -2
- package/lib/esm/components/livechatwidget/common/ActivityStreamHandler.js +32 -0
- package/lib/esm/components/livechatwidget/common/ActivitySubscriber/DefaultActivitySubscriber.js +13 -0
- package/lib/esm/components/livechatwidget/common/ActivitySubscriber/IActivitySubscriber.js +1 -0
- package/lib/esm/components/livechatwidget/common/ActivitySubscriber/PauseActivitySubscriber.js +27 -0
- package/lib/esm/components/livechatwidget/common/ChatAdapterShim.js +57 -0
- package/lib/esm/components/livechatwidget/common/Deferred.js +30 -0
- package/lib/esm/components/livechatwidget/common/authHelper.js +42 -0
- package/lib/esm/components/livechatwidget/common/createAdapter.js +12 -4
- package/lib/esm/components/livechatwidget/common/createFooter.js +4 -16
- package/lib/esm/components/livechatwidget/common/createInternetConnectionChangeHandler.js +10 -5
- package/lib/esm/components/livechatwidget/common/createMarkdown.js +38 -37
- package/lib/esm/components/livechatwidget/common/defaultProps/defaultScrollBarProps.js +7 -0
- package/lib/esm/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +148 -58
- package/lib/esm/components/livechatwidget/common/disposeTelemetryLoggers.js +4 -0
- package/lib/esm/components/livechatwidget/common/endChat.js +171 -42
- package/lib/esm/components/livechatwidget/common/getGeneralStylesForButton.js +0 -2
- package/lib/esm/components/livechatwidget/common/initCallingSdk.js +12 -11
- package/lib/esm/components/livechatwidget/common/initConfirmationPropsComposer.js +4 -5
- package/lib/esm/components/livechatwidget/common/initWebChatComposer.js +53 -26
- package/lib/esm/components/livechatwidget/common/reconnectChatHelper.js +98 -58
- package/lib/esm/components/livechatwidget/common/registerTelemetryLoggers.js +13 -11
- package/lib/esm/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +19 -21
- package/lib/esm/components/livechatwidget/common/shareObservable.js +35 -0
- package/lib/esm/components/livechatwidget/common/startChat.js +313 -52
- package/lib/esm/components/livechatwidget/common/startProactiveChat.js +5 -5
- package/lib/esm/components/livechatwidget/common/updateSessionDataForTelemetry.js +4 -2
- package/lib/esm/components/livechatwidget/interfaces/IScrollBarProps.js +1 -0
- package/lib/esm/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +371 -114
- package/lib/esm/components/loadingpanestateful/LoadingPaneStateful.js +20 -8
- package/lib/esm/components/loadingpanestateful/common/errorUIStyleProps/errorUILoadingPaneStyleProps.js +50 -0
- package/lib/esm/components/ooohpanestateful/OOOHPaneStateful.js +9 -4
- package/lib/esm/components/postchatloadingpanestateful/PostChatLoadingPaneStateful.js +9 -4
- package/lib/esm/components/postchatsurveypanestateful/PostChatSurveyPaneStateful.js +32 -11
- package/lib/esm/components/postchatsurveypanestateful/common/defaultStyleProps/defaultgeneralPostChatSurveyPaneStyleProps.js +1 -1
- package/lib/esm/components/postchatsurveypanestateful/enums/CustomerVoiceEvents.js +6 -0
- package/lib/esm/components/postchatsurveypanestateful/enums/PostChatSurveyMode.js +0 -1
- package/lib/esm/components/postchatsurveypanestateful/interfaces/IPostChatSurveyPaneStatefulProps.js +1 -0
- package/lib/esm/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +30 -28
- package/lib/esm/components/prechatsurveypanestateful/common/defaultStyles/defaultGeneralPreChatSurveyPaneStyleProps.js +1 -1
- package/lib/esm/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +30 -14
- package/lib/esm/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.js +1 -0
- package/lib/esm/components/reconnectchatpanestateful/ReconnectChatPaneStateful.js +6 -6
- package/lib/esm/components/webchatcontainerstateful/WebChatContainerStateful.js +94 -4
- package/lib/esm/components/webchatcontainerstateful/common/defaultProps/defaultWebChatContainerStatefulProps.js +3 -1
- package/lib/esm/components/webchatcontainerstateful/common/defaultProps/defaultWebChatStatefulProps.js +2 -2
- package/lib/esm/components/webchatcontainerstateful/common/defaultStyles/defaultAdaptiveCardStyles.js +4 -0
- package/lib/esm/components/webchatcontainerstateful/common/mockadapter.js +12 -19
- package/lib/esm/components/webchatcontainerstateful/common/mockchatsdk.js +9 -12
- package/lib/esm/components/webchatcontainerstateful/common/utils/BrowserInfo.js +2 -16
- package/lib/esm/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +7 -17
- package/lib/esm/components/webchatcontainerstateful/common/utils/isMaskingFromCustomer.js +5 -6
- package/lib/esm/components/webchatcontainerstateful/interfaces/IAdaptiveCardStyles.js +1 -0
- package/lib/esm/components/webchatcontainerstateful/interfaces/IBotMagicCodeConfig.js +1 -0
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/BotMagicCodeStore.js +5 -0
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/WebChatStoreLoader.js +3 -3
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/BrowserVendor.js +0 -1
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/DirectLineActivityType.js +0 -1
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/DirectLineSenderRole.js +0 -1
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/MessageType.js +0 -1
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/NotificationLevel.js +0 -1
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/NotificationScenarios.js +0 -1
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/SendStatus.js +0 -1
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/WebChatActionType.js +0 -1
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/adaptermiddlewares/formatTagsEgressMiddleware.js +2 -5
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/adaptermiddlewares/formatTagsIngressMiddleware.js +0 -4
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.js +34 -66
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityStatusMiddleware.js +12 -14
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/attachmentMiddleware.js +27 -40
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/avatarMiddleware.js +9 -8
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.js +34 -0
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.js +80 -0
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultReceivedMessageAnchorStyles.js +3 -0
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultSystemMessageBoxStyles.js +3 -0
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultTimestampFailedStyles.js +2 -1
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultTimestampRetryStyles.js +2 -1
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultUserMessageBoxStyles.js +3 -0
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/groupActivitiesMiddleware.js +3 -7
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/messageTimestampMiddleware.js +83 -0
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/DeliveredTimestamp.js +8 -9
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/NotDeliveredTimestamp.js +9 -28
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/SendingTimestamp.js +5 -14
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/typingIndicatorMiddleware.js +15 -19
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/attachmentProcessingMiddleware.js +5 -8
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/attachmentUploadValidatorMiddleware.js +6 -29
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/channelDataMiddleware.js +3 -7
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/conversationEndMiddleware.js +9 -14
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/dataMaskingMiddleware.js +17 -14
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/gifUploadMiddleware.js +3 -7
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/htmlPlayerMiddleware.js +3 -7
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/htmlTextMiddleware.js +15 -27
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/maxMessageSizeValidator.js +3 -5
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/preProcessingMiddleware.js +9 -9
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/sanitizationMiddleware.js +7 -9
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/notification/NotificationHandler.js +1 -13
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.js +27 -0
- package/lib/esm/contexts/ChatAdapterStore.js +2 -1
- package/lib/esm/contexts/ChatContextStore.js +2 -1
- package/lib/esm/contexts/ChatSDKStore.js +2 -1
- package/lib/esm/contexts/common/ConversationState.js +4 -3
- package/lib/esm/contexts/common/LiveChatWidgetActionType.js +30 -23
- package/lib/esm/contexts/common/LiveChatWidgetContextInitialState.js +21 -8
- package/lib/esm/contexts/createReducer.js +181 -97
- package/lib/esm/controller/componentController.js +6 -5
- package/lib/esm/hooks/useChatAdapterStore.js +0 -4
- package/lib/esm/hooks/useChatContextStore.js +0 -4
- package/lib/esm/hooks/useChatSDKStore.js +0 -4
- package/lib/esm/plugins/newMessageEventHandler.js +75 -0
- package/lib/types/assets/Audios.d.ts +1 -0
- package/lib/types/assets/Icons.d.ts +12 -0
- package/lib/types/common/Constants.d.ts +41 -1
- package/lib/types/common/contextDataStore/DataStoreManager.d.ts +4 -0
- package/lib/types/common/interfaces/IContextDataStore.d.ts +14 -0
- package/lib/types/common/storage/default/defaultCacheManager.d.ts +4 -0
- package/lib/types/common/storage/default/defaultClientDataStoreProvider.d.ts +2 -0
- package/lib/types/common/storage/default/defaultInMemoryDataStore.d.ts +6 -0
- package/lib/types/common/telemetry/TelemetryConstants.d.ts +62 -4
- package/lib/types/common/telemetry/TelemetryHelper.d.ts +2 -0
- package/lib/types/common/telemetry/TelemetryManager.d.ts +1 -0
- package/lib/types/common/telemetry/definitions/Contracts.d.ts +7 -4
- package/lib/types/common/telemetry/definitions/Payload.d.ts +16 -9
- package/lib/types/common/telemetry/interfaces/IChatSDKLogger.d.ts +1 -0
- package/lib/types/common/telemetry/interfaces/IInternalTelemetryData.d.ts +2 -0
- package/lib/types/common/telemetry/interfaces/ITelemetryConfig.d.ts +16 -0
- package/lib/types/common/utils.d.ts +8 -1
- package/lib/types/components/confirmationpanestateful/interfaces/IConfirmationPaneStatefulParams.d.ts +5 -2
- package/lib/types/components/footerstateful/audionotificationstateful/interfaces/IAudioNotificationStatefulParams.d.ts +0 -1
- package/lib/types/components/headerstateful/interfaces/IHeaderStatefulParams.d.ts +5 -1
- package/lib/types/components/livechatwidget/common/ActivityStreamHandler.d.ts +14 -0
- package/lib/types/components/livechatwidget/common/ActivitySubscriber/DefaultActivitySubscriber.d.ts +5 -0
- package/lib/types/components/livechatwidget/common/ActivitySubscriber/IActivitySubscriber.d.ts +6 -0
- package/lib/types/components/livechatwidget/common/ActivitySubscriber/PauseActivitySubscriber.d.ts +7 -0
- package/lib/types/components/livechatwidget/common/ChatAdapterShim.d.ts +7 -0
- package/lib/types/components/livechatwidget/common/Deferred.d.ts +9 -0
- package/lib/types/components/livechatwidget/common/authHelper.d.ts +5 -0
- package/lib/types/components/livechatwidget/common/defaultProps/defaultScrollBarProps.d.ts +2 -0
- package/lib/types/components/livechatwidget/common/disposeTelemetryLoggers.d.ts +1 -0
- package/lib/types/components/livechatwidget/common/endChat.d.ts +4 -1
- package/lib/types/components/livechatwidget/common/reconnectChatHelper.d.ts +6 -4
- package/lib/types/components/livechatwidget/common/setPostChatContextAndLoadSurvey.d.ts +1 -1
- package/lib/types/components/livechatwidget/common/shareObservable.d.ts +1 -0
- package/lib/types/components/livechatwidget/common/startChat.d.ts +5 -2
- package/lib/types/components/livechatwidget/common/startProactiveChat.d.ts +2 -1
- package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetComponentOverrides.d.ts +1 -0
- package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetControlProps.d.ts +4 -1
- package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetProps.d.ts +8 -3
- package/lib/types/components/livechatwidget/interfaces/IScrollBarProps.d.ts +22 -0
- package/lib/types/components/loadingpanestateful/common/errorUIStyleProps/errorUILoadingPaneStyleProps.d.ts +2 -0
- package/lib/types/components/postchatsurveypanestateful/PostChatSurveyPaneStateful.d.ts +2 -2
- package/lib/types/components/postchatsurveypanestateful/enums/CustomerVoiceEvents.d.ts +5 -0
- package/lib/types/components/postchatsurveypanestateful/interfaces/IPostChatSurveyPaneStatefulProps.d.ts +4 -0
- package/lib/types/components/prechatsurveypanestateful/interfaces/IPreChatSurveyPaneStatefulParams.d.ts +1 -1
- package/lib/types/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.d.ts +3 -0
- package/lib/types/components/reconnectchatpanestateful/interfaces/IReconnectChatPaneStatefulProps.d.ts +1 -2
- package/lib/types/components/webchatcontainerstateful/common/defaultStyles/defaultAdaptiveCardStyles.d.ts +2 -0
- package/lib/types/components/webchatcontainerstateful/common/mockchatsdk.d.ts +2 -0
- package/lib/types/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.d.ts +1 -1
- package/lib/types/components/webchatcontainerstateful/interfaces/IAdaptiveCardStyles.d.ts +4 -0
- package/lib/types/components/webchatcontainerstateful/interfaces/IBotMagicCodeConfig.d.ts +4 -0
- package/lib/types/components/webchatcontainerstateful/interfaces/IRenderingMiddlewareProps.d.ts +4 -1
- package/lib/types/components/webchatcontainerstateful/interfaces/IWebChatContainerStatefulProps.d.ts +4 -0
- package/lib/types/components/webchatcontainerstateful/webchatcontroller/BotMagicCodeStore.d.ts +3 -0
- package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.d.ts +0 -1
- package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityStatusMiddleware.d.ts +1 -1
- package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.d.ts +2 -0
- package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.d.ts +1 -0
- package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultReceivedMessageAnchorStyles.d.ts +2 -0
- package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultSystemMessageBoxStyles.d.ts +3 -0
- package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultUserMessageBoxStyles.d.ts +3 -0
- package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/messageTimestampMiddleware.d.ts +5 -0
- package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/SendingTimestamp.d.ts +1 -1
- package/lib/types/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.d.ts +1 -0
- package/lib/types/contexts/common/ConversationState.d.ts +4 -2
- package/lib/types/contexts/common/ILiveChatWidgetContext.d.ts +8 -3
- package/lib/types/contexts/common/LiveChatWidgetActionType.d.ts +30 -22
- package/lib/types/contexts/common/LiveChatWidgetContextInitialState.d.ts +1 -2
- package/lib/types/plugins/newMessageEventHandler.d.ts +2 -0
- package/package.json +14 -13
- package/lib/cjs/assets/audios/newMessageNotification.mp3 +0 -0
- package/lib/cjs/assets/icons/archiveIcon.svg +0 -3
- package/lib/cjs/assets/icons/audioIcon.svg +0 -6
- package/lib/cjs/assets/icons/blankIcon.svg +0 -6
- package/lib/cjs/assets/icons/excelIcon.svg +0 -6
- package/lib/cjs/assets/icons/imageIcon.svg +0 -6
- package/lib/cjs/assets/icons/oneNoteIcon.svg +0 -6
- package/lib/cjs/assets/icons/pdfIcon.svg +0 -6
- package/lib/cjs/assets/icons/powerpointIcon.svg +0 -6
- package/lib/cjs/assets/icons/videoIcon.svg +0 -6
- package/lib/cjs/assets/icons/visioIcon.svg +0 -6
- package/lib/cjs/assets/icons/wordIcon.svg +0 -6
- package/lib/esm/assets/assets.d.js +0 -0
- package/lib/esm/assets/audios/newMessageNotification.mp3 +0 -0
- package/lib/esm/assets/icons/archiveIcon.svg +0 -3
- package/lib/esm/assets/icons/audioIcon.svg +0 -6
- package/lib/esm/assets/icons/blankIcon.svg +0 -6
- package/lib/esm/assets/icons/excelIcon.svg +0 -6
- package/lib/esm/assets/icons/imageIcon.svg +0 -6
- package/lib/esm/assets/icons/oneNoteIcon.svg +0 -6
- package/lib/esm/assets/icons/pdfIcon.svg +0 -6
- package/lib/esm/assets/icons/powerpointIcon.svg +0 -6
- package/lib/esm/assets/icons/videoIcon.svg +0 -6
- package/lib/esm/assets/icons/visioIcon.svg +0 -6
- package/lib/esm/assets/icons/wordIcon.svg +0 -6
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { defaultTimestampContentStyles } from "./defaultTimestampContentStyles";
|
|
2
|
-
export const defaultTimestampRetryStyles = {
|
|
2
|
+
export const defaultTimestampRetryStyles = {
|
|
3
|
+
...defaultTimestampContentStyles,
|
|
3
4
|
color: "#0063B1",
|
|
4
5
|
cursor: "pointer"
|
|
5
6
|
};
|
|
@@ -4,13 +4,12 @@
|
|
|
4
4
|
* This middleware controls which messages are grouped together regarding to timestamps. It does the following processing:
|
|
5
5
|
* 1. Distinguishes different messages by sender name and whether it is a system message
|
|
6
6
|
******/
|
|
7
|
-
import { Constants } from "../../../../../common/Constants";
|
|
8
7
|
|
|
8
|
+
import { Constants } from "../../../../../common/Constants";
|
|
9
9
|
function bin(items, grouping) {
|
|
10
10
|
let lastBin;
|
|
11
11
|
const bins = [];
|
|
12
12
|
let lastItem;
|
|
13
|
-
|
|
14
13
|
if (items.length > 0) {
|
|
15
14
|
items.forEach(item => {
|
|
16
15
|
if (lastItem && grouping(lastItem, item)) {
|
|
@@ -19,20 +18,17 @@ function bin(items, grouping) {
|
|
|
19
18
|
lastBin = [item];
|
|
20
19
|
bins.push(lastBin);
|
|
21
20
|
}
|
|
22
|
-
|
|
23
21
|
lastItem = item;
|
|
24
22
|
});
|
|
25
23
|
}
|
|
26
|
-
|
|
27
24
|
return bins;
|
|
28
|
-
}
|
|
29
|
-
|
|
25
|
+
}
|
|
30
26
|
|
|
27
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any
|
|
31
28
|
export const groupActivitiesMiddleware = () => next => args => {
|
|
32
29
|
const {
|
|
33
30
|
activities
|
|
34
31
|
} = args;
|
|
35
|
-
|
|
36
32
|
if (activities != null && activities.length > 0) {
|
|
37
33
|
const {
|
|
38
34
|
status
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { WebChatActionType } from "../../enums/WebChatActionType";
|
|
2
|
+
import { Constants } from "../../../../../common/Constants";
|
|
3
|
+
|
|
4
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unused-vars
|
|
5
|
+
const createMessageTimeStampMiddleware = _ref => {
|
|
6
|
+
let {
|
|
7
|
+
dispatch
|
|
8
|
+
} = _ref;
|
|
9
|
+
return next => action => {
|
|
10
|
+
if (isApplicable(action)) {
|
|
11
|
+
return next(evaluateTagsAndOverrideTimeStamp(action));
|
|
12
|
+
}
|
|
13
|
+
return next(action);
|
|
14
|
+
};
|
|
15
|
+
};
|
|
16
|
+
const isApplicable = action => {
|
|
17
|
+
return action.type === WebChatActionType.DIRECT_LINE_INCOMING_ACTIVITY && isPVAConversation(action) && isPayloadValid(action) && isValidChannel(action);
|
|
18
|
+
};
|
|
19
|
+
const isPayloadValid = action => {
|
|
20
|
+
var _action$payload;
|
|
21
|
+
return action === null || action === void 0 ? void 0 : (_action$payload = action.payload) === null || _action$payload === void 0 ? void 0 : _action$payload.activity;
|
|
22
|
+
};
|
|
23
|
+
const isValidChannel = action => {
|
|
24
|
+
var _action$payload2, _action$payload2$acti;
|
|
25
|
+
return (action === null || action === void 0 ? void 0 : (_action$payload2 = action.payload) === null || _action$payload2 === void 0 ? void 0 : (_action$payload2$acti = _action$payload2.activity) === null || _action$payload2$acti === void 0 ? void 0 : _action$payload2$acti.channelId) === Constants.acsChannel;
|
|
26
|
+
};
|
|
27
|
+
const isPVAConversation = action => {
|
|
28
|
+
return !isTagIncluded(action, Constants.systemMessageTag) && !isTagIncluded(action, Constants.publicMessageTag) && !isRoleUserOn(action);
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
32
|
+
const isTagIncluded = (action, tag) => {
|
|
33
|
+
return isDataTagsPresent(action) && action.payload.activity.channelData.tags.includes(tag);
|
|
34
|
+
};
|
|
35
|
+
const isRoleUserOn = action => {
|
|
36
|
+
var _action$payload3, _action$payload3$acti, _action$payload3$acti2;
|
|
37
|
+
return (action === null || action === void 0 ? void 0 : (_action$payload3 = action.payload) === null || _action$payload3 === void 0 ? void 0 : (_action$payload3$acti = _action$payload3.activity) === null || _action$payload3$acti === void 0 ? void 0 : (_action$payload3$acti2 = _action$payload3$acti.from) === null || _action$payload3$acti2 === void 0 ? void 0 : _action$payload3$acti2.role) === Constants.userMessageTag;
|
|
38
|
+
};
|
|
39
|
+
const overrideTimeStamp = (timestampOriginal, timeStampNew) => {
|
|
40
|
+
return isTimestampValid(timeStampNew) ? timeStampNew : timestampOriginal;
|
|
41
|
+
};
|
|
42
|
+
const isTimestampValid = timeStamp => {
|
|
43
|
+
const regex = /(\d{4}-(0[1-9]|1[0-2])-(0[1-9]|[12]\d|3[01])(T)(\d{2})(:{1})(\d{2})(:{1})(\d{2})(.\d+)([Z]{1}))/;
|
|
44
|
+
return regex.test(timeStamp);
|
|
45
|
+
};
|
|
46
|
+
const isDataTagsPresent = action => {
|
|
47
|
+
var _action$payload4, _action$payload4$acti, _action$payload4$acti2;
|
|
48
|
+
return (action === null || action === void 0 ? void 0 : (_action$payload4 = action.payload) === null || _action$payload4 === void 0 ? void 0 : (_action$payload4$acti = _action$payload4.activity) === null || _action$payload4$acti === void 0 ? void 0 : (_action$payload4$acti2 = _action$payload4$acti.channelData) === null || _action$payload4$acti2 === void 0 ? void 0 : _action$payload4$acti2.tags) && action.payload.activity.channelData.tags.length > 0;
|
|
49
|
+
};
|
|
50
|
+
const evaluateTagsAndOverrideTimeStamp = action => {
|
|
51
|
+
const tagValue = tagLookup(action, Constants.prefixTimestampTag);
|
|
52
|
+
if (tagValue) {
|
|
53
|
+
const newTimestamp = extractTimeStamp(tagValue);
|
|
54
|
+
action.payload.activity.timestamp = overrideTimeStamp(action.payload.activity.timestamp, newTimestamp);
|
|
55
|
+
}
|
|
56
|
+
return action;
|
|
57
|
+
};
|
|
58
|
+
const extractTimeStamp = timeStamp => {
|
|
59
|
+
if (timeStamp && timeStamp.length > 0) {
|
|
60
|
+
const ts = timeStamp.split(Constants.prefixTimestampTag);
|
|
61
|
+
if (ts && ts.length > 1) {
|
|
62
|
+
return ts[1];
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
return timeStamp;
|
|
66
|
+
};
|
|
67
|
+
const tagLookup = (action, tag) => {
|
|
68
|
+
if (!isDataTagsPresent(action)) {
|
|
69
|
+
return null;
|
|
70
|
+
}
|
|
71
|
+
const tags = action.payload.activity.channelData.tags;
|
|
72
|
+
let value;
|
|
73
|
+
if (tags && tags.length > 0) {
|
|
74
|
+
for (let i = 0; i < tags.length; i++) {
|
|
75
|
+
value = tags[i];
|
|
76
|
+
if (value && value.indexOf(tag) > -1) {
|
|
77
|
+
return value;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
return null;
|
|
82
|
+
};
|
|
83
|
+
export default createMessageTimeStampMiddleware;
|
|
@@ -5,11 +5,10 @@ import { defaultMiddlewareLocalizedTexts } from "../../../../common/defaultProps
|
|
|
5
5
|
import { defaultTimestampContentStyles } from "../defaultStyles/defaultTimestampContentStyles";
|
|
6
6
|
import { getTimestampHourMinute } from "../../../../../../common/utils";
|
|
7
7
|
import { useChatContextStore } from "../../../../../..";
|
|
8
|
-
/* eslint @typescript-eslint/no-explicit-any: "off" */
|
|
9
8
|
|
|
9
|
+
/* eslint @typescript-eslint/no-explicit-any: "off" */
|
|
10
10
|
export const DeliveredTimestamp = _ref => {
|
|
11
11
|
var _state$domainStates$r, _state$domainStates$r2, _state$domainStates$m;
|
|
12
|
-
|
|
13
12
|
let {
|
|
14
13
|
args,
|
|
15
14
|
role,
|
|
@@ -17,7 +16,8 @@ export const DeliveredTimestamp = _ref => {
|
|
|
17
16
|
} = _ref;
|
|
18
17
|
const [state] = useChatContextStore();
|
|
19
18
|
const dir = ((_state$domainStates$r = state.domainStates.renderingMiddlewareProps) === null || _state$domainStates$r === void 0 ? void 0 : _state$domainStates$r.timestampDir) ?? state.domainStates.globalDir;
|
|
20
|
-
const contentStyles = {
|
|
19
|
+
const contentStyles = {
|
|
20
|
+
...defaultTimestampContentStyles,
|
|
21
21
|
...((_state$domainStates$r2 = state.domainStates.renderingMiddlewareProps) === null || _state$domainStates$r2 === void 0 ? void 0 : _state$domainStates$r2.timestampContentStyleProps)
|
|
22
22
|
};
|
|
23
23
|
const {
|
|
@@ -27,13 +27,12 @@ export const DeliveredTimestamp = _ref => {
|
|
|
27
27
|
} = args;
|
|
28
28
|
return /*#__PURE__*/React.createElement(Stack, {
|
|
29
29
|
style: contentStyles,
|
|
30
|
+
dir: dir
|
|
31
|
+
}, role === DirectLineSenderRole.Bot && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("span", {
|
|
30
32
|
dir: dir,
|
|
31
|
-
horizontal: true
|
|
32
|
-
}, role === DirectLineSenderRole.Bot && /*#__PURE__*/React.createElement("span", {
|
|
33
33
|
"aria-hidden": "false"
|
|
34
|
-
}, name), role === DirectLineSenderRole.
|
|
34
|
+
}, name, " - ", getTimestampHourMinute(timestamp))), role === DirectLineSenderRole.User && /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("span", {
|
|
35
|
+
"aria-hidden": "false",
|
|
35
36
|
dir: dir
|
|
36
|
-
}, " ", getTimestampHourMinute(timestamp)
|
|
37
|
-
"aria-hidden": "false"
|
|
38
|
-
}, ((_state$domainStates$m = state.domainStates.middlewareLocalizedTexts) === null || _state$domainStates$m === void 0 ? void 0 : _state$domainStates$m.MIDDLEWARE_MESSAGE_DELIVERED) ?? defaultMiddlewareLocalizedTexts.MIDDLEWARE_MESSAGE_DELIVERED));
|
|
37
|
+
}, " ", getTimestampHourMinute(timestamp), " - ", ((_state$domainStates$m = state.domainStates.middlewareLocalizedTexts) === null || _state$domainStates$m === void 0 ? void 0 : _state$domainStates$m.MIDDLEWARE_MESSAGE_DELIVERED) ?? defaultMiddlewareLocalizedTexts.MIDDLEWARE_MESSAGE_DELIVERED)));
|
|
39
38
|
};
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import React, { useCallback, useEffect, useRef } from "react";
|
|
2
|
-
import { HtmlAttributeNames } from "../../../../../../common/Constants";
|
|
3
2
|
import { KeyCodes } from "../../../../../../common/KeyCodes";
|
|
4
3
|
import { Stack } from "@fluentui/react";
|
|
5
4
|
import { defaultMiddlewareLocalizedTexts } from "../../../../common/defaultProps/defaultMiddlewareLocalizedTexts";
|
|
@@ -9,11 +8,10 @@ import { defaultTimestampRetryStyles } from "../defaultStyles/defaultTimestampRe
|
|
|
9
8
|
import { getTimestampHourMinute } from "../../../../../../common/utils";
|
|
10
9
|
import { hooks } from "botframework-webchat";
|
|
11
10
|
import { useChatContextStore } from "../../../../../..";
|
|
12
|
-
/* eslint @typescript-eslint/no-explicit-any: "off" */
|
|
13
11
|
|
|
12
|
+
/* eslint @typescript-eslint/no-explicit-any: "off" */
|
|
14
13
|
export const NotDeliveredTimestamp = _ref => {
|
|
15
14
|
var _state$domainStates$r, _state$domainStates$r2, _state$domainStates$r3, _state$domainStates$r4, _state$domainStates$m, _state$domainStates$m2;
|
|
16
|
-
|
|
17
15
|
let {
|
|
18
16
|
args
|
|
19
17
|
} = _ref;
|
|
@@ -32,54 +30,37 @@ export const NotDeliveredTimestamp = _ref => {
|
|
|
32
30
|
} = activity;
|
|
33
31
|
const [state] = useChatContextStore();
|
|
34
32
|
const dir = ((_state$domainStates$r = state.domainStates.renderingMiddlewareProps) === null || _state$domainStates$r === void 0 ? void 0 : _state$domainStates$r.timestampDir) ?? state.domainStates.globalDir;
|
|
35
|
-
const contentStyles = {
|
|
33
|
+
const contentStyles = {
|
|
34
|
+
...defaultTimestampContentStyles,
|
|
36
35
|
...((_state$domainStates$r2 = state.domainStates.renderingMiddlewareProps) === null || _state$domainStates$r2 === void 0 ? void 0 : _state$domainStates$r2.timestampContentStyleProps)
|
|
37
36
|
};
|
|
38
|
-
const failedTextStyles = {
|
|
37
|
+
const failedTextStyles = {
|
|
38
|
+
...defaultTimestampFailedStyles,
|
|
39
39
|
...((_state$domainStates$r3 = state.domainStates.renderingMiddlewareProps) === null || _state$domainStates$r3 === void 0 ? void 0 : _state$domainStates$r3.timestampFailedTextStyleProps)
|
|
40
40
|
};
|
|
41
|
-
const retryTextStyles = {
|
|
41
|
+
const retryTextStyles = {
|
|
42
|
+
...defaultTimestampRetryStyles,
|
|
42
43
|
...((_state$domainStates$r4 = state.domainStates.renderingMiddlewareProps) === null || _state$domainStates$r4 === void 0 ? void 0 : _state$domainStates$r4.timestampRetryTextStyleProps)
|
|
43
44
|
};
|
|
44
45
|
useEffect(() => {
|
|
45
46
|
var _timestampRef$current;
|
|
46
|
-
|
|
47
47
|
const timestampWebChatNodes = timestampRef === null || timestampRef === void 0 ? void 0 : (_timestampRef$current = timestampRef.current) === null || _timestampRef$current === void 0 ? void 0 : _timestampRef$current.childNodes;
|
|
48
|
-
|
|
49
48
|
if ((timestampWebChatNodes === null || timestampWebChatNodes === void 0 ? void 0 : timestampWebChatNodes.length) > 1) {
|
|
50
49
|
timestampWebChatNodes[1].innerText = getTimestampHourMinute(timestamp);
|
|
51
50
|
}
|
|
52
51
|
}, [timestampRef]);
|
|
53
|
-
const onRetryClick = useCallback(async
|
|
52
|
+
const onRetryClick = useCallback(async () => {
|
|
54
53
|
var _activity$channelData;
|
|
55
|
-
|
|
56
|
-
removeNotDeliveredTimestamp(event);
|
|
57
54
|
activity.previousClientActivityID = (_activity$channelData = activity.channelData) === null || _activity$channelData === void 0 ? void 0 : _activity$channelData.clientActivityID;
|
|
58
55
|
await postActivity(activity);
|
|
59
56
|
focus("sendBox");
|
|
60
57
|
}, [activity, focus, postActivity]);
|
|
61
|
-
|
|
62
58
|
const onRetryKeyEnter = event => {
|
|
63
59
|
if (event.code === KeyCodes.ENTER) {
|
|
64
60
|
event.preventDefault();
|
|
65
|
-
onRetryClick(
|
|
61
|
+
onRetryClick();
|
|
66
62
|
}
|
|
67
63
|
};
|
|
68
|
-
|
|
69
|
-
const removeNotDeliveredTimestamp = event => {
|
|
70
|
-
let parent = event.target.parentElement;
|
|
71
|
-
|
|
72
|
-
while (parent.tagName !== HtmlAttributeNames.listItem) {
|
|
73
|
-
parent = parent.parentElement;
|
|
74
|
-
|
|
75
|
-
if (parent.tagName === HtmlAttributeNames.unorderedList) {
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
parent.parentNode.removeChild(parent);
|
|
81
|
-
};
|
|
82
|
-
|
|
83
64
|
return /*#__PURE__*/React.createElement(Stack, {
|
|
84
65
|
style: contentStyles,
|
|
85
66
|
dir: dir,
|
|
@@ -2,29 +2,20 @@ import React from "react";
|
|
|
2
2
|
import { Stack } from "@fluentui/react";
|
|
3
3
|
import { defaultMiddlewareLocalizedTexts } from "../../../../common/defaultProps/defaultMiddlewareLocalizedTexts";
|
|
4
4
|
import { defaultTimestampContentStyles } from "../defaultStyles/defaultTimestampContentStyles";
|
|
5
|
-
import { getTimestampHourMinute } from "../../../../../../common/utils";
|
|
6
5
|
import { useChatContextStore } from "../../../../../..";
|
|
7
|
-
/* eslint @typescript-eslint/no-explicit-any: "off" */
|
|
8
6
|
|
|
9
|
-
|
|
7
|
+
/* eslint @typescript-eslint/no-explicit-any: "off" */
|
|
8
|
+
export const SendingTimestamp = () => {
|
|
10
9
|
var _state$domainStates$r, _state$domainStates$r2, _state$domainStates$m;
|
|
11
|
-
|
|
12
|
-
let {
|
|
13
|
-
args
|
|
14
|
-
} = _ref;
|
|
15
10
|
const [state] = useChatContextStore();
|
|
16
11
|
const dir = ((_state$domainStates$r = state.domainStates.renderingMiddlewareProps) === null || _state$domainStates$r === void 0 ? void 0 : _state$domainStates$r.timestampDir) ?? state.domainStates.globalDir;
|
|
17
|
-
const contentStyles = {
|
|
12
|
+
const contentStyles = {
|
|
13
|
+
...defaultTimestampContentStyles,
|
|
18
14
|
...((_state$domainStates$r2 = state.domainStates.renderingMiddlewareProps) === null || _state$domainStates$r2 === void 0 ? void 0 : _state$domainStates$r2.timestampContentStyleProps)
|
|
19
15
|
};
|
|
20
|
-
const {
|
|
21
|
-
activity: {
|
|
22
|
-
timestamp
|
|
23
|
-
}
|
|
24
|
-
} = args;
|
|
25
16
|
return /*#__PURE__*/React.createElement(Stack, {
|
|
26
17
|
style: contentStyles,
|
|
27
18
|
dir: dir,
|
|
28
19
|
horizontal: true
|
|
29
|
-
}, /*#__PURE__*/React.createElement("span", null, " ",
|
|
20
|
+
}, /*#__PURE__*/React.createElement("span", null, " ", ((_state$domainStates$m = state.domainStates.middlewareLocalizedTexts) === null || _state$domainStates$m === void 0 ? void 0 : _state$domainStates$m.MIDDLEWARE_MESSAGE_SENDING) ?? defaultMiddlewareLocalizedTexts.MIDDLEWARE_MESSAGE_SENDING, " "));
|
|
30
21
|
};
|
|
@@ -3,6 +3,7 @@
|
|
|
3
3
|
*
|
|
4
4
|
* This middleware changes the component that shows who's actively typing. It uses the default Microsoft LiveChatWidget styles.
|
|
5
5
|
******/
|
|
6
|
+
|
|
6
7
|
import React from "react";
|
|
7
8
|
import { DirectLineSenderRole } from "../../enums/DirectLineSenderRole";
|
|
8
9
|
import { defaultMiddlewareLocalizedTexts } from "../../../common/defaultProps/defaultMiddlewareLocalizedTexts";
|
|
@@ -10,11 +11,11 @@ import { defaultTypingIndicatorBubbleStyles } from "./defaultStyles/defaultTypin
|
|
|
10
11
|
import { defaultTypingIndicatorContainerStyles } from "./defaultStyles/defaultTypingIndicatorContainerStyles";
|
|
11
12
|
import { defaultTypingIndicatorMessageStyles } from "./defaultStyles/defaultTypingIndicatorMessageStyles";
|
|
12
13
|
import { useChatContextStore } from "../../../../..";
|
|
13
|
-
import useChatSDKStore from "../../../../../hooks/useChatSDKStore";
|
|
14
|
+
import useChatSDKStore from "../../../../../hooks/useChatSDKStore";
|
|
14
15
|
|
|
16
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
15
17
|
const TypingIndicator = _ref => {
|
|
16
18
|
var _state$domainStates$l, _state$domainStates$r, _state$domainStates$r2, _state$domainStates$r3;
|
|
17
|
-
|
|
18
19
|
let {
|
|
19
20
|
activeTyping,
|
|
20
21
|
visible
|
|
@@ -22,39 +23,37 @@ const TypingIndicator = _ref => {
|
|
|
22
23
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
23
24
|
const chatSDK = useChatSDKStore();
|
|
24
25
|
const [state] = useChatContextStore();
|
|
25
|
-
|
|
26
26
|
if (!activeTyping || Object.keys(activeTyping).length === 0 || ((_state$domainStates$l = state.domainStates.liveChatConfig) === null || _state$domainStates$l === void 0 ? void 0 : _state$domainStates$l.LiveChatVersion) === 1 && !visible) {
|
|
27
27
|
return null;
|
|
28
28
|
}
|
|
29
|
-
|
|
30
29
|
activeTyping = Object.keys(activeTyping).map(key => activeTyping[key]);
|
|
31
|
-
|
|
32
30
|
for (let i = 0; i < activeTyping.length; i++) {
|
|
33
31
|
if (activeTyping[i].role && activeTyping[i].role === DirectLineSenderRole.User) {
|
|
34
32
|
var _state$domainStates$l2;
|
|
35
|
-
|
|
36
33
|
//visible is set to false if the current user is typing, in which case, we just send typing indicator to OC
|
|
37
34
|
if (((_state$domainStates$l2 = state.domainStates.liveChatConfig) === null || _state$domainStates$l2 === void 0 ? void 0 : _state$domainStates$l2.LiveChatVersion) === 2 && !visible) {
|
|
38
35
|
chatSDK === null || chatSDK === void 0 ? void 0 : chatSDK.sendTypingEvent();
|
|
39
36
|
return null;
|
|
40
37
|
}
|
|
41
|
-
|
|
42
38
|
activeTyping.splice(i, 1);
|
|
43
39
|
i--;
|
|
44
40
|
}
|
|
45
41
|
}
|
|
46
|
-
|
|
47
|
-
|
|
42
|
+
const localizedTexts = {
|
|
43
|
+
...defaultMiddlewareLocalizedTexts,
|
|
48
44
|
...state.domainStates.middlewareLocalizedTexts
|
|
49
45
|
};
|
|
50
46
|
const message = getTypingIndicatorMessage(activeTyping, localizedTexts);
|
|
51
|
-
const typingIndicatorStyles = {
|
|
47
|
+
const typingIndicatorStyles = {
|
|
48
|
+
...defaultTypingIndicatorContainerStyles,
|
|
52
49
|
...((_state$domainStates$r = state.domainStates.renderingMiddlewareProps) === null || _state$domainStates$r === void 0 ? void 0 : _state$domainStates$r.typingIndicatorStyleProps)
|
|
53
50
|
};
|
|
54
|
-
const typingIndicatorBubbleStyles = {
|
|
51
|
+
const typingIndicatorBubbleStyles = {
|
|
52
|
+
...defaultTypingIndicatorBubbleStyles,
|
|
55
53
|
...((_state$domainStates$r2 = state.domainStates.renderingMiddlewareProps) === null || _state$domainStates$r2 === void 0 ? void 0 : _state$domainStates$r2.typingIndicatorBubbleStyleProps)
|
|
56
54
|
};
|
|
57
|
-
const typingIndicatorMessageStyles = {
|
|
55
|
+
const typingIndicatorMessageStyles = {
|
|
56
|
+
...defaultTypingIndicatorMessageStyles,
|
|
58
57
|
...((_state$domainStates$r3 = state.domainStates.renderingMiddlewareProps) === null || _state$domainStates$r3 === void 0 ? void 0 : _state$domainStates$r3.typingIndicatorMessageStyleProps)
|
|
59
58
|
};
|
|
60
59
|
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("style", null, `
|
|
@@ -96,9 +95,9 @@ const TypingIndicator = _ref => {
|
|
|
96
95
|
}), /*#__PURE__*/React.createElement("div", {
|
|
97
96
|
style: typingIndicatorMessageStyles
|
|
98
97
|
}, " ", message, " ")));
|
|
99
|
-
};
|
|
100
|
-
|
|
98
|
+
};
|
|
101
99
|
|
|
100
|
+
// eslint-disable-next-line react/display-name, @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any
|
|
102
101
|
export const typingIndicatorMiddleware = () => next => args => {
|
|
103
102
|
const {
|
|
104
103
|
activeTyping,
|
|
@@ -108,8 +107,9 @@ export const typingIndicatorMiddleware = () => next => args => {
|
|
|
108
107
|
activeTyping: activeTyping,
|
|
109
108
|
visible: visible
|
|
110
109
|
});
|
|
111
|
-
};
|
|
110
|
+
};
|
|
112
111
|
|
|
112
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
113
113
|
const getTypingIndicatorMessage = (activeTyping, localizedTexts) => {
|
|
114
114
|
if (!activeTyping || activeTyping.length === 0) {
|
|
115
115
|
return "";
|
|
@@ -120,19 +120,15 @@ const getTypingIndicatorMessage = (activeTyping, localizedTexts) => {
|
|
|
120
120
|
const firstMember = activeTyping[0].name;
|
|
121
121
|
const lastMember = activeTyping[1].name;
|
|
122
122
|
let message = localizedTexts.MIDDLEWARE_TYPING_INDICATOR_TWO;
|
|
123
|
-
|
|
124
123
|
if (!message) {
|
|
125
124
|
return "";
|
|
126
125
|
}
|
|
127
|
-
|
|
128
126
|
if (message.includes("{0}")) {
|
|
129
127
|
message = message.replace("{0}", firstMember);
|
|
130
128
|
}
|
|
131
|
-
|
|
132
129
|
if (message.includes("{1}")) {
|
|
133
130
|
message = message.replace("{1}", lastMember);
|
|
134
131
|
}
|
|
135
|
-
|
|
136
132
|
return message;
|
|
137
133
|
} else {
|
|
138
134
|
const message = localizedTexts.MIDDLEWARE_TYPING_INDICATOR_MULTIPLE;
|
|
@@ -3,8 +3,10 @@
|
|
|
3
3
|
*
|
|
4
4
|
* Handles attachment sending.
|
|
5
5
|
******/
|
|
6
|
-
import { WebChatActionType } from "../../enums/WebChatActionType"; // eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
7
6
|
|
|
7
|
+
import { WebChatActionType } from "../../enums/WebChatActionType";
|
|
8
|
+
|
|
9
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
8
10
|
const createSendFileAction = files => {
|
|
9
11
|
return {
|
|
10
12
|
payload: {
|
|
@@ -12,31 +14,26 @@ const createSendFileAction = files => {
|
|
|
12
14
|
},
|
|
13
15
|
type: WebChatActionType.WEB_CHAT_SEND_FILES
|
|
14
16
|
};
|
|
15
|
-
};
|
|
16
|
-
|
|
17
|
+
};
|
|
17
18
|
|
|
19
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
18
20
|
const attachmentProcessingMiddleware = _ref => {
|
|
19
21
|
let {
|
|
20
22
|
dispatch
|
|
21
23
|
} = _ref;
|
|
22
24
|
return next => async action => {
|
|
23
25
|
var _action$payload, _action$payload$files;
|
|
24
|
-
|
|
25
26
|
if ((action === null || action === void 0 ? void 0 : action.type) === WebChatActionType.WEB_CHAT_SEND_FILES && (action === null || action === void 0 ? void 0 : (_action$payload = action.payload) === null || _action$payload === void 0 ? void 0 : (_action$payload$files = _action$payload.files) === null || _action$payload$files === void 0 ? void 0 : _action$payload$files.length) > 0) {
|
|
26
27
|
const files = action.payload.files;
|
|
27
|
-
|
|
28
28
|
if (files.length === 1) {
|
|
29
29
|
return next(action);
|
|
30
30
|
}
|
|
31
|
-
|
|
32
31
|
const dispatchAction = createSendFileAction(files.slice(0, files.length - 1));
|
|
33
32
|
const nextAction = createSendFileAction([files[files.length - 1]]);
|
|
34
33
|
await dispatch(dispatchAction);
|
|
35
34
|
return next(nextAction);
|
|
36
35
|
}
|
|
37
|
-
|
|
38
36
|
return next(action);
|
|
39
37
|
};
|
|
40
38
|
};
|
|
41
|
-
|
|
42
39
|
export default attachmentProcessingMiddleware;
|
|
@@ -3,27 +3,25 @@
|
|
|
3
3
|
*
|
|
4
4
|
* Checks if the attachment being uploaded satisfies Omnichannel's requirement on file extensions and file size.
|
|
5
5
|
******/
|
|
6
|
+
|
|
6
7
|
import { NotificationHandler } from "../../notification/NotificationHandler";
|
|
7
8
|
import { NotificationScenarios } from "../../enums/NotificationScenarios";
|
|
8
9
|
import { WebChatActionType } from "../../enums/WebChatActionType";
|
|
9
10
|
const MBtoBRatio = 1000000;
|
|
11
|
+
|
|
10
12
|
/*
|
|
11
13
|
* If an attachment is invalid, delete this attachment from the attachments list
|
|
12
14
|
* If the result attachment list is empty, return a dummy action
|
|
13
15
|
*/
|
|
14
|
-
|
|
15
16
|
const validateAttachment = (action, allowedFileExtensions, maxUploadFileSize, localizedTexts) => {
|
|
16
17
|
var _action$payload, _action$payload$activ, _action$payload2, _action$payload2$acti, _action$payload2$acti2, _action$payload3, _action$payload3$acti, _action$payload3$acti2;
|
|
17
|
-
|
|
18
18
|
const attachments = action === null || action === void 0 ? void 0 : (_action$payload = action.payload) === null || _action$payload === void 0 ? void 0 : (_action$payload$activ = _action$payload.activity) === null || _action$payload$activ === void 0 ? void 0 : _action$payload$activ.attachments;
|
|
19
19
|
const attachmentSizes = action === null || action === void 0 ? void 0 : (_action$payload2 = action.payload) === null || _action$payload2 === void 0 ? void 0 : (_action$payload2$acti = _action$payload2.activity) === null || _action$payload2$acti === void 0 ? void 0 : (_action$payload2$acti2 = _action$payload2$acti.channelData) === null || _action$payload2$acti2 === void 0 ? void 0 : _action$payload2$acti2.attachmentSizes;
|
|
20
|
-
|
|
21
20
|
if (attachments) {
|
|
22
21
|
for (let i = 0; i < attachments.length; i++) {
|
|
23
22
|
const fileExtensionValid = validateFileExtension(attachments[i], allowedFileExtensions);
|
|
24
23
|
const fileSizeValid = validateFileSize(attachmentSizes[i], maxUploadFileSize);
|
|
25
24
|
const fileIsEmpty = parseInt(attachmentSizes[i]) == 0;
|
|
26
|
-
|
|
27
25
|
if (!fileExtensionValid || !fileSizeValid || fileIsEmpty) {
|
|
28
26
|
NotificationHandler.notifyError(NotificationScenarios.AttachmentError, buildErrorMessage(attachments[i].name, fileExtensionValid, fileSizeValid, fileIsEmpty, maxUploadFileSize, localizedTexts));
|
|
29
27
|
attachments.splice(i, 1);
|
|
@@ -32,7 +30,6 @@ const validateAttachment = (action, allowedFileExtensions, maxUploadFileSize, lo
|
|
|
32
30
|
}
|
|
33
31
|
}
|
|
34
32
|
}
|
|
35
|
-
|
|
36
33
|
if ((action === null || action === void 0 ? void 0 : (_action$payload3 = action.payload) === null || _action$payload3 === void 0 ? void 0 : (_action$payload3$acti = _action$payload3.activity) === null || _action$payload3$acti === void 0 ? void 0 : (_action$payload3$acti2 = _action$payload3$acti.attachments) === null || _action$payload3$acti2 === void 0 ? void 0 : _action$payload3$acti2.length) > 0) {
|
|
37
34
|
return action;
|
|
38
35
|
} else {
|
|
@@ -41,37 +38,30 @@ const validateAttachment = (action, allowedFileExtensions, maxUploadFileSize, lo
|
|
|
41
38
|
payload: null
|
|
42
39
|
};
|
|
43
40
|
}
|
|
44
|
-
};
|
|
45
|
-
|
|
41
|
+
};
|
|
46
42
|
|
|
43
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
47
44
|
const validateFileExtension = (attachment, allowedFileExtensions) => {
|
|
48
45
|
if (!allowedFileExtensions) {
|
|
49
46
|
return true;
|
|
50
47
|
}
|
|
51
|
-
|
|
52
48
|
const fileName = attachment.name.toLowerCase();
|
|
53
49
|
const index = fileName.lastIndexOf(".");
|
|
54
|
-
|
|
55
50
|
if (!index) {
|
|
56
51
|
return false;
|
|
57
52
|
}
|
|
58
|
-
|
|
59
53
|
const fileExtension = fileName.substring(index);
|
|
60
54
|
const allExtensions = allowedFileExtensions === null || allowedFileExtensions === void 0 ? void 0 : allowedFileExtensions.toLowerCase().split(",");
|
|
61
55
|
return allExtensions.indexOf(fileExtension) > -1;
|
|
62
56
|
};
|
|
63
|
-
|
|
64
57
|
const validateFileSize = (attachmentSize, maxUploadFileSize) => {
|
|
65
58
|
return (maxUploadFileSize && parseInt(maxUploadFileSize) * MBtoBRatio) > parseInt(attachmentSize);
|
|
66
59
|
};
|
|
67
|
-
|
|
68
60
|
const buildErrorMessage = (fileName, supportedFileExtension, supportedFileSize, fileIsEmpty, maxUploadFileSize, localizedTexts) => {
|
|
69
61
|
let errorMessage = "";
|
|
70
|
-
|
|
71
62
|
if (!fileName || !maxUploadFileSize) {
|
|
72
63
|
return localizedTexts.MIDDLEWARE_BANNER_FILE_NULL_ERROR ?? "";
|
|
73
64
|
}
|
|
74
|
-
|
|
75
65
|
if (!supportedFileExtension && !supportedFileSize) {
|
|
76
66
|
errorMessage = getFileSizeAndFileExtensionErrorMessage(fileName, maxUploadFileSize, localizedTexts);
|
|
77
67
|
} else if (!supportedFileSize) {
|
|
@@ -83,33 +73,25 @@ const buildErrorMessage = (fileName, supportedFileExtension, supportedFileSize,
|
|
|
83
73
|
} else {
|
|
84
74
|
errorMessage = localizedTexts.MIDDLEWARE_BANNER_ERROR_MESSAGE ?? "";
|
|
85
75
|
}
|
|
86
|
-
|
|
87
76
|
return errorMessage;
|
|
88
77
|
};
|
|
89
|
-
|
|
90
78
|
const getFileSizeAndFileExtensionErrorMessage = (fileName, maxUploadFileSize, localizedTexts) => {
|
|
91
79
|
const index = fileName.lastIndexOf(".");
|
|
92
80
|
let errorMessage;
|
|
93
|
-
|
|
94
81
|
if (index < 0) {
|
|
95
82
|
errorMessage = localizedTexts.MIDDLEWARE_BANNER_FILE_SIZE_WITHOUT_EXTENSION_ERROR;
|
|
96
83
|
} else {
|
|
97
84
|
var _errorMessage;
|
|
98
|
-
|
|
99
85
|
const fileExtension = fileName.substring(index);
|
|
100
86
|
errorMessage = localizedTexts.MIDDLEWARE_BANNER_FILE_SIZE_EXTENSION_ERROR;
|
|
101
|
-
|
|
102
87
|
if ((_errorMessage = errorMessage) !== null && _errorMessage !== void 0 && _errorMessage.includes("{1}")) {
|
|
103
88
|
errorMessage = errorMessage.replace("{1}", fileExtension);
|
|
104
89
|
}
|
|
105
90
|
}
|
|
106
|
-
|
|
107
91
|
return errorMessage ? errorMessage.includes("{0}") ? errorMessage.replace("{0}", maxUploadFileSize) : errorMessage : "";
|
|
108
92
|
};
|
|
109
|
-
|
|
110
93
|
const getFileExtensionErrorMessage = (fileName, localizedTexts) => {
|
|
111
94
|
const index = fileName.lastIndexOf(".");
|
|
112
|
-
|
|
113
95
|
if (index < 0) {
|
|
114
96
|
return localizedTexts.MIDDLEWARE_BANNER_FILE_WITHOUT_EXTENSION ?? "";
|
|
115
97
|
} else {
|
|
@@ -118,13 +100,12 @@ const getFileExtensionErrorMessage = (fileName, localizedTexts) => {
|
|
|
118
100
|
return errorMessage ? errorMessage.includes("{0}") ? errorMessage.replace("{0}", fileExtension) : errorMessage : "";
|
|
119
101
|
}
|
|
120
102
|
};
|
|
121
|
-
|
|
122
103
|
const getFileSizeErrorMessage = (maxUploadFileSize, localizedTexts) => {
|
|
123
104
|
const errorMessage = localizedTexts.MIDDLEWARE_BANNER_FILE_SIZE_ERROR;
|
|
124
105
|
return errorMessage ? errorMessage.includes("{0}") ? errorMessage.replace("{0}", maxUploadFileSize) : errorMessage : "";
|
|
125
|
-
};
|
|
126
|
-
|
|
106
|
+
};
|
|
127
107
|
|
|
108
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unused-vars
|
|
128
109
|
const createAttachmentUploadValidatorMiddleware = (allowedFileExtensions, maxUploadFileSize, localizedTexts) => _ref => {
|
|
129
110
|
let {
|
|
130
111
|
dispatch
|
|
@@ -132,18 +113,14 @@ const createAttachmentUploadValidatorMiddleware = (allowedFileExtensions, maxUpl
|
|
|
132
113
|
return next => action => {
|
|
133
114
|
if (action.type === WebChatActionType.DIRECT_LINE_POST_ACTIVITY) {
|
|
134
115
|
var _payload$activity, _payload$activity2, _payload$activity2$ch, _payload$activity3, _payload$activity3$at, _payload$activity4, _payload$activity4$ch, _payload$activity4$ch2;
|
|
135
|
-
|
|
136
116
|
const {
|
|
137
117
|
payload
|
|
138
118
|
} = action;
|
|
139
|
-
|
|
140
119
|
if (payload !== null && payload !== void 0 && (_payload$activity = payload.activity) !== null && _payload$activity !== void 0 && _payload$activity.attachments && payload !== null && payload !== void 0 && (_payload$activity2 = payload.activity) !== null && _payload$activity2 !== void 0 && (_payload$activity2$ch = _payload$activity2.channelData) !== null && _payload$activity2$ch !== void 0 && _payload$activity2$ch.attachmentSizes && (payload === null || payload === void 0 ? void 0 : (_payload$activity3 = payload.activity) === null || _payload$activity3 === void 0 ? void 0 : (_payload$activity3$at = _payload$activity3.attachments) === null || _payload$activity3$at === void 0 ? void 0 : _payload$activity3$at.length) === (payload === null || payload === void 0 ? void 0 : (_payload$activity4 = payload.activity) === null || _payload$activity4 === void 0 ? void 0 : (_payload$activity4$ch = _payload$activity4.channelData) === null || _payload$activity4$ch === void 0 ? void 0 : (_payload$activity4$ch2 = _payload$activity4$ch.attachmentSizes) === null || _payload$activity4$ch2 === void 0 ? void 0 : _payload$activity4$ch2.length)) {
|
|
141
120
|
return next(validateAttachment(action, allowedFileExtensions, maxUploadFileSize, localizedTexts));
|
|
142
121
|
}
|
|
143
122
|
}
|
|
144
|
-
|
|
145
123
|
return next(action);
|
|
146
124
|
};
|
|
147
125
|
};
|
|
148
|
-
|
|
149
126
|
export default createAttachmentUploadValidatorMiddleware;
|
|
@@ -3,26 +3,25 @@
|
|
|
3
3
|
*
|
|
4
4
|
* Adds necessary tags if not present so that the rendering middlewares can process them later.
|
|
5
5
|
******/
|
|
6
|
+
|
|
6
7
|
import { Constants } from "../../../../../common/Constants";
|
|
7
8
|
import { DeliveryMode } from "@microsoft/omnichannel-chat-sdk";
|
|
8
|
-
import { WebChatActionType } from "../../enums/WebChatActionType";
|
|
9
|
+
import { WebChatActionType } from "../../enums/WebChatActionType";
|
|
9
10
|
|
|
11
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/no-unused-vars
|
|
10
12
|
const channelDataMiddleware = _ref => {
|
|
11
13
|
let {
|
|
12
14
|
dispatch
|
|
13
15
|
} = _ref;
|
|
14
16
|
return next => action => {
|
|
15
17
|
var _action$payload, _action$payload$activ;
|
|
16
|
-
|
|
17
18
|
if ((action === null || action === void 0 ? void 0 : action.type) === WebChatActionType.DIRECT_LINE_POST_ACTIVITY_PENDING && action !== null && action !== void 0 && (_action$payload = action.payload) !== null && _action$payload !== void 0 && (_action$payload$activ = _action$payload.activity) !== null && _action$payload$activ !== void 0 && _action$payload$activ.channelData) {
|
|
18
19
|
const channelIdTag = `${Constants.channelIdKey}${Constants.ChannelId}`;
|
|
19
20
|
const customerMessageTag = `${Constants.CustomerTag}`;
|
|
20
|
-
|
|
21
21
|
if (action.payload.activity.channelData.tags) {
|
|
22
22
|
if (!action.payload.activity.channelData.tags.includes(channelIdTag)) {
|
|
23
23
|
action.payload.activity.channelData.tags.push(channelIdTag);
|
|
24
24
|
}
|
|
25
|
-
|
|
26
25
|
if (!action.payload.activity.channelData.tags.includes(customerMessageTag)) {
|
|
27
26
|
action.payload.activity.channelData.tags.push(customerMessageTag);
|
|
28
27
|
}
|
|
@@ -30,14 +29,11 @@ const channelDataMiddleware = _ref => {
|
|
|
30
29
|
action.payload.activity.channelData.tags = [channelIdTag];
|
|
31
30
|
action.payload.activity.channelData.tags.push(customerMessageTag);
|
|
32
31
|
}
|
|
33
|
-
|
|
34
32
|
action.payload.activity.channelData.metadata = {
|
|
35
33
|
deliveryMode: DeliveryMode.Bridged
|
|
36
34
|
};
|
|
37
35
|
}
|
|
38
|
-
|
|
39
36
|
return next(action);
|
|
40
37
|
};
|
|
41
38
|
};
|
|
42
|
-
|
|
43
39
|
export default channelDataMiddleware;
|