@microsoft/omnichannel-chat-widget 0.1.0-main.df02f14 → 0.1.0-main.df142b8
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/lib/cjs/assets/Icons.js +4 -2
- package/lib/cjs/common/Constants.js +17 -168
- package/lib/cjs/common/KeyCodes.js +0 -3
- package/lib/cjs/common/contextDataStore/DataStoreManager.js +0 -4
- package/lib/cjs/common/storage/default/defaultCacheManager.js +24 -0
- package/lib/cjs/common/storage/default/defaultClientDataStoreProvider.js +102 -0
- package/lib/cjs/common/storage/default/defaultInMemoryDataStore.js +78 -0
- package/lib/cjs/common/telemetry/TelemetryConstants.js +28 -23
- package/lib/cjs/common/telemetry/TelemetryHelper.js +16 -57
- package/lib/cjs/common/telemetry/TelemetryManager.js +0 -31
- package/lib/cjs/common/telemetry/defaultConfigs/defaultTelemetryConfiguration.js +0 -2
- package/lib/cjs/common/telemetry/loggers/ariaTelemetryLogger.js +30 -36
- package/lib/cjs/common/telemetry/loggers/consoleLogger.js +0 -9
- package/lib/cjs/common/utils.js +18 -105
- package/lib/cjs/components/callingcontainerstateful/CallingContainerStateful.js +8 -46
- package/lib/cjs/components/chatbuttonstateful/ChatButtonStateful.js +2 -24
- package/lib/cjs/components/chatbuttonstateful/common/styleProps/defaultOutOfOfficeChatButtonStyleProps.js +3 -0
- package/lib/cjs/components/confirmationpanestateful/ConfirmationPaneStateful.js +8 -32
- package/lib/cjs/components/dimlayer/DimLayer.js +0 -4
- package/lib/cjs/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.js +8 -36
- package/lib/cjs/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.spec.js +6 -8
- package/lib/cjs/components/footerstateful/FooterStateful.js +11 -42
- package/lib/cjs/components/footerstateful/audionotificationstateful/AudioNotificationStateful.js +0 -6
- package/lib/cjs/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.js +7 -45
- package/lib/cjs/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.spec.js +6 -8
- package/lib/cjs/components/headerstateful/HeaderStateful.js +15 -30
- package/lib/cjs/components/livechatwidget/LiveChatWidget.js +2 -14
- package/lib/cjs/components/livechatwidget/common/ActivityStreamHandler.js +2 -9
- package/lib/cjs/components/livechatwidget/common/ActivitySubscriber/DefaultActivitySubscriber.js +0 -5
- package/lib/cjs/components/livechatwidget/common/ActivitySubscriber/PauseActivitySubscriber.js +4 -11
- package/lib/cjs/components/livechatwidget/common/ChatAdapterShim.js +11 -19
- package/lib/cjs/components/livechatwidget/common/Deferred.js +3 -10
- package/lib/cjs/components/livechatwidget/common/authHelper.js +50 -0
- package/lib/cjs/components/livechatwidget/common/createAdapter.js +2 -13
- 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 +16 -24
- package/lib/cjs/components/livechatwidget/common/defaultProps/defaultScrollBarProps.js +14 -0
- package/lib/cjs/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +62 -38
- package/lib/cjs/components/livechatwidget/common/disposeTelemetryLoggers.js +0 -3
- package/lib/cjs/components/livechatwidget/common/endChat.js +50 -35
- package/lib/cjs/components/livechatwidget/common/getGeneralStylesForButton.js +0 -6
- package/lib/cjs/components/livechatwidget/common/initCallingSdk.js +7 -16
- package/lib/cjs/components/livechatwidget/common/initConfirmationPropsComposer.js +4 -8
- package/lib/cjs/components/livechatwidget/common/initWebChatComposer.js +20 -54
- package/lib/cjs/components/livechatwidget/common/reconnectChatHelper.js +78 -136
- package/lib/cjs/components/livechatwidget/common/registerTelemetryLoggers.js +4 -17
- package/lib/cjs/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +2 -11
- package/lib/cjs/components/livechatwidget/common/shareObservable.js +4 -8
- package/lib/cjs/components/livechatwidget/common/startChat.js +151 -141
- package/lib/cjs/components/livechatwidget/common/startProactiveChat.js +0 -8
- 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 +232 -250
- package/lib/cjs/components/loadingpanestateful/LoadingPaneStateful.js +19 -19
- package/lib/cjs/components/loadingpanestateful/common/errorUIStyleProps/errorUILoadingPaneStyleProps.js +57 -0
- package/lib/cjs/components/ooohpanestateful/OOOHPaneStateful.js +4 -17
- package/lib/cjs/components/postchatloadingpanestateful/PostChatLoadingPaneStateful.js +4 -17
- 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 +9 -37
- package/lib/cjs/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +2 -32
- package/lib/cjs/components/reconnectchatpanestateful/ReconnectChatPaneStateful.js +6 -24
- package/lib/cjs/components/webchatcontainerstateful/WebChatContainerStateful.js +29 -34
- 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 +9 -26
- package/lib/cjs/components/webchatcontainerstateful/common/mockchatsdk.js +2 -17
- package/lib/cjs/components/webchatcontainerstateful/common/utils/BrowserInfo.js +2 -24
- package/lib/cjs/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +3 -15
- 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/webchatcontroller/BotMagicCodeStore.js +0 -4
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/WebChatStoreLoader.js +0 -4
- 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 +17 -41
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityStatusMiddleware.js +9 -19
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/attachmentMiddleware.js +23 -60
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/avatarMiddleware.js +7 -15
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.js +2 -13
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.js +0 -16
- 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 +2 -30
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/DeliveredTimestamp.js +2 -12
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/NotDeliveredTimestamp.js +6 -28
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/SendingTimestamp.js +2 -11
- 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 +1 -12
- 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 +0 -12
- 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 +0 -1
- package/lib/cjs/contexts/common/LiveChatWidgetActionType.js +30 -29
- package/lib/cjs/contexts/common/LiveChatWidgetContextInitialState.js +10 -11
- package/lib/cjs/contexts/createReducer.js +154 -108
- package/lib/cjs/controller/componentController.js +2 -31
- 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 +15 -36
- package/lib/esm/assets/Icons.js +2 -1
- package/lib/esm/common/Constants.js +14 -155
- package/lib/esm/common/KeyCodes.js +0 -2
- package/lib/esm/common/contextDataStore/DataStoreManager.js +0 -2
- package/lib/esm/common/storage/default/defaultCacheManager.js +16 -0
- package/lib/esm/common/storage/default/defaultClientDataStoreProvider.js +95 -0
- package/lib/esm/common/storage/default/defaultInMemoryDataStore.js +70 -0
- package/lib/esm/common/telemetry/TelemetryConstants.js +32 -20
- package/lib/esm/common/telemetry/TelemetryHelper.js +16 -45
- package/lib/esm/common/telemetry/TelemetryManager.js +0 -18
- package/lib/esm/common/telemetry/loggers/ariaTelemetryLogger.js +28 -24
- package/lib/esm/common/telemetry/loggers/consoleLogger.js +0 -5
- package/lib/esm/common/utils.js +18 -53
- package/lib/esm/components/callingcontainerstateful/CallingContainerStateful.js +8 -17
- package/lib/esm/components/chatbuttonstateful/ChatButtonStateful.js +2 -7
- package/lib/esm/components/chatbuttonstateful/common/styleProps/defaultOutOfOfficeChatButtonStyleProps.js +3 -0
- package/lib/esm/components/confirmationpanestateful/ConfirmationPaneStateful.js +10 -13
- package/lib/esm/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.js +8 -15
- package/lib/esm/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.spec.js +6 -6
- package/lib/esm/components/footerstateful/FooterStateful.js +13 -23
- package/lib/esm/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.js +7 -35
- package/lib/esm/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.spec.js +6 -6
- package/lib/esm/components/headerstateful/HeaderStateful.js +15 -15
- package/lib/esm/components/livechatwidget/LiveChatWidget.js +2 -2
- package/lib/esm/components/livechatwidget/common/ActivityStreamHandler.js +2 -6
- package/lib/esm/components/livechatwidget/common/ActivitySubscriber/DefaultActivitySubscriber.js +0 -3
- package/lib/esm/components/livechatwidget/common/ActivitySubscriber/PauseActivitySubscriber.js +4 -8
- package/lib/esm/components/livechatwidget/common/ChatAdapterShim.js +11 -15
- package/lib/esm/components/livechatwidget/common/Deferred.js +3 -8
- package/lib/esm/components/livechatwidget/common/authHelper.js +42 -0
- package/lib/esm/components/livechatwidget/common/createAdapter.js +4 -6
- 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 +18 -18
- package/lib/esm/components/livechatwidget/common/defaultProps/defaultScrollBarProps.js +7 -0
- package/lib/esm/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +64 -25
- package/lib/esm/components/livechatwidget/common/endChat.js +52 -20
- package/lib/esm/components/livechatwidget/common/getGeneralStylesForButton.js +0 -2
- package/lib/esm/components/livechatwidget/common/initCallingSdk.js +9 -11
- package/lib/esm/components/livechatwidget/common/initConfirmationPropsComposer.js +4 -5
- package/lib/esm/components/livechatwidget/common/initWebChatComposer.js +22 -19
- package/lib/esm/components/livechatwidget/common/reconnectChatHelper.js +78 -118
- package/lib/esm/components/livechatwidget/common/registerTelemetryLoggers.js +4 -9
- package/lib/esm/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +4 -3
- package/lib/esm/components/livechatwidget/common/shareObservable.js +4 -7
- package/lib/esm/components/livechatwidget/common/startChat.js +152 -114
- 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 +235 -185
- package/lib/esm/components/loadingpanestateful/LoadingPaneStateful.js +19 -7
- package/lib/esm/components/loadingpanestateful/common/errorUIStyleProps/errorUILoadingPaneStyleProps.js +50 -0
- package/lib/esm/components/ooohpanestateful/OOOHPaneStateful.js +4 -5
- package/lib/esm/components/postchatloadingpanestateful/PostChatLoadingPaneStateful.js +4 -5
- 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 +11 -21
- package/lib/esm/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +4 -8
- package/lib/esm/components/reconnectchatpanestateful/ReconnectChatPaneStateful.js +6 -6
- package/lib/esm/components/webchatcontainerstateful/WebChatContainerStateful.js +27 -9
- 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 +9 -18
- package/lib/esm/components/webchatcontainerstateful/common/mockchatsdk.js +2 -13
- package/lib/esm/components/webchatcontainerstateful/common/utils/BrowserInfo.js +2 -16
- package/lib/esm/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +3 -5
- 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/webchatcontroller/BotMagicCodeStore.js +0 -2
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/WebChatStoreLoader.js +0 -2
- 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 +17 -26
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityStatusMiddleware.js +11 -11
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/attachmentMiddleware.js +23 -38
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/avatarMiddleware.js +9 -8
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.js +2 -9
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.js +0 -14
- 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 +4 -28
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/DeliveredTimestamp.js +3 -3
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/NotDeliveredTimestamp.js +7 -14
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/SendingTimestamp.js +3 -3
- 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 +3 -8
- 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 +0 -5
- 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 +0 -1
- package/lib/esm/contexts/common/LiveChatWidgetActionType.js +30 -29
- package/lib/esm/contexts/common/LiveChatWidgetContextInitialState.js +10 -7
- package/lib/esm/contexts/createReducer.js +154 -105
- package/lib/esm/controller/componentController.js +3 -2
- 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 +15 -26
- package/lib/types/assets/Icons.d.ts +1 -0
- package/lib/types/common/Constants.d.ts +12 -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 +16 -5
- package/lib/types/common/telemetry/definitions/Contracts.d.ts +2 -4
- 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/reconnectChatHelper.d.ts +5 -7
- package/lib/types/components/livechatwidget/common/startChat.d.ts +3 -2
- package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetControlProps.d.ts +1 -1
- package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetProps.d.ts +4 -2
- 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/reconnectchatpanestateful/interfaces/IReconnectChatPaneStatefulProps.d.ts +0 -1
- package/lib/types/components/webchatcontainerstateful/common/defaultStyles/defaultAdaptiveCardStyles.d.ts +2 -0
- package/lib/types/components/webchatcontainerstateful/interfaces/IAdaptiveCardStyles.d.ts +4 -0
- package/lib/types/components/webchatcontainerstateful/interfaces/IRenderingMiddlewareProps.d.ts +4 -1
- package/lib/types/components/webchatcontainerstateful/interfaces/IWebChatContainerStatefulProps.d.ts +2 -0
- package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityStatusMiddleware.d.ts +1 -1
- 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/contexts/common/ILiveChatWidgetContext.d.ts +3 -2
- package/lib/types/contexts/common/LiveChatWidgetActionType.d.ts +30 -28
- package/lib/types/contexts/common/LiveChatWidgetContextInitialState.d.ts +1 -2
- package/package.json +3 -3
|
@@ -3,25 +3,13 @@ import React from "react";
|
|
|
3
3
|
import { decodeComponentString } from "@microsoft/omnichannel-chat-components";
|
|
4
4
|
import { shouldShowFooter } from "../../../controller/componentController";
|
|
5
5
|
export const createFooter = (props, state) => {
|
|
6
|
-
var _props$
|
|
7
|
-
|
|
8
|
-
const
|
|
9
|
-
controlProps: { ...((_props$footerProps = props.footerProps) === null || _props$footerProps === void 0 ? void 0 : _props$footerProps.controlProps),
|
|
10
|
-
hideDownloadTranscriptButton: true,
|
|
11
|
-
hideEmailTranscriptButton: true,
|
|
12
|
-
hideAudioNotificationButton: true
|
|
13
|
-
}
|
|
14
|
-
};
|
|
15
|
-
const footer = !((_props$controlProps = props.controlProps) !== null && _props$controlProps !== void 0 && _props$controlProps.hideFooter) && shouldShowFooter(state) ? decodeComponentString((_props$componentOverr = props.componentOverrides) === null || _props$componentOverr === void 0 ? void 0 : _props$componentOverr.footer) || /*#__PURE__*/React.createElement(FooterStateful, {
|
|
6
|
+
var _props$controlProps, _props$componentOverr;
|
|
7
|
+
const hideFooterDisplay = !((_props$controlProps = props.controlProps) !== null && _props$controlProps !== void 0 && _props$controlProps.hideFooter) && shouldShowFooter(state) ? false : true;
|
|
8
|
+
const footer = decodeComponentString((_props$componentOverr = props.componentOverrides) === null || _props$componentOverr === void 0 ? void 0 : _props$componentOverr.footer) || /*#__PURE__*/React.createElement(FooterStateful, {
|
|
16
9
|
footerProps: props.footerProps,
|
|
17
10
|
downloadTranscriptProps: props.downloadTranscriptProps,
|
|
18
11
|
audioNotificationProps: props.audioNotificationProps,
|
|
19
|
-
hideFooterDisplay:
|
|
20
|
-
}) : decodeComponentString((_props$componentOverr2 = props.componentOverrides) === null || _props$componentOverr2 === void 0 ? void 0 : _props$componentOverr2.footer) || /*#__PURE__*/React.createElement(FooterStateful, {
|
|
21
|
-
footerProps: footerPropsHidden,
|
|
22
|
-
downloadTranscriptProps: props.downloadTranscriptProps,
|
|
23
|
-
audioNotificationProps: props.audioNotificationProps,
|
|
24
|
-
hideFooterDisplay: true
|
|
12
|
+
hideFooterDisplay: hideFooterDisplay
|
|
25
13
|
});
|
|
26
14
|
return footer;
|
|
27
15
|
};
|
|
@@ -2,7 +2,8 @@ import { Constants } from "../../../common/Constants";
|
|
|
2
2
|
import { NotificationHandler } from "../../webchatcontainerstateful/webchatcontroller/notification/NotificationHandler";
|
|
3
3
|
import { NotificationScenarios } from "../../webchatcontainerstateful/webchatcontroller/enums/NotificationScenarios";
|
|
4
4
|
import { defaultMiddlewareLocalizedTexts } from "../../webchatcontainerstateful/common/defaultProps/defaultMiddlewareLocalizedTexts";
|
|
5
|
-
|
|
5
|
+
import { TelemetryHelper } from "../../../common/telemetry/TelemetryHelper";
|
|
6
|
+
import { LogLevel, TelemetryEvent } from "../../../common/telemetry/TelemetryConstants";
|
|
6
7
|
const isInternetConnected = async () => {
|
|
7
8
|
try {
|
|
8
9
|
const response = await fetch(Constants.internetConnectionTestUrl);
|
|
@@ -12,19 +13,23 @@ const isInternetConnected = async () => {
|
|
|
12
13
|
return false;
|
|
13
14
|
}
|
|
14
15
|
};
|
|
15
|
-
|
|
16
16
|
export const createInternetConnectionChangeHandler = async () => {
|
|
17
17
|
const handler = async () => {
|
|
18
18
|
const connected = await isInternetConnected();
|
|
19
|
-
|
|
20
19
|
if (!connected) {
|
|
20
|
+
TelemetryHelper.logActionEvent(LogLevel.WARN, {
|
|
21
|
+
Event: TelemetryEvent.NetworkDisconnected
|
|
22
|
+
});
|
|
21
23
|
NotificationHandler.notifyError(NotificationScenarios.InternetConnection, defaultMiddlewareLocalizedTexts.MIDDLEWARE_BANNER_NO_INTERNET_CONNECTION);
|
|
22
24
|
} else {
|
|
25
|
+
TelemetryHelper.logActionEvent(LogLevel.WARN, {
|
|
26
|
+
Event: TelemetryEvent.NetworkReconnected
|
|
27
|
+
});
|
|
23
28
|
NotificationHandler.notifySuccess(NotificationScenarios.InternetConnection, defaultMiddlewareLocalizedTexts.MIDDLEWARE_BANNER_INTERNET_BACK_ONLINE);
|
|
24
29
|
}
|
|
25
|
-
};
|
|
26
|
-
|
|
30
|
+
};
|
|
27
31
|
|
|
32
|
+
// Checking connection status on online & offline events due to possible false positives
|
|
28
33
|
window.addEventListener("online", () => handler(), false);
|
|
29
34
|
window.addEventListener("offline", () => handler(), false);
|
|
30
35
|
};
|
|
@@ -1,17 +1,18 @@
|
|
|
1
1
|
import MarkdownIt from "markdown-it";
|
|
2
2
|
import MarkdownItForInline from "markdown-it-for-inline";
|
|
3
3
|
import { defaultMarkdownLocalizedTexts } from "../../webchatcontainerstateful/common/defaultProps/defaultMarkdownLocalizedTexts";
|
|
4
|
-
import { Constants } from "../../../common/Constants";
|
|
4
|
+
import { Constants } from "../../../common/Constants";
|
|
5
5
|
|
|
6
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
6
7
|
export const createMarkdown = (disableMarkdownMessageFormatting, disableNewLineMarkdownSupport) => {
|
|
7
8
|
let markdown;
|
|
8
|
-
|
|
9
9
|
if (!disableMarkdownMessageFormatting) {
|
|
10
10
|
markdown = new MarkdownIt(Constants.Default, {
|
|
11
11
|
html: true,
|
|
12
12
|
linkify: true,
|
|
13
13
|
breaks: !disableNewLineMarkdownSupport
|
|
14
|
-
});
|
|
14
|
+
});
|
|
15
|
+
// ToDo: Commenting below usage of plugin until deferred bug is resolved: https://github.com/mayashavin/markdown-it-slack/issues/1
|
|
15
16
|
// markdown.use(MarkdownSlack);
|
|
16
17
|
} else {
|
|
17
18
|
markdown = new MarkdownIt(Constants.Zero, {
|
|
@@ -19,38 +20,37 @@ export const createMarkdown = (disableMarkdownMessageFormatting, disableNewLineM
|
|
|
19
20
|
linkify: true,
|
|
20
21
|
breaks: !disableNewLineMarkdownSupport
|
|
21
22
|
});
|
|
22
|
-
markdown.enable(["entity",
|
|
23
|
-
|
|
24
|
-
"
|
|
25
|
-
|
|
23
|
+
markdown.enable(["entity",
|
|
24
|
+
// Rule to process html entity - {, ¯, "
|
|
25
|
+
"linkify",
|
|
26
|
+
// Rule to replace link-like texts with link nodes
|
|
27
|
+
"html_block",
|
|
28
|
+
// Rule to process html blocks and paragraphs
|
|
29
|
+
"html_inline",
|
|
30
|
+
// Rule to process html tags
|
|
26
31
|
"newline" // Rule to proceess '\n'
|
|
27
32
|
]);
|
|
28
|
-
}
|
|
29
|
-
|
|
33
|
+
}
|
|
30
34
|
|
|
35
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
31
36
|
markdown.use(MarkdownItForInline, "url_new_win", "link_open", function (tokens, idx, env) {
|
|
32
|
-
const targetAttrIndex = tokens[idx].attrIndex(Constants.Target);
|
|
33
|
-
|
|
37
|
+
const targetAttrIndex = tokens[idx].attrIndex(Constants.Target);
|
|
38
|
+
// Put a transparent pixel instead of the "open in new window" icon, so developers can easily modify the icon in CSS.
|
|
34
39
|
const TRANSPARENT_GIF = "data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7";
|
|
35
|
-
|
|
36
40
|
if (~targetAttrIndex) {
|
|
37
41
|
tokens[idx].attrs[targetAttrIndex][1] = Constants.Blank;
|
|
38
42
|
} else {
|
|
39
43
|
tokens[idx].attrPush([Constants.Target, Constants.Blank]);
|
|
40
44
|
}
|
|
41
|
-
|
|
42
45
|
const relAttrIndex = tokens[idx].attrIndex(Constants.TargetRelationship);
|
|
43
|
-
|
|
44
46
|
if (~relAttrIndex) {
|
|
45
47
|
tokens[idx].attrs[relAttrIndex][1] = Constants.TargetRelationshipAttributes;
|
|
46
48
|
} else {
|
|
47
49
|
tokens[idx].attrPush([Constants.TargetRelationship, Constants.TargetRelationshipAttributes]);
|
|
48
|
-
|
|
49
50
|
if (!disableMarkdownMessageFormatting) {
|
|
50
|
-
tokens[idx].attrPush([Constants.Title, defaultMarkdownLocalizedTexts.MARKDOWN_EXTERNAL_LINK_ALT]);
|
|
51
|
-
|
|
51
|
+
tokens[idx].attrPush([Constants.Title, defaultMarkdownLocalizedTexts.MARKDOWN_EXTERNAL_LINK_ALT]);
|
|
52
|
+
// eslint-disable-next-line quotes
|
|
52
53
|
const iconTokens = markdown.parseInline(``, env)[0].children;
|
|
53
|
-
|
|
54
54
|
if (iconTokens && iconTokens.length > 0) {
|
|
55
55
|
iconTokens[0].attrJoin("class", Constants.OpenLinkIconCssClass);
|
|
56
56
|
tokens.splice(idx + 2, 0, ...iconTokens);
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
/* eslint-disable @typescript-eslint/no-empty-function, @typescript-eslint/no-explicit-any */
|
|
2
|
+
|
|
2
3
|
import { ChatReconnectIconBase64, CloseChatButtonIconBase64, ModernChatIconBase64, ProactiveChatBannerBase64 } from "@microsoft/omnichannel-chat-components";
|
|
3
4
|
import MockAdapter from "../../../webchatcontainerstateful/common/mockadapter";
|
|
4
5
|
import { NewMessageNotificationSoundBase64 } from "../../../../assets/Audios";
|
|
@@ -10,8 +11,9 @@ import { createAvatarMiddleware } from "../../../webchatcontainerstateful/webcha
|
|
|
10
11
|
import { createMarkdown } from "../createMarkdown";
|
|
11
12
|
import { groupActivitiesMiddleware } from "../../../webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/groupActivitiesMiddleware";
|
|
12
13
|
import { typingIndicatorMiddleware } from "../../../webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/typingIndicatorMiddleware";
|
|
13
|
-
import { createWebChatTelemetry } from "../../../webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger";
|
|
14
|
+
import { createWebChatTelemetry } from "../../../webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger";
|
|
14
15
|
|
|
16
|
+
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
15
17
|
export const dummyDefaultProps = {
|
|
16
18
|
audioNotificationProps: {
|
|
17
19
|
audioSrc: NewMessageNotificationSoundBase64
|
|
@@ -166,24 +168,28 @@ export const dummyDefaultProps = {
|
|
|
166
168
|
},
|
|
167
169
|
audioCallButtonStyleProps: {
|
|
168
170
|
borderRadius: "50%",
|
|
169
|
-
color: "#FFFFFF",
|
|
170
171
|
backgroundColor: "#008000",
|
|
171
172
|
lineHeight: "40px",
|
|
172
173
|
height: "40px",
|
|
173
174
|
width: "40px",
|
|
174
|
-
|
|
175
|
+
icon: {
|
|
176
|
+
fontSize: 18,
|
|
177
|
+
color: "#FFFFFF"
|
|
178
|
+
}
|
|
175
179
|
},
|
|
176
180
|
audioCallButtonHoverStyleProps: {
|
|
177
181
|
filter: "brightness(0.8)"
|
|
178
182
|
},
|
|
179
183
|
videoCallButtonStyleProps: {
|
|
180
184
|
borderRadius: "50%",
|
|
181
|
-
color: "#FFFFFF",
|
|
182
185
|
backgroundColor: "#008000",
|
|
183
186
|
lineHeight: "40px",
|
|
184
187
|
height: "40px",
|
|
185
188
|
width: "40px",
|
|
186
|
-
|
|
189
|
+
icon: {
|
|
190
|
+
fontSize: 18,
|
|
191
|
+
color: "#FFFFFF"
|
|
192
|
+
}
|
|
187
193
|
},
|
|
188
194
|
videoCallButtonHoverStyleProps: {
|
|
189
195
|
filter: "brightness(0.8)"
|
|
@@ -194,13 +200,15 @@ export const dummyDefaultProps = {
|
|
|
194
200
|
},
|
|
195
201
|
declineCallButtonStyleProps: {
|
|
196
202
|
borderRadius: "50%",
|
|
197
|
-
color: "#FFFFFF",
|
|
198
203
|
backgroundColor: "#DC0000",
|
|
199
204
|
lineHeight: "40px",
|
|
200
205
|
height: "40px",
|
|
201
206
|
width: "40px",
|
|
202
|
-
|
|
203
|
-
|
|
207
|
+
marginLeft: "5px",
|
|
208
|
+
icon: {
|
|
209
|
+
fontSize: 18,
|
|
210
|
+
color: "#FFFFFF"
|
|
211
|
+
}
|
|
204
212
|
},
|
|
205
213
|
incomingCallTitleStyleProps: {
|
|
206
214
|
margin: "0 5px",
|
|
@@ -318,7 +326,8 @@ export const dummyDefaultProps = {
|
|
|
318
326
|
hideChatTitle: false,
|
|
319
327
|
hideNotificationBubble: true,
|
|
320
328
|
unreadMessageString: "new messages",
|
|
321
|
-
largeUnreadMessageString: "99+"
|
|
329
|
+
largeUnreadMessageString: "99+",
|
|
330
|
+
ariaLabelUnreadMessageString: "you have new messages"
|
|
322
331
|
},
|
|
323
332
|
styleProps: {
|
|
324
333
|
generalStyleProps: {
|
|
@@ -464,8 +473,8 @@ export const dummyDefaultProps = {
|
|
|
464
473
|
onConfirm: () => {},
|
|
465
474
|
// Detailed implementation omitted
|
|
466
475
|
onCancel: () => {} // Detailed implementation omitted
|
|
467
|
-
|
|
468
476
|
},
|
|
477
|
+
|
|
469
478
|
styleProps: {
|
|
470
479
|
generalStyleProps: {
|
|
471
480
|
backgroundColor: "#FFFFFF",
|
|
@@ -570,7 +579,7 @@ export const dummyDefaultProps = {
|
|
|
570
579
|
hideProactiveChatPane: false,
|
|
571
580
|
hideReconnectChatPane: false,
|
|
572
581
|
hideWebChatContainer: false,
|
|
573
|
-
|
|
582
|
+
hideStartChatButton: false
|
|
574
583
|
},
|
|
575
584
|
directLine: new MockAdapter(),
|
|
576
585
|
downloadTranscriptProps: {
|
|
@@ -770,6 +779,7 @@ export const dummyDefaultProps = {
|
|
|
770
779
|
},
|
|
771
780
|
audioNotificationButtonProps: {
|
|
772
781
|
id: "oc-lcw-footer-audionotification-button",
|
|
782
|
+
type: "icon",
|
|
773
783
|
ariaLabel: "Turn sound off",
|
|
774
784
|
toggleAriaLabel: "Turn sound on",
|
|
775
785
|
iconName: "Volume3",
|
|
@@ -795,8 +805,10 @@ export const dummyDefaultProps = {
|
|
|
795
805
|
padding: "0 10px 5px 10px"
|
|
796
806
|
},
|
|
797
807
|
downloadTranscriptButtonStyleProps: {
|
|
798
|
-
|
|
799
|
-
|
|
808
|
+
icon: {
|
|
809
|
+
color: "blue",
|
|
810
|
+
fontSize: 16
|
|
811
|
+
},
|
|
800
812
|
height: "25px",
|
|
801
813
|
lineHeight: "25px",
|
|
802
814
|
width: "25px"
|
|
@@ -806,8 +818,10 @@ export const dummyDefaultProps = {
|
|
|
806
818
|
backgroundColor: "#C8C8C8"
|
|
807
819
|
},
|
|
808
820
|
emailTranscriptButtonStyleProps: {
|
|
809
|
-
|
|
810
|
-
|
|
821
|
+
cicon: {
|
|
822
|
+
color: "blue",
|
|
823
|
+
fontSize: 16
|
|
824
|
+
},
|
|
811
825
|
height: "25px",
|
|
812
826
|
lineHeight: "25px",
|
|
813
827
|
width: "25px"
|
|
@@ -817,8 +831,10 @@ export const dummyDefaultProps = {
|
|
|
817
831
|
backgroundColor: "#C8C8C8"
|
|
818
832
|
},
|
|
819
833
|
audioNotificationButtonStyleProps: {
|
|
820
|
-
|
|
821
|
-
|
|
834
|
+
icon: {
|
|
835
|
+
color: "blue",
|
|
836
|
+
fontSize: 16
|
|
837
|
+
},
|
|
822
838
|
height: "25px",
|
|
823
839
|
lineHeight: "25px",
|
|
824
840
|
width: "25px"
|
|
@@ -869,7 +885,7 @@ export const dummyDefaultProps = {
|
|
|
869
885
|
className: undefined
|
|
870
886
|
},
|
|
871
887
|
closeButtonProps: {
|
|
872
|
-
id: "oc-lcw-header-
|
|
888
|
+
id: "oc-lcw-header-close-button",
|
|
873
889
|
type: "icon",
|
|
874
890
|
iconName: "ChromeClose",
|
|
875
891
|
ariaLabel: "Close",
|
|
@@ -1048,8 +1064,8 @@ export const dummyDefaultProps = {
|
|
|
1048
1064
|
titleText: "We're Offline",
|
|
1049
1065
|
subtitleText: "No agents available",
|
|
1050
1066
|
onClick: () => {} // Detailed implementation omitted
|
|
1051
|
-
|
|
1052
1067
|
},
|
|
1068
|
+
|
|
1053
1069
|
styleProps: {
|
|
1054
1070
|
// ...[Existing chat button style props]
|
|
1055
1071
|
iconStyleProps: {
|
|
@@ -1067,8 +1083,8 @@ export const dummyDefaultProps = {
|
|
|
1067
1083
|
text: "We're Offline"
|
|
1068
1084
|
},
|
|
1069
1085
|
onMinimizeClick: () => {} // Detailed implementation omitted
|
|
1070
|
-
|
|
1071
1086
|
},
|
|
1087
|
+
|
|
1072
1088
|
styleProps: {
|
|
1073
1089
|
// ...[Existing chat button style props]
|
|
1074
1090
|
generalStyleProps: {
|
|
@@ -1165,7 +1181,8 @@ export const dummyDefaultProps = {
|
|
|
1165
1181
|
backgroundColor: "#FFFFFF",
|
|
1166
1182
|
borderColor: "#F1F1F1"
|
|
1167
1183
|
}
|
|
1168
|
-
}
|
|
1184
|
+
},
|
|
1185
|
+
isCustomerVoiceSurveyCompact: undefined
|
|
1169
1186
|
},
|
|
1170
1187
|
proactiveChatPaneProps: {
|
|
1171
1188
|
componentOverrides: {
|
|
@@ -1185,7 +1202,17 @@ export const dummyDefaultProps = {
|
|
|
1185
1202
|
hideSubtitle: false,
|
|
1186
1203
|
subtitleText: "Live chat support!",
|
|
1187
1204
|
hideCloseButton: false,
|
|
1188
|
-
|
|
1205
|
+
closeButtonProps: {
|
|
1206
|
+
id: "oc-lcw-proactivechat-closebutton",
|
|
1207
|
+
type: "icon",
|
|
1208
|
+
iconName: "ChromeClose",
|
|
1209
|
+
ariaLabel: "Close",
|
|
1210
|
+
imageIconProps: undefined,
|
|
1211
|
+
text: "Close",
|
|
1212
|
+
onClick: undefined,
|
|
1213
|
+
className: undefined,
|
|
1214
|
+
hideButtonTitle: true
|
|
1215
|
+
},
|
|
1189
1216
|
isBodyContainerHorizantal: false,
|
|
1190
1217
|
hideBodyTitle: false,
|
|
1191
1218
|
bodyTitleText: "Hi! Have any questions? I am here to help.",
|
|
@@ -1195,8 +1222,8 @@ export const dummyDefaultProps = {
|
|
|
1195
1222
|
onClose: () => {},
|
|
1196
1223
|
// Detailed implementation omitted
|
|
1197
1224
|
onStart: () => {} // Detailed implementation omitted
|
|
1198
|
-
|
|
1199
1225
|
},
|
|
1226
|
+
|
|
1200
1227
|
styleProps: {
|
|
1201
1228
|
generalStyleProps: {
|
|
1202
1229
|
backgroundColor: "rgb(255, 255, 255)",
|
|
@@ -1327,8 +1354,8 @@ export const dummyDefaultProps = {
|
|
|
1327
1354
|
onStartNewChat: () => {},
|
|
1328
1355
|
// Detailed implementation omitted
|
|
1329
1356
|
onMinimize: () => {} // Detailed implementation omitted
|
|
1330
|
-
|
|
1331
1357
|
},
|
|
1358
|
+
|
|
1332
1359
|
styleProps: {
|
|
1333
1360
|
generalStyleProps: {
|
|
1334
1361
|
backgroundColor: "rgb(255, 255, 255)",
|
|
@@ -1413,7 +1440,6 @@ export const dummyDefaultProps = {
|
|
|
1413
1440
|
startNewChatButtonClassName: undefined
|
|
1414
1441
|
}
|
|
1415
1442
|
},
|
|
1416
|
-
isReconnectEnabled: undefined,
|
|
1417
1443
|
reconnectId: undefined,
|
|
1418
1444
|
redirectInSameWindow: undefined
|
|
1419
1445
|
},
|
|
@@ -1535,6 +1561,12 @@ export const dummyDefaultProps = {
|
|
|
1535
1561
|
lineHeight: "16px",
|
|
1536
1562
|
padding: "0px 10px 0 10px"
|
|
1537
1563
|
},
|
|
1564
|
+
userMessageBoxStyles: {
|
|
1565
|
+
maxWidth: "75%"
|
|
1566
|
+
},
|
|
1567
|
+
systemMessageBoxStyles: {
|
|
1568
|
+
maxWidth: "75%"
|
|
1569
|
+
},
|
|
1538
1570
|
typingIndicatorStyleProps: {
|
|
1539
1571
|
marginLeft: "10px",
|
|
1540
1572
|
marginBottom: "5px",
|
|
@@ -1654,6 +1686,9 @@ export const dummyDefaultProps = {
|
|
|
1654
1686
|
},
|
|
1655
1687
|
attachmentSizeStyles: {
|
|
1656
1688
|
display: "none"
|
|
1689
|
+
},
|
|
1690
|
+
receivedMessageAnchorStyles: {
|
|
1691
|
+
color: "white"
|
|
1657
1692
|
}
|
|
1658
1693
|
},
|
|
1659
1694
|
localizedTexts: {
|
|
@@ -1681,6 +1716,10 @@ export const dummyDefaultProps = {
|
|
|
1681
1716
|
botMagicCode: {
|
|
1682
1717
|
disabled: false,
|
|
1683
1718
|
fwdUrl: ""
|
|
1719
|
+
},
|
|
1720
|
+
adaptiveCardStyles: {
|
|
1721
|
+
background: "white",
|
|
1722
|
+
color: "black"
|
|
1684
1723
|
}
|
|
1685
1724
|
},
|
|
1686
1725
|
telemetryConfig: undefined,
|
|
@@ -7,16 +7,34 @@ import { WebChatStoreLoader } from "../../webchatcontainerstateful/webchatcontro
|
|
|
7
7
|
import { defaultWebChatContainerStatefulProps } from "../../webchatcontainerstateful/common/defaultProps/defaultWebChatContainerStatefulProps";
|
|
8
8
|
import { PostChatSurveyMode } from "../../postchatsurveypanestateful/enums/PostChatSurveyMode";
|
|
9
9
|
import { Constants } from "../../../common/Constants";
|
|
10
|
-
import { addDelayInMs, getWidgetEndChatEventName } from "../../../common/utils";
|
|
10
|
+
import { addDelayInMs, getWidgetEndChatEventName } from "../../../common/utils";
|
|
11
|
+
import { getAuthClientFunction, handleAuthentication } from "./authHelper";
|
|
11
12
|
|
|
13
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
12
14
|
const prepareEndChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, state) => {
|
|
13
15
|
var _state$domainStates$l, _state$domainStates$l2, _state$domainStates$l3, _state$domainStates$l4, _conversationDetails;
|
|
14
|
-
|
|
15
16
|
const isPostChatEnabled = (_state$domainStates$l = state.domainStates.liveChatConfig) === null || _state$domainStates$l === void 0 ? void 0 : (_state$domainStates$l2 = _state$domainStates$l.LiveWSAndLiveChatEngJoin) === null || _state$domainStates$l2 === void 0 ? void 0 : _state$domainStates$l2.msdyn_postconversationsurveyenable;
|
|
16
|
-
const postChatSurveyMode = (_state$domainStates$l3 = state.domainStates.liveChatConfig) === null || _state$domainStates$l3 === void 0 ? void 0 : (_state$domainStates$l4 = _state$domainStates$l3.LiveWSAndLiveChatEngJoin) === null || _state$domainStates$l4 === void 0 ? void 0 : _state$domainStates$l4.msdyn_postconversationsurveymode;
|
|
17
|
+
const postChatSurveyMode = (_state$domainStates$l3 = state.domainStates.liveChatConfig) === null || _state$domainStates$l3 === void 0 ? void 0 : (_state$domainStates$l4 = _state$domainStates$l3.LiveWSAndLiveChatEngJoin) === null || _state$domainStates$l4 === void 0 ? void 0 : _state$domainStates$l4.msdyn_postconversationsurveymode;
|
|
18
|
+
|
|
19
|
+
//Unable to end chat if token has expired
|
|
20
|
+
if (props.getAuthToken) {
|
|
21
|
+
const authClientFunction = getAuthClientFunction(props.chatConfig);
|
|
22
|
+
if (props.getAuthToken && authClientFunction) {
|
|
23
|
+
// set auth token to chat sdk before start chat
|
|
24
|
+
const authSuccess = await handleAuthentication(chatSDK, props.chatConfig, props.getAuthToken);
|
|
25
|
+
if (!authSuccess) {
|
|
26
|
+
TelemetryHelper.logActionEvent(LogLevel.ERROR, {
|
|
27
|
+
Event: TelemetryEvent.GetAuthTokenFailed,
|
|
28
|
+
ExceptionDetails: {
|
|
29
|
+
exception: "Unable to get auth token during end chat"
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
17
35
|
|
|
36
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
18
37
|
let conversationDetails = undefined;
|
|
19
|
-
|
|
20
38
|
try {
|
|
21
39
|
conversationDetails = await chatSDK.getConversationDetails();
|
|
22
40
|
} catch (erorr) {
|
|
@@ -27,12 +45,16 @@ const prepareEndChat = async (props, chatSDK, setAdapter, setWebChatStyles, disp
|
|
|
27
45
|
}
|
|
28
46
|
});
|
|
29
47
|
}
|
|
30
|
-
|
|
31
48
|
if (isPostChatEnabled === "true" && ((_conversationDetails = conversationDetails) === null || _conversationDetails === void 0 ? void 0 : _conversationDetails.canRenderPostChat) === Constants.truePascal) {
|
|
32
49
|
const skipEndChatSDK = false;
|
|
33
50
|
const skipCloseChat = true;
|
|
51
|
+
const chatSession = await (chatSDK === null || chatSDK === void 0 ? void 0 : chatSDK.getCurrentLiveChatContext());
|
|
34
52
|
await endChat(props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, skipEndChatSDK, skipCloseChat, false);
|
|
35
|
-
|
|
53
|
+
if (chatSession) {
|
|
54
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
55
|
+
chatSDK.chatToken = chatSession.chatToken ?? {};
|
|
56
|
+
chatSDK.requestId = chatSession.requestId;
|
|
57
|
+
}
|
|
36
58
|
if (postChatSurveyMode === PostChatSurveyMode.Embed) {
|
|
37
59
|
dispatch({
|
|
38
60
|
type: LiveChatWidgetActionType.SET_CONVERSATION_STATE,
|
|
@@ -44,19 +66,29 @@ const prepareEndChat = async (props, chatSDK, setAdapter, setWebChatStyles, disp
|
|
|
44
66
|
};
|
|
45
67
|
BroadcastService.postMessage(loadPostChatEvent);
|
|
46
68
|
} else if (postChatSurveyMode === PostChatSurveyMode.Link) {
|
|
69
|
+
var _props$webChatContain, _props$webChatContain2;
|
|
47
70
|
dispatch({
|
|
48
71
|
type: LiveChatWidgetActionType.SET_CONVERSATION_STATE,
|
|
49
72
|
payload: ConversationState.InActive
|
|
50
73
|
});
|
|
51
|
-
}
|
|
52
74
|
|
|
75
|
+
// Disable SendBox
|
|
76
|
+
if ((props === null || props === void 0 ? void 0 : (_props$webChatContain = props.webChatContainerProps) === null || _props$webChatContain === void 0 ? void 0 : (_props$webChatContain2 = _props$webChatContain.renderingMiddlewareProps) === null || _props$webChatContain2 === void 0 ? void 0 : _props$webChatContain2.hideSendboxOnConversationEnd) !== false) {
|
|
77
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
78
|
+
setWebChatStyles(styles => {
|
|
79
|
+
return {
|
|
80
|
+
...styles,
|
|
81
|
+
hideSendBox: true
|
|
82
|
+
};
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
}
|
|
53
86
|
return;
|
|
54
87
|
}
|
|
55
|
-
|
|
56
88
|
await endChat(props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, false, false, true);
|
|
57
|
-
};
|
|
58
|
-
|
|
89
|
+
};
|
|
59
90
|
|
|
91
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
60
92
|
const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, skipEndChatSDK, skipCloseChat, postMessageToOtherTab) => {
|
|
61
93
|
if (!skipEndChatSDK) {
|
|
62
94
|
try {
|
|
@@ -73,9 +105,9 @@ const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, a
|
|
|
73
105
|
});
|
|
74
106
|
postMessageToOtherTab = false;
|
|
75
107
|
}
|
|
76
|
-
}
|
|
77
|
-
|
|
108
|
+
}
|
|
78
109
|
|
|
110
|
+
// Need to clear these states immediately when chat ended from OC.
|
|
79
111
|
dispatch({
|
|
80
112
|
type: LiveChatWidgetActionType.SET_CUSTOM_CONTEXT,
|
|
81
113
|
payload: undefined
|
|
@@ -88,15 +120,18 @@ const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, a
|
|
|
88
120
|
type: LiveChatWidgetActionType.SET_LIVE_CHAT_CONTEXT,
|
|
89
121
|
payload: undefined
|
|
90
122
|
});
|
|
91
|
-
|
|
123
|
+
dispatch({
|
|
124
|
+
type: LiveChatWidgetActionType.SET_RECONNECT_ID,
|
|
125
|
+
payload: undefined
|
|
126
|
+
});
|
|
92
127
|
if (!skipCloseChat) {
|
|
93
128
|
try {
|
|
94
|
-
var _props$
|
|
95
|
-
|
|
129
|
+
var _props$webChatContain3;
|
|
96
130
|
adapter === null || adapter === void 0 ? void 0 : adapter.end();
|
|
97
131
|
setAdapter(undefined);
|
|
98
|
-
setWebChatStyles({
|
|
99
|
-
...
|
|
132
|
+
setWebChatStyles({
|
|
133
|
+
...defaultWebChatContainerStatefulProps.webChatStyles,
|
|
134
|
+
...((_props$webChatContain3 = props.webChatContainerProps) === null || _props$webChatContain3 === void 0 ? void 0 : _props$webChatContain3.webChatStyles)
|
|
100
135
|
});
|
|
101
136
|
WebChatStoreLoader.store = null;
|
|
102
137
|
dispatch({
|
|
@@ -127,10 +162,8 @@ const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, a
|
|
|
127
162
|
proactiveChatInNewWindow: false
|
|
128
163
|
}
|
|
129
164
|
});
|
|
130
|
-
|
|
131
165
|
if (postMessageToOtherTab) {
|
|
132
166
|
var _chatSDK$omnichannelC, _chatSDK$omnichannelC2, _props$controlProps;
|
|
133
|
-
|
|
134
167
|
const endChatEventName = getWidgetEndChatEventName(chatSDK === null || chatSDK === void 0 ? void 0 : (_chatSDK$omnichannelC = chatSDK.omnichannelConfig) === null || _chatSDK$omnichannelC === void 0 ? void 0 : _chatSDK$omnichannelC.orgId, chatSDK === null || chatSDK === void 0 ? void 0 : (_chatSDK$omnichannelC2 = chatSDK.omnichannelConfig) === null || _chatSDK$omnichannelC2 === void 0 ? void 0 : _chatSDK$omnichannelC2.widgetId, (props === null || props === void 0 ? void 0 : (_props$controlProps = props.controlProps) === null || _props$controlProps === void 0 ? void 0 : _props$controlProps.widgetInstanceId) ?? "");
|
|
135
168
|
BroadcastService.postMessage({
|
|
136
169
|
eventName: endChatEventName
|
|
@@ -146,5 +179,4 @@ const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, a
|
|
|
146
179
|
}
|
|
147
180
|
}
|
|
148
181
|
};
|
|
149
|
-
|
|
150
182
|
export { prepareEndChat, endChat };
|
|
@@ -2,7 +2,6 @@ import { shouldShowChatButton, shouldShowProactiveChatPane } from "../../../cont
|
|
|
2
2
|
import { defaultLiveChatWidgetGeneralStyles } from "./defaultStyles/defaultLiveChatWidgetGeneralStyles";
|
|
3
3
|
export const getGeneralStylesForButton = state => {
|
|
4
4
|
let generalStylesForButton = defaultLiveChatWidgetGeneralStyles;
|
|
5
|
-
|
|
6
5
|
if (!shouldShowChatButton(state) && !shouldShowProactiveChatPane(state)) {
|
|
7
6
|
generalStylesForButton = Object.assign({}, defaultLiveChatWidgetGeneralStyles, {
|
|
8
7
|
boxShadow: "0px 0px 2px rgba(0, 0, 0, 0.16), 0px 4px 8px rgba(0, 0, 0, 0.12)",
|
|
@@ -12,6 +11,5 @@ export const getGeneralStylesForButton = state => {
|
|
|
12
11
|
padding: "0.5"
|
|
13
12
|
});
|
|
14
13
|
}
|
|
15
|
-
|
|
16
14
|
return generalStylesForButton;
|
|
17
15
|
};
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { LogLevel, TelemetryEvent } from "../../../common/telemetry/TelemetryConstants";
|
|
2
|
-
import { TelemetryHelper } from "../../../common/telemetry/TelemetryHelper";
|
|
2
|
+
import { TelemetryHelper } from "../../../common/telemetry/TelemetryHelper";
|
|
3
3
|
|
|
4
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
4
5
|
export const initCallingSdk = async (chatSDK, setVoiceVideoCallingSDK) => {
|
|
5
6
|
try {
|
|
6
7
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
@@ -13,18 +14,15 @@ export const initCallingSdk = async (chatSDK, setVoiceVideoCallingSDK) => {
|
|
|
13
14
|
});
|
|
14
15
|
return true;
|
|
15
16
|
}
|
|
16
|
-
|
|
17
17
|
return false;
|
|
18
18
|
} catch (error) {
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
}
|
|
27
|
-
|
|
19
|
+
TelemetryHelper.logCallingEvent(LogLevel.ERROR, {
|
|
20
|
+
Event: TelemetryEvent.CallingSDKLoadFailed,
|
|
21
|
+
ExceptionDetails: {
|
|
22
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
23
|
+
exception: error.message
|
|
24
|
+
}
|
|
25
|
+
});
|
|
28
26
|
return false;
|
|
29
27
|
}
|
|
30
28
|
};
|
|
@@ -1,14 +1,13 @@
|
|
|
1
1
|
import { defaultConfirmationPaneLocalizedTexts } from "../../confirmationpanestateful/common/defaultProps/defaultConfirmationPaneLocalizedTexts";
|
|
2
2
|
export const initConfirmationPropsComposer = props => {
|
|
3
3
|
var _props$confirmationPa, _props$footerProps, _props$footerProps$co, _props$footerProps2, _props$footerProps2$c, _props$confirmationPa2;
|
|
4
|
-
|
|
5
|
-
|
|
4
|
+
const confirmationPanelocalizedTexts = {
|
|
5
|
+
...defaultConfirmationPaneLocalizedTexts,
|
|
6
6
|
...(props === null || props === void 0 ? void 0 : (_props$confirmationPa = props.confirmationPaneProps) === null || _props$confirmationPa === void 0 ? void 0 : _props$confirmationPa.confirmationPaneLocalizedTexts)
|
|
7
7
|
};
|
|
8
8
|
let confirmationPaneInputs;
|
|
9
9
|
const emailTranscriptDisabled = ((_props$footerProps = props.footerProps) === null || _props$footerProps === void 0 ? void 0 : (_props$footerProps$co = _props$footerProps.controlProps) === null || _props$footerProps$co === void 0 ? void 0 : _props$footerProps$co.hideEmailTranscriptButton) ?? false;
|
|
10
10
|
const downloadTranscriptDisabled = ((_props$footerProps2 = props.footerProps) === null || _props$footerProps2 === void 0 ? void 0 : (_props$footerProps2$c = _props$footerProps2.controlProps) === null || _props$footerProps2$c === void 0 ? void 0 : _props$footerProps2$c.hideDownloadTranscriptButton) ?? false;
|
|
11
|
-
|
|
12
11
|
if (!emailTranscriptDisabled && !downloadTranscriptDisabled) {
|
|
13
12
|
confirmationPaneInputs = {
|
|
14
13
|
title: confirmationPanelocalizedTexts.CLOSE_CONFIRMATION_DIALOG_TITLE_FOR_EMAIL_AND_DOWNLOAD_TRANSCRIPT_ENABLED,
|
|
@@ -30,8 +29,8 @@ export const initConfirmationPropsComposer = props => {
|
|
|
30
29
|
description: confirmationPanelocalizedTexts.CLOSE_CONFIRMATION_DIALOG_DESCRIPTION_DEFAULT
|
|
31
30
|
};
|
|
32
31
|
}
|
|
33
|
-
|
|
34
|
-
|
|
32
|
+
const confirmationPaneProps = {
|
|
33
|
+
...props.confirmationPaneProps,
|
|
35
34
|
controlProps: {
|
|
36
35
|
titleText: confirmationPaneInputs.title,
|
|
37
36
|
subtitleText: confirmationPaneInputs.description,
|