@microsoft/omnichannel-chat-widget 0.1.0-main.86df755 → 0.1.0-main.886e5cf

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 (186) hide show
  1. package/README.md +259 -0
  2. package/lib/cjs/assets/Audios.js +8 -0
  3. package/lib/cjs/assets/Icons.js +28 -0
  4. package/lib/cjs/common/Constants.js +52 -4
  5. package/lib/cjs/common/contextDataStore/DataStoreManager.js +14 -0
  6. package/lib/cjs/{assets/assets.d.js → common/interfaces/IContextDataStore.js} +0 -0
  7. package/lib/cjs/common/telemetry/TelemetryConstants.js +59 -4
  8. package/lib/cjs/common/telemetry/TelemetryHelper.js +22 -4
  9. package/lib/cjs/common/telemetry/TelemetryManager.js +28 -9
  10. package/lib/cjs/common/telemetry/defaultConfigs/defaultAriaConfig.js +3 -3
  11. package/lib/cjs/common/telemetry/defaultConfigs/defaultTelemetryConfiguration.js +4 -1
  12. package/lib/cjs/common/telemetry/loggers/ariaTelemetryLogger.js +48 -15
  13. package/lib/cjs/common/telemetry/loggers/consoleLogger.js +9 -5
  14. package/lib/cjs/common/utils.js +76 -2
  15. package/lib/cjs/components/callingcontainerstateful/CallingContainerStateful.js +14 -0
  16. package/lib/cjs/components/chatbuttonstateful/ChatButtonStateful.js +28 -5
  17. package/lib/cjs/components/confirmationpanestateful/ConfirmationPaneStateful.js +7 -54
  18. package/lib/cjs/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.js +2 -2
  19. package/lib/cjs/components/footerstateful/FooterStateful.js +4 -5
  20. package/lib/cjs/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.js +11 -2
  21. package/lib/cjs/components/headerstateful/HeaderStateful.js +13 -10
  22. package/lib/cjs/components/livechatwidget/common/createMarkdown.js +3 -4
  23. package/lib/cjs/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +53 -48
  24. package/lib/cjs/components/livechatwidget/common/disposeTelemetryLoggers.js +14 -0
  25. package/lib/cjs/components/livechatwidget/common/endChat.js +142 -43
  26. package/lib/cjs/components/livechatwidget/common/initCallingSdk.js +5 -0
  27. package/lib/cjs/components/livechatwidget/common/initWebChatComposer.js +48 -11
  28. package/lib/cjs/components/livechatwidget/common/reconnectChatHelper.js +107 -22
  29. package/lib/cjs/components/livechatwidget/common/registerTelemetryLoggers.js +11 -7
  30. package/lib/cjs/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +22 -24
  31. package/lib/cjs/components/livechatwidget/common/startChat.js +179 -41
  32. package/lib/cjs/components/livechatwidget/common/startProactiveChat.js +3 -3
  33. package/lib/cjs/components/livechatwidget/interfaces/IAuthProps.js +1 -0
  34. package/lib/cjs/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +249 -67
  35. package/lib/cjs/components/loadingpanestateful/LoadingPaneStateful.js +1 -1
  36. package/lib/cjs/components/ooohpanestateful/OOOHPaneStateful.js +8 -0
  37. package/lib/cjs/components/postchatloadingpanestateful/PostChatLoadingPaneStateful.js +8 -0
  38. package/lib/cjs/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +22 -10
  39. package/lib/cjs/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +27 -5
  40. package/lib/cjs/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.js +1 -0
  41. package/lib/cjs/components/webchatcontainerstateful/WebChatContainerStateful.js +80 -0
  42. package/lib/cjs/components/webchatcontainerstateful/common/mockchatsdk.js +4 -0
  43. package/lib/cjs/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +51 -73
  44. package/lib/cjs/components/webchatcontainerstateful/interfaces/IBotMagicCodeConfig.js +1 -0
  45. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/BotMagicCodeStore.js +14 -0
  46. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.js +25 -48
  47. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/attachmentMiddleware.js +3 -1
  48. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.js +52 -0
  49. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.js +98 -0
  50. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/messageTimestampMiddleware.js +117 -0
  51. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/conversationEndMiddleware.js +6 -6
  52. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.js +45 -0
  53. package/lib/cjs/contexts/common/ConversationState.js +4 -2
  54. package/lib/cjs/contexts/common/LiveChatWidgetActionType.js +13 -7
  55. package/lib/cjs/contexts/common/LiveChatWidgetContextInitialState.js +13 -5
  56. package/lib/cjs/contexts/createReducer.js +43 -10
  57. package/lib/cjs/controller/componentController.js +5 -5
  58. package/lib/cjs/plugins/newMessageEventHandler.js +99 -0
  59. package/lib/esm/assets/Audios.js +1 -0
  60. package/lib/esm/assets/Icons.js +11 -0
  61. package/lib/esm/common/Constants.js +48 -3
  62. package/lib/esm/common/contextDataStore/DataStoreManager.js +5 -0
  63. package/lib/esm/common/interfaces/IContextDataStore.js +1 -0
  64. package/lib/esm/common/telemetry/TelemetryConstants.js +55 -3
  65. package/lib/esm/common/telemetry/TelemetryHelper.js +22 -5
  66. package/lib/esm/common/telemetry/TelemetryManager.js +22 -9
  67. package/lib/esm/common/telemetry/defaultConfigs/defaultAriaConfig.js +3 -3
  68. package/lib/esm/common/telemetry/defaultConfigs/defaultTelemetryConfiguration.js +4 -1
  69. package/lib/esm/common/telemetry/loggers/ariaTelemetryLogger.js +50 -15
  70. package/lib/esm/common/telemetry/loggers/consoleLogger.js +9 -5
  71. package/lib/esm/common/utils.js +55 -1
  72. package/lib/esm/components/callingcontainerstateful/CallingContainerStateful.js +14 -0
  73. package/lib/esm/components/chatbuttonstateful/ChatButtonStateful.js +31 -8
  74. package/lib/esm/components/confirmationpanestateful/ConfirmationPaneStateful.js +7 -50
  75. package/lib/esm/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.js +2 -2
  76. package/lib/esm/components/footerstateful/FooterStateful.js +4 -5
  77. package/lib/esm/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.js +9 -3
  78. package/lib/esm/components/headerstateful/HeaderStateful.js +14 -11
  79. package/lib/esm/components/livechatwidget/common/createMarkdown.js +3 -3
  80. package/lib/esm/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +51 -49
  81. package/lib/esm/components/livechatwidget/common/disposeTelemetryLoggers.js +4 -0
  82. package/lib/esm/components/livechatwidget/common/endChat.js +139 -42
  83. package/lib/esm/components/livechatwidget/common/initCallingSdk.js +3 -0
  84. package/lib/esm/components/livechatwidget/common/initWebChatComposer.js +42 -12
  85. package/lib/esm/components/livechatwidget/common/reconnectChatHelper.js +98 -23
  86. package/lib/esm/components/livechatwidget/common/registerTelemetryLoggers.js +10 -3
  87. package/lib/esm/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +19 -22
  88. package/lib/esm/components/livechatwidget/common/startChat.js +172 -39
  89. package/lib/esm/components/livechatwidget/common/startProactiveChat.js +5 -5
  90. package/lib/esm/components/livechatwidget/interfaces/IAuthProps.js +1 -0
  91. package/lib/esm/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +235 -71
  92. package/lib/esm/components/loadingpanestateful/LoadingPaneStateful.js +1 -1
  93. package/lib/esm/components/ooohpanestateful/OOOHPaneStateful.js +6 -0
  94. package/lib/esm/components/postchatloadingpanestateful/PostChatLoadingPaneStateful.js +6 -0
  95. package/lib/esm/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +22 -10
  96. package/lib/esm/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +26 -6
  97. package/lib/esm/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.js +1 -0
  98. package/lib/esm/components/webchatcontainerstateful/WebChatContainerStateful.js +72 -0
  99. package/lib/esm/components/webchatcontainerstateful/common/mockchatsdk.js +4 -0
  100. package/lib/esm/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +2 -12
  101. package/lib/esm/components/webchatcontainerstateful/interfaces/IBotMagicCodeConfig.js +1 -0
  102. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/BotMagicCodeStore.js +5 -0
  103. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.js +23 -46
  104. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/attachmentMiddleware.js +2 -1
  105. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.js +41 -0
  106. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.js +94 -0
  107. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/messageTimestampMiddleware.js +107 -0
  108. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/conversationEndMiddleware.js +6 -6
  109. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.js +32 -0
  110. package/lib/esm/contexts/common/ConversationState.js +4 -2
  111. package/lib/esm/contexts/common/LiveChatWidgetActionType.js +13 -7
  112. package/lib/esm/contexts/common/LiveChatWidgetContextInitialState.js +13 -5
  113. package/lib/esm/contexts/createReducer.js +43 -9
  114. package/lib/esm/controller/componentController.js +5 -5
  115. package/lib/esm/plugins/newMessageEventHandler.js +82 -0
  116. package/lib/types/assets/Audios.d.ts +1 -0
  117. package/lib/types/assets/Icons.d.ts +11 -0
  118. package/lib/types/common/Constants.d.ts +26 -1
  119. package/lib/types/common/contextDataStore/DataStoreManager.d.ts +4 -0
  120. package/lib/types/common/interfaces/IContextDataStore.d.ts +14 -0
  121. package/lib/types/common/telemetry/TelemetryConstants.d.ts +43 -2
  122. package/lib/types/common/telemetry/TelemetryHelper.d.ts +3 -1
  123. package/lib/types/common/telemetry/TelemetryManager.d.ts +1 -0
  124. package/lib/types/common/telemetry/definitions/Contracts.d.ts +3 -0
  125. package/lib/types/common/telemetry/definitions/Payload.d.ts +15 -9
  126. package/lib/types/common/telemetry/interfaces/IChatSDKLogger.d.ts +1 -0
  127. package/lib/types/common/telemetry/interfaces/IInternalTelemetryData.d.ts +2 -0
  128. package/lib/types/common/telemetry/interfaces/ITelemetryConfig.d.ts +12 -0
  129. package/lib/types/common/utils.d.ts +6 -0
  130. package/lib/types/components/confirmationpanestateful/interfaces/IConfirmationPaneStatefulParams.d.ts +5 -2
  131. package/lib/types/components/footerstateful/audionotificationstateful/interfaces/IAudioNotificationStatefulParams.d.ts +0 -1
  132. package/lib/types/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.d.ts +1 -1
  133. package/lib/types/components/headerstateful/interfaces/IHeaderStatefulParams.d.ts +4 -1
  134. package/lib/types/components/livechatwidget/common/disposeTelemetryLoggers.d.ts +1 -0
  135. package/lib/types/components/livechatwidget/common/endChat.d.ts +4 -1
  136. package/lib/types/components/livechatwidget/common/reconnectChatHelper.d.ts +6 -2
  137. package/lib/types/components/livechatwidget/common/setPostChatContextAndLoadSurvey.d.ts +1 -1
  138. package/lib/types/components/livechatwidget/common/startChat.d.ts +4 -2
  139. package/lib/types/components/livechatwidget/common/startProactiveChat.d.ts +2 -1
  140. package/lib/types/components/livechatwidget/interfaces/IAuthProps.d.ts +4 -0
  141. package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetComponentOverrides.d.ts +1 -0
  142. package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetProps.d.ts +5 -1
  143. package/lib/types/components/prechatsurveypanestateful/interfaces/IPreChatSurveyPaneStatefulParams.d.ts +1 -1
  144. package/lib/types/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.d.ts +3 -0
  145. package/lib/types/components/reconnectchatpanestateful/interfaces/IReconnectChatPaneStatefulProps.d.ts +1 -1
  146. package/lib/types/components/webchatcontainerstateful/common/mockchatsdk.d.ts +1 -0
  147. package/lib/types/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.d.ts +1 -1
  148. package/lib/types/components/webchatcontainerstateful/interfaces/IBotMagicCodeConfig.d.ts +4 -0
  149. package/lib/types/components/webchatcontainerstateful/interfaces/IWebChatContainerStatefulProps.d.ts +2 -0
  150. package/lib/types/components/webchatcontainerstateful/webchatcontroller/BotMagicCodeStore.d.ts +3 -0
  151. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.d.ts +1 -2
  152. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/avatarMiddleware.d.ts +1 -1
  153. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.d.ts +2 -0
  154. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.d.ts +1 -0
  155. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/messageTimestampMiddleware.d.ts +5 -0
  156. package/lib/types/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.d.ts +1 -0
  157. package/lib/types/contexts/common/ConversationState.d.ts +4 -2
  158. package/lib/types/contexts/common/ILiveChatWidgetContext.d.ts +5 -1
  159. package/lib/types/contexts/common/LiveChatWidgetActionType.d.ts +14 -8
  160. package/lib/types/plugins/newMessageEventHandler.d.ts +2 -0
  161. package/package.json +11 -11
  162. package/lib/cjs/assets/audios/newMessageNotification.mp3 +0 -0
  163. package/lib/cjs/assets/icons/archiveIcon.svg +0 -3
  164. package/lib/cjs/assets/icons/audioIcon.svg +0 -6
  165. package/lib/cjs/assets/icons/blankIcon.svg +0 -6
  166. package/lib/cjs/assets/icons/excelIcon.svg +0 -6
  167. package/lib/cjs/assets/icons/imageIcon.svg +0 -6
  168. package/lib/cjs/assets/icons/oneNoteIcon.svg +0 -6
  169. package/lib/cjs/assets/icons/pdfIcon.svg +0 -6
  170. package/lib/cjs/assets/icons/powerpointIcon.svg +0 -6
  171. package/lib/cjs/assets/icons/videoIcon.svg +0 -6
  172. package/lib/cjs/assets/icons/visioIcon.svg +0 -6
  173. package/lib/cjs/assets/icons/wordIcon.svg +0 -6
  174. package/lib/esm/assets/assets.d.js +0 -0
  175. package/lib/esm/assets/audios/newMessageNotification.mp3 +0 -0
  176. package/lib/esm/assets/icons/archiveIcon.svg +0 -3
  177. package/lib/esm/assets/icons/audioIcon.svg +0 -6
  178. package/lib/esm/assets/icons/blankIcon.svg +0 -6
  179. package/lib/esm/assets/icons/excelIcon.svg +0 -6
  180. package/lib/esm/assets/icons/imageIcon.svg +0 -6
  181. package/lib/esm/assets/icons/oneNoteIcon.svg +0 -6
  182. package/lib/esm/assets/icons/pdfIcon.svg +0 -6
  183. package/lib/esm/assets/icons/powerpointIcon.svg +0 -6
  184. package/lib/esm/assets/icons/videoIcon.svg +0 -6
  185. package/lib/esm/assets/icons/visioIcon.svg +0 -6
  186. package/lib/esm/assets/icons/wordIcon.svg +0 -6
