@microsoft/omnichannel-chat-widget 0.1.0-main.8b6c0d8 → 0.1.0-main.ae27766

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 (159) hide show
  1. package/README.md +227 -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 +38 -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 +37 -3
  8. package/lib/cjs/common/telemetry/TelemetryHelper.js +22 -4
  9. package/lib/cjs/common/telemetry/TelemetryManager.js +22 -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 +35 -3
  13. package/lib/cjs/common/telemetry/loggers/consoleLogger.js +3 -0
  14. package/lib/cjs/common/utils.js +15 -2
  15. package/lib/cjs/components/chatbuttonstateful/ChatButtonStateful.js +8 -1
  16. package/lib/cjs/components/confirmationpanestateful/ConfirmationPaneStateful.js +8 -54
  17. package/lib/cjs/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.js +2 -2
  18. package/lib/cjs/components/footerstateful/FooterStateful.js +4 -5
  19. package/lib/cjs/components/headerstateful/HeaderStateful.js +11 -8
  20. package/lib/cjs/components/livechatwidget/common/createMarkdown.js +3 -4
  21. package/lib/cjs/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +43 -35
  22. package/lib/cjs/components/livechatwidget/common/disposeTelemetryLoggers.js +14 -0
  23. package/lib/cjs/components/livechatwidget/common/endChat.js +102 -50
  24. package/lib/cjs/components/livechatwidget/common/initCallingSdk.js +5 -0
  25. package/lib/cjs/components/livechatwidget/common/initWebChatComposer.js +29 -9
  26. package/lib/cjs/components/livechatwidget/common/reconnectChatHelper.js +105 -20
  27. package/lib/cjs/components/livechatwidget/common/registerTelemetryLoggers.js +11 -7
  28. package/lib/cjs/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +26 -24
  29. package/lib/cjs/components/livechatwidget/common/startChat.js +113 -54
  30. package/lib/cjs/components/livechatwidget/common/startProactiveChat.js +3 -3
  31. package/lib/cjs/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +101 -32
  32. package/lib/cjs/components/loadingpanestateful/LoadingPaneStateful.js +1 -1
  33. package/lib/cjs/components/ooohpanestateful/OOOHPaneStateful.js +8 -0
  34. package/lib/cjs/components/postchatloadingpanestateful/PostChatLoadingPaneStateful.js +8 -0
  35. package/lib/cjs/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +28 -11
  36. package/lib/cjs/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +10 -4
  37. package/lib/cjs/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.js +1 -0
  38. package/lib/cjs/components/webchatcontainerstateful/common/mockchatsdk.js +4 -0
  39. package/lib/cjs/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +51 -73
  40. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.js +9 -46
  41. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/attachmentMiddleware.js +3 -1
  42. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/conversationEndMiddleware.js +6 -6
  43. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.js +44 -0
  44. package/lib/cjs/contexts/common/ConversationState.js +3 -2
  45. package/lib/cjs/contexts/common/LiveChatWidgetActionType.js +15 -12
  46. package/lib/cjs/contexts/common/LiveChatWidgetContextInitialState.js +11 -4
  47. package/lib/cjs/contexts/createReducer.js +27 -10
  48. package/lib/cjs/controller/componentController.js +2 -2
  49. package/lib/cjs/plugins/newMessageEventHandler.js +102 -0
  50. package/lib/esm/assets/Audios.js +1 -0
  51. package/lib/esm/assets/Icons.js +11 -0
  52. package/lib/esm/common/Constants.js +34 -3
  53. package/lib/esm/common/contextDataStore/DataStoreManager.js +5 -0
  54. package/lib/esm/common/interfaces/IContextDataStore.js +1 -0
  55. package/lib/esm/common/telemetry/TelemetryConstants.js +33 -2
  56. package/lib/esm/common/telemetry/TelemetryHelper.js +22 -5
  57. package/lib/esm/common/telemetry/TelemetryManager.js +17 -9
  58. package/lib/esm/common/telemetry/defaultConfigs/defaultAriaConfig.js +3 -3
  59. package/lib/esm/common/telemetry/defaultConfigs/defaultTelemetryConfiguration.js +4 -1
  60. package/lib/esm/common/telemetry/loggers/ariaTelemetryLogger.js +32 -2
  61. package/lib/esm/common/telemetry/loggers/consoleLogger.js +3 -0
  62. package/lib/esm/common/utils.js +11 -1
  63. package/lib/esm/components/chatbuttonstateful/ChatButtonStateful.js +9 -1
  64. package/lib/esm/components/confirmationpanestateful/ConfirmationPaneStateful.js +8 -50
  65. package/lib/esm/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.js +2 -2
  66. package/lib/esm/components/footerstateful/FooterStateful.js +4 -5
  67. package/lib/esm/components/headerstateful/HeaderStateful.js +12 -9
  68. package/lib/esm/components/livechatwidget/common/createMarkdown.js +3 -3
  69. package/lib/esm/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +41 -36
  70. package/lib/esm/components/livechatwidget/common/disposeTelemetryLoggers.js +4 -0
  71. package/lib/esm/components/livechatwidget/common/endChat.js +100 -47
  72. package/lib/esm/components/livechatwidget/common/initCallingSdk.js +3 -0
  73. package/lib/esm/components/livechatwidget/common/initWebChatComposer.js +25 -9
  74. package/lib/esm/components/livechatwidget/common/reconnectChatHelper.js +94 -20
  75. package/lib/esm/components/livechatwidget/common/registerTelemetryLoggers.js +10 -3
  76. package/lib/esm/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +23 -22
  77. package/lib/esm/components/livechatwidget/common/startChat.js +108 -51
  78. package/lib/esm/components/livechatwidget/common/startProactiveChat.js +5 -5
  79. package/lib/esm/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +94 -33
  80. package/lib/esm/components/loadingpanestateful/LoadingPaneStateful.js +1 -1
  81. package/lib/esm/components/ooohpanestateful/OOOHPaneStateful.js +6 -0
  82. package/lib/esm/components/postchatloadingpanestateful/PostChatLoadingPaneStateful.js +6 -0
  83. package/lib/esm/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +26 -10
  84. package/lib/esm/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +9 -5
  85. package/lib/esm/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.js +1 -0
  86. package/lib/esm/components/webchatcontainerstateful/common/mockchatsdk.js +4 -0
  87. package/lib/esm/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +2 -12
  88. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.js +7 -44
  89. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/attachmentMiddleware.js +2 -1
  90. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/conversationEndMiddleware.js +6 -6
  91. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.js +31 -0
  92. package/lib/esm/contexts/common/ConversationState.js +3 -2
  93. package/lib/esm/contexts/common/LiveChatWidgetActionType.js +15 -12
  94. package/lib/esm/contexts/common/LiveChatWidgetContextInitialState.js +11 -4
  95. package/lib/esm/contexts/createReducer.js +27 -9
  96. package/lib/esm/controller/componentController.js +2 -2
  97. package/lib/esm/plugins/newMessageEventHandler.js +84 -0
  98. package/lib/types/assets/Audios.d.ts +1 -0
  99. package/lib/types/assets/Icons.d.ts +11 -0
  100. package/lib/types/common/Constants.d.ts +19 -1
  101. package/lib/types/common/contextDataStore/DataStoreManager.d.ts +4 -0
  102. package/lib/types/common/interfaces/IContextDataStore.d.ts +14 -0
  103. package/lib/types/common/telemetry/TelemetryConstants.d.ts +24 -1
  104. package/lib/types/common/telemetry/TelemetryHelper.d.ts +1 -0
  105. package/lib/types/common/telemetry/TelemetryManager.d.ts +1 -0
  106. package/lib/types/common/telemetry/definitions/Contracts.d.ts +3 -0
  107. package/lib/types/common/telemetry/definitions/Payload.d.ts +3 -0
  108. package/lib/types/common/telemetry/interfaces/IChatSDKLogger.d.ts +1 -0
  109. package/lib/types/common/telemetry/interfaces/IInternalTelemetryData.d.ts +2 -0
  110. package/lib/types/common/telemetry/interfaces/ITelemetryConfig.d.ts +12 -0
  111. package/lib/types/common/utils.d.ts +1 -0
  112. package/lib/types/components/confirmationpanestateful/interfaces/IConfirmationPaneStatefulParams.d.ts +5 -2
  113. package/lib/types/components/footerstateful/audionotificationstateful/interfaces/IAudioNotificationStatefulParams.d.ts +0 -1
  114. package/lib/types/components/headerstateful/interfaces/IHeaderStatefulParams.d.ts +4 -1
  115. package/lib/types/components/livechatwidget/common/disposeTelemetryLoggers.d.ts +1 -0
  116. package/lib/types/components/livechatwidget/common/endChat.d.ts +4 -1
  117. package/lib/types/components/livechatwidget/common/reconnectChatHelper.d.ts +5 -2
  118. package/lib/types/components/livechatwidget/common/setPostChatContextAndLoadSurvey.d.ts +1 -1
  119. package/lib/types/components/livechatwidget/common/startChat.d.ts +1 -1
  120. package/lib/types/components/livechatwidget/common/startProactiveChat.d.ts +2 -1
  121. package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetComponentOverrides.d.ts +1 -0
  122. package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetProps.d.ts +3 -1
  123. package/lib/types/components/prechatsurveypanestateful/interfaces/IPreChatSurveyPaneStatefulParams.d.ts +1 -1
  124. package/lib/types/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.d.ts +3 -0
  125. package/lib/types/components/reconnectchatpanestateful/interfaces/IReconnectChatPaneStatefulProps.d.ts +1 -0
  126. package/lib/types/components/webchatcontainerstateful/common/mockchatsdk.d.ts +1 -0
  127. package/lib/types/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.d.ts +1 -1
  128. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/activityMiddleware.d.ts +0 -1
  129. package/lib/types/components/webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger.d.ts +1 -0
  130. package/lib/types/contexts/common/ConversationState.d.ts +3 -2
  131. package/lib/types/contexts/common/ILiveChatWidgetContext.d.ts +3 -0
  132. package/lib/types/contexts/common/LiveChatWidgetActionType.d.ts +15 -12
  133. package/lib/types/plugins/newMessageEventHandler.d.ts +2 -0
  134. package/package.json +11 -11
  135. package/lib/cjs/assets/audios/newMessageNotification.mp3 +0 -0
  136. package/lib/cjs/assets/icons/archiveIcon.svg +0 -3
  137. package/lib/cjs/assets/icons/audioIcon.svg +0 -6
  138. package/lib/cjs/assets/icons/blankIcon.svg +0 -6
  139. package/lib/cjs/assets/icons/excelIcon.svg +0 -6
  140. package/lib/cjs/assets/icons/imageIcon.svg +0 -6
  141. package/lib/cjs/assets/icons/oneNoteIcon.svg +0 -6
  142. package/lib/cjs/assets/icons/pdfIcon.svg +0 -6
  143. package/lib/cjs/assets/icons/powerpointIcon.svg +0 -6
  144. package/lib/cjs/assets/icons/videoIcon.svg +0 -6
  145. package/lib/cjs/assets/icons/visioIcon.svg +0 -6
  146. package/lib/cjs/assets/icons/wordIcon.svg +0 -6
  147. package/lib/esm/assets/assets.d.js +0 -0
  148. package/lib/esm/assets/audios/newMessageNotification.mp3 +0 -0
  149. package/lib/esm/assets/icons/archiveIcon.svg +0 -3
  150. package/lib/esm/assets/icons/audioIcon.svg +0 -6
  151. package/lib/esm/assets/icons/blankIcon.svg +0 -6
  152. package/lib/esm/assets/icons/excelIcon.svg +0 -6
  153. package/lib/esm/assets/icons/imageIcon.svg +0 -6
  154. package/lib/esm/assets/icons/oneNoteIcon.svg +0 -6
  155. package/lib/esm/assets/icons/pdfIcon.svg +0 -6
  156. package/lib/esm/assets/icons/powerpointIcon.svg +0 -6
  157. package/lib/esm/assets/icons/videoIcon.svg +0 -6
  158. package/lib/esm/assets/icons/visioIcon.svg +0 -6
  159. package/lib/esm/assets/icons/wordIcon.svg +0 -6
