@microsoft/omnichannel-chat-widget 0.1.0-main.edd8c2a → 0.1.0-main.fdf1fdf

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 (216) 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 +54 -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 +61 -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 +89 -2
  15. package/lib/cjs/components/callingcontainerstateful/CallingContainerStateful.js +14 -0
  16. package/lib/cjs/components/chatbuttonstateful/ChatButtonStateful.js +20 -4
  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 +14 -10
  22. package/lib/cjs/components/livechatwidget/common/ActivityStreamHandler.js +44 -0
  23. package/lib/cjs/components/livechatwidget/common/ActivitySubscriber/DefaultActivitySubscriber.js +23 -0
  24. package/lib/cjs/components/livechatwidget/common/ActivitySubscriber/IActivitySubscriber.js +1 -0
  25. package/lib/cjs/components/livechatwidget/common/ActivitySubscriber/PauseActivitySubscriber.js +39 -0
  26. package/lib/cjs/components/livechatwidget/common/ChatAdapterShim.js +70 -0
  27. package/lib/cjs/components/livechatwidget/common/Deferred.js +42 -0
  28. package/lib/cjs/components/livechatwidget/common/authHelper.js +52 -0
  29. package/lib/cjs/components/livechatwidget/common/createAdapter.js +13 -1
  30. package/lib/cjs/components/livechatwidget/common/createMarkdown.js +32 -32
  31. package/lib/cjs/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +30 -24
  32. package/lib/cjs/components/livechatwidget/common/disposeTelemetryLoggers.js +14 -0
  33. package/lib/cjs/components/livechatwidget/common/endChat.js +142 -43
  34. package/lib/cjs/components/livechatwidget/common/initCallingSdk.js +5 -0
  35. package/lib/cjs/components/livechatwidget/common/initWebChatComposer.js +51 -10
  36. package/lib/cjs/components/livechatwidget/common/reconnectChatHelper.js +144 -39
  37. package/lib/cjs/components/livechatwidget/common/registerTelemetryLoggers.js +11 -7
  38. package/lib/cjs/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +22 -24
  39. package/lib/cjs/components/livechatwidget/common/shareObservable.js +45 -0
  40. package/lib/cjs/components/livechatwidget/common/startChat.js +198 -41
  41. package/lib/cjs/components/livechatwidget/common/startProactiveChat.js +3 -3
  42. package/lib/cjs/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +299 -72
  43. package/lib/cjs/components/loadingpanestateful/LoadingPaneStateful.js +1 -1
  44. package/lib/cjs/components/ooohpanestateful/OOOHPaneStateful.js +8 -0
  45. package/lib/cjs/components/postchatloadingpanestateful/PostChatLoadingPaneStateful.js +8 -0
  46. package/lib/cjs/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +22 -10
  47. package/lib/cjs/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +27 -5
  48. package/lib/cjs/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.js +1 -0
  49. package/lib/cjs/components/webchatcontainerstateful/WebChatContainerStateful.js +91 -0
  50. package/lib/cjs/components/webchatcontainerstateful/common/defaultProps/defaultWebChatContainerStatefulProps.js +4 -1
  51. package/lib/cjs/components/webchatcontainerstateful/common/defaultStyles/defaultAdaptiveCardStyles.js +11 -0
  52. package/lib/cjs/components/webchatcontainerstateful/common/mockchatsdk.js +6 -0
  53. package/lib/cjs/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +51 -73
  54. package/lib/cjs/components/webchatcontainerstateful/interfaces/IAdaptiveCardStyles.js +1 -0
  55. package/lib/cjs/components/webchatcontainerstateful/interfaces/IBotMagicCodeConfig.js +1 -0
  56. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/BotMagicCodeStore.js +14 -0
  57. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.js +25 -48
  58. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/attachmentMiddleware.js +3 -1
  59. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.js +52 -0
  60. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.js +98 -0
  61. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/messageTimestampMiddleware.js +117 -0
  62. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/conversationEndMiddleware.js +6 -6
  63. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.js +45 -0
  64. package/lib/cjs/contexts/common/ConversationState.js +4 -2
  65. package/lib/cjs/contexts/common/LiveChatWidgetActionType.js +13 -7
  66. package/lib/cjs/contexts/common/LiveChatWidgetContextInitialState.js +12 -4
  67. package/lib/cjs/contexts/createReducer.js +44 -10
  68. package/lib/cjs/controller/componentController.js +5 -5
  69. package/lib/cjs/plugins/newMessageEventHandler.js +99 -0
  70. package/lib/esm/assets/Audios.js +1 -0
  71. package/lib/esm/assets/Icons.js +11 -0
  72. package/lib/esm/common/Constants.js +50 -3
  73. package/lib/esm/common/contextDataStore/DataStoreManager.js +5 -0
  74. package/lib/esm/common/interfaces/IContextDataStore.js +1 -0
  75. package/lib/esm/common/telemetry/TelemetryConstants.js +57 -3
  76. package/lib/esm/common/telemetry/TelemetryHelper.js +22 -5
  77. package/lib/esm/common/telemetry/TelemetryManager.js +22 -9
  78. package/lib/esm/common/telemetry/defaultConfigs/defaultAriaConfig.js +3 -3
  79. package/lib/esm/common/telemetry/defaultConfigs/defaultTelemetryConfiguration.js +4 -1
  80. package/lib/esm/common/telemetry/loggers/ariaTelemetryLogger.js +50 -15
  81. package/lib/esm/common/telemetry/loggers/consoleLogger.js +9 -5
  82. package/lib/esm/common/utils.js +64 -1
  83. package/lib/esm/components/callingcontainerstateful/CallingContainerStateful.js +14 -0
  84. package/lib/esm/components/chatbuttonstateful/ChatButtonStateful.js +22 -7
  85. package/lib/esm/components/confirmationpanestateful/ConfirmationPaneStateful.js +7 -50
  86. package/lib/esm/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.js +2 -2
  87. package/lib/esm/components/footerstateful/FooterStateful.js +4 -5
  88. package/lib/esm/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.js +9 -3
  89. package/lib/esm/components/headerstateful/HeaderStateful.js +15 -11
  90. package/lib/esm/components/livechatwidget/common/ActivityStreamHandler.js +34 -0
  91. package/lib/esm/components/livechatwidget/common/ActivitySubscriber/DefaultActivitySubscriber.js +14 -0
  92. package/lib/esm/components/livechatwidget/common/ActivitySubscriber/IActivitySubscriber.js +1 -0
  93. package/lib/esm/components/livechatwidget/common/ActivitySubscriber/PauseActivitySubscriber.js +29 -0
  94. package/lib/esm/components/livechatwidget/common/ChatAdapterShim.js +59 -0
  95. package/lib/esm/components/livechatwidget/common/Deferred.js +33 -0
  96. package/lib/esm/components/livechatwidget/common/authHelper.js +39 -0
  97. package/lib/esm/components/livechatwidget/common/createAdapter.js +12 -2
  98. package/lib/esm/components/livechatwidget/common/createMarkdown.js +32 -31
  99. package/lib/esm/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +28 -25
  100. package/lib/esm/components/livechatwidget/common/disposeTelemetryLoggers.js +4 -0
  101. package/lib/esm/components/livechatwidget/common/endChat.js +139 -42
  102. package/lib/esm/components/livechatwidget/common/initCallingSdk.js +3 -0
  103. package/lib/esm/components/livechatwidget/common/initWebChatComposer.js +45 -11
  104. package/lib/esm/components/livechatwidget/common/reconnectChatHelper.js +134 -41
  105. package/lib/esm/components/livechatwidget/common/registerTelemetryLoggers.js +10 -3
  106. package/lib/esm/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +19 -22
  107. package/lib/esm/components/livechatwidget/common/shareObservable.js +38 -0
  108. package/lib/esm/components/livechatwidget/common/startChat.js +186 -39
  109. package/lib/esm/components/livechatwidget/common/startProactiveChat.js +5 -5
  110. package/lib/esm/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +283 -77
  111. package/lib/esm/components/loadingpanestateful/LoadingPaneStateful.js +1 -1
  112. package/lib/esm/components/ooohpanestateful/OOOHPaneStateful.js +6 -0
  113. package/lib/esm/components/postchatloadingpanestateful/PostChatLoadingPaneStateful.js +6 -0
  114. package/lib/esm/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +22 -10
  115. package/lib/esm/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +26 -6
  116. package/lib/esm/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.js +1 -0
  117. package/lib/esm/components/webchatcontainerstateful/WebChatContainerStateful.js +82 -0
  118. package/lib/esm/components/webchatcontainerstateful/common/defaultProps/defaultWebChatContainerStatefulProps.js +3 -1
  119. package/lib/esm/components/webchatcontainerstateful/common/defaultStyles/defaultAdaptiveCardStyles.js +4 -0
  120. package/lib/esm/components/webchatcontainerstateful/common/mockchatsdk.js +6 -0
  121. package/lib/esm/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +2 -12
  122. package/lib/esm/components/webchatcontainerstateful/interfaces/IAdaptiveCardStyles.js +1 -0
  123. package/lib/esm/components/webchatcontainerstateful/interfaces/IBotMagicCodeConfig.js +1 -0
  124. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/BotMagicCodeStore.js +5 -0
  125. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.js +23 -46
  126. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/attachmentMiddleware.js +2 -1
  127. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.js +41 -0
  128. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.js +94 -0
  129. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/messageTimestampMiddleware.js +107 -0
  130. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/conversationEndMiddleware.js +6 -6
  131. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.js +32 -0
  132. package/lib/esm/contexts/common/ConversationState.js +4 -2
  133. package/lib/esm/contexts/common/LiveChatWidgetActionType.js +13 -7
  134. package/lib/esm/contexts/common/LiveChatWidgetContextInitialState.js +12 -4
  135. package/lib/esm/contexts/createReducer.js +44 -9
  136. package/lib/esm/controller/componentController.js +5 -5
  137. package/lib/esm/plugins/newMessageEventHandler.js +82 -0
  138. package/lib/types/assets/Audios.d.ts +1 -0
  139. package/lib/types/assets/Icons.d.ts +11 -0
  140. package/lib/types/common/Constants.d.ts +27 -1
  141. package/lib/types/common/contextDataStore/DataStoreManager.d.ts +4 -0
  142. package/lib/types/common/interfaces/IContextDataStore.d.ts +14 -0
  143. package/lib/types/common/telemetry/TelemetryConstants.d.ts +45 -2
  144. package/lib/types/common/telemetry/TelemetryHelper.d.ts +2 -0
  145. package/lib/types/common/telemetry/TelemetryManager.d.ts +1 -0
  146. package/lib/types/common/telemetry/definitions/Contracts.d.ts +3 -0
  147. package/lib/types/common/telemetry/definitions/Payload.d.ts +15 -9
  148. package/lib/types/common/telemetry/interfaces/IChatSDKLogger.d.ts +1 -0
  149. package/lib/types/common/telemetry/interfaces/IInternalTelemetryData.d.ts +2 -0
  150. package/lib/types/common/telemetry/interfaces/ITelemetryConfig.d.ts +12 -0
  151. package/lib/types/common/utils.d.ts +8 -1
  152. package/lib/types/components/confirmationpanestateful/interfaces/IConfirmationPaneStatefulParams.d.ts +5 -2
  153. package/lib/types/components/footerstateful/audionotificationstateful/interfaces/IAudioNotificationStatefulParams.d.ts +0 -1
  154. package/lib/types/components/headerstateful/interfaces/IHeaderStatefulParams.d.ts +5 -1
  155. package/lib/types/components/livechatwidget/common/ActivityStreamHandler.d.ts +14 -0
  156. package/lib/types/components/livechatwidget/common/ActivitySubscriber/DefaultActivitySubscriber.d.ts +5 -0
  157. package/lib/types/components/livechatwidget/common/ActivitySubscriber/IActivitySubscriber.d.ts +6 -0
  158. package/lib/types/components/livechatwidget/common/ActivitySubscriber/PauseActivitySubscriber.d.ts +7 -0
  159. package/lib/types/components/livechatwidget/common/ChatAdapterShim.d.ts +7 -0
  160. package/lib/types/components/livechatwidget/common/Deferred.d.ts +9 -0
  161. package/lib/types/components/livechatwidget/common/authHelper.d.ts +4 -0
  162. package/lib/types/components/livechatwidget/common/disposeTelemetryLoggers.d.ts +1 -0
  163. package/lib/types/components/livechatwidget/common/endChat.d.ts +4 -1
  164. package/lib/types/components/livechatwidget/common/reconnectChatHelper.d.ts +6 -2
  165. package/lib/types/components/livechatwidget/common/setPostChatContextAndLoadSurvey.d.ts +1 -1
  166. package/lib/types/components/livechatwidget/common/shareObservable.d.ts +1 -0
  167. package/lib/types/components/livechatwidget/common/startChat.d.ts +4 -2
  168. package/lib/types/components/livechatwidget/common/startProactiveChat.d.ts +2 -1
  169. package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetComponentOverrides.d.ts +1 -0
  170. package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetControlProps.d.ts +1 -0
  171. package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetProps.d.ts +4 -1
  172. package/lib/types/components/prechatsurveypanestateful/interfaces/IPreChatSurveyPaneStatefulParams.d.ts +1 -1
  173. package/lib/types/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.d.ts +3 -0
  174. package/lib/types/components/reconnectchatpanestateful/interfaces/IReconnectChatPaneStatefulProps.d.ts +1 -1
  175. package/lib/types/components/webchatcontainerstateful/common/defaultStyles/defaultAdaptiveCardStyles.d.ts +2 -0
  176. package/lib/types/components/webchatcontainerstateful/common/mockchatsdk.d.ts +2 -0
  177. package/lib/types/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.d.ts +1 -1
  178. package/lib/types/components/webchatcontainerstateful/interfaces/IAdaptiveCardStyles.d.ts +4 -0
  179. package/lib/types/components/webchatcontainerstateful/interfaces/IBotMagicCodeConfig.d.ts +4 -0
  180. package/lib/types/components/webchatcontainerstateful/interfaces/IWebChatContainerStatefulProps.d.ts +4 -0
  181. package/lib/types/components/webchatcontainerstateful/webchatcontroller/BotMagicCodeStore.d.ts +3 -0
  182. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.d.ts +0 -1
  183. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.d.ts +2 -0
  184. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/cardActionMiddleware.spec.d.ts +1 -0
  185. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/messageTimestampMiddleware.d.ts +5 -0
  186. package/lib/types/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.d.ts +1 -0
  187. package/lib/types/contexts/common/ConversationState.d.ts +4 -2
  188. package/lib/types/contexts/common/ILiveChatWidgetContext.d.ts +5 -1
  189. package/lib/types/contexts/common/LiveChatWidgetActionType.d.ts +14 -8
  190. package/lib/types/plugins/newMessageEventHandler.d.ts +2 -0
  191. package/package.json +13 -12
  192. package/lib/cjs/assets/audios/newMessageNotification.mp3 +0 -0
  193. package/lib/cjs/assets/icons/archiveIcon.svg +0 -3
  194. package/lib/cjs/assets/icons/audioIcon.svg +0 -6
  195. package/lib/cjs/assets/icons/blankIcon.svg +0 -6
  196. package/lib/cjs/assets/icons/excelIcon.svg +0 -6
  197. package/lib/cjs/assets/icons/imageIcon.svg +0 -6
  198. package/lib/cjs/assets/icons/oneNoteIcon.svg +0 -6
  199. package/lib/cjs/assets/icons/pdfIcon.svg +0 -6
  200. package/lib/cjs/assets/icons/powerpointIcon.svg +0 -6
  201. package/lib/cjs/assets/icons/videoIcon.svg +0 -6
  202. package/lib/cjs/assets/icons/visioIcon.svg +0 -6
  203. package/lib/cjs/assets/icons/wordIcon.svg +0 -6
  204. package/lib/esm/assets/assets.d.js +0 -0
  205. package/lib/esm/assets/audios/newMessageNotification.mp3 +0 -0
  206. package/lib/esm/assets/icons/archiveIcon.svg +0 -3
  207. package/lib/esm/assets/icons/audioIcon.svg +0 -6
  208. package/lib/esm/assets/icons/blankIcon.svg +0 -6
  209. package/lib/esm/assets/icons/excelIcon.svg +0 -6
  210. package/lib/esm/assets/icons/imageIcon.svg +0 -6
  211. package/lib/esm/assets/icons/oneNoteIcon.svg +0 -6
  212. package/lib/esm/assets/icons/pdfIcon.svg +0 -6
  213. package/lib/esm/assets/icons/powerpointIcon.svg +0 -6
  214. package/lib/esm/assets/icons/videoIcon.svg +0 -6
  215. package/lib/esm/assets/icons/visioIcon.svg +0 -6
  216. package/lib/esm/assets/icons/wordIcon.svg +0 -6
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.TelemetryEvent = exports.TelemetryConstants = exports.ScenarioType = exports.LogLevel = void 0;
6
+ exports.TelemetryEvent = exports.TelemetryConstants = exports.ScenarioType = exports.LogLevel = exports.BroadcastEvent = void 0;
7
7
  let ScenarioType;