@@ -17,6 +17,8 @@ var _omnichannelChatComponents = require("@microsoft/omnichannel-chat-components
17
17
 
18
18
  var _LiveChatWidgetActionType = require("../../contexts/common/LiveChatWidgetActionType");
19
19
 
20
+ var _Audios = require("../../assets/Audios");
21
+
20
22
  var _NotificationHandler = require("../webchatcontainerstateful/webchatcontroller/notification/NotificationHandler");
21
23
 
22
24
  var _NotificationScenarios = require("../webchatcontainerstateful/webchatcontroller/enums/NotificationScenarios");
@@ -29,8 +31,6 @@ var _useChatContextStore = _interopRequireDefault(require("../../hooks/useChatCo
29
31
 
30
32
  var _useChatSDKStore = _interopRequireDefault(require("../../hooks/useChatSDKStore"));
31
33
 
32
- var _newMessageNotification = _interopRequireDefault(require("../../assets/audios/newMessageNotification.mp3"));
33
-
34
34
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
35
35
 
36
36
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
@@ -122,9 +122,8 @@ const FooterStateful = props => {
122
122
  controlProps: controlProps,
123
123
  styleProps: footerProps === null || footerProps === void 0 ? void 0 : footerProps.styleProps
124
124
  }), /*#__PURE__*/_react.default.createElement(_AudioNotificationStateful.default, {
125
- audioSrc: (audioNotificationProps === null || audioNotificationProps === void 0 ? void 0 : audioNotificationProps.audioSrc) ?? _newMessageNotification.default,
126
- hideAudioNotificationButton: (footerProps === null || footerProps === void 0 ? void 0 : (_footerProps$controlP4 = footerProps.controlProps) === null || _footerProps$controlP4 === void 0 ? void 0 : _footerProps$controlP4.hideAudioNotificationButton) ?? false,
127
- isAudioMuted: state.appStates.isAudioMuted ?? false
125
+ audioSrc: (audioNotificationProps === null || audioNotificationProps === void 0 ? void 0 : audioNotificationProps.audioSrc) ?? _Audios.NewMessageNotificationSoundBase64,
126
+ isAudioMuted: state.appStates.isAudioMuted === null ? (footerProps === null || footerProps === void 0 ? void 0 : (_footerProps$controlP4 = footerProps.controlProps) === null || _footerProps$controlP4 === void 0 ? void 0 : _footerProps$controlP4.hideAudioNotificationButton) ?? false : state.appStates.isAudioMuted ?? false
128
127
  }));
129
128
  };
