@microsoft/omnichannel-chat-widget 0.1.0-main.8e79cb8 → 0.1.0-main.94f4f7a

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.
Files changed (332) hide show
  1. package/README.md +7 -2
  2. package/lib/cjs/assets/Icons.js +4 -2
  3. package/lib/cjs/common/Constants.js +34 -163
  4. package/lib/cjs/common/KeyCodes.js +3 -4
  5. package/lib/cjs/common/contextDataStore/DataStoreManager.js +3 -5
  6. package/lib/cjs/common/storage/default/defaultCacheManager.js +26 -0
  7. package/lib/cjs/common/storage/default/defaultClientDataStoreProvider.js +111 -0
  8. package/lib/cjs/common/storage/default/defaultInMemoryDataStore.js +78 -0
  9. package/lib/cjs/common/telemetry/TelemetryConstants.js +82 -29
  10. package/lib/cjs/common/telemetry/TelemetryHelper.js +21 -59
  11. package/lib/cjs/common/telemetry/TelemetryManager.js +3 -32
  12. package/lib/cjs/common/telemetry/defaultConfigs/defaultTelemetryConfiguration.js +0 -2
  13. package/lib/cjs/common/telemetry/loggers/ariaTelemetryLogger.js +30 -36
  14. package/lib/cjs/common/telemetry/loggers/consoleLogger.js +0 -9
  15. package/lib/cjs/common/utils.js +85 -92
  16. package/lib/cjs/components/callingcontainerstateful/CallingContainerStateful.js +8 -46
  17. package/lib/cjs/components/chatbuttonstateful/ChatButtonStateful.js +19 -25
  18. package/lib/cjs/components/chatbuttonstateful/common/styleProps/defaultOutOfOfficeChatButtonStyleProps.js +3 -0
  19. package/lib/cjs/components/confirmationpanestateful/ConfirmationPaneStateful.js +18 -50
  20. package/lib/cjs/components/dimlayer/DimLayer.js +0 -4
  21. package/lib/cjs/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.js +9 -37
  22. package/lib/cjs/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.spec.js +6 -8
  23. package/lib/cjs/components/footerstateful/FooterStateful.js +11 -42
  24. package/lib/cjs/components/footerstateful/audionotificationstateful/AudioNotificationStateful.js +0 -6
  25. package/lib/cjs/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.js +14 -43
  26. package/lib/cjs/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.spec.js +6 -8
  27. package/lib/cjs/components/headerstateful/HeaderStateful.js +21 -32
  28. package/lib/cjs/components/livechatwidget/LiveChatWidget.js +2 -14
  29. package/lib/cjs/components/livechatwidget/common/ActivityStreamHandler.js +39 -0
  30. package/lib/cjs/components/livechatwidget/common/ActivitySubscriber/BotAuthActivitySubscriber.js +139 -0
  31. package/lib/cjs/components/livechatwidget/common/ActivitySubscriber/DefaultActivitySubscriber.js +20 -0
  32. package/lib/cjs/components/livechatwidget/common/ActivitySubscriber/IActivitySubscriber.js +1 -0
  33. package/lib/cjs/components/livechatwidget/common/ActivitySubscriber/PauseActivitySubscriber.js +34 -0
  34. package/lib/cjs/components/livechatwidget/common/ChatAdapterShim.js +64 -0
  35. package/lib/cjs/components/livechatwidget/common/Deferred.js +37 -0
  36. package/lib/cjs/components/livechatwidget/common/agentEndConversationHelper.js +36 -0
  37. package/lib/cjs/components/livechatwidget/common/authHelper.js +50 -0
  38. package/lib/cjs/components/livechatwidget/common/createAdapter.js +12 -9
  39. package/lib/cjs/components/livechatwidget/common/createFooter.js +4 -23
  40. package/lib/cjs/components/livechatwidget/common/createInternetConnectionChangeHandler.js +10 -10
  41. package/lib/cjs/components/livechatwidget/common/createMarkdown.js +36 -43
  42. package/lib/cjs/components/livechatwidget/common/defaultProps/defaultScrollBarProps.js +14 -0
  43. package/lib/cjs/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +133 -51
  44. package/lib/cjs/components/livechatwidget/common/disposeTelemetryLoggers.js +0 -3
  45. package/lib/cjs/components/livechatwidget/common/endChat.js +86 -63
  46. package/lib/cjs/components/livechatwidget/common/getGeneralStylesForButton.js +0 -6
  47. package/lib/cjs/components/livechatwidget/common/initCallingSdk.js +7 -16
  48. package/lib/cjs/components/livechatwidget/common/initConfirmationPropsComposer.js +4 -8
  49. package/lib/cjs/components/livechatwidget/common/initWebChatComposer.js +29 -88
  50. package/lib/cjs/components/livechatwidget/common/reconnectChatHelper.js +76 -129
  51. package/lib/cjs/components/livechatwidget/common/registerTelemetryLoggers.js +4 -17
  52. package/lib/cjs/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +247 -14
  53. package/lib/cjs/components/livechatwidget/common/shareObservable.js +41 -0
  54. package/lib/cjs/components/livechatwidget/common/startChat.js +235 -127
  55. package/lib/cjs/components/livechatwidget/common/startProactiveChat.js +0 -8
  56. package/lib/cjs/components/livechatwidget/common/updateSessionDataForTelemetry.js +2 -11
  57. package/lib/cjs/components/livechatwidget/interfaces/IScrollBarProps.js +1 -0
  58. package/lib/cjs/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +355 -207
  59. package/lib/cjs/components/loadingpanestateful/LoadingPaneStateful.js +26 -19
  60. package/lib/cjs/components/loadingpanestateful/common/errorUIStyleProps/errorUILoadingPaneStyleProps.js +57 -0
  61. package/lib/cjs/components/ooohpanestateful/OOOHPaneStateful.js +4 -17
  62. package/lib/cjs/components/postchatloadingpanestateful/PostChatLoadingPaneStateful.js +4 -17
  63. package/lib/cjs/components/postchatsurveypanestateful/PostChatSurveyPaneStateful.js +32 -23
  64. package/lib/cjs/components/postchatsurveypanestateful/common/defaultStyleProps/defaultgeneralPostChatSurveyPaneStyleProps.js +1 -1
  65. package/lib/cjs/components/postchatsurveypanestateful/enums/CustomerVoiceEvents.js +13 -0
  66. package/lib/cjs/components/postchatsurveypanestateful/enums/PostChatSurveyMode.js +0 -1
  67. package/lib/cjs/components/postchatsurveypanestateful/interfaces/IPostChatSurveyPaneStatefulProps.js +1 -0
  68. package/lib/cjs/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +11 -43
  69. package/lib/cjs/components/prechatsurveypanestateful/common/defaultStyles/defaultGeneralPreChatSurveyPaneStyleProps.js +1 -1
  70. package/lib/cjs/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +19 -33
  71. package/lib/cjs/components/reconnectchatpanestateful/ReconnectChatPaneStateful.js +6 -24
  72. package/lib/cjs/components/webchatcontainerstateful/WebChatContainerStateful.js +94 -19
  73. package/lib/cjs/components/webchatcontainerstateful/common/defaultProps/defaultWebChatContainerStatefulProps.js +3 -7
  74. package/lib/cjs/components/webchatcontainerstateful/common/defaultProps/defaultWebChatStatefulProps.js +2 -6
  75. package/lib/cjs/components/webchatcontainerstateful/common/defaultStyles/defaultAdaptiveCardStyles.js +11 -0
  76. package/lib/cjs/components/webchatcontainerstateful/common/mockadapter.js +12 -27
  77. package/lib/cjs/components/webchatcontainerstateful/common/mockchatsdk.js +6 -17
  78. package/lib/cjs/components/webchatcontainerstateful/common/utils/BrowserInfo.js +2 -24
  79. package/lib/cjs/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +5 -15
  80. package/lib/cjs/components/webchatcontainerstateful/common/utils/isMaskingFromCustomer.js +5 -8
  81. package/lib/cjs/components/webchatcontainerstateful/interfaces/IAdaptiveCardStyles.js +1 -0
  82. package/lib/cjs/components/webchatcontainerstateful/interfaces/IBotMagicCodeConfig.js +1 -0
  83. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/BotMagicCodeStore.js +12 -0
  84. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/WebChatStoreLoader.js +3 -5
  85. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/BrowserVendor.js +0 -1
  86. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/DirectLineActivityType.js +0 -1
  87. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/DirectLineSenderRole.js +0 -1
  88. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/MessageType.js +0 -1
  89. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/NotificationLevel.js +0 -1
  90. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/NotificationScenarios.js +0 -1
  91. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/SendStatus.js +0 -1
  92. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/enums/WebChatActionType.js +0 -1
  93. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/adaptermiddlewares/formatTagsEgressMiddleware.js +0 -7
  94. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/adaptermiddlewares/formatTagsIngressMiddleware.js +0 -5
  95. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.js +27 -37
  96. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityStatusMiddleware.js +10 -22
  97. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/attachmentMiddleware.js +25 -61
  98. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/avatarMiddleware.js +7 -15
  99. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.js +41 -0
  100. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.js +82 -0
  101. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultReceivedMessageAnchorStyles.js +10 -0
  102. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultSystemMessageBoxStyles.js +10 -0
  103. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultTimestampFailedStyles.js +2 -3
  104. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultTimestampRetryStyles.js +2 -3
  105. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultUserMessageBoxStyles.js +10 -0
  106. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/groupActivitiesMiddleware.js +3 -9
  107. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/messageTimestampMiddleware.js +89 -0
  108. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/DeliveredTimestamp.js +7 -18
  109. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/NotDeliveredTimestamp.js +8 -42
  110. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/SendingTimestamp.js +4 -22
  111. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/typingIndicatorMiddleware.js +20 -33
  112. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/attachmentProcessingMiddleware.js +3 -9
  113. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/attachmentUploadValidatorMiddleware.js +6 -34
  114. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/channelDataMiddleware.js +1 -10
  115. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/conversationEndMiddleware.js +1 -12
  116. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/dataMaskingMiddleware.js +17 -19
  117. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/gifUploadMiddleware.js +1 -9
  118. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/htmlPlayerMiddleware.js +3 -9
  119. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/htmlTextMiddleware.js +13 -34
  120. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/maxMessageSizeValidator.js +1 -10
  121. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/preProcessingMiddleware.js +7 -11
  122. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/sanitizationMiddleware.js +5 -14
  123. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/notification/NotificationHandler.js +1 -21
  124. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.js +0 -12
  125. package/lib/cjs/contexts/ChatAdapterStore.js +0 -2
  126. package/lib/cjs/contexts/ChatContextStore.js +0 -2
  127. package/lib/cjs/contexts/ChatSDKStore.js +0 -2
  128. package/lib/cjs/contexts/common/ConversationEndEntity.js +12 -0
  129. package/lib/cjs/contexts/common/ConversationState.js +3 -3
  130. package/lib/cjs/contexts/common/LiveChatWidgetActionType.js +32 -26
  131. package/lib/cjs/contexts/common/LiveChatWidgetContextInitialState.js +18 -14
  132. package/lib/cjs/contexts/createReducer.js +183 -104
  133. package/lib/cjs/controller/componentController.js +4 -33
  134. package/lib/cjs/hooks/useChatAdapterStore.js +0 -6
  135. package/lib/cjs/hooks/useChatContextStore.js +0 -6
  136. package/lib/cjs/hooks/useChatSDKStore.js +0 -6
  137. package/lib/cjs/hooks/useDebounce.js +28 -0
  138. package/lib/cjs/hooks/useWindowDimensions.js +30 -0
  139. package/lib/cjs/index.js +0 -5
  140. package/lib/cjs/plugins/newMessageEventHandler.js +29 -36
  141. package/lib/esm/assets/Icons.js +2 -1
  142. package/lib/esm/common/Constants.js +31 -150
  143. package/lib/esm/common/KeyCodes.js +3 -3
  144. package/lib/esm/common/contextDataStore/DataStoreManager.js +3 -3
  145. package/lib/esm/common/storage/default/defaultCacheManager.js +18 -0
  146. package/lib/esm/common/storage/default/defaultClientDataStoreProvider.js +104 -0
  147. package/lib/esm/common/storage/default/defaultInMemoryDataStore.js +70 -0
  148. package/lib/esm/common/telemetry/TelemetryConstants.js +86 -26
  149. package/lib/esm/common/telemetry/TelemetryHelper.js +21 -47
  150. package/lib/esm/common/telemetry/TelemetryManager.js +3 -19
  151. package/lib/esm/common/telemetry/loggers/ariaTelemetryLogger.js +28 -24
  152. package/lib/esm/common/telemetry/loggers/consoleLogger.js +0 -5
  153. package/lib/esm/common/utils.js +81 -51
  154. package/lib/esm/components/callingcontainerstateful/CallingContainerStateful.js +8 -17
  155. package/lib/esm/components/chatbuttonstateful/ChatButtonStateful.js +22 -12
  156. package/lib/esm/components/chatbuttonstateful/common/styleProps/defaultOutOfOfficeChatButtonStyleProps.js +3 -0
  157. package/lib/esm/components/confirmationpanestateful/ConfirmationPaneStateful.js +20 -31
  158. package/lib/esm/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.js +9 -16
  159. package/lib/esm/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.spec.js +6 -6
  160. package/lib/esm/components/footerstateful/FooterStateful.js +13 -23
  161. package/lib/esm/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.js +14 -36
  162. package/lib/esm/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.spec.js +6 -6
  163. package/lib/esm/components/headerstateful/HeaderStateful.js +21 -17
  164. package/lib/esm/components/livechatwidget/LiveChatWidget.js +2 -2
  165. package/lib/esm/components/livechatwidget/common/ActivityStreamHandler.js +32 -0
  166. package/lib/esm/components/livechatwidget/common/ActivitySubscriber/BotAuthActivitySubscriber.js +134 -0
  167. package/lib/esm/components/livechatwidget/common/ActivitySubscriber/DefaultActivitySubscriber.js +13 -0
  168. package/lib/esm/components/livechatwidget/common/ActivitySubscriber/IActivitySubscriber.js +1 -0
  169. package/lib/esm/components/livechatwidget/common/ActivitySubscriber/PauseActivitySubscriber.js +27 -0
  170. package/lib/esm/components/livechatwidget/common/ChatAdapterShim.js +57 -0
  171. package/lib/esm/components/livechatwidget/common/Deferred.js +30 -0
  172. package/lib/esm/components/livechatwidget/common/agentEndConversationHelper.js +30 -0
  173. package/lib/esm/components/livechatwidget/common/authHelper.js +42 -0
  174. package/lib/esm/components/livechatwidget/common/createAdapter.js +14 -4
  175. package/lib/esm/components/livechatwidget/common/createFooter.js +4 -16
  176. package/lib/esm/components/livechatwidget/common/createInternetConnectionChangeHandler.js +10 -5
  177. package/lib/esm/components/livechatwidget/common/createMarkdown.js +38 -37
  178. package/lib/esm/components/livechatwidget/common/defaultProps/defaultScrollBarProps.js +7 -0
  179. package/lib/esm/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +134 -37
  180. package/lib/esm/components/livechatwidget/common/endChat.js +89 -48
  181. package/lib/esm/components/livechatwidget/common/getGeneralStylesForButton.js +0 -2
  182. package/lib/esm/components/livechatwidget/common/initCallingSdk.js +9 -11
  183. package/lib/esm/components/livechatwidget/common/initConfirmationPropsComposer.js +4 -5
  184. package/lib/esm/components/livechatwidget/common/initWebChatComposer.js +32 -57
  185. package/lib/esm/components/livechatwidget/common/reconnectChatHelper.js +77 -111
  186. package/lib/esm/components/livechatwidget/common/registerTelemetryLoggers.js +4 -9
  187. package/lib/esm/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +250 -8
  188. package/lib/esm/components/livechatwidget/common/shareObservable.js +35 -0
  189. package/lib/esm/components/livechatwidget/common/startChat.js +233 -103
  190. package/lib/esm/components/livechatwidget/common/updateSessionDataForTelemetry.js +4 -2
  191. package/lib/esm/components/livechatwidget/interfaces/IScrollBarProps.js +1 -0
  192. package/lib/esm/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +358 -151
  193. package/lib/esm/components/loadingpanestateful/LoadingPaneStateful.js +26 -7
  194. package/lib/esm/components/loadingpanestateful/common/errorUIStyleProps/errorUILoadingPaneStyleProps.js +50 -0
  195. package/lib/esm/components/ooohpanestateful/OOOHPaneStateful.js +4 -5
  196. package/lib/esm/components/postchatloadingpanestateful/PostChatLoadingPaneStateful.js +4 -5
  197. package/lib/esm/components/postchatsurveypanestateful/PostChatSurveyPaneStateful.js +32 -11
  198. package/lib/esm/components/postchatsurveypanestateful/common/defaultStyleProps/defaultgeneralPostChatSurveyPaneStyleProps.js +1 -1
  199. package/lib/esm/components/postchatsurveypanestateful/enums/CustomerVoiceEvents.js +6 -0
  200. package/lib/esm/components/postchatsurveypanestateful/enums/PostChatSurveyMode.js +0 -1
  201. package/lib/esm/components/postchatsurveypanestateful/interfaces/IPostChatSurveyPaneStatefulProps.js +1 -0
  202. package/lib/esm/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +14 -27
  203. package/lib/esm/components/prechatsurveypanestateful/common/defaultStyles/defaultGeneralPreChatSurveyPaneStyleProps.js +1 -1
  204. package/lib/esm/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +21 -9
  205. package/lib/esm/components/reconnectchatpanestateful/ReconnectChatPaneStateful.js +6 -6
  206. package/lib/esm/components/webchatcontainerstateful/WebChatContainerStateful.js +94 -4
  207. package/lib/esm/components/webchatcontainerstateful/common/defaultProps/defaultWebChatContainerStatefulProps.js +3 -1
  208. package/lib/esm/components/webchatcontainerstateful/common/defaultProps/defaultWebChatStatefulProps.js +2 -2
  209. package/lib/esm/components/webchatcontainerstateful/common/defaultStyles/defaultAdaptiveCardStyles.js +4 -0
  210. package/lib/esm/components/webchatcontainerstateful/common/mockadapter.js +12 -19
  211. package/lib/esm/components/webchatcontainerstateful/common/mockchatsdk.js +6 -13
  212. package/lib/esm/components/webchatcontainerstateful/common/utils/BrowserInfo.js +2 -16
  213. package/lib/esm/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +5 -5
  214. package/lib/esm/components/webchatcontainerstateful/common/utils/isMaskingFromCustomer.js +5 -6
  215. package/lib/esm/components/webchatcontainerstateful/interfaces/IAdaptiveCardStyles.js +1 -0
  216. package/lib/esm/components/webchatcontainerstateful/interfaces/IBotMagicCodeConfig.js +1 -0
  217. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/BotMagicCodeStore.js +5 -0
  218. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/WebChatStoreLoader.js +3 -3
  219. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/BrowserVendor.js +0 -1
  220. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/DirectLineActivityType.js +0 -1
  221. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/DirectLineSenderRole.js +0 -1
  222. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/MessageType.js +0 -1
  223. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/NotificationLevel.js +0 -1
  224. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/NotificationScenarios.js +0 -1
  225. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/SendStatus.js +0 -1
  226. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/enums/WebChatActionType.js +0 -1
  227. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/adaptermiddlewares/formatTagsEgressMiddleware.js +2 -5
  228. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/adaptermiddlewares/formatTagsIngressMiddleware.js +0 -4
  229. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.js +27 -22
  230. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityStatusMiddleware.js +12 -14
  231. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/attachmentMiddleware.js +25 -39
  232. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/avatarMiddleware.js +9 -8
  233. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.js +34 -0
  234. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.js +80 -0
  235. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultReceivedMessageAnchorStyles.js +3 -0
  236. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultSystemMessageBoxStyles.js +3 -0
  237. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultTimestampFailedStyles.js +2 -1
  238. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultTimestampRetryStyles.js +2 -1
  239. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultUserMessageBoxStyles.js +3 -0
  240. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/groupActivitiesMiddleware.js +3 -7
  241. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/messageTimestampMiddleware.js +83 -0
  242. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/DeliveredTimestamp.js +8 -9
  243. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/NotDeliveredTimestamp.js +9 -28
  244. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/SendingTimestamp.js +5 -14
  245. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/typingIndicatorMiddleware.js +20 -22
  246. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/attachmentProcessingMiddleware.js +5 -8
  247. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/attachmentUploadValidatorMiddleware.js +6 -29
  248. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/channelDataMiddleware.js +3 -7
  249. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/conversationEndMiddleware.js +3 -8
  250. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/dataMaskingMiddleware.js +17 -14
  251. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/gifUploadMiddleware.js +3 -7
  252. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/htmlPlayerMiddleware.js +3 -7
  253. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/htmlTextMiddleware.js +15 -27
  254. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/maxMessageSizeValidator.js +3 -5
  255. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/preProcessingMiddleware.js +9 -9
  256. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/sanitizationMiddleware.js +7 -9
  257. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/notification/NotificationHandler.js +1 -13
  258. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.js +0 -5
  259. package/lib/esm/contexts/ChatAdapterStore.js +2 -1
  260. package/lib/esm/contexts/ChatContextStore.js +2 -1
  261. package/lib/esm/contexts/ChatSDKStore.js +2 -1
  262. package/lib/esm/contexts/common/ConversationEndEntity.js +5 -0
  263. package/lib/esm/contexts/common/ConversationState.js +3 -3
  264. package/lib/esm/contexts/common/LiveChatWidgetActionType.js +32 -26
  265. package/lib/esm/contexts/common/LiveChatWidgetContextInitialState.js +18 -10
  266. package/lib/esm/contexts/createReducer.js +183 -101
  267. package/lib/esm/controller/componentController.js +5 -4
  268. package/lib/esm/hooks/useChatAdapterStore.js +0 -4
  269. package/lib/esm/hooks/useChatContextStore.js +0 -4
  270. package/lib/esm/hooks/useChatSDKStore.js +0 -4
  271. package/lib/esm/hooks/useDebounce.js +22 -0
  272. package/lib/esm/hooks/useWindowDimensions.js +23 -0
  273. package/lib/esm/plugins/newMessageEventHandler.js +29 -26
  274. package/lib/types/assets/Icons.d.ts +1 -0
  275. package/lib/types/common/Constants.d.ts +24 -0
  276. package/lib/types/common/interfaces/IContextDataStore.d.ts +1 -1
  277. package/lib/types/common/storage/default/defaultCacheManager.d.ts +4 -0
  278. package/lib/types/common/storage/default/defaultClientDataStoreProvider.d.ts +2 -0
  279. package/lib/types/common/storage/default/defaultInMemoryDataStore.d.ts +6 -0
  280. package/lib/types/common/telemetry/TelemetryConstants.d.ts +63 -11
  281. package/lib/types/common/telemetry/definitions/Contracts.d.ts +4 -4
  282. package/lib/types/common/telemetry/definitions/Payload.d.ts +1 -0
  283. package/lib/types/common/telemetry/interfaces/ITelemetryConfig.d.ts +4 -0
  284. package/lib/types/common/utils.d.ts +8 -3
  285. package/lib/types/components/confirmationpanestateful/interfaces/IConfirmationPaneStatefulParams.d.ts +0 -7
  286. package/lib/types/components/headerstateful/interfaces/IHeaderStatefulParams.d.ts +2 -1
  287. package/lib/types/components/livechatwidget/common/ActivityStreamHandler.d.ts +14 -0
  288. package/lib/types/components/livechatwidget/common/ActivitySubscriber/BotAuthActivitySubscriber.d.ts +9 -0
  289. package/lib/types/components/livechatwidget/common/ActivitySubscriber/DefaultActivitySubscriber.d.ts +5 -0
  290. package/lib/types/components/livechatwidget/common/ActivitySubscriber/IActivitySubscriber.d.ts +6 -0
  291. package/lib/types/components/livechatwidget/common/ActivitySubscriber/PauseActivitySubscriber.d.ts +7 -0
  292. package/lib/types/components/livechatwidget/common/ChatAdapterShim.d.ts +7 -0
  293. package/lib/types/components/livechatwidget/common/Deferred.d.ts +9 -0
  294. package/lib/types/components/livechatwidget/common/agentEndConversationHelper.d.ts +6 -0
  295. package/lib/types/components/livechatwidget/common/authHelper.d.ts +5 -0
  296. package/lib/types/components/livechatwidget/common/defaultProps/defaultScrollBarProps.d.ts +2 -0
  297. package/lib/types/components/livechatwidget/common/initWebChatComposer.d.ts +1 -1
  298. package/lib/types/components/livechatwidget/common/reconnectChatHelper.d.ts +6 -7
  299. package/lib/types/components/livechatwidget/common/setPostChatContextAndLoadSurvey.d.ts +6 -1
  300. package/lib/types/components/livechatwidget/common/shareObservable.d.ts +1 -0
  301. package/lib/types/components/livechatwidget/common/startChat.d.ts +5 -2
  302. package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetControlProps.d.ts +4 -1
  303. package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetProps.d.ts +5 -2
  304. package/lib/types/components/livechatwidget/interfaces/IScrollBarProps.d.ts +22 -0
  305. package/lib/types/components/loadingpanestateful/common/errorUIStyleProps/errorUILoadingPaneStyleProps.d.ts +2 -0
  306. package/lib/types/components/postchatsurveypanestateful/PostChatSurveyPaneStateful.d.ts +2 -2
  307. package/lib/types/components/postchatsurveypanestateful/enums/CustomerVoiceEvents.d.ts +5 -0
  308. package/lib/types/components/postchatsurveypanestateful/interfaces/IPostChatSurveyPaneStatefulProps.d.ts +4 -0
  309. package/lib/types/components/reconnectchatpanestateful/interfaces/IReconnectChatPaneStatefulProps.d.ts +0 -2
  310. package/lib/types/components/webchatcontainerstateful/common/defaultStyles/defaultAdaptiveCardStyles.d.ts +2 -0
  311. package/lib/types/components/webchatcontainerstateful/common/mockchatsdk.d.ts +1 -0
  312. package/lib/types/components/webchatcontainerstateful/interfaces/IAdaptiveCardStyles.d.ts +4 -0
  313. package/lib/types/components/webchatcontainerstateful/interfaces/IBotMagicCodeConfig.d.ts +4 -0
  314. package/lib/types/components/webchatcontainerstateful/interfaces/IRenderingMiddlewareProps.d.ts +4 -1
  315. package/lib/types/components/webchatcontainerstateful/interfaces/IWebChatContainerStatefulProps.d.ts +4 -0
  316. package/lib/types/components/webchatcontainerstateful/webchatcontroller/BotMagicCodeStore.d.ts +3 -0
  317. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityStatusMiddleware.d.ts +1 -1
  318. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.d.ts +2 -0
  319. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.d.ts +1 -0
  320. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultReceivedMessageAnchorStyles.d.ts +2 -0
  321. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultSystemMessageBoxStyles.d.ts +3 -0
  322. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultUserMessageBoxStyles.d.ts +3 -0
  323. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/messageTimestampMiddleware.d.ts +5 -0
  324. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/timestamps/SendingTimestamp.d.ts +1 -1
  325. package/lib/types/contexts/common/ConversationEndEntity.d.ts +4 -0
  326. package/lib/types/contexts/common/ConversationState.d.ts +3 -2
  327. package/lib/types/contexts/common/ILiveChatWidgetContext.d.ts +9 -4
  328. package/lib/types/contexts/common/LiveChatWidgetActionType.d.ts +32 -25
  329. package/lib/types/contexts/common/LiveChatWidgetContextInitialState.d.ts +1 -2
  330. package/lib/types/hooks/useDebounce.d.ts +3 -0
  331. package/lib/types/hooks/useWindowDimensions.d.ts +4 -0
  332. package/package.json +5 -4