8
8
  exports.ScenarioType = ScenarioType;
9
9
 
@@ -20,7 +20,8 @@ exports.ScenarioType = ScenarioType;
20
20
  ScenarioType["ACS_ADAPTER"] = "LCW_ACSAdapterEvents";
21
21
  })(ScenarioType || (exports.ScenarioType = ScenarioType = {}));
22
22
 
23
- let LogLevel;
23
+ let LogLevel; // Events used in certain functionalities that are not being logged
24
+
24
25
  exports.LogLevel = LogLevel;
25
26
 
26
27
  (function (LogLevel) {
@@ -30,6 +31,37 @@ exports.LogLevel = LogLevel;
30
31
  LogLevel["ERROR"] = "ERROR";
31
32
  })(LogLevel || (exports.LogLevel = LogLevel = {}));
32
33
 
34
+ let BroadcastEvent; // Events being logged
35
+
36
+ exports.BroadcastEvent = BroadcastEvent;
37
+
38
+ (function (BroadcastEvent) {
39
+ BroadcastEvent["LoadPostChatSurvey"] = "LoadPostChatSurvey";
40
+ BroadcastEvent["ChatEnded"] = "ChatEnded";
41
+ BroadcastEvent["NewMessageNotification"] = "NewMessageNotification";
42
+ BroadcastEvent["UnreadMessageCount"] = "UnreadMessageCount";
43
+ BroadcastEvent["StartProactiveChat"] = "StartProactiveChat";
44
+ BroadcastEvent["ProactiveChatStartChat"] = "ProactiveChatStartChat";
45
+ BroadcastEvent["ProactiveChatStartPopoutChat"] = "ProactiveChatStartPopoutChat";
46
+ BroadcastEvent["ProactiveChatIsInPopoutMode"] = "ProactiveChatIsInPopoutMode";
47
+ BroadcastEvent["ResetProactiveChatParams"] = "ResetProactiveChatParams";
48
+ BroadcastEvent["InvalidAdaptiveCardFormat"] = "InvalidAdaptiveCardFormat";
49
+ BroadcastEvent["NewMessageSent"] = "NewMessageSent";
50
+ BroadcastEvent["NewMessageReceived"] = "NewMessageReceived";
51
+ BroadcastEvent["RedirectPageRequest"] = "RedirectPageRequest";
52
+ BroadcastEvent["StartChat"] = "StartChat";
53
+ BroadcastEvent["StartChatSkippingChatButtonRendering"] = "StartChatSkippingChatButtonRendering";
54
+ BroadcastEvent["StartUnauthenticatedReconnectChat"] = "StartUnauthenticatedReconnectChat";
55
+ BroadcastEvent["InitiateEndChat"] = "InitiateEndChat";
56
+ BroadcastEvent["SetCustomContext"] = "SetCustomContext";
57
+ BroadcastEvent["ChatRetrievedFromCache"] = "ChatRetrievedFromCache";
58
+ BroadcastEvent["MaximizeChat"] = "MaximizeChat";
59
+ BroadcastEvent["ChatInitiated"] = "ChatInitiated";
60
+ BroadcastEvent["CloseChat"] = "CloseChat";
61
+ BroadcastEvent["InitiateEndChatOnBrowserUnload"] = "InitiateEndChatOnBrowserUnload";
62
+ BroadcastEvent["ClosePopoutWindow"] = "ClosePopoutWindow";
63
+ })(BroadcastEvent || (exports.BroadcastEvent = BroadcastEvent = {}));
64
+
33
65
  let TelemetryEvent;