130
129
 
@@ -116,8 +116,17 @@ const beautifyChatTranscripts = (chatTranscripts, renderMarkDown, attachmentMess
116
116
  let fileAttachmentName = _Constants.TranscriptConstants.DefaultFileAttachmentName;
117
117
  let dialogColor = _Constants.TranscriptConstants.CustomerDialogColor;
118
118
  let fontColor = _Constants.TranscriptConstants.CustomerFontColor;
119
+ const isSystemMessage = value.tags && value.tags.toLowerCase().indexOf(_Constants.Constants.systemMessageTag) !== -1;
120
+ const isControlMessage = value.isControlMessage && value.isControlMessage === true;
119
121
 
120
- if (value.tags && value.tags.toLowerCase().indexOf(_Constants.Constants.systemMessageTag) !== -1 || value.isControlMessage && value.isControlMessage === true || value.contentType && value.contentType.toLowerCase() === _Constants.TranscriptConstants.AdaptiveCardType || value.deliveryMode && value.deliveryMode.toLowerCase() === _Constants.TranscriptConstants.InternalMode) {
122
+ const isAdaptiveCard = value.contentType && value.contentType.toLowerCase() === _Constants.TranscriptConstants.AdaptiveCardType;
123
+
124
+ const isInternalMessage = value.deliveryMode && value.deliveryMode.toLowerCase() === _Constants.TranscriptConstants.InternalMode;
125
+
126
+ const isHiddenMessage = value.tags && value.tags.toLowerCase().indexOf(_Constants.Constants.hiddenTag.toLowerCase()) !== -1;
127
+ const shouldIgnoreMessage = isSystemMessage || isControlMessage || isAdaptiveCard || isInternalMessage || isHiddenMessage;
128
+
129
+ if (shouldIgnoreMessage) {
121
130
  return;
122
131
  } else if (value.from) {
123
132
  if (value.from.application) {
@@ -138,7 +147,7 @@ const beautifyChatTranscripts = (chatTranscripts, renderMarkDown, attachmentMess
138
147
 
139
148
  if (value.attachments && value.attachments.length > 0 && value.attachments[0].name) {
140
149
  fileAttachmentName = value.attachments[0].name;
141
- value.content = attachmentMessage ?? "The following attachment was uploaded during the conversation:" + fileAttachmentName;
150
+ value.content = attachmentMessage ? attachmentMessage + " " + fileAttachmentName : "The following attachment was uploaded during the conversation: " + fileAttachmentName;
142
151
  }
143
152
  }
144
153
 
@@ -43,6 +43,7 @@ const HeaderStateful = props => {
43
43
 
44
44
  const [outOfOperatingHours, setOutOfOperatingHours] = (0, _react.useState)(((_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.OutOfOperatingHours) === "True");
45
45
  const outOfOfficeStyleProps = Object.assign({}, _defaultOutOfOfficeHeaderStyleProps.defaultOutOfOfficeHeaderStyleProps, outOfOfficeHeaderProps === null || outOfOfficeHeaderProps === void 0 ? void 0 : outOfOfficeHeaderProps.styleProps);
46
+ const conversationState = (0, _react.useRef)(state.appStates.conversationState);
46
47
  const controlProps = {
47
48
  id: "oc-lcw-header",
48
49
  dir: state.domainStates.globalDir,
@@ -63,17 +64,15 @@ const HeaderStateful = props => {
63
64
  Description: "Header Close button clicked."
64
65
  });
65
66
 
66
- if (state.appStates.conversationState === _ConversationState.ConversationState.Active) {
67
+ if (conversationState.current === _ConversationState.ConversationState.Active) {
67
68
  dispatch({
68
69
  type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_SHOW_CONFIRMATION,
69
70
  payload: true
70
71
  });
71
- } else if (state.appStates.conversationState === _ConversationState.ConversationState.Postchat) {
72
- dispatch({
73
- type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_SHOULD_SHOW_POST_CHAT,
74
- payload: false
75
- });
76
- await endChat(adapter);
72
+ } else {
73
+ const skipEndChatSDK = true;
74
+ const skipCloseChat = false;
75
+ await endChat(adapter, skipEndChatSDK, skipCloseChat);
77
76
  }
78
77
 
79
78
  dispatch({
@@ -82,8 +81,8 @@ const HeaderStateful = props => {
82
81
  });
83
82
  },
84
83
  ...(headerProps === null || headerProps === void 0 ? void 0 : headerProps.controlProps),
85
- hideTitle: state.appStates.conversationState === _ConversationState.ConversationState.Loading || (headerProps === null || headerProps === void 0 ? void 0 : (_headerProps$controlP = headerProps.controlProps) === null || _headerProps$controlP === void 0 ? void 0 : _headerProps$controlP.hideTitle),
86
- hideIcon: state.appStates.conversationState === _ConversationState.ConversationState.Loading || (headerProps === null || headerProps === void 0 ? void 0 : (_headerProps$controlP2 = headerProps.controlProps) === null || _headerProps$controlP2 === void 0 ? void 0 : _headerProps$controlP2.hideIcon),
84
+ hideTitle: state.appStates.conversationState === _ConversationState.ConversationState.Loading || state.appStates.conversationState === _ConversationState.ConversationState.PostchatLoading || (headerProps === null || headerProps === void 0 ? void 0 : (_headerProps$controlP = headerProps.controlProps) === null || _headerProps$controlP === void 0 ? void 0 : _headerProps$controlP.hideTitle),
85
+ hideIcon: state.appStates.conversationState === _ConversationState.ConversationState.Loading || state.appStates.conversationState === _ConversationState.ConversationState.PostchatLoading || (headerProps === null || headerProps === void 0 ? void 0 : (_headerProps$controlP2 = headerProps.controlProps) === null || _headerProps$controlP2 === void 0 ? void 0 : _headerProps$controlP2.hideIcon),
87
86
  hideCloseButton: state.appStates.conversationState === _ConversationState.ConversationState.Loading || state.appStates.conversationState === _ConversationState.ConversationState.Prechat || state.appStates.conversationState === _ConversationState.ConversationState.ReconnectChat || (headerProps === null || headerProps === void 0 ? void 0 : (_headerProps$controlP3 = headerProps.controlProps) === null || _headerProps$controlP3 === void 0 ? void 0 : _headerProps$controlP3.hideCloseButton)
88
87
  };
89
88
  const outOfOfficeControlProps = {
@@ -105,7 +104,11 @@ const HeaderStateful = props => {
105
104
  if (state.appStates.outsideOperatingHours) {
106
105
  setOutOfOperatingHours(true);
107
106
  }
108
- }, []);
107
+
108
+ if (state.appStates.conversationState) {
109
+ conversationState.current = state.appStates.conversationState;
110
+ }
111
+ }, [state.appStates]);
109
112
  return /*#__PURE__*/_react.default.createElement(_omnichannelChatComponents.Header, {
110
113
  componentOverrides: headerProps === null || headerProps === void 0 ? void 0 : headerProps.componentOverrides,
111
114
  controlProps: outOfOperatingHours || state.appStates.conversationState === _ConversationState.ConversationState.OutOfOffice ? outOfOfficeControlProps : controlProps,
@@ -7,8 +7,6 @@ exports.createMarkdown = void 0;
7
7
 
8
8
  var _markdownIt = _interopRequireDefault(require("markdown-it"));
9
9
 
10
- var _slackMarkdownIt = _interopRequireDefault(require("slack-markdown-it"));
11
-
12
10
  var _markdownItForInline = _interopRequireDefault(require("markdown-it-for-inline"));
13
11
 
14
12
  var _defaultMarkdownLocalizedTexts = require("../../webchatcontainerstateful/common/defaultProps/defaultMarkdownLocalizedTexts");
@@ -26,8 +24,9 @@ const createMarkdown = (disableMarkdownMessageFormatting, disableNewLineMarkdown
26
24
  html: true,
27
25
  linkify: true,
28
26
  breaks: !disableNewLineMarkdownSupport
29
- });
30
- markdown.use(_slackMarkdownIt.default); // Markdown override for open link in new tab
27
+ }); // ToDo: Commenting below usage of plugin until deferred bug is resolved: https://github.com/mayashavin/markdown-it-slack/issues/1
28
+ // markdown.use(MarkdownSlack);
29
+ // Markdown override for open link in new tab
31
30
  // eslint-disable-next-line @typescript-eslint/no-explicit-any, quotes
32
31
 
33
32
  markdown.use(_markdownItForInline.default, "url_new_win", "link_open", function (tokens, idx, env) {
@@ -5,8 +5,12 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.dummyDefaultProps = void 0;
7
7
 
8
+ var _omnichannelChatComponents = require("@microsoft/omnichannel-chat-components");
9
+
8
10
  var _mockadapter = _interopRequireDefault(require("../../../webchatcontainerstateful/common/mockadapter"));
9
11
 
12
+ var _Audios = require("../../../../assets/Audios");
13
+
10
14
  var _WebChatStoreLoader = require("../../../webchatcontainerstateful/webchatcontroller/WebChatStoreLoader");
11
15
 
12
16
  var _activityStatusMiddleware = require("../../../webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityStatusMiddleware");
@@ -23,13 +27,15 @@ var _groupActivitiesMiddleware = require("../../../webchatcontainerstateful/webc
23
27
 
24
28
  var _typingIndicatorMiddleware = require("../../../webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/typingIndicatorMiddleware");
25
29
 
30
+ var _WebChatLogger = require("../../../webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger");
31
+
26
32
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
27
33
 
28
34
  /* eslint-disable @typescript-eslint/no-empty-function, @typescript-eslint/no-explicit-any */
29
35
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
30
36
  const dummyDefaultProps = {
31
37
  audioNotificationProps: {
32
- audioSrc: "assets/audios/newMessageNotification.mp3"
38
+ audioSrc: _Audios.NewMessageNotificationSoundBase64
33
39
  },
34
40
  callingContainerProps: {
35
41
  controlProps: {
@@ -150,7 +156,7 @@ const dummyDefaultProps = {
150
156
  id: "oc-lcw-CurrentCall-timer",
151
157
  showHours: false,
152
158
  timerStyles: {
153
- color: "white",
159
+ color: "#FFFFFF",
154
160
  textAlign: "center",
155
161
  backgroundColor: "#3d3c3c",
156
162
  height: "45px",
@@ -181,8 +187,8 @@ const dummyDefaultProps = {
181
187
  },
182
188
  audioCallButtonStyleProps: {
183
189
  borderRadius: "50%",
184
- color: "white",
185
- backgroundColor: "green",
190
+ color: "#FFFFFF",
191
+ backgroundColor: "#008000",
186
192
  lineHeight: "40px",
187
193
  height: "40px",
188
194
  width: "40px",
@@ -193,8 +199,8 @@ const dummyDefaultProps = {
193
199
  },
194
200
  videoCallButtonStyleProps: {
195
201
  borderRadius: "50%",
196
- color: "white",
197
- backgroundColor: "green",
202
+ color: "#FFFFFF",
203
+ backgroundColor: "#008000",
198
204
  lineHeight: "40px",
199
205
  height: "40px",
200
206
  width: "40px",
@@ -209,8 +215,8 @@ const dummyDefaultProps = {
209
215
  },
210
216
  declineCallButtonStyleProps: {
211
217
  borderRadius: "50%",
212
- color: "white",
213
- backgroundColor: "red",
218
+ color: "#FFFFFF",
219
+ backgroundColor: "#DC0000",
214
220
  lineHeight: "40px",
215
221
  height: "40px",
216
222
  width: "40px",
@@ -219,12 +225,12 @@ const dummyDefaultProps = {
219
225
  },
220
226
  incomingCallTitleStyleProps: {
221
227
  margin: "0 5px",
222
- color: "white",
228
+ color: "#FFFFFF",
223
229
  fontSize: 12,
224
230
  fontFamily: "Segoe UI, Arial, sans-serif"
225
231
  },
226
232
  itemFocusStyleProps: {
227
- outline: "2px solid white"
233
+ outline: "2px solid #FFFFFF"
228
234
  }
229
235
  },
230
236
  currentCallStyleProps: {
@@ -236,7 +242,7 @@ const dummyDefaultProps = {
236
242
  },
237
243
  micButtonStyleProps: {
238
244
  borderRadius: "2px",
239
- color: "white",
245
+ color: "#FFFFFF",
240
246
  backgroundColor: "#3d3c3c",
241
247
  height: "45px",
242
248
  width: "50px",
@@ -247,7 +253,7 @@ const dummyDefaultProps = {
247
253
  },
248
254
  videoOffButtonStyleProps: {
249
255
  borderRadius: "2px",
250
- color: "white",
256
+ color: "#FFFFFF",
251
257
  backgroundColor: "#3d3c3c",
252
258
  height: "45px",
253
259
  width: "50px",
@@ -261,25 +267,13 @@ const dummyDefaultProps = {
261
267
  },
262
268
  endCallButtonStyleProps: {
263
269
  borderRadius: "2px",
264
- color: "white",
265
- backgroundColor: "red",
270
+ color: "#FFFFFF",
271
+ backgroundColor: "#DC0000",
266
272
  lineHeight: "50px",
267
273
  height: "45px",
268
274
  width: "50px",
269
275
  fontSize: "18px"
270
276
  },
271
- currentCallTimerStyleProps: {
272
- borderRadius: "2px",
273
- margin: "1px",
274
- color: "white",
275
- paddingTop: "18px",
276
- fontSize: 12,
277
- fontFamily: "Segoe UI, Arial, sans-serif",
278
- backgroundColor: "darkgrey",
279
- height: "45px",
280
- width: "50px",
281
- textAlign: "center"
282
- },
283
277
  videoTileStyleProps: {
284
278
  width: "100%",
285
279
  marginLeft: "auto",
@@ -343,7 +337,9 @@ const dummyDefaultProps = {
343
337
  hideChatTextContainer: false,
344
338
  hideChatSubtitle: false,
345
339
  hideChatTitle: false,
346
- hideNotificationBubble: true
340
+ hideNotificationBubble: true,
341
+ unreadMessageString: "new messages",
342
+ largeUnreadMessageString: "99+"
347
343
  },
348
344
  styleProps: {
349
345
  generalStyleProps: {
@@ -384,7 +380,7 @@ const dummyDefaultProps = {
384
380
  margin: "-2px -2px -2px -3px",
385
381
  justifyContent: "center",
386
382
  backgroundSize: "65% 65%",
387
- backgroundImage: "assets/imgs/chat.svg",
383
+ backgroundImage: `url(${_omnichannelChatComponents.ModernChatIconBase64})`,
388
384
  display: "flex",
389
385
  backgroundRepeat: "no-repeat",
390
386
  backgroundPosition: "center"
@@ -493,7 +489,7 @@ const dummyDefaultProps = {
493
489
  },
494
490
  styleProps: {
495
491
  generalStyleProps: {
496
- backgroundColor: "white",
492
+ backgroundColor: "#FFFFFF",
497
493
  borderRadius: "2px",
498
494
  color: "black",
499
495
  fontFamily: "Segoe UI, Arial, sans-serif",
@@ -535,7 +531,7 @@ const dummyDefaultProps = {
535
531
  },
536
532
  confirmButtonStyleProps: {
537
533
  backgroundColor: "rgba(9,72,159,1)",
538
- color: "white",
534
+ color: "#FFFFFF",
539
535
  fontFamily: "Segoe UI, Arial, sans-serif",
540
536
  fontSize: "14px",
541
537
  fontWeight: "500",
@@ -549,7 +545,7 @@ const dummyDefaultProps = {
549
545
  border: "2px dotted #000"
550
546
  },
551
547
  cancelButtonStyleProps: {
552
- backgroundColor: "white",
548
+ backgroundColor: "#FFFFFF",
553
549
  fontFamily: "Segoe UI, Arial, sans-serif",
554
550
  fontSize: "14px",
555
551
  fontWeight: "500",
@@ -905,7 +901,7 @@ const dummyDefaultProps = {
905
901
  },
906
902
  headerIconProps: {
907
903
  id: "oc-lcw-header-icon",
908
- src: "assets/imgs/chatIcon.svg",
904
+ src: _omnichannelChatComponents.ModernChatIconBase64,
909
905
  alt: "Chat Icon",
910
906
  className: undefined
911
907
  },
@@ -934,16 +930,16 @@ const dummyDefaultProps = {
934
930
  fontSize: 16,
935
931
  fontFamily: "Segoe UI, Arial, sans-serif",
936
932
  fontWeight: "450",
937
- color: "white",
933
+ color: "#FFFFFF",
938
934
  padding: "3px 0"
939
935
  },
940
936
  minimizeButtonStyleProps: {
941
- color: "white",
937
+ color: "#FFFFFF",
942
938
  margin: "5px 0",
943
939
  fontSize: "12px"
944
940
  },
945
941
  closeButtonStyleProps: {
946
- color: "white",
942
+ color: "#FFFFFF",
947
943
  margin: "5px 0",
948
944
  fontSize: "12px"
949
945
  },
@@ -1030,7 +1026,7 @@ const dummyDefaultProps = {
1030
1026
  alignSelf: "auto"
1031
1027
  },
1032
1028
  iconImageProps: {
1033
- src: "assets/imgs/chat.svg",
1029
+ src: "",
1034
1030
  imageFit: 0,
1035
1031
  width: "86px",
1036
1032
  height: "86px",
@@ -1105,7 +1101,7 @@ const dummyDefaultProps = {
1105
1101
  titleStyleProps: {
1106
1102
  // ...[Existing chat button title style props]
1107
1103
  margin: "0 0 0 10px",
1108
- color: "White"
1104
+ color: "#FFFFFF"
1109
1105
  }
1110
1106
  }
1111
1107
  },
@@ -1238,7 +1234,7 @@ const dummyDefaultProps = {
1238
1234
  },
1239
1235
  headerContainerStyleProps: {
1240
1236
  backgroundColor: "rgb(49, 95, 162)",
1241
- backgroundImage: "assets/imgs/Proactive_banner.png",
1237
+ backgroundImage: `url(${_omnichannelChatComponents.ProactiveChatBannerBase64})`,
1242
1238
  backgroundPosition: "initial",
1243
1239
  backgroundRepeat: "no-repeat",
1244
1240
  borderTopLeftRadius: "inherit",
@@ -1266,7 +1262,7 @@ const dummyDefaultProps = {
1266
1262
  fontWeight: "600"
1267
1263
  },
1268
1264
  closeButtonStyleProps: {
1269
- backgroundImage: "assets/imgs/closeChatButton.svg",
1265
+ backgroundImage: `url(${_omnichannelChatComponents.CloseChatButtonIconBase64})`,
1270
1266
  backgroundPosition: "center",
1271
1267
  backgroundRepeat: "no-repeat",
1272
1268
  color: "#605e5c",
@@ -1389,7 +1385,7 @@ const dummyDefaultProps = {
1389
1385
  lineHeight: "19px"
1390
1386
  },
1391
1387
  iconStyleProps: {
1392
- backgroundImage: "assets/imgs//ChatReconnectPopupIcon.png",
1388
+ backgroundImage: `url(${_omnichannelChatComponents.ChatReconnectIconBase64})`,
1393
1389
  backgroundPosition: "center",
1394
1390
  backgroundRepeat: "no-repeat",
1395
1391
  backgroundSize: "200px",
@@ -1438,9 +1434,9 @@ const dummyDefaultProps = {
1438
1434
  startNewChatButtonClassName: undefined
1439
1435
  }
1440
1436
  },
1441
- authClientFunction: undefined,
1442
1437
  isReconnectEnabled: undefined,
1443
- reconnectId: undefined
1438
+ reconnectId: undefined,
1439
+ redirectInSameWindow: undefined
1444
1440
  },
1445
1441
  styleProps: {
1446
1442
  generalStyles: {
@@ -1471,7 +1467,7 @@ const dummyDefaultProps = {
1471
1467
  bubbleBackground: "#315FA2",
1472
1468
  bubbleBorderRadius: 4,
1473
1469
  bubbleBorderWidth: 0,
1474
- bubbleFromUserBackground: "White",
1470
+ bubbleFromUserBackground: "#FFFFFF",
1475
1471
  bubbleFromUserBorderRadius: 4,
1476
1472
  bubbleFromUserBorderWidth: 1,
1477
1473
  bubbleFromUserTextColor: "Black",
@@ -1479,7 +1475,7 @@ const dummyDefaultProps = {
1479
1475
  bubbleMaxWidth: 250,
1480
1476
  bubbleMinHeight: 34,
1481
1477
  bubbleMinWidth: 20,
1482
- bubbleTextColor: "White",
1478
+ bubbleTextColor: "#FFFFFF",
1483
1479
  hideSendBox: false,
1484
1480
  hideUploadButton: true,
1485
1481
  primaryFont: "Segoe UI, Arial, sans-serif",
@@ -1488,7 +1484,7 @@ const dummyDefaultProps = {
1488
1484
  sendBoxTextWrap: true,
1489
1485
  sendBoxHeight: 60,
1490
1486
  sendBoxMaxHeight: 96,
1491
- sendBoxBackground: "White",
1487
+ sendBoxBackground: "#FFFFFF",
1492
1488
  showAvatarInGroup: true,
1493
1489
  suggestedActionsStackedHeight: 125,
1494
1490
  suggestedActionsStackedOverflow: "scroll",
@@ -1512,7 +1508,7 @@ const dummyDefaultProps = {
1512
1508
  internalErrorBoxClass: undefined,
1513
1509
  internalRenderErrorBox: undefined,
1514
1510
  locale: "en-US",
1515
- onTelemetry: undefined,
1511
+ onTelemetry: (0, _WebChatLogger.createWebChatTelemetry)(),
1516
1512
  overrideLocalizedStrings: undefined,
1517
1513
  renderMarkdown: (0, _createMarkdown.createMarkdown)(false, false),
1518
1514
  scrollToEndButtonMiddleware: undefined,
@@ -1599,7 +1595,7 @@ const dummyDefaultProps = {
1599
1595
  fontWeight: 600,
1600
1596
  fontSize: "13px",
1601
1597
  lineHeight: "18px",
1602
- color: "white",
1598
+ color: "#FFFFFF",
1603
1599
  paddingTop: "7px",
1604
1600
  WebkitUserSelect: "none",
1605
1601
  MozUserSelect: "none",
@@ -1702,7 +1698,16 @@ const dummyDefaultProps = {
1702
1698
  MIDDLEWARE_MESSAGE_RETRY: "Retry",
1703
1699
  PRECHAT_REQUIRED_FIELD_MISSING_MESSAGE: "{0} field is required",
1704
1700
  MARKDOWN_EXTERNAL_LINK_ALT: "Opens in a new window; external."
1701
+ },
1702
+ botMagicCode: {
1703
+ disabled: false,
1704
+ fwdUrl: ""
1705
1705
  }
1706
- }
1706
+ },
1707
+ authProps: {
1708
+ authClientFunction: undefined,
1709
+ setAuthTokenProviderToChatSdk: undefined
1710
+ },
1711
+ telemetryConfig: undefined
1707
1712
  };
1708
1713
  exports.dummyDefaultProps = dummyDefaultProps;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.disposeTelemetryLoggers = void 0;
7
+
8
+ var _TelemetryManager = require("../../../common/telemetry/TelemetryManager");
9
+
10
+ const disposeTelemetryLoggers = () => {
11
+ (0, _TelemetryManager.disposeLoggers)();
12
+ };
13
+
14
+ exports.disposeTelemetryLoggers = disposeTelemetryLoggers;