@@ -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";
@@ -8,10 +9,11 @@ import { createActivityMiddleware } from "../../../webchatcontainerstateful/webc
8
9
  import createAttachmentMiddleware from "../../../webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/attachmentMiddleware";
9
10
  import { createAvatarMiddleware } from "../../../webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/avatarMiddleware";
10
11
  import { createMarkdown } from "../createMarkdown";
12
+ import { createWebChatTelemetry } from "../../../webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger";
11
13
  import { groupActivitiesMiddleware } from "../../../webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/groupActivitiesMiddleware";
12
14
  import { typingIndicatorMiddleware } from "../../../webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/typingIndicatorMiddleware";
13
- import { createWebChatTelemetry } from "../../../webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger"; // eslint-disable-next-line @typescript-eslint/no-unused-vars
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
- fontSize: 18
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
- fontSize: 18
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
- fontSize: 18,
203
- marginLeft: "5px"
207
+ marginLeft: "5px",
208
+ icon: {
209
+ fontSize: 18,
210
+ color: "#FFFFFF"
211
+ }
204
212
  },
205
213
  incomingCallTitleStyleProps: {
206
214
  margin: "0 5px",
@@ -316,7 +324,10 @@ export const dummyDefaultProps = {
316
324
  hideChatTextContainer: false,
317
325
  hideChatSubtitle: false,
318
326
  hideChatTitle: false,
319
- hideNotificationBubble: true
327
+ hideNotificationBubble: true,
328
+ unreadMessageString: "new messages",
329
+ largeUnreadMessageString: "99+",
330
+ ariaLabelUnreadMessageString: "you have new messages"
320
331
  },
321
332
  styleProps: {
322
333
  generalStyleProps: {
@@ -396,6 +407,7 @@ export const dummyDefaultProps = {
396
407
  width: "90px",
397
408
  cursor: "pointer",
398
409
  overflow: "hidden",
410
+ padding: "0px",
399
411
  whiteSpace: "nowrap"
400
412
  },
401
413
  subtitleStyleProps: {
@@ -403,12 +415,14 @@ export const dummyDefaultProps = {
403
415
  fontWeight: "200",
404
416
  color: "#666",
405
417
  overflow: "hidden",
418
+ padding: "0px",
406
419
  fontFamily: "'Segoe UI',Arial,sans-serif",
407
420
  display: "block",
408
421
  alignItems: "center",
409
422
  margin: "0px 14px 0px 14px",
410
423
  textOverflow: "ellipsis !important",
411
- width: "max-content",
424
+ width: "90px",
425
+ whiteSpace: "nowrap",
412
426
  cursor: "pointer"
413
427
  },
414
428
  classNames: {
@@ -458,28 +472,30 @@ export const dummyDefaultProps = {
458
472
  cancelButtonText: "Cancel",
459
473
  cancelButtonAriaLabel: "Cancel. Return to Chat",
460
474
  brightnessValueOnDim: "0.2",
461
- disableDimLayer: false,
462
475
  onConfirm: () => {},
463
476
  // Detailed implementation omitted
464
477
  onCancel: () => {} // Detailed implementation omitted
465
-
466
478
  },
479
+
467
480
  styleProps: {
468
481
  generalStyleProps: {
482
+ display: "flex",
483
+ minHeight: "160px",
484
+ maxHeight: "300px",
485
+ boxSizing: "border-box",
469
486
  backgroundColor: "#FFFFFF",
470
487
  borderRadius: "2px",
471
488
  color: "black",
472
489
  fontFamily: "Segoe UI, Arial, sans-serif",
473
490
  fontSize: "14px",
474
- height: "160px",
475
491
  padding: "10px 20px",
476
- width: "262px",
477
492
  position: "absolute",
478
493
  justifyContent: "center",
479
494
  alignItems: "center",
480
- display: "flex",
481
495
  flexFlow: "column",
482
- zIndex: "9999"
496
+ zIndex: "9999",
497
+ left: "26px",
498
+ right: "26px"
483
499
  },
484
500
  titleStyleProps: {
485
501
  color: "#323130",
@@ -501,10 +517,14 @@ export const dummyDefaultProps = {
501
517
  },
502
518
  buttonGroupStyleProps: {
503
519
  display: "flex",
520
+ width: "auto",
521
+ height: "auto",
522
+ boxSizing: "border-box",
504
523
  flexFlow: "row",
505
524
  justifyContent: "center",
506
525
  alignItems: "center",
507
- gap: "10px"
526
+ gap: "10px",
527
+ marginBottom: "10px"
508
528
  },
509
529
  confirmButtonStyleProps: {
510
530
  backgroundColor: "rgba(9,72,159,1)",
@@ -559,6 +579,7 @@ export const dummyDefaultProps = {
559
579
  hideCallingContainer: false,
560
580
  hideChatButton: false,
561
581
  hideConfirmationPane: false,
582
+ hideErrorUIPane: false,
562
583
  hideFooter: false,
563
584
  hideHeader: false,
564
585
  hideLoadingPane: false,
@@ -568,7 +589,7 @@ export const dummyDefaultProps = {
568
589
  hideProactiveChatPane: false,
569
590
  hideReconnectChatPane: false,
570
591
  hideWebChatContainer: false,
571
- skipChatButtonRendering: false
592
+ hideStartChatButton: false
572
593
  },
573
594
  directLine: new MockAdapter(),
574
595
  downloadTranscriptProps: {
@@ -609,7 +630,6 @@ export const dummyDefaultProps = {
609
630
  cancelButtonText: "Cancel",
610
631
  cancelButtonAriaLabel: "Cancel",
611
632
  brightnessValueOnDim: "0.2",
612
- disableDimLayer: false,
613
633
  onSend: undefined,
614
634
  onCancel: undefined,
615
635
  checkInput: undefined
@@ -768,6 +788,7 @@ export const dummyDefaultProps = {
768
788
  },
769
789
  audioNotificationButtonProps: {
770
790
  id: "oc-lcw-footer-audionotification-button",
791
+ type: "icon",
771
792
  ariaLabel: "Turn sound off",
772
793
  toggleAriaLabel: "Turn sound on",
773
794
  iconName: "Volume3",
@@ -793,8 +814,10 @@ export const dummyDefaultProps = {
793
814
  padding: "0 10px 5px 10px"
794
815
  },
795
816
  downloadTranscriptButtonStyleProps: {
796
- color: "blue",
797
- fontSize: 16,
817
+ icon: {
818
+ color: "blue",
819
+ fontSize: 16
820
+ },
798
821
  height: "25px",
799
822
  lineHeight: "25px",
800
823
  width: "25px"
@@ -804,8 +827,10 @@ export const dummyDefaultProps = {
804
827
  backgroundColor: "#C8C8C8"
805
828
  },
806
829
  emailTranscriptButtonStyleProps: {
807
- color: "blue",
808
- fontSize: 16,
830
+ cicon: {
831
+ color: "blue",
832
+ fontSize: 16
833
+ },
809
834
  height: "25px",
810
835
  lineHeight: "25px",
811
836
  width: "25px"
@@ -815,8 +840,10 @@ export const dummyDefaultProps = {
815
840
  backgroundColor: "#C8C8C8"
816
841
  },
817
842
  audioNotificationButtonStyleProps: {
818
- color: "blue",
819
- fontSize: 16,
843
+ icon: {
844
+ color: "blue",
845
+ fontSize: 16
846
+ },
820
847
  height: "25px",
821
848
  lineHeight: "25px",
822
849
  width: "25px"
@@ -867,7 +894,7 @@ export const dummyDefaultProps = {
867
894
  className: undefined
868
895
  },
869
896
  closeButtonProps: {
870
- id: "oc-lcw-header-minimize-button",
897
+ id: "oc-lcw-header-close-button",
871
898
  type: "icon",
872
899
  iconName: "ChromeClose",
873
900
  ariaLabel: "Close",
@@ -1000,7 +1027,8 @@ export const dummyDefaultProps = {
1000
1027
  margin: "0px 0px 20px 0px",
1001
1028
  display: "flex",
1002
1029
  order: 1,
1003
- alignSelf: "auto"
1030
+ alignSelf: "auto",
1031
+ overflow: "visible"
1004
1032
  },
1005
1033
  iconImageProps: {
1006
1034
  src: "",
@@ -1046,8 +1074,8 @@ export const dummyDefaultProps = {
1046
1074
  titleText: "We're Offline",
1047
1075
  subtitleText: "No agents available",
1048
1076
  onClick: () => {} // Detailed implementation omitted
1049
-
1050
1077
  },
1078
+
1051
1079
  styleProps: {
1052
1080
  // ...[Existing chat button style props]
1053
1081
  iconStyleProps: {
@@ -1065,8 +1093,8 @@ export const dummyDefaultProps = {
1065
1093
  text: "We're Offline"
1066
1094
  },
1067
1095
  onMinimizeClick: () => {} // Detailed implementation omitted
1068
-
1069
1096
  },
1097
+
1070
1098
  styleProps: {
1071
1099
  // ...[Existing chat button style props]
1072
1100
  generalStyleProps: {
@@ -1092,7 +1120,8 @@ export const dummyDefaultProps = {
1092
1120
  dir: "auto",
1093
1121
  hideOOOHPane: false,
1094
1122
  hideTitle: false,
1095
- titleText: "Thanks for contacting us. You have reached us outside of our operating hours. An agent will respond when we open."
1123
+ titleText: "Thanks for contacting us. You have reached us outside of our operating hours. An agent will respond when we open. Please see link https://microsoft.com",
1124
+ openLinkInNewTab: true
1096
1125
  },
1097
1126
  styleProps: {
1098
1127
  generalStyleProps: {
@@ -1135,7 +1164,7 @@ export const dummyDefaultProps = {
1135
1164
  subtitleText: "Please take a moment to give us feedback about your chat experience. We are loading the survey for you now."
1136
1165
  },
1137
1166
  styleProps: {
1138
- // ...[Existing chat button style props]
1167
+ // ...[Existing loading pane style props]
1139
1168
  generalStyleProps: {
1140
1169
  position: "initial",
1141
1170
  width: "100%",
@@ -1163,6 +1192,48 @@ export const dummyDefaultProps = {
1163
1192
  backgroundColor: "#FFFFFF",
1164
1193
  borderColor: "#F1F1F1"
1165
1194
  }
1195
+ },
1196
+ isCustomerVoiceSurveyCompact: undefined
1197
+ },
1198
+ preChatSurveyPaneProps: {
1199
+ controlProps: {
1200
+ id: "oc-lcw-prechatsurveypane-default",
1201
+ dir: "auto",
1202
+ hidePreChatSurveyPane: false,
1203
+ adaptiveCardHostConfig: "{\"fontFamily\":\"Segoe UI, Helvetica Neue, sans-serif\",\"containerStyles\":{\"default\":{\"foregroundColors\":{\"default\":{\"default\":\"#000000\"}},\"backgroundColor\":\"#FFFFFF\"}},\"actions\":{\"actionsOrientation\":\"Vertical\",\"actionAlignment\":\"stretch\"}}",
1204
+ payload: "{\"$schema\":\"http://adaptivecards.io/schemas/adaptive-card.json\",\"type\":\"AdaptiveCard\",\"version\":\"1.1\",\"body\":[{\"type\":\"TextBlock\",\"weight\":\"bolder\",\"text\":\"Please answer below questions.\"},{\"type\":\"Input.Text\",\"id\":\"1e5e4e7a-8f0b-ec11-b6e6-000d3a305d38\",\"label\":\"name pls?\",\"maxLength\":100,\"isRequired\":true,\"errorMessage\":\"Name is required\"},{\"type\":\"Input.Text\",\"id\":\"7f8f5d6d-995e-ec11-8f8f-000d3a31376e\",\"label\":\"multi\\nmulti\\nmulti\",\"style\":\"text\",\"isMultiline\":true,\"maxLength\":250},{\"type\":\"Input.ChoiceSet\",\"id\":\"e4bdf7cb-995e-ec11-8f8f-000d3a31376e\",\"label\":\"options\",\"isMultiSelect\":false,\"value\":\"1\",\"style\":\"compact\",\"choices\":[{\"title\":\"one\",\"value\":\"1\"},{\"title\":\"two\",\"value\":\"2\"},{\"title\":\"three\",\"value\":\"3\"}]},{\"type\":\"Input.Toggle\",\"id\":\"b26011d2-995e-ec11-8f8f-000d3a31376e\",\"title\":\"consent\",\"valueOn\":\"True\",\"valueOff\":\"False\",\"value\":\"false\"},{\"type\":\"TextBlock\",\"isSubtle\":true,\"text\":\"Fields marked with * are mandatory.\",\"wrap\":true}],\"actions\":[{\"type\":\"Action.Submit\",\"title\":\"Submit\",\"data\":{\"Type\":\"InputSubmit\"}}]}",
1205
+ onSubmit: function () {} // Detailed implementation omitted
1206
+ },
1207
+
1208
+ styleProps: {
1209
+ generalStyleProps: {
1210
+ borderStyle: "solid",
1211
+ borderRadius: "4px",
1212
+ borderWidth: "0px",
1213
+ backgroundColor: "#FFFFFF",
1214
+ borderColor: "#F1F1F1",
1215
+ overflowY: "auto",
1216
+ height: "inherit",
1217
+ width: "inherit"
1218
+ },
1219
+ customButtonStyleProps: {
1220
+ backgroundColor: "rgb(49, 95, 162)",
1221
+ color: "#FFFFFF",
1222
+ fontFamily: "Segoe UI, Arial, sans-serif",
1223
+ fontSize: "15px",
1224
+ height: "48px"
1225
+ },
1226
+ adaptiveCardContainerStyleProps: {
1227
+ border: "1px solid #ECECEC",
1228
+ borderRadius: "4px",
1229
+ margin: "3%"
1230
+ },
1231
+ customTextInputStyleProps: {
1232
+ height: "20px"
1233
+ },
1234
+ customMultilineTextInputStyleProps: {
1235
+ height: "52px"
1236
+ }
1166
1237
  }
1167
1238
  },
1168
1239
  proactiveChatPaneProps: {
@@ -1183,7 +1254,17 @@ export const dummyDefaultProps = {
1183
1254
  hideSubtitle: false,
1184
1255
  subtitleText: "Live chat support!",
1185
1256
  hideCloseButton: false,
1186
- closeButtonAriaLabel: "Close Button",
1257
+ closeButtonProps: {
1258
+ id: "oc-lcw-proactivechat-closebutton",
1259
+ type: "icon",
1260
+ iconName: "ChromeClose",
1261
+ ariaLabel: "Close",
1262
+ imageIconProps: undefined,
1263
+ text: "Close",
1264
+ onClick: undefined,
1265
+ className: undefined,
1266
+ hideButtonTitle: true
1267
+ },
1187
1268
  isBodyContainerHorizantal: false,
1188
1269
  hideBodyTitle: false,
1189
1270
  bodyTitleText: "Hi! Have any questions? I am here to help.",
@@ -1193,8 +1274,8 @@ export const dummyDefaultProps = {
1193
1274
  onClose: () => {},
1194
1275
  // Detailed implementation omitted
1195
1276
  onStart: () => {} // Detailed implementation omitted
1196
-
1197
1277
  },
1278
+
1198
1279
  styleProps: {
1199
1280
  generalStyleProps: {
1200
1281
  backgroundColor: "rgb(255, 255, 255)",
@@ -1325,8 +1406,8 @@ export const dummyDefaultProps = {
1325
1406
  onStartNewChat: () => {},
1326
1407
  // Detailed implementation omitted
1327
1408
  onMinimize: () => {} // Detailed implementation omitted
1328
-
1329
1409
  },
1410
+
1330
1411
  styleProps: {
1331
1412
  generalStyleProps: {
1332
1413
  backgroundColor: "rgb(255, 255, 255)",
@@ -1411,8 +1492,6 @@ export const dummyDefaultProps = {
1411
1492
  startNewChatButtonClassName: undefined
1412
1493
  }
1413
1494
  },
1414
- authClientFunction: undefined,
1415
- isReconnectEnabled: undefined,
1416
1495
  reconnectId: undefined,
1417
1496
  redirectInSameWindow: undefined
1418
1497
  },
@@ -1534,6 +1613,12 @@ export const dummyDefaultProps = {
1534
1613
  lineHeight: "16px",
1535
1614
  padding: "0px 10px 0 10px"
1536
1615
  },
1616
+ userMessageBoxStyles: {
1617
+ maxWidth: "90%"
1618
+ },
1619
+ systemMessageBoxStyles: {
1620
+ maxWidth: "90%"
1621
+ },
1537
1622
  typingIndicatorStyleProps: {
1538
1623
  marginLeft: "10px",
1539
1624
  marginBottom: "5px",
@@ -1653,6 +1738,9 @@ export const dummyDefaultProps = {
1653
1738
  },
1654
1739
  attachmentSizeStyles: {
1655
1740
  display: "none"
1741
+ },
1742
+ receivedMessageAnchorStyles: {
1743
+ color: "white"
1656
1744
  }
1657
1745
  },
1658
1746
  localizedTexts: {
@@ -1676,7 +1764,16 @@ export const dummyDefaultProps = {
1676
1764
  MIDDLEWARE_MESSAGE_RETRY: "Retry",
1677
1765
  PRECHAT_REQUIRED_FIELD_MISSING_MESSAGE: "{0} field is required",
1678
1766
  MARKDOWN_EXTERNAL_LINK_ALT: "Opens in a new window; external."
1767
+ },
1768
+ botMagicCode: {
1769
+ disabled: false,
1770
+ fwdUrl: ""
1771
+ },
1772
+ adaptiveCardStyles: {
1773
+ background: "white",
1774
+ color: "black"
1679
1775
  }
1680
1776
  },
1681
- telemetryConfig: undefined
1777
+ telemetryConfig: undefined,
1778
+ getAuthToken: undefined
1682
1779
  };
@@ -1,51 +1,43 @@
1
- import { BroadcastEvent, LogLevel, TelemetryEvent } from "../../../common/telemetry/TelemetryConstants";
1
+ import { LogLevel, TelemetryEvent } from "../../../common/telemetry/TelemetryConstants";
2
2
  import { BroadcastService } from "@microsoft/omnichannel-chat-components";
3
3
  import { ConversationState } from "../../../contexts/common/ConversationState";
4
4
  import { LiveChatWidgetActionType } from "../../../contexts/common/LiveChatWidgetActionType";
5
5
  import { TelemetryHelper } from "../../../common/telemetry/TelemetryHelper";
6
6
  import { WebChatStoreLoader } from "../../webchatcontainerstateful/webchatcontroller/WebChatStoreLoader";
7
7
  import { defaultWebChatContainerStatefulProps } from "../../webchatcontainerstateful/common/defaultProps/defaultWebChatContainerStatefulProps";
8
- import { PostChatSurveyMode } from "../../postchatsurveypanestateful/enums/PostChatSurveyMode";
9
- import { Constants } from "../../../common/Constants";
10
- import { getWidgetEndChatEventName } from "../../../common/utils"; // eslint-disable-next-line @typescript-eslint/no-explicit-any
8
+ import { getWidgetEndChatEventName } from "../../../common/utils";
9
+ import { getAuthClientFunction, handleAuthentication } from "./authHelper";
10
+ import { checkPostChatEnabled, initiatePostChat } from "./setPostChatContextAndLoadSurvey";
11
+ import { ConversationEndEntity } from "../../../contexts/common/ConversationEndEntity";
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
- var _state$domainStates$l, _state$domainStates$l2, _state$domainStates$l3, _state$domainStates$l4;
14
-
15
- 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 conversationDetails = await chatSDK.getConversationDetails();
18
-
19
- if (isPostChatEnabled === "true" && (conversationDetails === null || conversationDetails === void 0 ? void 0 : conversationDetails.canRenderPostChat) === Constants.truePascal) {
20
- const skipEndChatSDK = false;
21
- const skipCloseChat = true;
22
- await endChat(props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, skipEndChatSDK, skipCloseChat, true);
23
-
24
- if (postChatSurveyMode === PostChatSurveyMode.Embed) {
25
- const loadPostChatEvent = {
26
- eventName: BroadcastEvent.LoadPostChatSurvey
27
- };
28
- BroadcastService.postMessage(loadPostChatEvent);
29
- } else if (postChatSurveyMode === PostChatSurveyMode.Link) {
30
- dispatch({
31
- type: LiveChatWidgetActionType.SET_CONVERSATION_STATE,
32
- payload: ConversationState.InActive
33
- });
15
+ //Unable to end chat if token has expired
16
+ if (props.getAuthToken) {
17
+ const authClientFunction = getAuthClientFunction(props.chatConfig);
18
+ if (props.getAuthToken && authClientFunction) {
19
+ // set auth token to chat sdk before end chat
20
+ const authSuccess = await handleAuthentication(chatSDK, props.chatConfig, props.getAuthToken);
21
+ if (!authSuccess) {
22
+ TelemetryHelper.logActionEvent(LogLevel.ERROR, {
23
+ Event: TelemetryEvent.GetAuthTokenFailed,
24
+ ExceptionDetails: {
25
+ exception: "Unable to get auth token during end chat"
26
+ }
27
+ });
28
+ }
34
29
  }
35
- } else {
36
- await endChat(props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, false, false, true);
37
30
  }
38
- }; // eslint-disable-next-line @typescript-eslint/no-explicit-any
39
-
40
-
41
- const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, skipEndChatSDK, skipCloseChat, postMessageToOtherTab) => {
42
- if (!skipEndChatSDK) {
31
+ const isPostChatEnabled = checkPostChatEnabled(props, state);
32
+ if (isPostChatEnabled) {
43
33
  try {
44
- TelemetryHelper.logSDKEvent(LogLevel.INFO, {
45
- Event: TelemetryEvent.EndChatSDKCall
46
- });
47
- await (chatSDK === null || chatSDK === void 0 ? void 0 : chatSDK.endChat()); // Need to clear these states immediately when chat ended from OC.
48
-
34
+ await initiatePostChat(props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, state);
35
+ } catch (error) {
36
+ // Ending chat because something went wrong
37
+ await endChat(props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, false, false, true);
38
+ }
39
+ } else {
40
+ if (state.appStates.conversationEndedBy === ConversationEndEntity.Agent) {
49
41
  dispatch({
50
42
  type: LiveChatWidgetActionType.SET_CHAT_TOKEN,
51
43
  payload: undefined
@@ -54,6 +46,20 @@ const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, a
54
46
  type: LiveChatWidgetActionType.SET_LIVE_CHAT_CONTEXT,
55
47
  payload: undefined
56
48
  });
49
+ } else {
50
+ await endChat(props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, false, false, true);
51
+ }
52
+ }
53
+ };
54
+
55
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
56
+ const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, skipEndChatSDK, skipCloseChat, postMessageToOtherTab) => {
57
+ if (!skipEndChatSDK) {
58
+ try {
59
+ TelemetryHelper.logSDKEvent(LogLevel.INFO, {
60
+ Event: TelemetryEvent.EndChatSDKCall
61
+ });
62
+ await (chatSDK === null || chatSDK === void 0 ? void 0 : chatSDK.endChat());
57
63
  } catch (ex) {
58
64
  TelemetryHelper.logSDKEvent(LogLevel.ERROR, {
59
65
  Event: TelemetryEvent.EndChatSDKCallFailed,
@@ -64,14 +70,30 @@ const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, a
64
70
  postMessageToOtherTab = false;
65
71
  }
66
72
  }
67
-
73
+ // Need to clear these states immediately when chat ended from OC.
74
+ dispatch({
75
+ type: LiveChatWidgetActionType.SET_CUSTOM_CONTEXT,
76
+ payload: undefined
77
+ });
78
+ dispatch({
79
+ type: LiveChatWidgetActionType.SET_CHAT_TOKEN,
80
+ payload: undefined
81
+ });
82
+ dispatch({
83
+ type: LiveChatWidgetActionType.SET_LIVE_CHAT_CONTEXT,
84
+ payload: undefined
85
+ });
86
+ dispatch({
87
+ type: LiveChatWidgetActionType.SET_RECONNECT_ID,
88
+ payload: undefined
89
+ });
68
90
  if (!skipCloseChat) {
69
91
  try {
70
92
  var _props$webChatContain;
71
-
72
93
  adapter === null || adapter === void 0 ? void 0 : adapter.end();
73
94
  setAdapter(undefined);
74
- setWebChatStyles({ ...defaultWebChatContainerStatefulProps.webChatStyles,
95
+ setWebChatStyles({
96
+ ...defaultWebChatContainerStatefulProps.webChatStyles,
75
97
  ...((_props$webChatContain = props.webChatContainerProps) === null || _props$webChatContain === void 0 ? void 0 : _props$webChatContain.webChatStyles)
76
98
  });
77
99
  WebChatStoreLoader.store = null;
@@ -80,9 +102,17 @@ const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, a
80
102
  payload: ConversationState.Closed
81
103
  });
82
104
  dispatch({
83
- type: LiveChatWidgetActionType.SET_CONVERSATION_ENDED_BY_AGENT,
105
+ type: LiveChatWidgetActionType.SET_POST_CHAT_WORKFLOW_IN_PROGRESS,
106
+ payload: false
107
+ });
108
+ dispatch({
109
+ type: LiveChatWidgetActionType.SET_CONVERSATION_ENDED_BY_AGENT_EVENT_RECEIVED,
84
110
  payload: false
85
111
  });
112
+ dispatch({
113
+ type: LiveChatWidgetActionType.SET_CONVERSATION_ENDED_BY,
114
+ payload: undefined
115
+ });
86
116
  dispatch({
87
117
  type: LiveChatWidgetActionType.SET_RECONNECT_ID,
88
118
  payload: undefined
@@ -91,18 +121,25 @@ const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, a
91
121
  type: LiveChatWidgetActionType.SET_AUDIO_NOTIFICATION,
92
122
  payload: null
93
123
  });
94
- BroadcastService.postMessage({
95
- eventName: BroadcastEvent.EndChat
124
+ dispatch({
125
+ type: LiveChatWidgetActionType.SET_PROACTIVE_CHAT_PARAMS,
126
+ payload: {
127
+ proactiveChatBodyTitle: "",
128
+ proactiveChatEnablePrechat: false,
129
+ proactiveChatInNewWindow: false
130
+ }
96
131
  });
97
-
98
132
  if (postMessageToOtherTab) {
99
- var _chatSDK$omnichannelC, _chatSDK$omnichannelC2;
100
-
101
- 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);
133
+ var _chatSDK$omnichannelC, _chatSDK$omnichannelC2, _props$controlProps;
134
+ 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) ?? "");
102
135
  BroadcastService.postMessage({
103
136
  eventName: endChatEventName
104
137
  });
105
138
  }
139
+ TelemetryHelper.logActionEvent(LogLevel.INFO, {
140
+ Event: TelemetryEvent.CloseChatCall,
141
+ Description: "Chat was closed succesfully"
142
+ });
106
143
  } catch (error) {
107
144
  TelemetryHelper.logActionEvent(LogLevel.ERROR, {
108
145
  Event: TelemetryEvent.CloseChatMethodException,
@@ -110,8 +147,12 @@ const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, a
110
147
  exception: `Failed to endChat: ${error}`
111
148
  }
112
149
  });
150
+ } finally {
151
+ dispatch({
152
+ type: LiveChatWidgetActionType.SET_UNREAD_MESSAGE_COUNT,
153
+ payload: 0
154
+ });
113
155
  }
114
156
  }
115
157
  };
116
-
117
158
  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
  };