34
66
  exports.TelemetryEvent = TelemetryEvent;
35
67
 
@@ -79,7 +111,10 @@ exports.TelemetryEvent = TelemetryEvent;
79
111
  TelemetryEvent["PrechatSurveyLoaded"] = "PrechatSurveyLoaded";
80
112
  TelemetryEvent["PrechatSubmitted"] = "PrechatSubmitted";
81
113
  TelemetryEvent["StartChatSDKCall"] = "StartChatCall";
82
- TelemetryEvent["EndChatSDKCall"] = "EndChatCall";
114
+ TelemetryEvent["StartChatEventRecevied"] = "StartChatEventReceived";
115
+ TelemetryEvent["EndChatSDKCall"] = "EndChatSDKCall";
116
+ TelemetryEvent["EndChatEventReceived"] = "EndChatEventReceived";
117
+ TelemetryEvent["WindowClosed"] = "WindowClosed";
83
118
  TelemetryEvent["OnNewMessageFailed"] = "OnNewMessageFailed";
84
119
  TelemetryEvent["OnNewMessageAudioNotificationFailed"] = "OnNewMessageAudioNotificationFailed";
85
120
  TelemetryEvent["DownloadTranscriptResponseNullOrUndefined"] = "DownloadTranscriptResponseNullOrUndefined";