@@ -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,8 +267,8 @@ 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",
@@ -271,7 +277,7 @@ const dummyDefaultProps = {
271
277
  currentCallTimerStyleProps: {
272
278
  borderRadius: "2px",
273
279
  margin: "1px",
274
- color: "white",
280
+ color: "#FFFFFF",
275
281
  paddingTop: "18px",
276
282
  fontSize: 12,
277
283
  fontFamily: "Segoe UI, Arial, sans-serif",
@@ -384,7 +390,7 @@ const dummyDefaultProps = {
384
390
  margin: "-2px -2px -2px -3px",
385
391
  justifyContent: "center",
386
392
  backgroundSize: "65% 65%",
387
- backgroundImage: "assets/imgs/chat.svg",
393
+ backgroundImage: `url(${_omnichannelChatComponents.ModernChatIconBase64})`,
388
394
  display: "flex",
389
395
  backgroundRepeat: "no-repeat",
390
396
  backgroundPosition: "center"
@@ -493,7 +499,7 @@ const dummyDefaultProps = {
493
499
  },
494
500
  styleProps: {
495
501
  generalStyleProps: {
496
- backgroundColor: "white",
502
+ backgroundColor: "#FFFFFF",
497
503
  borderRadius: "2px",
498
504
  color: "black",
499
505
  fontFamily: "Segoe UI, Arial, sans-serif",
@@ -535,7 +541,7 @@ const dummyDefaultProps = {
535
541
  },
536
542
  confirmButtonStyleProps: {
537
543
  backgroundColor: "rgba(9,72,159,1)",
538
- color: "white",
544
+ color: "#FFFFFF",
539
545
  fontFamily: "Segoe UI, Arial, sans-serif",
540
546
  fontSize: "14px",
541
547
  fontWeight: "500",
@@ -549,7 +555,7 @@ const dummyDefaultProps = {
549
555
  border: "2px dotted #000"
550
556
  },
551
557
  cancelButtonStyleProps: {
552
- backgroundColor: "white",
558
+ backgroundColor: "#FFFFFF",
553
559
  fontFamily: "Segoe UI, Arial, sans-serif",
554
560
  fontSize: "14px",
555
561
  fontWeight: "500",
@@ -905,7 +911,7 @@ const dummyDefaultProps = {
905
911
  },
906
912
  headerIconProps: {
907
913
  id: "oc-lcw-header-icon",
908
- src: "assets/imgs/chatIcon.svg",
914
+ src: _omnichannelChatComponents.ModernChatIconBase64,
909
915
  alt: "Chat Icon",
910
916
  className: undefined
911
917
  },
@@ -934,16 +940,16 @@ const dummyDefaultProps = {
934
940
  fontSize: 16,
935
941
  fontFamily: "Segoe UI, Arial, sans-serif",
936
942
  fontWeight: "450",
937
- color: "white",
943
+ color: "#FFFFFF",
938
944
  padding: "3px 0"
939
945
  },
940
946
  minimizeButtonStyleProps: {
941
- color: "white",
947
+ color: "#FFFFFF",
942
948
  margin: "5px 0",
943
949
  fontSize: "12px"
944
950
  },
945
951
  closeButtonStyleProps: {
946
- color: "white",
952
+ color: "#FFFFFF",
947
953
  margin: "5px 0",
948
954
  fontSize: "12px"
949
955
  },
@@ -1030,7 +1036,7 @@ const dummyDefaultProps = {
1030
1036
  alignSelf: "auto"
1031
1037
  },
1032
1038
  iconImageProps: {
1033
- src: "assets/imgs/chat.svg",
1039
+ src: "",
1034
1040
  imageFit: 0,
1035
1041
  width: "86px",
1036
1042
  height: "86px",
@@ -1105,7 +1111,7 @@ const dummyDefaultProps = {
1105
1111
  titleStyleProps: {
1106
1112
  // ...[Existing chat button title style props]
1107
1113
  margin: "0 0 0 10px",
1108
- color: "White"
1114
+ color: "#FFFFFF"
1109
1115
  }
1110
1116
  }
1111
1117
  },
@@ -1238,7 +1244,7 @@ const dummyDefaultProps = {
1238
1244
  },
1239
1245
  headerContainerStyleProps: {
1240
1246
  backgroundColor: "rgb(49, 95, 162)",
1241
- backgroundImage: "assets/imgs/Proactive_banner.png",
1247
+ backgroundImage: `url(${_omnichannelChatComponents.ProactiveChatBannerBase64})`,
1242
1248
  backgroundPosition: "initial",
1243
1249
  backgroundRepeat: "no-repeat",
1244
1250
  borderTopLeftRadius: "inherit",
@@ -1266,7 +1272,7 @@ const dummyDefaultProps = {
1266
1272
  fontWeight: "600"
1267
1273
  },
1268
1274
  closeButtonStyleProps: {
1269
- backgroundImage: "assets/imgs/closeChatButton.svg",
1275
+ backgroundImage: `url(${_omnichannelChatComponents.CloseChatButtonIconBase64})`,
1270
1276
  backgroundPosition: "center",
1271
1277
  backgroundRepeat: "no-repeat",
1272
1278
  color: "#605e5c",
@@ -1389,7 +1395,7 @@ const dummyDefaultProps = {
1389
1395
  lineHeight: "19px"
1390
1396
  },
1391
1397
  iconStyleProps: {
1392
- backgroundImage: "assets/imgs//ChatReconnectPopupIcon.png",
1398
+ backgroundImage: `url(${_omnichannelChatComponents.ChatReconnectIconBase64})`,
1393
1399
  backgroundPosition: "center",
1394
1400
  backgroundRepeat: "no-repeat",
1395
1401
  backgroundSize: "200px",
@@ -1440,7 +1446,8 @@ const dummyDefaultProps = {
1440
1446
  },
1441
1447
  authClientFunction: undefined,
1442
1448
  isReconnectEnabled: undefined,
1443
- reconnectId: undefined
1449
+ reconnectId: undefined,
1450
+ redirectInSameWindow: undefined
1444
1451
  },
1445
1452
  styleProps: {
1446
1453
  generalStyles: {
@@ -1471,7 +1478,7 @@ const dummyDefaultProps = {
1471
1478
  bubbleBackground: "#315FA2",
1472
1479
  bubbleBorderRadius: 4,
1473
1480
  bubbleBorderWidth: 0,
1474
- bubbleFromUserBackground: "White",
1481
+ bubbleFromUserBackground: "#FFFFFF",
1475
1482
  bubbleFromUserBorderRadius: 4,
1476
1483
  bubbleFromUserBorderWidth: 1,
1477
1484
  bubbleFromUserTextColor: "Black",
@@ -1479,7 +1486,7 @@ const dummyDefaultProps = {
1479
1486
  bubbleMaxWidth: 250,
1480
1487
  bubbleMinHeight: 34,
1481
1488
  bubbleMinWidth: 20,
1482
- bubbleTextColor: "White",
1489
+ bubbleTextColor: "#FFFFFF",
1483
1490
  hideSendBox: false,
1484
1491
  hideUploadButton: true,
1485
1492
  primaryFont: "Segoe UI, Arial, sans-serif",
@@ -1488,7 +1495,7 @@ const dummyDefaultProps = {
1488
1495
  sendBoxTextWrap: true,
1489
1496
  sendBoxHeight: 60,
1490
1497
  sendBoxMaxHeight: 96,
1491
- sendBoxBackground: "White",
1498
+ sendBoxBackground: "#FFFFFF",
1492
1499
  showAvatarInGroup: true,
1493
1500
  suggestedActionsStackedHeight: 125,
1494
1501
  suggestedActionsStackedOverflow: "scroll",
@@ -1512,7 +1519,7 @@ const dummyDefaultProps = {
1512
1519
  internalErrorBoxClass: undefined,
1513
1520
  internalRenderErrorBox: undefined,
1514
1521
  locale: "en-US",
1515
- onTelemetry: undefined,
1522
+ onTelemetry: (0, _WebChatLogger.createWebChatTelemetry)(),
1516
1523
  overrideLocalizedStrings: undefined,
1517
1524
  renderMarkdown: (0, _createMarkdown.createMarkdown)(false, false),
1518
1525
  scrollToEndButtonMiddleware: undefined,
@@ -1599,7 +1606,7 @@ const dummyDefaultProps = {
1599
1606
  fontWeight: 600,
1600
1607
  fontSize: "13px",
1601
1608
  lineHeight: "18px",
1602
- color: "white",
1609
+ color: "#FFFFFF",
1603
1610
  paddingTop: "7px",
1604
1611
  WebkitUserSelect: "none",
1605
1612
  MozUserSelect: "none",
@@ -1703,6 +1710,7 @@ const dummyDefaultProps = {
1703
1710
  PRECHAT_REQUIRED_FIELD_MISSING_MESSAGE: "{0} field is required",
1704
1711
  MARKDOWN_EXTERNAL_LINK_ALT: "Opens in a new window; external."
1705
1712
  }
1706
- }
1713
+ },
1714
+ telemetryConfig: undefined
1707
1715
  };
1708
1716
  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;
@@ -3,71 +3,123 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.endChat = void 0;
6
+ exports.prepareEndChat = exports.endChat = void 0;
7
7
 
8
8
  var _TelemetryConstants = require("../../../common/telemetry/TelemetryConstants");
9
9
 
10
+ var _omnichannelChatComponents = require("@microsoft/omnichannel-chat-components");
11
+
10
12
  var _ConversationState = require("../../../contexts/common/ConversationState");
11
13
 
12
14
  var _LiveChatWidgetActionType = require("../../../contexts/common/LiveChatWidgetActionType");
13
15
 
14
- var _NotificationHandler = require("../../webchatcontainerstateful/webchatcontroller/notification/NotificationHandler");
15
-
16
- var _NotificationScenarios = require("../../webchatcontainerstateful/webchatcontroller/enums/NotificationScenarios");
17
-
18
16
  var _TelemetryHelper = require("../../../common/telemetry/TelemetryHelper");
19
17
 
20
18
  var _WebChatStoreLoader = require("../../webchatcontainerstateful/webchatcontroller/WebChatStoreLoader");
21
19
 
22
20
  var _defaultWebChatContainerStatefulProps = require("../../webchatcontainerstateful/common/defaultProps/defaultWebChatContainerStatefulProps");
23
21
 
24
- var _omnichannelChatComponents = require("@microsoft/omnichannel-chat-components");
22
+ var _PostChatSurveyMode = require("../../postchatsurveypanestateful/enums/PostChatSurveyMode");
23
+
24
+ var _Constants = require("../../../common/Constants");
25
25
 
26
26
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
27
- const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter) => {
28
- try {
29
- var _props$webChatContain;
30
-
31
- _TelemetryHelper.TelemetryHelper.logConfigDataEvent(_TelemetryConstants.LogLevel.INFO, {
32
- Event: _TelemetryConstants.TelemetryEvent.EndChatSDKCall
33
- });
34
-
35
- await (chatSDK === null || chatSDK === void 0 ? void 0 : chatSDK.endChat());
36
- adapter === null || adapter === void 0 ? void 0 : adapter.end();
37
- setAdapter(undefined);
38
- setWebChatStyles({ ..._defaultWebChatContainerStatefulProps.defaultWebChatContainerStatefulProps.webChatStyles,
39
- ...((_props$webChatContain = props.webChatContainerProps) === null || _props$webChatContain === void 0 ? void 0 : _props$webChatContain.webChatStyles)
40
- });
41
- _WebChatStoreLoader.WebChatStoreLoader.store = null;
42
- dispatch({
43
- type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_CONVERSATION_STATE,
44
- payload: _ConversationState.ConversationState.Closed
45
- });
46
- dispatch({
47
- type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_RECONNECT_ID,
48
- payload: undefined
49
- });
50
- dispatch({
51
- type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_AUDIO_NOTIFICATION,
52
- payload: null
53
- });
54
- dispatch({
55
- type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_CHAT_TOKEN,
56
- payload: undefined
57
- });
58
-
59
- _omnichannelChatComponents.BroadcastService.postMessage({
60
- eventName: "EndChat"
61
- });
62
- } catch (ex) {
63
- _TelemetryHelper.TelemetryHelper.logSDKEvent(_TelemetryConstants.LogLevel.ERROR, {
64
- Event: _TelemetryConstants.TelemetryEvent.EndChatSDKCallFailed,
65
- ExceptionDetails: {
66
- exception: ex
67
- }
68
- });
69
-
70
- _NotificationHandler.NotificationHandler.notifyError(_NotificationScenarios.NotificationScenarios.Connection, "End Chat Call Failed: " + ex);
27
+ const prepareEndChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, state) => {
28
+ var _state$domainStates$l, _state$domainStates$l2, _state$domainStates$l3, _state$domainStates$l4;
29
+
30
+ const isPostChatEnabled = (_state$domainStates$l = state.domainStates.liveChatConfig) === null || _state$domainStates$l === void 0 ? void 0 : (_state$domainStates$l2 = _state$domainStates$l.LiveWSAndLiveChatEngJoin) === null || _state$domainStates$l2 === void 0 ? void 0 : _state$domainStates$l2.msdyn_postconversationsurveyenable;
31
+ const postChatSurveyMode = (_state$domainStates$l3 = state.domainStates.liveChatConfig) === null || _state$domainStates$l3 === void 0 ? void 0 : (_state$domainStates$l4 = _state$domainStates$l3.LiveWSAndLiveChatEngJoin) === null || _state$domainStates$l4 === void 0 ? void 0 : _state$domainStates$l4.msdyn_postconversationsurveymode;
32
+ const conversationDetails = await chatSDK.getConversationDetails();
33
+
34
+ if (isPostChatEnabled === "true" && (conversationDetails === null || conversationDetails === void 0 ? void 0 : conversationDetails.canRenderPostChat) === _Constants.Constants.truePascal) {
35
+ const skipEndChatSDK = false;
36
+ const skipCloseChat = true;
37
+ await endChat(props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, skipEndChatSDK, skipCloseChat);
38
+
39
+ if (postChatSurveyMode === _PostChatSurveyMode.PostChatSurveyMode.Embed) {
40
+ const loadPostChatEvent = {
41
+ eventName: _TelemetryConstants.BroadcastEvent.LoadPostChatSurvey
42
+ };
43
+
44
+ _omnichannelChatComponents.BroadcastService.postMessage(loadPostChatEvent);
45
+ } else if (postChatSurveyMode === _PostChatSurveyMode.PostChatSurveyMode.Link) {
46
+ dispatch({
47
+ type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_CONVERSATION_STATE,
48
+ payload: _ConversationState.ConversationState.InActive
49
+ });
50
+ }
51
+ } else {
52
+ await endChat(props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter);
53
+ }
54
+ }; // eslint-disable-next-line @typescript-eslint/no-explicit-any
55
+
56
+
57
+ exports.prepareEndChat = prepareEndChat;
58
+
59
+ const endChat = async (props, chatSDK, setAdapter, setWebChatStyles, dispatch, adapter, skipEndChatSDK, skipCloseChat) => {
60
+ if (!skipEndChatSDK) {
61
+ try {
62
+ _TelemetryHelper.TelemetryHelper.logSDKEvent(_TelemetryConstants.LogLevel.INFO, {
63
+ Event: _TelemetryConstants.TelemetryEvent.EndChatSDKCall
64
+ });
65
+
66
+ await (chatSDK === null || chatSDK === void 0 ? void 0 : chatSDK.endChat());
67
+ } catch (ex) {
68
+ _TelemetryHelper.TelemetryHelper.logSDKEvent(_TelemetryConstants.LogLevel.ERROR, {
69
+ Event: _TelemetryConstants.TelemetryEvent.EndChatSDKCallFailed,
70
+ ExceptionDetails: {
71
+ exception: ex
72
+ }
73
+ });
74
+ }
75
+ }
76
+
77
+ if (!skipCloseChat) {
78
+ try {
79
+ var _props$webChatContain;
80
+
81
+ adapter === null || adapter === void 0 ? void 0 : adapter.end();
82
+ setAdapter(undefined);
83
+ setWebChatStyles({ ..._defaultWebChatContainerStatefulProps.defaultWebChatContainerStatefulProps.webChatStyles,
84
+ ...((_props$webChatContain = props.webChatContainerProps) === null || _props$webChatContain === void 0 ? void 0 : _props$webChatContain.webChatStyles)
85
+ });
86
+ _WebChatStoreLoader.WebChatStoreLoader.store = null;
87
+ dispatch({
88
+ type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_CONVERSATION_STATE,
89
+ payload: _ConversationState.ConversationState.Closed
90
+ });
91
+ dispatch({
92
+ type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_CONVERSATION_ENDED_BY_AGENT,
93
+ payload: false
94
+ });
95
+ dispatch({
96
+ type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_RECONNECT_ID,
97
+ payload: undefined
98
+ });
99
+ dispatch({
100
+ type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_AUDIO_NOTIFICATION,
101
+ payload: null
102
+ });
103
+ dispatch({
104
+ type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_CHAT_TOKEN,
105
+ payload: undefined
106
+ });
107
+ dispatch({
108
+ type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_LIVE_CHAT_CONTEXT,
109
+ payload: undefined
110
+ });
111
+
112
+ _omnichannelChatComponents.BroadcastService.postMessage({
113
+ eventName: _TelemetryConstants.BroadcastEvent.EndChat
114
+ });
115
+ } catch (error) {
116
+ _TelemetryHelper.TelemetryHelper.logActionEvent(_TelemetryConstants.LogLevel.ERROR, {
117
+ Event: _TelemetryConstants.TelemetryEvent.CloseChatMethodException,
118
+ ExceptionDetails: {
119
+ exception: `Failed to endChat: ${error}`
120
+ }
121
+ });
122
+ }
71
123
  }
72
124
  };
73
125
 
@@ -17,6 +17,11 @@ const initCallingSdk = async (chatSDK, setVoiceVideoCallingSDK) => {
17
17
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
18
18
  const callingSDK = await chatSDK.getVoiceVideoCalling();
19
19
  setVoiceVideoCallingSDK(callingSDK);
20
+
21
+ _TelemetryHelper.TelemetryHelper.logCallingEvent(_TelemetryConstants.LogLevel.INFO, {
22
+ Event: _TelemetryConstants.TelemetryEvent.CallingSDKLoadSuccess
23
+ });
24
+
20
25
  return true;
21
26
  }
22
27
 
@@ -5,14 +5,20 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.initWebChatComposer = void 0;
7
7
 
8
+ var _TelemetryConstants = require("../../../common/telemetry/TelemetryConstants");
9
+
8
10
  var _botframeworkWebchat = require("botframework-webchat");
9
11
 
12
+ var _omnichannelChatComponents = require("@microsoft/omnichannel-chat-components");
13
+
10
14
  var _ConversationState = require("../../../contexts/common/ConversationState");
11
15
 
12
16
  var _LiveChatWidgetActionType = require("../../../contexts/common/LiveChatWidgetActionType");
13
17
 
14
18
  var _PostChatSurveyMode = require("../../postchatsurveypanestateful/enums/PostChatSurveyMode");
15
19
 
20
+ var _TelemetryHelper = require("../../../common/telemetry/TelemetryHelper");
21
+
16
22
  var _WebChatStoreLoader = require("../../webchatcontainerstateful/webchatcontroller/WebChatStoreLoader");
17
23
 
18
24
  var _attachmentProcessingMiddleware = _interopRequireDefault(require("../../webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/attachmentProcessingMiddleware"));
@@ -37,6 +43,8 @@ var _createMarkdown = require("./createMarkdown");
37
43
 
38
44
  var _maxMessageSizeValidator = _interopRequireDefault(require("../../webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/maxMessageSizeValidator"));
39
45
 
46
+ var _WebChatLogger = require("../../webchatcontainerstateful/webchatcontroller/webchattelemetry/WebChatLogger");
47
+
40
48
  var _defaultAttachmentProps = require("../../webchatcontainerstateful/common/defaultProps/defaultAttachmentProps");
41
49
 
42
50
  var _defaultMiddlewareLocalizedTexts = require("../../webchatcontainerstateful/common/defaultProps/defaultMiddlewareLocalizedTexts");
@@ -55,8 +63,6 @@ var _preProcessingMiddleware = _interopRequireDefault(require("../../webchatcont
55
63
 
56
64
  var _sanitizationMiddleware = _interopRequireDefault(require("../../webchatcontainerstateful/webchatcontroller/middlewares/storemiddlewares/sanitizationMiddleware"));
57
65
 
58
- var _setPostChatContextAndLoadSurvey = require("./setPostChatContextAndLoadSurvey");
59
-
60
66
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
61
67
 
62
68
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
@@ -80,6 +86,11 @@ const initWebChatComposer = (props, chatSDK, state, dispatch, setWebChatStyles)
80
86
  const conversationEndCallback = async () => {
81
87
  var _props$webChatContain4, _props$webChatContain5;
82
88
 
89
+ _TelemetryHelper.TelemetryHelper.logActionEvent(_TelemetryConstants.LogLevel.INFO, {
90
+ Event: _TelemetryConstants.TelemetryEvent.ConversationEndedThreadEventReceived,
91
+ Description: "Conversation is ended by agent side or by timeout."
92
+ });
93
+
83
94
  if ((props === null || props === void 0 ? void 0 : (_props$webChatContain4 = props.webChatContainerProps) === null || _props$webChatContain4 === void 0 ? void 0 : (_props$webChatContain5 = _props$webChatContain4.renderingMiddlewareProps) === null || _props$webChatContain5 === void 0 ? void 0 : _props$webChatContain5.hideSendboxOnConversationEnd) !== false) {
84
95
  setWebChatStyles(styles => {
85
96
  return { ...styles,
@@ -88,16 +99,24 @@ const initWebChatComposer = (props, chatSDK, state, dispatch, setWebChatStyles)
88
99
  });
89
100
  }
90
101
 
91
- if (isPostChatEnabled === "true" && postChatSurveyMode === _PostChatSurveyMode.PostChatSurveyMode.Embed) {
102
+ if (isPostChatEnabled === "true") {
103
+ if (postChatSurveyMode === _PostChatSurveyMode.PostChatSurveyMode.Embed) {
104
+ const loadPostChatEvent = {
105
+ eventName: _TelemetryConstants.BroadcastEvent.LoadPostChatSurvey
106
+ };
107
+
108
+ _omnichannelChatComponents.BroadcastService.postMessage(loadPostChatEvent);
109
+ } else if (postChatSurveyMode === _PostChatSurveyMode.PostChatSurveyMode.Link) {
110
+ dispatch({
111
+ type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_CONVERSATION_STATE,
112
+ payload: _ConversationState.ConversationState.InActive
113
+ });
114
+ }
115
+ } else {
92
116
  dispatch({
93
- type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_SHOULD_SHOW_POST_CHAT,
117
+ type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_CONVERSATION_ENDED_BY_AGENT,
94
118
  payload: true
95
119
  });
96
- dispatch({
97
- type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_CONVERSATION_STATE,
98
- payload: _ConversationState.ConversationState.Loading
99
- });
100
- await (0, _setPostChatContextAndLoadSurvey.setPostChatContextAndLoadSurvey)(chatSDK, dispatch, true);
101
120
  }
102
121
 
103
122
  dispatch({
@@ -124,6 +143,7 @@ const initWebChatComposer = (props, chatSDK, state, dispatch, setWebChatStyles)
124
143
  avatarMiddleware: (_props$webChatContain15 = props.webChatContainerProps) !== null && _props$webChatContain15 !== void 0 && (_props$webChatContain16 = _props$webChatContain15.renderingMiddlewareProps) !== null && _props$webChatContain16 !== void 0 && _props$webChatContain16.disableAvatarMiddleware ? undefined : (0, _avatarMiddleware.createAvatarMiddleware)((_state$domainStates$r5 = state.domainStates.renderingMiddlewareProps) === null || _state$domainStates$r5 === void 0 ? void 0 : _state$domainStates$r5.avatarStyleProps, (_state$domainStates$r6 = state.domainStates.renderingMiddlewareProps) === null || _state$domainStates$r6 === void 0 ? void 0 : _state$domainStates$r6.avatarTextStyleProps),
125
144
  groupActivitiesMiddleware: (_props$webChatContain17 = props.webChatContainerProps) !== null && _props$webChatContain17 !== void 0 && (_props$webChatContain18 = _props$webChatContain17.renderingMiddlewareProps) !== null && _props$webChatContain18 !== void 0 && _props$webChatContain18.disableGroupActivitiesMiddleware ? undefined : (_defaultWebChatContai2 = _defaultWebChatContainerStatefulProps.defaultWebChatContainerStatefulProps.webChatProps) === null || _defaultWebChatContai2 === void 0 ? void 0 : _defaultWebChatContai2.groupActivitiesMiddleware,
126
145
  typingIndicatorMiddleware: (_props$webChatContain19 = props.webChatContainerProps) !== null && _props$webChatContain19 !== void 0 && (_props$webChatContain20 = _props$webChatContain19.renderingMiddlewareProps) !== null && _props$webChatContain20 !== void 0 && _props$webChatContain20.disableTypingIndicatorMiddleware ? undefined : (_defaultWebChatContai3 = _defaultWebChatContainerStatefulProps.defaultWebChatContainerStatefulProps.webChatProps) === null || _defaultWebChatContai3 === void 0 ? void 0 : _defaultWebChatContai3.typingIndicatorMiddleware,
146
+ onTelemetry: (0, _WebChatLogger.createWebChatTelemetry)(),
127
147
  ...((_props$webChatContain21 = props.webChatContainerProps) === null || _props$webChatContain21 === void 0 ? void 0 : _props$webChatContain21.webChatProps)
128
148
  };
129
149
  return webChatProps;