@@ -93,6 +128,7 @@ exports.TelemetryEvent = TelemetryEvent;
93
128
  TelemetryEvent["LoadingPaneLoaded"] = "LoadingPaneLoaded";
94
129
  TelemetryEvent["EmailTranscriptLoaded"] = "EmailTranscriptLoaded";
95
130
  TelemetryEvent["OutOfOfficePaneLoaded"] = "OutOfOfficePaneLoaded";
131
+ TelemetryEvent["PostChatSurveyLoadingPaneLoaded"] = "PostChatSurveyLoadingPaneLoaded";
96
132
  TelemetryEvent["PostChatSurveyLoaded"] = "PostChatSurveyLoaded";
97
133
  TelemetryEvent["ConfirmationPaneLoaded"] = "ConfirmationPaneLoaded";
98
134
  TelemetryEvent["ProactiveChatPaneLoaded"] = "ProactiveChatPaneLoaded";
@@ -103,6 +139,12 @@ exports.TelemetryEvent = TelemetryEvent;
103
139
  TelemetryEvent["EmailTranscriptButtonClicked"] = "EmailTranscriptButtonClicked";
104
140
  TelemetryEvent["EmailTranscriptCancelButtonClicked"] = "EmailTranscriptCancelButtonClicked";
105
141
  TelemetryEvent["AudioToggleButtonClicked"] = "AudioToggleButtonClicked";
142
+ TelemetryEvent["SuppressBotMagicCodeSucceeded"] = "SuppressBotMagicCodeSucceeded";
143
+ TelemetryEvent["SuppressBotMagicCodeFailed"] = "SuppressBotMagicCodeFailed";
144
+ TelemetryEvent["GetConversationDetailsException"] = "GetConversationDetailsException";
145
+ TelemetryEvent["BrowserUnloadEventStarted"] = "BrowserUnloadEventStarted";
146
+ TelemetryEvent["GetAuthTokenCalled"] = "GetAuthTokenCalled";
147
+ TelemetryEvent["ReceivedNullOrEmptyToken"] = "ReceivedNullOrEmptyToken";
106
148
  TelemetryEvent["ProcessingHTMLTextMiddlewareFailed"] = "ProcessingHTMLTextMiddlewareFailed";
107
149
  TelemetryEvent["ProcessingSanitizationMiddlewareFailed"] = "ProcessingSanitizationMiddlewareFailed";
108
150
  TelemetryEvent["FormatTagsMiddlewareJSONStringifyFailed"] = "FormatTagsMiddlewareJSONStringifyFailed";
@@ -114,7 +156,10 @@ exports.TelemetryEvent = TelemetryEvent;
114
156
  TelemetryEvent["InvalidConfiguration"] = "InvalidConfiguration";
115
157
  TelemetryEvent["SendTypingIndicatorSucceeded"] = "SendTypingIndicatorSucceeded";
116
158
  TelemetryEvent["SendTypingIndicatorFailed"] = "SendTypingIndicatorFailed";
159
+ TelemetryEvent["WebChatEvent"] = "WebChatEvent";
117
160
  TelemetryEvent["PreChatSurveyStartChatMethodFailed"] = "PreChatSurveyStartChatMethodFailed";
161
+ TelemetryEvent["ChatAlreadyTriggered"] = "ChatAlreadyTriggered";
162
+ TelemetryEvent["StartProactiveChatEventReceived"] = "StartProactiveChatEventReceived";
118
163
  TelemetryEvent["StartProactiveChatMethodFailed"] = "StartProactiveChatMethodFailed";
119
164
  TelemetryEvent["ProactiveChatAccepted"] = "ProactiveChatAccepted";
120
165
  TelemetryEvent["ProactiveChatRejected"] = "ProactiveChatRejected";
@@ -123,12 +168,14 @@ exports.TelemetryEvent = TelemetryEvent;
123
168
  TelemetryEvent["ReconnectChatContinueConversation"] = "ReconnectChatContinueConversation";
124
169
  TelemetryEvent["ReconnectChatStartNewConversation"] = "ReconnectChatStartNewConversation";
125
170
  TelemetryEvent["ReconnectChatMinimize"] = "ReconnectChatMinimize";
171
+ TelemetryEvent["MessageSent"] = "MessageSent";
172
+ TelemetryEvent["MessageReceived"] = "MessageReceived";
173
+ TelemetryEvent["CustomContextReceived"] = "CustomContextReceived";
126
174
  })(TelemetryEvent || (exports.TelemetryEvent = TelemetryEvent = {}));
127
175
 
128
176
  class TelemetryConstants {
129
177
  static map(eventTypeOrScenarioType) {
130
178
  switch (eventTypeOrScenarioType) {
131
- case TelemetryEvent.StartChatSDKCall:
132
179
  case TelemetryEvent.ParseAdaptiveCardFailed:
133
180
  return ScenarioType.CONFIG_VALIDATION;
134
181
 
@@ -139,6 +186,7 @@ class TelemetryConstants {
139
186
  case TelemetryEvent.LCWChatButtonShow:
140
187
  case TelemetryEvent.PrechatSurveyLoaded:
141
188
  case TelemetryEvent.LoadingPaneLoaded:
189
+ case TelemetryEvent.PostChatSurveyLoadingPaneLoaded:
142
190
  case TelemetryEvent.PostChatSurveyLoaded:
143
191
  case TelemetryEvent.EmailTranscriptLoaded:
144
192
  case TelemetryEvent.OutOfOfficePaneLoaded:
@@ -165,14 +213,23 @@ class TelemetryConstants {
165
213
  case TelemetryEvent.PreChatSurveyStartChatMethodFailed:
166
214
  case TelemetryEvent.HeaderCloseButtonClicked:
167
215
  case TelemetryEvent.HeaderMinimizeButtonClicked:
216
+ case TelemetryEvent.MessageSent:
217
+ case TelemetryEvent.MessageReceived:
218
+ case TelemetryEvent.CustomContextReceived:
219
+ case TelemetryEvent.BrowserUnloadEventStarted:
168
220
  return ScenarioType.ACTIONS;
169
221
 
222
+ case TelemetryEvent.StartChatSDKCall:
223
+ case TelemetryEvent.StartChatEventRecevied:
170
224
  case TelemetryEvent.StartChatMethodException:
171
225
  case TelemetryEvent.CloseChatMethodException:
226
+ case TelemetryEvent.StartProactiveChatEventReceived:
172
227
  case TelemetryEvent.StartProactiveChatMethodFailed:
173
228
  case TelemetryEvent.OnNewMessageFailed:
174
229
  case TelemetryEvent.OnNewMessageAudioNotificationFailed:
175
230
  case TelemetryEvent.GetConversationDetailsCallFailed:
231
+ case TelemetryEvent.EndChatSDKCall:
232
+ case TelemetryEvent.EndChatEventReceived:
176
233
  case TelemetryEvent.EndChatSDKCallFailed:
177
234
  case TelemetryEvent.PostChatContextCallFailed:
178
235
  case TelemetryEvent.PostChatContextCallSucceed:
@@ -109,6 +109,8 @@ class TelemetryHelper {
109
109
  static conformToLoadContract(level, input) {
110
110
  const payload = input.payload;
111
111
  return TelemetryHelper.populate(level, payload, event => {
112
+ var _TelemetryManager$Int11, _TelemetryManager$Int12, _TelemetryManager$Int13;
113
+
112
114
  event.Event = payload.Event;
113
115
  event.ResourcePath = payload.ResourcePath;
114
116
  event.WidgetState = payload.WidgetState;
@@ -116,16 +118,19 @@ class TelemetryHelper {
116
118
  event.ChatType = payload.ChatType;
117
119
  event.ElapsedTimeInMilliseconds = payload.ElapsedTimeInMilliseconds;
118
120
  event.ExceptionDetails = JSON.stringify(payload.ExceptionDetails);
121
+ event.OCChatSDKVersion = ((_TelemetryManager$Int11 = _TelemetryManager.TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int11 === void 0 ? void 0 : _TelemetryManager$Int11.OCChatSDKVersion) ?? "";
122
+ event.OCChatWidgetVersion = ((_TelemetryManager$Int12 = _TelemetryManager.TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int12 === void 0 ? void 0 : _TelemetryManager$Int12.chatWidgetVersion) ?? "";
123
+ event.OCChatComponentsVersion = ((_TelemetryManager$Int13 = _TelemetryManager.TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int13 === void 0 ? void 0 : _TelemetryManager$Int13.chatComponentVersion) ?? "";
119
124
  });
120
125
  }
121
126
 
122
127
  static conformToIC3ClientContract(level, input) {
123
128
  const payload = input.payload;
124
129
  return TelemetryHelper.populate(level, payload, event => {
125
- var _TelemetryManager$Int11;
130
+ var _TelemetryManager$Int14;
126
131
 
127
132
  event.Event = payload.Event;
128
- event.IC3ClientVersion = (_TelemetryManager$Int11 = _TelemetryManager.TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int11 === void 0 ? void 0 : _TelemetryManager$Int11.IC3ClientVersion;
133
+ event.IC3ClientVersion = (_TelemetryManager$Int14 = _TelemetryManager.TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int14 === void 0 ? void 0 : _TelemetryManager$Int14.IC3ClientVersion;
129
134
  event.SubscriptionId = payload.SubscriptionId;
130
135
  event.EndpointUrl = payload.EndpointUrl;
131
136
  event.EndpointId = payload.EndpointId;
@@ -249,14 +254,14 @@ _defineProperty(TelemetryHelper, "logActionEvent", (logLevel, payload) => {
249
254
  });
250
255
 
251
256
  _defineProperty(TelemetryHelper, "logSDKEvent", (logLevel, payload) => {
252
- var _TelemetryManager$Int12;
257
+ var _TelemetryManager$Int15;
253
258
 
254
259
  const telemetryEvent = {
255
260
  eventName: (payload === null || payload === void 0 ? void 0 : payload.Event) ?? "",
256
261
  logLevel: logLevel,
257
262
  payload: { ...payload,
258
263
  TransactionId: (0, _utils.newGuid)(),
259
- RequestId: (_TelemetryManager$Int12 = _TelemetryManager.TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int12 === void 0 ? void 0 : _TelemetryManager$Int12.currentRequestId
264
+ RequestId: (_TelemetryManager$Int15 = _TelemetryManager.TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int15 === void 0 ? void 0 : _TelemetryManager$Int15.currentRequestId
260
265
  }
261
266
  };
262
267
 
@@ -271,5 +276,18 @@ _defineProperty(TelemetryHelper, "logConfigDataEvent", (logLevel, payload) => {
271
276
  }
272
277
  };
273
278
 
279
+ _omnichannelChatComponents.BroadcastService.postMessage(telemetryEvent);
280
+ });
281
+
282
+ _defineProperty(TelemetryHelper, "logWebChatEvent", (logLevel, payload) => {
283
+ const telemetryEvent = {
284
+ eventName: _TelemetryConstants.TelemetryEvent.WebChatEvent,
285
+ logLevel: logLevel,
286
+ payload: { ...payload,
287
+ type: _TelemetryConstants.TelemetryEvent.WebChatEvent,
288
+ scenarioType: _TelemetryConstants.ScenarioType.WEBCHAT
289
+ }
290
+ };
291
+
274
292
  _omnichannelChatComponents.BroadcastService.postMessage(telemetryEvent);
275
293
  });
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.TelemetryTimers = exports.TelemetryManager = exports.RegisterLoggers = void 0;
6
+ exports.disposeLoggers = exports.TelemetryTimers = exports.TelemetryManager = exports.RegisterLoggers = void 0;
7
7
 
8
8
  var _TelemetryConstants = require("./TelemetryConstants");
9
9
 
@@ -13,6 +13,10 @@ var _ariaTelemetryLogger = require("./loggers/ariaTelemetryLogger");
13
13
 
14
14
  var _consoleLogger = require("./loggers/consoleLogger");
15
15
 
16
+ var _defaultAriaConfig = require("./defaultConfigs/defaultAriaConfig");
17
+
18
+ var _TelemetryHelper = require("./TelemetryHelper");
19
+
16
20
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
17
21
 
18
22
  class TelemetryTimers {}
@@ -31,31 +35,39 @@ exports.TelemetryManager = TelemetryManager;
31
35
 
32
36
  _defineProperty(TelemetryManager, "InternalTelemetryData", void 0);
33
37
 
34
- const RegisterLoggers = () => {
35
- const loggers = [];
38
+ const loggers = [];
39
+
40
+ const disposeLoggers = () => {
41
+ loggers.map(logger => {
42
+ logger.dispose();
43
+ });
44
+ };
45
+
46
+ exports.disposeLoggers = disposeLoggers;
36
47
 
48
+ const RegisterLoggers = () => {
37
49
  const registerLoggers = () => {
38
50
  var _TelemetryManager$Int, _TelemetryManager$Int2, _TelemetryManager$Int3, _TelemetryManager$Int4, _TelemetryManager$Int5, _TelemetryManager$Int6, _TelemetryManager$Int7, _TelemetryManager$Int8;
39
51
 
40
- if (!((_TelemetryManager$Int = TelemetryManager.InternalTelemetryData) !== null && _TelemetryManager$Int !== void 0 && (_TelemetryManager$Int2 = _TelemetryManager$Int.telemetryConfig) !== null && _TelemetryManager$Int2 !== void 0 && _TelemetryManager$Int2.disableConsoleLog) || !((_TelemetryManager$Int3 = TelemetryManager.InternalTelemetryData) !== null && _TelemetryManager$Int3 !== void 0 && (_TelemetryManager$Int4 = _TelemetryManager$Int3.telemetryConfig) !== null && _TelemetryManager$Int4 !== void 0 && _TelemetryManager$Int4.telemetryDisabled)) {
52
+ if (((_TelemetryManager$Int = TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int === void 0 ? void 0 : (_TelemetryManager$Int2 = _TelemetryManager$Int.telemetryConfig) === null || _TelemetryManager$Int2 === void 0 ? void 0 : _TelemetryManager$Int2.disableConsoleLog) === false || ((_TelemetryManager$Int3 = TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int3 === void 0 ? void 0 : (_TelemetryManager$Int4 = _TelemetryManager$Int3.telemetryConfig) === null || _TelemetryManager$Int4 === void 0 ? void 0 : _TelemetryManager$Int4.telemetryDisabled) === false) {
41
53
  _omnichannelChatComponents.BroadcastService.getAnyMessage().subscribe(event => {
42
- if (event.payload) {
54
+ if (event.payload && event.eventName in _TelemetryConstants.TelemetryEvent) {
43
55
  logTelemetry(event);
44
56
  }
45
57
  });
46
58
  }
47
59
 
48
- if (!((_TelemetryManager$Int5 = TelemetryManager.InternalTelemetryData) !== null && _TelemetryManager$Int5 !== void 0 && (_TelemetryManager$Int6 = _TelemetryManager$Int5.telemetryConfig) !== null && _TelemetryManager$Int6 !== void 0 && _TelemetryManager$Int6.disableConsoleLog)) {
60
+ if (((_TelemetryManager$Int5 = TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int5 === void 0 ? void 0 : (_TelemetryManager$Int6 = _TelemetryManager$Int5.telemetryConfig) === null || _TelemetryManager$Int6 === void 0 ? void 0 : _TelemetryManager$Int6.disableConsoleLog) === false) {
49
61
  loggers.push((0, _consoleLogger.consoleLogger)());
50
62
  }
51
63
 
52
- if (!((_TelemetryManager$Int7 = TelemetryManager.InternalTelemetryData) !== null && _TelemetryManager$Int7 !== void 0 && (_TelemetryManager$Int8 = _TelemetryManager$Int7.telemetryConfig) !== null && _TelemetryManager$Int8 !== void 0 && _TelemetryManager$Int8.telemetryDisabled)) {
64
+ if (((_TelemetryManager$Int7 = TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int7 === void 0 ? void 0 : (_TelemetryManager$Int8 = _TelemetryManager$Int7.telemetryConfig) === null || _TelemetryManager$Int8 === void 0 ? void 0 : _TelemetryManager$Int8.telemetryDisabled) === false) {
53
65
  var _TelemetryManager$Int9, _TelemetryManager$Int18, _TelemetryManager$Int19;
54
66
 
55
67
  if ((_TelemetryManager$Int9 = TelemetryManager.InternalTelemetryData) !== null && _TelemetryManager$Int9 !== void 0 && _TelemetryManager$Int9.ariaConfig) {
56
68
  var _TelemetryManager$Int10, _TelemetryManager$Int11, _TelemetryManager$Int12, _TelemetryManager$Int13, _TelemetryManager$Int14, _TelemetryManager$Int15, _TelemetryManager$Int16, _TelemetryManager$Int17;
57
69
 
58
- loggers.push((0, _ariaTelemetryLogger.ariaTelemetryLogger)(((_TelemetryManager$Int10 = TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int10 === void 0 ? void 0 : (_TelemetryManager$Int11 = _TelemetryManager$Int10.ariaConfig) === null || _TelemetryManager$Int11 === void 0 ? void 0 : _TelemetryManager$Int11.ariaTelemetryKey) ?? "", ((_TelemetryManager$Int12 = TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int12 === void 0 ? void 0 : (_TelemetryManager$Int13 = _TelemetryManager$Int12.ariaConfig) === null || _TelemetryManager$Int13 === void 0 ? void 0 : _TelemetryManager$Int13.disableCookieUsage) ?? false, ((_TelemetryManager$Int14 = TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int14 === void 0 ? void 0 : (_TelemetryManager$Int15 = _TelemetryManager$Int14.ariaConfig) === null || _TelemetryManager$Int15 === void 0 ? void 0 : _TelemetryManager$Int15.collectorUriForTelemetry) ?? "", ((_TelemetryManager$Int16 = TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int16 === void 0 ? void 0 : (_TelemetryManager$Int17 = _TelemetryManager$Int16.ariaConfig) === null || _TelemetryManager$Int17 === void 0 ? void 0 : _TelemetryManager$Int17.ariaTelemetryApplicationName) ?? "OmniChannelProd_Web"));
70
+ loggers.push((0, _ariaTelemetryLogger.ariaTelemetryLogger)(((_TelemetryManager$Int10 = TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int10 === void 0 ? void 0 : (_TelemetryManager$Int11 = _TelemetryManager$Int10.ariaConfig) === null || _TelemetryManager$Int11 === void 0 ? void 0 : _TelemetryManager$Int11.ariaTelemetryKey) ?? _defaultAriaConfig.defaultAriaConfig.ariaTelemetryKey, ((_TelemetryManager$Int12 = TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int12 === void 0 ? void 0 : (_TelemetryManager$Int13 = _TelemetryManager$Int12.ariaConfig) === null || _TelemetryManager$Int13 === void 0 ? void 0 : _TelemetryManager$Int13.disableCookieUsage) ?? _defaultAriaConfig.defaultAriaConfig.disableCookieUsage, ((_TelemetryManager$Int14 = TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int14 === void 0 ? void 0 : (_TelemetryManager$Int15 = _TelemetryManager$Int14.ariaConfig) === null || _TelemetryManager$Int15 === void 0 ? void 0 : _TelemetryManager$Int15.collectorUriForTelemetry) ?? _defaultAriaConfig.defaultAriaConfig.collectorUriForTelemetry, ((_TelemetryManager$Int16 = TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int16 === void 0 ? void 0 : (_TelemetryManager$Int17 = _TelemetryManager$Int16.ariaConfig) === null || _TelemetryManager$Int17 === void 0 ? void 0 : _TelemetryManager$Int17.ariaTelemetryApplicationName) ?? _defaultAriaConfig.defaultAriaConfig.ariaTelemetryApplicationName));
59
71
  }
60
72
 
61
73
  const customLoggers = (_TelemetryManager$Int18 = TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int18 === void 0 ? void 0 : (_TelemetryManager$Int19 = _TelemetryManager$Int18.telemetryConfig) === null || _TelemetryManager$Int19 === void 0 ? void 0 : _TelemetryManager$Int19.telemetryLoggers;
@@ -78,8 +90,15 @@ const RegisterLoggers = () => {
78
90
 
79
91
  const logTelemetry = telemetryEvent => {
80
92
  loggers.map(logger => {
93
+ var _payload;
94
+
81
95
  const logLevel = telemetryEvent.logLevel ?? _TelemetryConstants.LogLevel.INFO;
82
- logger.log(logLevel, parseInput(telemetryEvent === null || telemetryEvent === void 0 ? void 0 : telemetryEvent.payload));
96
+ const scenarioType = ((_payload = telemetryEvent.payload) === null || _payload === void 0 ? void 0 : _payload.scenarioType) ?? _TelemetryConstants.ScenarioType.UNDEFINED;
97
+ const telemetryInput = parseInput(telemetryEvent === null || telemetryEvent === void 0 ? void 0 : telemetryEvent.payload, scenarioType);
98
+ telemetryInput.telemetryInfo = {
99
+ telemetryInfo: _TelemetryHelper.TelemetryHelper.buildTelemetryEvent(logLevel, telemetryInput)
100
+ };
101
+ logger.log(logLevel, telemetryInput);
83
102
  });
84
103
  };
85
104
 
@@ -5,9 +5,9 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.defaultAriaConfig = void 0;
7
7
  const defaultAriaConfig = {
8
- collectorUriForTelemetry: "https://browser.pipe.aria.microsoft.com/Collector/3.0/",
9
- ariaTelemetryKey: "1574efd98545488983328fac0c9bcb59-45c2ff50-ebcc-473d-949d-e3134ef2189e-6906",
10
- ariaTelemetryApplicationName: "D365_Omnichannel_Client_Sandbox",
8
+ collectorUriForTelemetry: "",
9
+ ariaTelemetryKey: "c7655518acf1403f93ff6b9f77942f0a-d01a02fd-6b50-4de3-a566-62eda11f93bc-7083",
10
+ ariaTelemetryApplicationName: "D365_Omnichannel_Client_Public_Prod",
11
11
  disableCookieUsage: true
12
12
  };
13
13
  exports.defaultAriaConfig = defaultAriaConfig;
@@ -11,6 +11,9 @@ const defaultTelemetryConfiguration = {
11
11
  telemetryDisabled: false,
12
12
  disableConsoleLog: false,
13
13
  telemetryLoggers: [],
14
- ariaConfigurations: _defaultAriaConfig.defaultAriaConfig
14
+ ariaConfigurations: _defaultAriaConfig.defaultAriaConfig,
15
+ chatWidgetVersion: "0.0.0-0",
16
+ chatComponentVersion: "0.0.0-0",
17
+ OCChatSDKVersion: "0.0.0-0"
15
18
  };
16
19
  exports.defaultTelemetryConfiguration = defaultTelemetryConfiguration;
@@ -15,7 +15,7 @@ var _Enums = require("@microsoft/omnichannel-chat-sdk/lib/external/aria/common/E
15
15
 
16
16
  var _Constants = require("../../Constants");
17
17
 
18
- var _TelemetryHelper = require("../TelemetryHelper");
18
+ var _TelemetryManager = require("../TelemetryManager");
19
19
 
20
20
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
21
21
 
@@ -30,9 +30,32 @@ const ariaTelemetryLogger = (ariaTelemetryKey, disabledCookieUsage, collectiorUr
30
30
 
31
31
  if (!(0, _utils.isNullOrEmptyString)(collectiorUriForTelemetry)) {
32
32
  configuration.collectorUri = collectiorUriForTelemetry;
33
+ } else {
34
+ if (_TelemetryManager.TelemetryManager.InternalTelemetryData.environmentVersion == _Constants.EnvironmentVersion.prod) {
35
+ var _TelemetryManager$Int;
36
+
37
+ const orgUrl = (_TelemetryManager$Int = _TelemetryManager.TelemetryManager.InternalTelemetryData) === null || _TelemetryManager$Int === void 0 ? void 0 : _TelemetryManager$Int.orgUrl;
38
+
39
+ if (!(0, _utils.isNullOrUndefined)(orgUrl)) {
40
+ // If the given org is a Production EU org, modify the Aria collector uri
41
+ const region = (0, _utils.getDomain)(orgUrl);
42
+
43
+ if (region === _Constants.AriaTelemetryConstants.EU) {
44
+ configuration.collectorUri = _Constants.AriaTelemetryConstants.EUROPE_ENDPOINT;
45
+ }
46
+ }
47
+ }
33
48
  }
34
49
 
35
- _logger = _AWTLogManager.default.initialize(ariaTelemetryKey, configuration);
50
+ try {
51
+ _logger = _AWTLogManager.default.initialize(ariaTelemetryKey, configuration);
52
+
53
+ if (_logger === undefined) {
54
+ _logger = _AWTLogManager.default.getLogger(ariaTelemetryKey);
55
+ }
56
+ } catch (error) {
57
+ console.log(error);
58
+ }
36
59
  }
37
60
 
38
61
  return _logger;
@@ -40,20 +63,30 @@ const ariaTelemetryLogger = (ariaTelemetryKey, disabledCookieUsage, collectiorUr
40
63
 
41
64
  const ariaLogger = {
42
65
  log: (logLevel, telemetryInput) => {
43
- let property;
44
- const eventProperties = new _AWTEventProperties.default();
45
-
46
- const event = _TelemetryHelper.TelemetryHelper.buildTelemetryEvent(logLevel, telemetryInput);
47
-
48
- eventProperties.setName(telemetryInput.scenarioType);
49
-
50
- for (const key of Object.keys(event)) {
51
- property = typeof event[key] === "object" ? JSON.stringify(event[key]) : event[key];
52
- eventProperties.setProperty(key, property);
66
+ try {
67
+ let property;
68
+ const telemetryInfo = telemetryInput === null || telemetryInput === void 0 ? void 0 : telemetryInput.telemetryInfo;
69
+ const eventProperties = new _AWTEventProperties.default();
70
+ eventProperties.setName(telemetryInput.scenarioType);
71
+
72
+ if (telemetryInfo) {
73
+ for (const key of Object.keys(telemetryInfo)) {
74
+ property = typeof telemetryInfo[key] === "object" ? JSON.stringify(telemetryInfo[key]) : telemetryInfo[key];
75
+ eventProperties.setProperty(key, property);
76
+ }
77
+
78
+ eventProperties.setPropertyWithPii(ariaTelemetryApplicationName, _Constants.Constants.LiveChatWidget, _Enums.AWTPiiKind.GenericData);
79
+ }
80
+
81
+ logger() ? logger().logEvent(eventProperties) : console.log("Unable to initialize aria logger");
82
+ } catch (error) {
83
+ console.error("Error in logging telemetry to Aria logger:" + error);
53
84
  }
54
-
55
- eventProperties.setPropertyWithPii(ariaTelemetryApplicationName, _Constants.Constants.LiveChatWidget, _Enums.AWTPiiKind.GenericData);
56
- logger() ? logger().logEvent(eventProperties) : console.log("Unable to initialize aria logger");
85
+ },
86
+ dispose: () => {
87
+ _AWTLogManager.default.flush(function () {
88
+ console.log("Aria logger disposed");
89
+ });
57
90
  }
58
91
  };
59
92
  return ariaLogger;
@@ -13,32 +13,36 @@ const consoleLogger = () => {
13
13
  const consoleLogger = {
14
14
  log: (logLevel, telemetryInput) => {
15
15
  const payload = telemetryInput !== null && telemetryInput !== void 0 && telemetryInput.payload && Object.keys(telemetryInput === null || telemetryInput === void 0 ? void 0 : telemetryInput.payload).length > 0 ? telemetryInput === null || telemetryInput === void 0 ? void 0 : telemetryInput.payload : "";
16
+ const telemetryInfo = telemetryInput !== null && telemetryInput !== void 0 && telemetryInput.telemetryInfo && Object.keys(telemetryInput === null || telemetryInput === void 0 ? void 0 : telemetryInput.telemetryInfo).length > 0 ? telemetryInput === null || telemetryInput === void 0 ? void 0 : telemetryInput.telemetryInfo : "";
16
17
 
17
18
  try {
18
19
  switch (logLevel) {
19
20
  case _TelemetryConstants.LogLevel.INFO:
20
- console.info(_Constants.Constants.LiveChatWidget, payload);
21
+ console.info(_Constants.Constants.LiveChatWidget, payload, telemetryInfo);
21
22
  break;
22
23
 
23
24
  case _TelemetryConstants.LogLevel.DEBUG:
24
- console.debug(_Constants.Constants.LiveChatWidget, payload);
25
+ console.debug(_Constants.Constants.LiveChatWidget, payload, telemetryInfo);
25
26
  break;
26
27
 
27
28
  case _TelemetryConstants.LogLevel.WARN:
28
- console.warn(_Constants.Constants.LiveChatWidget, payload);
29
+ console.warn(_Constants.Constants.LiveChatWidget, payload, telemetryInfo);
29
30
  break;
30
31
 
31
32
  case _TelemetryConstants.LogLevel.ERROR:
32
- console.error(_Constants.Constants.LiveChatWidget, payload);
33
+ console.error(_Constants.Constants.LiveChatWidget, payload, telemetryInfo);
33
34
  break;
34
35
 
35
36
  default:
36
- console.debug(_Constants.Constants.LiveChatWidget, payload);
37
+ console.debug(_Constants.Constants.LiveChatWidget, payload, telemetryInfo);
37
38
  break;
38
39
  }
39
40
  } catch (ex) {
40
41
  console.error("An unexpected error occurred in the Telemetry client: " + ex);
41
42
  }
43
+ },
44
+ dispose: () => {
45
+ console.log("disposing loggers");
42
46
  }
43
47
  };
44
48
  return consoleLogger;
@@ -3,12 +3,18 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.setTabIndices = exports.setFocusOnSendBox = exports.setFocusOnElement = exports.preventFocusToMoveOutOfElement = exports.parseAdaptiveCardPayload = exports.newGuid = exports.isNullOrUndefined = exports.isNullOrEmptyString = exports.getTimestampHourMinute = exports.getLocaleDirection = exports.getIconText = exports.findParentFocusableElementsWithoutChildContainer = exports.findAllFocusableElement = exports.extractPreChatSurveyResponseValues = exports.escapeHtml = exports.createTimer = exports.changeLanguageCodeFormatForWebChat = void 0;
6
+ exports.setTabIndices = exports.setFocusOnSendBox = exports.setFocusOnElement = exports.preventFocusToMoveOutOfElement = exports.parseAdaptiveCardPayload = exports.newGuid = exports.isUndefinedOrEmpty = exports.isNullOrUndefined = exports.isNullOrEmptyString = exports.getWidgetEndChatEventName = exports.getWidgetCacheId = exports.getTimestampHourMinute = exports.getStateFromCache = exports.getLocaleDirection = exports.getIconText = exports.getDomain = exports.getBroadcastChannelName = exports.findParentFocusableElementsWithoutChildContainer = exports.findAllFocusableElement = exports.extractPreChatSurveyResponseValues = exports.escapeHtml = exports.createTimer = exports.changeLanguageCodeFormatForWebChat = exports.addDelayInMs = void 0;
7
7
 
8
8
  var _Constants = require("./Constants");
9
9
 
10
+ var _DataStoreManager = require("./contextDataStore/DataStoreManager");
11
+
10
12
  var _KeyCodes = require("./KeyCodes");
11
13
 
14
+ var _TelemetryConstants = require("./telemetry/TelemetryConstants");
15
+
16
+ var _md5Typescript = require("md5-typescript");
17
+
12
18
  const getElementBySelector = selector => {
13
19
  let element;
14
20
 
@@ -332,6 +338,87 @@ const createTimer = () => {
332
338
  }
333
339
 
334
340
  };
341
+ }; // Returns the domain of the org
342
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
343
+
344
+
345
+ exports.createTimer = createTimer;
346
+
347
+ const getDomain = hostValue => {
348
+ for (let i = 0; i < _Constants.AriaTelemetryConstants.lcwEUDomainNames.length; i++) {
349
+ if (hostValue.endsWith(_Constants.AriaTelemetryConstants.lcwEUDomainNames[i])) {
350
+ return _Constants.AriaTelemetryConstants.EU;
351
+ }
352
+ }
353
+
354
+ return _Constants.AriaTelemetryConstants.Public;
355
+ };
356
+
357
+ exports.getDomain = getDomain;
358
+
359
+ const getWidgetCacheId = (orgId, widgetId, widgetInstanceId) => {
360
+ const widgetCacheId = `${widgetInstanceId}_${orgId}_${widgetId}`;
361
+ return _md5Typescript.Md5.init(widgetCacheId);
362
+ };
363
+
364
+ exports.getWidgetCacheId = getWidgetCacheId;
365
+
366
+ const getWidgetEndChatEventName = (orgId, widgetId, widgetInstanceId) => {
367
+ if (!isNullOrEmptyString(widgetInstanceId)) {
368
+ return `${_TelemetryConstants.BroadcastEvent.ChatEnded}_${widgetInstanceId}_${orgId}_${widgetId}`;
369
+ }
370
+
371
+ return `${_TelemetryConstants.BroadcastEvent.ChatEnded}_${orgId}_${widgetId}`;
372
+ }; // eslint-disable-next-line @typescript-eslint/no-explicit-any
373
+
374
+
375
+ exports.getWidgetEndChatEventName = getWidgetEndChatEventName;
376
+
377
+ const getStateFromCache = (orgId, widgetId, widgetInstanceId) => {
378
+ // Getting updated state from cache
379
+ try {
380
+ if (_DataStoreManager.DataStoreManager.clientDataStore) {
381
+ var _DataStoreManager$cli;
382
+
383
+ const widgetStateEventName = getWidgetCacheId(orgId, widgetId, widgetInstanceId);
384
+ const widgetStateFromCache = (_DataStoreManager$cli = _DataStoreManager.DataStoreManager.clientDataStore) === null || _DataStoreManager$cli === void 0 ? void 0 : _DataStoreManager$cli.getData(widgetStateEventName, "localStorage");
385
+ const persistedState = widgetStateFromCache ? JSON.parse(widgetStateFromCache) : undefined;
386
+ return persistedState;
387
+ } else {
388
+ return null;
389
+ }
390
+ } catch (error) {
391
+ console.log(error);
392
+ return null;
393
+ }
394
+ }; // eslint-disable-next-line @typescript-eslint/no-explicit-any
395
+
396
+
397
+ exports.getStateFromCache = getStateFromCache;
398
+
399
+ const isUndefinedOrEmpty = object => {
400
+ if (object) {
401
+ if (Object.keys(object).length === 0) {
402
+ return true;
403
+ }
404
+
405
+ return false;
406
+ } else {
407
+ return true;
408
+ }
409
+ }; // eslint-disable-next-line @typescript-eslint/no-explicit-any
410
+
411
+
412
+ exports.isUndefinedOrEmpty = isUndefinedOrEmpty;
413
+
414
+ const addDelayInMs = ms => {
415
+ return new Promise(resolve => setTimeout(resolve, ms));
416
+ };
417
+
418
+ exports.addDelayInMs = addDelayInMs;
419
+
420
+ const getBroadcastChannelName = (widgetId, widgetInstanceId) => {
421
+ return widgetInstanceId && !isNullOrEmptyString(widgetInstanceId) ? `${widgetInstanceId}_${widgetId}` : widgetId;
335
422
  };
336
423
 
337
- exports.createTimer = createTimer;
424
+ exports.getBroadcastChannelName = getBroadcastChannelName;
@@ -206,6 +206,20 @@ const CallingContainerStateful = props => {
206
206
  });
207
207
  }
208
208
  });
209
+ window.addEventListener("beforeunload", () => {
210
+ if (state.uiStates.isIncomingCall) {
211
+ voiceVideoCallingSdk === null || voiceVideoCallingSdk === void 0 ? void 0 : voiceVideoCallingSdk.rejectCall();
212
+ } else {
213
+ voiceVideoCallingSdk === null || voiceVideoCallingSdk === void 0 ? void 0 : voiceVideoCallingSdk.stopCall();
214
+ }
215
+
216
+ voiceVideoCallingSdk === null || voiceVideoCallingSdk === void 0 ? void 0 : voiceVideoCallingSdk.close();
217
+ dispatch({
218
+ type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_E2VV_ENABLED,
219
+ payload: false
220
+ });
221
+ resetCallingStates(true);
222
+ });
209
223
  }, []);
210
224
  const controlProps = {
211
225
  id: "oc-lcw-callingcontainer",