@microsoft/omnichannel-chat-widget 0.1.0-main.89c6531 → 0.1.0-main.eb80fb1

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 (96) hide show
  1. package/README.md +235 -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 +2 -0
  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 +5 -1
  8. package/lib/cjs/components/confirmationpanestateful/ConfirmationPaneStateful.js +15 -28
  9. package/lib/cjs/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.js +2 -2
  10. package/lib/cjs/components/footerstateful/FooterStateful.js +3 -3
  11. package/lib/cjs/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +11 -7
  12. package/lib/cjs/components/livechatwidget/common/endChat.js +11 -3
  13. package/lib/cjs/components/livechatwidget/common/initCallingSdk.js +5 -0
  14. package/lib/cjs/components/livechatwidget/common/initWebChatComposer.js +8 -9
  15. package/lib/cjs/components/livechatwidget/common/registerTelemetryLoggers.js +20 -3
  16. package/lib/cjs/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +23 -22
  17. package/lib/cjs/components/livechatwidget/common/startChat.js +72 -26
  18. package/lib/cjs/components/livechatwidget/common/startProactiveChat.js +3 -3
  19. package/lib/cjs/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +32 -14
  20. package/lib/cjs/components/loadingpanestateful/LoadingPaneStateful.js +1 -1
  21. package/lib/cjs/components/ooohpanestateful/OOOHPaneStateful.js +8 -0
  22. package/lib/cjs/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +28 -11
  23. package/lib/cjs/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +10 -4
  24. package/lib/cjs/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.js +1 -0
  25. package/lib/cjs/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +51 -73
  26. package/lib/cjs/contexts/common/LiveChatWidgetActionType.js +3 -0
  27. package/lib/cjs/contexts/common/LiveChatWidgetContextInitialState.js +4 -2
  28. package/lib/cjs/contexts/createReducer.js +20 -0
  29. package/lib/esm/assets/Audios.js +1 -0
  30. package/lib/esm/assets/Icons.js +11 -0
  31. package/lib/esm/common/Constants.js +2 -0
  32. package/lib/esm/common/contextDataStore/DataStoreManager.js +5 -0
  33. package/lib/esm/common/interfaces/IContextDataStore.js +1 -0
  34. package/lib/esm/common/telemetry/TelemetryConstants.js +5 -1
  35. package/lib/esm/components/confirmationpanestateful/ConfirmationPaneStateful.js +15 -28
  36. package/lib/esm/components/emailtranscriptpanestateful/EmailTranscriptPaneStateful.js +2 -2
  37. package/lib/esm/components/footerstateful/FooterStateful.js +3 -3
  38. package/lib/esm/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +11 -9
  39. package/lib/esm/components/livechatwidget/common/endChat.js +11 -3
  40. package/lib/esm/components/livechatwidget/common/initCallingSdk.js +3 -0
  41. package/lib/esm/components/livechatwidget/common/initWebChatComposer.js +8 -9
  42. package/lib/esm/components/livechatwidget/common/registerTelemetryLoggers.js +18 -3
  43. package/lib/esm/components/livechatwidget/common/setPostChatContextAndLoadSurvey.js +22 -22
  44. package/lib/esm/components/livechatwidget/common/startChat.js +67 -22
  45. package/lib/esm/components/livechatwidget/common/startProactiveChat.js +5 -5
  46. package/lib/esm/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +31 -14
  47. package/lib/esm/components/loadingpanestateful/LoadingPaneStateful.js +1 -1
  48. package/lib/esm/components/ooohpanestateful/OOOHPaneStateful.js +6 -0
  49. package/lib/esm/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +26 -10
  50. package/lib/esm/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +8 -4
  51. package/lib/esm/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.js +1 -0
  52. package/lib/esm/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.js +2 -12
  53. package/lib/esm/contexts/common/LiveChatWidgetActionType.js +3 -0
  54. package/lib/esm/contexts/common/LiveChatWidgetContextInitialState.js +4 -2
  55. package/lib/esm/contexts/createReducer.js +20 -0
  56. package/lib/types/assets/Audios.d.ts +1 -0
  57. package/lib/types/assets/Icons.d.ts +11 -0
  58. package/lib/types/common/Constants.d.ts +1 -0
  59. package/lib/types/common/contextDataStore/DataStoreManager.d.ts +4 -0
  60. package/lib/types/common/interfaces/IContextDataStore.d.ts +14 -0
  61. package/lib/types/common/telemetry/TelemetryConstants.d.ts +4 -0
  62. package/lib/types/components/livechatwidget/common/setPostChatContextAndLoadSurvey.d.ts +1 -1
  63. package/lib/types/components/livechatwidget/common/startChat.d.ts +1 -1
  64. package/lib/types/components/livechatwidget/common/startProactiveChat.d.ts +2 -1
  65. package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetProps.d.ts +3 -1
  66. package/lib/types/components/prechatsurveypanestateful/interfaces/IPreChatSurveyPaneStatefulParams.d.ts +1 -1
  67. package/lib/types/components/proactivechatpanestateful/interfaces/IProactiveChatNotificationConfig.d.ts +3 -0
  68. package/lib/types/components/webchatcontainerstateful/common/utils/FileAttachmentIconManager.d.ts +1 -1
  69. package/lib/types/contexts/common/ILiveChatWidgetContext.d.ts +2 -0
  70. package/lib/types/contexts/common/LiveChatWidgetActionType.d.ts +4 -1
  71. package/package.json +4 -2
  72. package/lib/cjs/assets/audios/newMessageNotification.mp3 +0 -0
  73. package/lib/cjs/assets/icons/archiveIcon.svg +0 -3
  74. package/lib/cjs/assets/icons/audioIcon.svg +0 -6
  75. package/lib/cjs/assets/icons/blankIcon.svg +0 -6
  76. package/lib/cjs/assets/icons/excelIcon.svg +0 -6
  77. package/lib/cjs/assets/icons/imageIcon.svg +0 -6
  78. package/lib/cjs/assets/icons/oneNoteIcon.svg +0 -6
  79. package/lib/cjs/assets/icons/pdfIcon.svg +0 -6
  80. package/lib/cjs/assets/icons/powerpointIcon.svg +0 -6
  81. package/lib/cjs/assets/icons/videoIcon.svg +0 -6
  82. package/lib/cjs/assets/icons/visioIcon.svg +0 -6
  83. package/lib/cjs/assets/icons/wordIcon.svg +0 -6
  84. package/lib/esm/assets/assets.d.js +0 -0
  85. package/lib/esm/assets/audios/newMessageNotification.mp3 +0 -0
  86. package/lib/esm/assets/icons/archiveIcon.svg +0 -3
  87. package/lib/esm/assets/icons/audioIcon.svg +0 -6
  88. package/lib/esm/assets/icons/blankIcon.svg +0 -6
  89. package/lib/esm/assets/icons/excelIcon.svg +0 -6
  90. package/lib/esm/assets/icons/imageIcon.svg +0 -6
  91. package/lib/esm/assets/icons/oneNoteIcon.svg +0 -6
  92. package/lib/esm/assets/icons/pdfIcon.svg +0 -6
  93. package/lib/esm/assets/icons/powerpointIcon.svg +0 -6
  94. package/lib/esm/assets/icons/videoIcon.svg +0 -6
  95. package/lib/esm/assets/icons/visioIcon.svg +0 -6
  96. package/lib/esm/assets/icons/wordIcon.svg +0 -6
package/README.md ADDED
@@ -0,0 +1,235 @@
1
+ # Omnichannel Live Chat Widget UI Components
2
+
3
+ ![Release CI](https://github.com/microsoft/omnichannel-chat-widget/workflows/chat-components-release/badge.svg) [![npm version](https://badge.fury.io/js/%40microsoft%2Fomnichannel-chat-components.svg)](https://badge.fury.io/js/%40microsoft%2Fomnichannel-chat-components.svg) ![npm](https://img.shields.io/npm/dm/@microsoft/omnichannel-chat-components)\
4
+ ![Release CI](https://github.com/microsoft/omnichannel-chat-widget/workflows/chat-widget-release/badge.svg) [![npm version](https://badge.fury.io/js/%40microsoft%2Fomnichannel-chat-widget.svg)](https://badge.fury.io/js/%40microsoft%2Fomnichannel-chat-widget.svg) ![npm](https://img.shields.io/npm/dm/@microsoft/omnichannel-chat-widget)
5
+
6
+ [@microsoft/omnichannel-chat-widget](https://www.npmjs.com/package/@microsoft/omnichannel-chat-widget) is a React-based UI component library which allows you to build your own live chat widget experience using [@microsoft/omnichannel-chat-sdk](https://www.npmjs.com/package/@microsoft/omnichannel-chat-sdk).
7
+
8
+ ## Table of Contents
9
+
10
+ 1. [Introduction](#introduction)
11
+ 1. [Installation](#installation)
12
+ 1. [Example Usage](#example-usage)
13
+ 1. [Components](#components)
14
+ 1. [Telemetry](#telemetry)
15
+ 1. [Features](#features)
16
+
17
+ ## Introduction
18
+
19
+ Omnichannel Live Chat Widget UI Components offers a re-usable component-based library to help create a custom chat widget that can be connected to the Dynamics 365 Customer Service experience.
20
+
21
+ For more information about Live Chat Widget, see [here](https://docs.microsoft.com/en-us/dynamics365/customer-service/set-up-chat-widget).
22
+
23
+ ## Installation
24
+
25
+ ```powershell
26
+ npm i @microsoft/omnichannel-chat-sdk
27
+ npm i @microsoft/omnichannel-chat-widget
28
+ ```
29
+
30
+ or
31
+
32
+ ```powershell
33
+ yarn add @microsoft/omnichannel-chat-sdk
34
+ yarn add @microsoft/omnichannel-chat-widget
35
+ ```
36
+
37
+ The repo also contains the ```@microsoft/omnichannel-chat-components``` package, which is a collection of UI components. The ```@microsoft/omnichannel-chat-widget``` package is an integration of the Chat SDK and the UI components. To install the UI components separately, do
38
+
39
+ ```powershell
40
+ npm i @microsoft/omnichannel-chat-components
41
+ ```
42
+
43
+ or
44
+
45
+ ```powershell
46
+ yarn add @microsoft/omnichannel-chat-components
47
+ ```
48
+
49
+ ## Example Usage
50
+
51
+ The basic example below takes in the ```<LiveChatWidget/>``` component along with the Chat SDK to create a customized Omnichannel chat widget.
52
+ > :warning: The Chat SDK has to be **_initialized_** before being passed in.
53
+
54
+ ```js
55
+ import * as React from "react";
56
+
57
+ import { LiveChatWidget } from "@microsoft/omnichannel-chat-widget";
58
+ import { OmnichannelChatSDK } from "@microsoft/omnichannel-chat-sdk";
59
+ import ReactDOM from "react-dom";
60
+ //Below version numbers will help us to troubleshoot issues with specific package
61
+ import { version as chatSdkVersion } from "@microsoft/omnichannel-chat-sdk/package.json";
62
+ import { version as chatWidgetVersion } from "../package.json";
63
+ import { version as chatComponentVersion } from "@microsoft/omnichannel-chat-components/package.json";
64
+
65
+ const render = async () => {
66
+ const omnichannelConfig = {
67
+ orgId: "00000000-0000-0000-0000-000000000000", // dummy config
68
+ orgUrl: "https://www.org-url.com", // dummy config
69
+ widgetId: "00000000-0000-0000-0000-000000000000" // dummy config
70
+ };
71
+ const chatSDK = new OmnichannelChatSDK(omnichannelConfig);
72
+ await chatSDK.initialize(); // mandatory
73
+ const chatConfig = await chatSDK.getLiveChatConfig();
74
+ const liveChatWidgetProps = {
75
+ styleProps: {
76
+ generalStyles: {
77
+ width: "700px",
78
+ height: "800px"
79
+ }
80
+ },
81
+ headerProps: {
82
+ controlProps: {
83
+ hideMinimizeButton: true
84
+ }
85
+ },
86
+ chatSDK: chatSDK, // mandatory
87
+ chatConfig: chatConfig, // mandatory
88
+ telemetryConfig: { //mandatory
89
+ orgId: omnichannelConfig.orgId,
90
+ orgUrl: omnichannelConfig.orgUrl,
91
+ appId: omnichannelConfig.widgetId,
92
+ OCChatSDKVersion: chatSdkVersion,
93
+ chatComponentVersion: chatComponentVersion,
94
+ chatWidgetVersion: chatWidgetVersion
95
+ }
96
+ };
97
+
98
+ ReactDOM.render(
99
+ <LiveChatWidget {...liveChatWidgetProps}/>,
100
+ document.getElementById("my-container")
101
+ );
102
+ };
103
+
104
+ render();
105
+ ```
106
+
107
+ A sample widget can be found in this repo [here](https://github.com/microsoft/omnichannel-chat-widget/tree/main/chat-widget/sample). To build it, do ```yarn build-sample``` or ```yarn build-sample:dev``` from project root.
108
+
109
+ ## Components
110
+
111
+ ### Stateless UI Components
112
+
113
+ These are components that are included in the ```@microsoft/omnichannel-chat-components``` package.
114
+
115
+ | Component | Usage | Interface |
116
+ | ----- | -------- | ----- |
117
+ | CallingContainerPane | The container for voice and video feature in the chat widget | [ICallingContainerProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/callingcontainer/interfaces/ICallingContainerProps.ts) |
118
+ | ChatButton | The button that appears on the user's portal that is designed to be the entry point for the user to initate chat | [IChatButtonProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/chatbutton/interfaces/IChatButtonProps.ts) |
119
+ | CommandButton | A customizable button component that can be injected to the header and/or footer | [ICommandButtonProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/common/interfaces/ICommandButtonProps.ts)|
120
+ | ConfirmationPane | The default pane used when the Header close button is launched | [IConfirmationPaneProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/confirmationpane/interfaces/IConfirmationPaneProps.ts) |
121
+ | Footer | The bottom container of the chat containing the download transcript, notification sound and email transcript buttons by default. | [IFooterProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/footer/interfaces/IFooterProps.ts) |
122
+ | Header | The top container of the chat containing the default minimize, close and title of the chat widget | [IHeaderProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/header/interfaces/IHeaderProps.ts) |
123
+ | InputValidationPane | A pop-up input pane with validation. In the default widget this is used as part of [EmailTranscriptPane](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-widget/src/components/emailtranscriptpanestateful/interfaces/IEmailTranscriptPaneProps.ts) | [IInputValidationPaneProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/inputvalidationpane/interfaces/IInputValidationPaneProps.ts) |
124
+ | LoadingPane | The default pane used after the chat button is clicked and before the chat loads completely | [ILoadingPaneProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/loadingpane/interfaces/ILoadingPaneProps.ts) |
125
+ | OutOfOfficeHoursPane | The pane that is displayed when the chat is outside of operating hours set on admin side | [IOOOHPaneProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/outofofficehourspane/interfaces/IOOOHPaneProps.ts) |
126
+ | PostChatSurveyPane | The pane that holds the [Customer Voice](https://dynamics.microsoft.com/en-us/customer-voice/overview/) survey which would be used by the customer to input their chat experience, provide user ratings etc. It uses an IFrame to render the survey URL fetched from `getPostChatSurveyContext` call from [OmniChannel ChatSDK](https://github.com/microsoft/omnichannel-chat-sdk#get-postchat-survey). | [IPostChatSurveyPaneProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/postchatsurveypane/interfaces/IPostChatSurveyPaneProps.ts) |
127
+ | PreChatSurveyPane | The pane that holds the form which would be used by the customer to input helpful information for using the Support Chat before starting up the Chat Process. Makes use of [AdaptiveCards](https://adaptivecards.io/) | [IPreChatSurveyPaneProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/prechatsurveypane/interfaces/IPreChatSurveyPaneProps.ts) |
128
+ | ProactiveChatSurveyPane | A pane that holds more information than a normal chat button and can be configured to proactively pop up | [IProactiveChatPaneProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/proactivechatpane/interfaces/IProactiveChatPaneProps.ts) |
129
+ | ReconnectChatPane | The pane that shows up when the customer is re-connecting to the chat to add additional conversation | [IReconnectChatPaneProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/reconnectchatpane/interfaces/IReconnectChatPaneProps.ts) |
130
+
131
+ > :warning: Because the components extend Microsoft's [Fluent UI](https://developer.microsoft.com/en-us/fluentui#/) components, the base interface for all the ```styleProps``` in the above table is [IStyle](https://github.com/microsoft/fluentui/blob/master/packages/merge-styles/src/IStyle.ts), which extends the [IRawStyleBase](https://docs.microsoft.com/en-us/javascript/api/merge-styles/irawstylebase?view=office-ui-fabric-react-latest) interface, which is the most useful reference.
132
+
133
+ ### Stateful Components
134
+
135
+ | Component | Default Usage | Interface |
136
+ | ----- | -------- | ----- |
137
+ | LiveChatWidget | The default widget that stitches the UI components with Chat SDK | [ILiveChatWidgetProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-widget/src/components/livechatwidget/interfaces/ILiveChatWidgetProps.ts) |
138
+
139
+ Some of the interfaces listed in the Stateless table have Stateful counterparts defined in the ```@microsoft/omnichannel-chat-widget``` package. For example, [IConfirmationPaneStatefulProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-widget/src/components/confirmationpanestateful/interfaces/IConfirmationPaneStatefulProps.ts) extends [IConfirmationPaneProps](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-components/src/components/confirmationpane/interfaces/IConfirmationPaneProps.ts) with additional attributes that only makes sense in the stateful context.
140
+
141
+ ### Default Props
142
+
143
+ For a list of all default props used in the default stateful widget, please see [here](https://github.com/microsoft/omnichannel-chat-widget/blob/main/chat-widget/src/components/livechatwidget/common/defaultProps/dummyDefaultProps.ts). If you want to change a default prop, you need to explicitly set it and parse the object as the argument to ```<LiveChatWidget/>```
144
+
145
+ ### Custom Components
146
+
147
+ There are two ways to custom the components provided in the library - 1) Replacing components using ComponentOverrides, and 2) Adding custom components in header and footer.
148
+
149
+ #### ComponentOverrides
150
+
151
+ Most sub-components and the default panes provided can be overriden. Components have "componentOverrides" as part of props interface, which consists of ReactNodes or strings for each part of the component. For example, the "ProactiveChatPane" component has a close button, and the close button can be overriden by creating a custom react node and setting it to the "closeButton" attribute of "componentOverrides" interface that is part of the props.
152
+
153
+ ```js
154
+ const customButton = (
155
+ <button style={{
156
+ background: "green",
157
+ height: "80px",
158
+ margin: "30px 15px 0 0",
159
+ padding: "10px",
160
+ width: "160px"
161
+ }}>
162
+ This is a custom button
163
+ </button>
164
+ );
165
+
166
+ const liveChatWidgetProps = {
167
+ proactiveChatPaneProps: {
168
+ componentOverrides: {
169
+ closeButton: customButton
170
+ };
171
+ };
172
+ }
173
+ ```
174
+
175
+ #### Custom Components in Header and Footer
176
+
177
+ Header's and Footer's child components consist of three parts:
178
+
179
+ 1. "leftGroup" - adding child components at the left of the Header/Footer
180
+ 1. "middleGroup" - adding child components in the middle of the Header/Footer
181
+ 1. "rightGroup" - adding child components at the right of the Header/Footer
182
+
183
+ By default Header has the header icon and title on the left and minimize and close buttons on the right, and Footer has Download Transcript and Email Transcript buttons on the left and audio notification button on the right. These components can be overriden with [ComponentOverrides](#ComponentOverrides). In addition, other custom child components can be added to both Header and Footer by creating custom react nodes and adding them to attributes "leftGroup", "middleGroup" or "rightGroup" of "controlProps".
184
+
185
+ ```js
186
+ const buttonStyleProps: IButtonStyles = {
187
+ root: {
188
+ color: "blue",
189
+ height: 25,
190
+ width: 25,
191
+ }
192
+ };
193
+
194
+ const calendarIcon: IIconProps = { iconName: "Calendar" };
195
+ const calendarIconButton = <IconButton
196
+ key="calendarIconButton"
197
+ iconProps={calendarIcon}
198
+ styles={buttonStyleProps}
199
+ title="Calendar">
200
+ </IconButton>;
201
+
202
+ const emojiIcon: IIconProps = { iconName: "Emoji2" };
203
+ const emojiIconButton = <IconButton
204
+ key="emojiIconButton"
205
+ iconProps={emojiIcon}
206
+ styles={buttonStyleProps}
207
+ title="Sentiment">
208
+ </IconButton>;
209
+
210
+ const uploadIcon: IIconProps = { iconName: "Upload" };
211
+ const uploadIconButton = <IconButton
212
+ key="uploadIconButton"
213
+ iconProps={uploadIcon}
214
+ styles={buttonStyleProps}
215
+ title="Upload">
216
+ </IconButton>;
217
+
218
+ const customizedFooterProp: IFooterProps = {
219
+ controlProps: {
220
+ leftGroup: { children: [uploadIconButton] },
221
+ middleGroup: { children: [calendarIconButton] },
222
+ rightGroup: { children: [emojiIconButton] }
223
+ }
224
+ };
225
+ ```
226
+
227
+ > :pushpin: Note that [WebChat hooks](https://github.com/microsoft/BotFramework-WebChat/blob/main/docs/HOOKS.md) can also be used in any custom components.
228
+
229
+ ## See Also
230
+
231
+ [Telemetry](https://github.com/microsoft/omnichannel-chat-widget/blob/main/docs/Telemetry.md)\
232
+ [Create LCW widget with Webpack5 and TypeScript](https://github.com/microsoft/omnichannel-chat-widget/blob/main/docs/BuildingUsingWebpack5.md)\
233
+ [Omnichannel Features](https://github.com/microsoft/omnichannel-chat-widget/blob/main/docs/Features.md)\
234
+ [How to Add Visual Regression Tests](https://github.com/microsoft/omnichannel-chat-widget/blob/main/docs/VisualRegressionTestingGuide.md)\
235
+ [Security](https://github.com/microsoft/omnichannel-chat-widget/blob/main/SECURITY.md)
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.NewMessageNotificationSoundBase64 = void 0;
7
+ const NewMessageNotificationSoundBase64 = "data:audio/mpeg;base64,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0rlIUnJlGQpRBEtCcG6zF7JKWFk2UR4nALwGqXKtYouCKfOcxZdb9fN7v9kbuitnYwADd4/2tAAoy8zDRoQneMhEwy2AjKB6xlpUcdNxCu6ETljCEY10OdK5SFJyZRkKUQRLQnBusxeySlhZNlEeJwC8BqlyrWKLginznMWXW/Xze7/ZG7or2iIK3+1sgAD0p+KqlpFbwoDMvBAEYeenYGsCFzhe3JgqDoVYtsDhixLnXfEdFGhEzUwxBAHa6iF0LuT4W0tszkvwB6B6zNyJBPTrQY5lQX2or9G0RBW/2tkAAelPxVUtIreFAZl4IAjDz07A1gQucL25MFQdCrFtgcMWJc674joo0ImamGIIA7XUQuhdyfC2ltmcl+APQPWZuRIJ6daDHMqC+1FfoGh1ERN5n/60ADdOliyF5yshWlHYqWneWxIkiFcSW5M3M1jr9kXtq4oXDDg4NnSAJu//+5IAw4ACwBhTe1h6TlgDCm9rD0nKXF1Hre3pMUuLqPW9vSYzTSyNOJMxS1Ep2/O4IDFrapSwJOf3t+/1////+0OoiJvM//WgAbp0sWQvOVkK0o7FS07y2JEkQriS3Jm5msdfsi9tXFC4YcHBs6QBN3maaWRpxJmKWolO353BAYtbVKWBJz+9v3+vewkq/7WgAATSMoCBDCRFBICRMuIYuSmEBJ5IEi0XxA56mxJ5NP4QxJcvl3vxPpZKhXHO4sjg1l8TycewFQ8O1cAaq63HxBQutc2rewkq/7WgAATSMoCBDCRFBICRMuIYuSmEBJ5IEi0XxA56mxJ5NP4QxJcvl3vxPpZKhXHO4sjg1l8TycewFQ8O1cAaq63HxBQutc2o3rAD3+2oAAGCfSVgNCxBAe2IQlFNGND6kpgquVYxKhqRSFYdzwcp8CjjLtNxoUB6zJxGS31ErCAtFdHj0azBhSpL//////////////////////////////////////////////////////////////////////////////////////uSANeAAm0X1Hs4wkxKIvqPZxhJiWBjR63t6TEsDGj1vb0m///////////////////////////////////////////////////////////////////////////////3rAD3+2oAAGCfSVgNCxBAe2IQlFNGND6kpgquVYxKhqRSFYdzwcp8CjjLtNxoUB6zJxGS31ErCAtFdHj0azBhSpK+wkq/7WgAASwBygOhdwKivAdAqcHGACcKkzawRcdFR2M4nMZ4QYZ+6PWIc6FS2o+aWaDEa3GApbDuFhKYd0oovsJKv+1oAAEsAcoDoXcCorwHQKnBxgAnCpM2sEXHRUdjOJzGeEGGfuj1iHOhUtqPmlmgxGtxgKWw7hYSmHdKKL7CS9/tQAABvBYcsow9BRJcwBwEizwDX0IGnZz+5SnLOXTvf3jGoBVlsf3HKOXqki3XsvABktTfH//////////////////////////////////////////////////////////////////////////////////////////////////7kgD/gAXiGNJrGHpMQcMaTWMPSYgAWUen7ecxAAso9P285v///////////////////////////////////////////////////////////////////////////////////////////////////////////////77CS9/tQAABvBYcsow9BRJcwBwEizwDX0IGnZz+5SnLOXTvf3jGoBVlsf3HKOXqki3XsvABktTfGbwEG720AAAflahxWtTVMcKEEs5rjqxISAOjCL97vw5N1Pvc1XB0RRPCk5pspYKPVv0tgk1qHDSObwEG720AAAflahxWtTVMcKEEs5rjqxISAOjCL97vw5N1Pvc1XB0RRPCk5pspYKPVv0tgk1qHDSO/skrfbUAAAc4qRFcEADJh2wITwoFE7zfkoRwgxbHL/ztc3jyemuWVpHUDElKscnC5WHDSMdf/////////////////////////////////////////////////////////////////////////////////////////////////////+5IA/4AGqBdSa1hiTjiC6k1rDEnHCF1DrOWJOOELqHWcsSf//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////f2SVvtqAAAOcVIiuCABkw7YEJ4UCid5vyUI4QYtjl/52ubx5PTXLK0jqBiSlWOThcrDhpGOpsgQrtJAAABl1nCY5dwwnawgLC3D2x/RGM+gi+FvDOV0lPg0qhm4yIhVKq8v93/pJ5UZmyBCu0kAAAGXWcJjl3DCdrCAsLcPbH9EYz6CL4W8M5XSU+DSqGbjIiFUqry/3f+knlRkv9CI29tAAAFHxlpwlZDA/QGQhIDxFQkBISBIe//2u1sfaioIgPA0hh7hV+/6kGiemv////////////////////////////////////////////////////////////////////////////////////////////////////////////uSAP+ABxUXUetZWk41ouo9aytJxlhbP6xhJzDLC2f1jCTm//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////v9CI29tAAAFHxlpwlZDA/QGQhIDxFQkBISBIe//2u1sfaioIgPA0hh7hV+/6kGiemr/SlP9bQAABdoF1qAFywAQBQTMgVOB/XtIADaNjGdJnhDkv1cos1GpzWas8NPf9wkzV/pSn+toAAAu0C61AC5YAIAoJmQKnA/r2kABtGxjOkzwhyX6uUWajU5rNWeGnv+4SZom0KKusgAAAFplGchOwKjJy3AzyZ6qlw6ENtwfw/ftDKoJeJ9D6v53//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////7kAD/gAdEFlFp+UnOMQLKLT8pOcY0WUes5Mc4xoso9ZyY5/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////m0KKusgAAAFplGchOwKjJy3AzyZ6qlw6ENtwfw/ftDKoJeJ9D6v52/0pXbWgAAAc7ADtq2CEKYgFOiCV6tsn6BQq+qG5vvO6pQpGJ639lHv9KV21oAAAHOwA7atghCmIBToglerbJ+gUKvqhub7zuqUKRiet/ZR3awSrJ4AAd0/jX1MAaFiAJKIDjhGj7gkcsHX+d5Uz57V1bT36Ylf//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////7kgD/gAg0DU/p+Rk+J4Gp/T8jJ8UAWUesZEcwoAso9YyI5v//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////3awSrJ4AAd0/jX1MAaFiAJKIDjhGj7gkcsHX+d5Uz57V1bT36YlZdSlaLIAAABva4xDJr7qELgHoTpIQioeVVYCmcjLuL0FrhQjLqUrRZAAAAN7XGIZNfdQhcA9CdJCEVDyqrAUzkZdxegtcKESbUpTWiAAAAfSvOQg4JhIcxEm3DZXsiwvKT8v8zrsdX/p/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////+5IA/4AIghbOYxkRzCZC2cxjIjmEdCU/pecEsI6Ep/S84Jb/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////5tSlNaIAAAB9K85CDgmEhzESbcNleyLC8pPy/zOux1f+kIlgIocHFAAAA/fsh1j8dMLBDM4jPVMOCggkZrPrKtkOOCX6AiWAihwcUAAAD9+yHWPx0wsEMziM9Uw4KCCRms+sq2Q44JfoCskDN5gBwAAAP3jeSgDXYABRUdScti0IEw0XbxoI7P9P//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////uSAP+ACKoJ0Gn5wSwhQToNPzglhHglMefnBKCPBKY8/" + "OCU//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////hWSBm8wA4AAAH7xvJQBrsAAoqOpOWxaECYaLt40Edn+lHhABJh3tAAAAp44rCHDmcsYd4yIYRK4zjpDNHYsu8T5ApaAhaJNTHOhd2iP5NRIeBYHI63gyPCACTDvaAAABTxxWEOHM5Yw7xkQwiVxnHSGaOxZd4nyBS0BC0SamOdC7tEfyaiQ8CwOR1vBjbtdYxXicOI0COLSEeEVIyiD5Kgv5kJdZZpUX/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////7kgD/gAeNCE55+cEoIKEJzz84JQa8PS3s4ebo14elvZw83f////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////m3a6xivE4cRoEcWkI8IqRlEHyVBfzIS6yzSogAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAD/+5IA/4ALFQlIoY95KhshKRQx7yVAAAEuAAAAIAAAJcAAAAQAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAVEFHAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAw=";
8
+ exports.NewMessageNotificationSoundBase64 = NewMessageNotificationSoundBase64;
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.WordIcon = exports.VisioIcon = exports.VideoIcon = exports.PowerpointIcon = exports.PDFIcon = exports.OneNoteIcon = exports.ImageIcon = exports.ExcelIcon = exports.BlankIcon = exports.AudioIcon = exports.ArchiveIcon = void 0;
7
+ const ArchiveIcon = "";
8
+ exports.ArchiveIcon = ArchiveIcon;
9
+ const AudioIcon = "";
10
+ exports.AudioIcon = AudioIcon;
11
+ const BlankIcon = "";
12
+ exports.BlankIcon = BlankIcon;
13
+ const ExcelIcon = "";
14
+ exports.ExcelIcon = ExcelIcon;
15
+ const ImageIcon = "";
16
+ exports.ImageIcon = ImageIcon;
17
+ const OneNoteIcon = "";
18
+ exports.OneNoteIcon = OneNoteIcon;
19
+ const PDFIcon = "";
20
+ exports.PDFIcon = PDFIcon;
21
+ const PowerpointIcon = "";
22
+ exports.PowerpointIcon = PowerpointIcon;
23
+ const VideoIcon = "";
24
+ exports.VideoIcon = VideoIcon;
25
+ const VisioIcon = "";
26
+ exports.VisioIcon = VisioIcon;
27
+ const WordIcon = "";
28
+ exports.WordIcon = WordIcon;
@@ -41,6 +41,8 @@ _defineProperty(Constants, "false", "false");
41
41
 
42
42
  _defineProperty(Constants, "maximumUnreadMessageCount", 99);
43
43
 
44
+ _defineProperty(Constants, "widgetStateDataKey", "LcwChatWidgetState");
45
+
44
46
  _defineProperty(Constants, "channelIdKey", "ChannelId-");
45
47
 
46
48
  _defineProperty(Constants, "ChannelId", "lcw");
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.DataStoreManager = void 0;
7
+
8
+ 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; }
9
+
10
+ class DataStoreManager {}
11
+
12
+ exports.DataStoreManager = DataStoreManager;
13
+
14
+ _defineProperty(DataStoreManager, "clientDataStore", void 0);
@@ -115,11 +115,15 @@ exports.TelemetryEvent = TelemetryEvent;
115
115
  TelemetryEvent["SendTypingIndicatorSucceeded"] = "SendTypingIndicatorSucceeded";
116
116
  TelemetryEvent["SendTypingIndicatorFailed"] = "SendTypingIndicatorFailed";
117
117
  TelemetryEvent["PreChatSurveyStartChatMethodFailed"] = "PreChatSurveyStartChatMethodFailed";
118
+ TelemetryEvent["ChatAlreadyTriggered"] = "ChatAlreadyTriggered";
119
+ TelemetryEvent["StartProactiveChatEventReceived"] = "StartProactiveChatEventReceived";
118
120
  TelemetryEvent["StartProactiveChatMethodFailed"] = "StartProactiveChatMethodFailed";
119
121
  TelemetryEvent["ProactiveChatAccepted"] = "ProactiveChatAccepted";
120
122
  TelemetryEvent["ProactiveChatRejected"] = "ProactiveChatRejected";
121
123
  TelemetryEvent["IncomingProactiveChatScreenLoaded"] = "IncomingProactiveChatScreenLoaded";
122
124
  TelemetryEvent["ProactiveChatClosed"] = "ProactiveChatClosed";
125
+ TelemetryEvent["ProactiveChatStartChat"] = "ProactiveChatStartChat";
126
+ TelemetryEvent["ProactiveChatStartPopoutChat"] = "ProactiveChatStartPopoutChat";
123
127
  TelemetryEvent["ReconnectChatContinueConversation"] = "ReconnectChatContinueConversation";
124
128
  TelemetryEvent["ReconnectChatStartNewConversation"] = "ReconnectChatStartNewConversation";
125
129
  TelemetryEvent["ReconnectChatMinimize"] = "ReconnectChatMinimize";
@@ -129,7 +133,6 @@ exports.TelemetryEvent = TelemetryEvent;
129
133
  class TelemetryConstants {
130
134
  static map(eventTypeOrScenarioType) {
131
135
  switch (eventTypeOrScenarioType) {
132
- case TelemetryEvent.StartChatSDKCall:
133
136
  case TelemetryEvent.ParseAdaptiveCardFailed:
134
137
  return ScenarioType.CONFIG_VALIDATION;
135
138
 
@@ -168,6 +171,7 @@ class TelemetryConstants {
168
171
  case TelemetryEvent.HeaderMinimizeButtonClicked:
169
172
  return ScenarioType.ACTIONS;
170
173
 
174
+ case TelemetryEvent.StartChatSDKCall:
171
175
  case TelemetryEvent.StartChatMethodException:
172
176
  case TelemetryEvent.CloseChatMethodException:
173
177
  case TelemetryEvent.StartProactiveChatMethodFailed:
@@ -13,10 +13,6 @@ var _utils = require("../../common/utils");
13
13
 
14
14
  var _omnichannelChatComponents = require("@microsoft/omnichannel-chat-components");
15
15
 
16
- var _Constants = require("../../common/Constants");
17
-
18
- var _ConversationState = require("../../contexts/common/ConversationState");
19
-
20
16
  var _DimLayer = require("../dimlayer/DimLayer");
21
17
 
22
18
  var _LiveChatWidgetActionType = require("../../contexts/common/LiveChatWidgetActionType");
@@ -35,6 +31,8 @@ var _useChatContextStore = _interopRequireDefault(require("../../hooks/useChatCo
35
31
 
36
32
  var _useChatSDKStore = _interopRequireDefault(require("../../hooks/useChatSDKStore"));
37
33
 
34
+ var _Constants = require("../../common/Constants");
35
+
38
36
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
39
37
 
40
38
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
@@ -46,14 +44,14 @@ const ConfirmationPaneStateful = props => {
46
44
  var _state$domainStates$l, _state$domainStates$l2, _state$domainStates$l3, _state$domainStates$l4;
47
45
 
48
46
  const initialTabIndexMap = new Map();
49
- let elements = [];
47
+ let elements = []; // eslint-disable-next-line @typescript-eslint/no-explicit-any
48
+
49
+ const chatSDK = (0, _useChatSDKStore.default)();
50
50
  const [state, dispatch] = (0, _useChatContextStore.default)();
51
51
  const {
52
- setPostChatContext,
53
52
  endChat
54
53
  } = props; // eslint-disable-next-line @typescript-eslint/no-explicit-any
55
-
56
- const chatSDK = (0, _useChatSDKStore.default)(); // eslint-disable-next-line @typescript-eslint/no-explicit-any
54
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
57
55
 
58
56
  const [adapter] = (0, _useChatAdapterStore.default)();
59
57
  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;
@@ -62,7 +60,7 @@ const ConfirmationPaneStateful = props => {
62
60
  id: "oc-lcw-confirmation-pane",
63
61
  dir: state.domainStates.globalDir,
64
62
  onConfirm: async () => {
65
- _TelemetryHelper.TelemetryHelper.logConfigDataEvent(_TelemetryConstants.LogLevel.INFO, {
63
+ _TelemetryHelper.TelemetryHelper.logActionEvent(_TelemetryConstants.LogLevel.INFO, {
66
64
  Event: _TelemetryConstants.TelemetryEvent.ConfirmationConfirmButtonClicked,
67
65
  Description: "Confirmation pane Confirm button clicked"
68
66
  });
@@ -73,26 +71,15 @@ const ConfirmationPaneStateful = props => {
73
71
  });
74
72
 
75
73
  try {
76
- //ToDo: End Chat before PostChat Context and conversation Details is set once the getPostChatContext request ID fetch issue is fixed
77
- const conversationDetails = await chatSDK.getConversationDetails(); // ToDo: Replace with CanRenderPostChat once available in conversationDetails API response
74
+ // check agent has joined conversation
75
+ const conversationDetails = await chatSDK.getConversationDetails();
78
76
 
79
77
  if (isPostChatEnabled === "true" && postChatSurveyMode === _PostChatSurveyMode.PostChatSurveyMode.Embed && conversationDetails.canRenderPostChat === _Constants.Constants.truePascal) {
80
- dispatch({
81
- type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_SHOULD_SHOW_POST_CHAT,
82
- payload: true
83
- });
84
- dispatch({
85
- type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_CONVERSATION_STATE,
86
- payload: _ConversationState.ConversationState.Loading
87
- });
88
- await setPostChatContext();
89
-
90
- if (state.domainStates.postChatContext) {
91
- dispatch({
92
- type: _LiveChatWidgetActionType.LiveChatWidgetActionType.SET_CONVERSATION_STATE,
93
- payload: _ConversationState.ConversationState.Postchat
94
- });
95
- }
78
+ const loadPostChatEvent = {
79
+ eventName: "LoadPostChatSurvey"
80
+ };
81
+
82
+ _omnichannelChatComponents.BroadcastService.postMessage(loadPostChatEvent);
96
83
  } else {
97
84
  (0, _utils.setTabIndices)(elements, initialTabIndexMap, true);
98
85
 
@@ -119,7 +106,7 @@ const ConfirmationPaneStateful = props => {
119
106
  }
120
107
  },
121
108
  onCancel: () => {
122
- _TelemetryHelper.TelemetryHelper.logConfigDataEvent(_TelemetryConstants.LogLevel.INFO, {
109
+ _TelemetryHelper.TelemetryHelper.logActionEvent(_TelemetryConstants.LogLevel.INFO, {
123
110
  Event: _TelemetryConstants.TelemetryEvent.ConfirmationCancelButtonClicked,
124
111
  Description: "Confirmation pane Cancel button clicked."
125
112
  });
@@ -95,8 +95,8 @@ const EmailTranscriptPaneStateful = props => {
95
95
  },
96
96
  onCancel: () => {
97
97
  _TelemetryHelper.TelemetryHelper.logActionEvent(_TelemetryConstants.LogLevel.INFO, {
98
- Event: _TelemetryConstants.TelemetryEvent.EmailTranscriptButtonClicked,
99
- Description: "Email Transcript button clicked."
98
+ Event: _TelemetryConstants.TelemetryEvent.EmailTranscriptCancelButtonClicked,
99
+ Description: "Email Transcript cancel button clicked."
100
100
  });
101
101
 
102
102
  closeEmailTranscriptPane();
@@ -17,6 +17,8 @@ var _omnichannelChatComponents = require("@microsoft/omnichannel-chat-components
17
17
 
18
18
  var _LiveChatWidgetActionType = require("../../contexts/common/LiveChatWidgetActionType");
19
19
 
20
+ var _Audios = require("../../assets/Audios");
21
+
20
22
  var _NotificationHandler = require("../webchatcontainerstateful/webchatcontroller/notification/NotificationHandler");
21
23
 
22
24
  var _NotificationScenarios = require("../webchatcontainerstateful/webchatcontroller/enums/NotificationScenarios");
@@ -29,8 +31,6 @@ var _useChatContextStore = _interopRequireDefault(require("../../hooks/useChatCo
29
31
 
30
32
  var _useChatSDKStore = _interopRequireDefault(require("../../hooks/useChatSDKStore"));
31
33
 
32
- var _newMessageNotification = _interopRequireDefault(require("../../assets/audios/newMessageNotification.mp3"));
33
-
34
34
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
35
35
 
36
36
  // eslint-disable-next-line @typescript-eslint/no-explicit-any
@@ -122,7 +122,7 @@ const FooterStateful = props => {
122
122
  controlProps: controlProps,
123
123
  styleProps: footerProps === null || footerProps === void 0 ? void 0 : footerProps.styleProps
124
124
  }), /*#__PURE__*/_react.default.createElement(_AudioNotificationStateful.default, {
125
- audioSrc: (audioNotificationProps === null || audioNotificationProps === void 0 ? void 0 : audioNotificationProps.audioSrc) ?? _newMessageNotification.default,
125
+ audioSrc: (audioNotificationProps === null || audioNotificationProps === void 0 ? void 0 : audioNotificationProps.audioSrc) ?? _Audios.NewMessageNotificationSoundBase64,
126
126
  hideAudioNotificationButton: (footerProps === null || footerProps === void 0 ? void 0 : (_footerProps$controlP4 = footerProps.controlProps) === null || _footerProps$controlP4 === void 0 ? void 0 : _footerProps$controlP4.hideAudioNotificationButton) ?? false,
127
127
  isAudioMuted: state.appStates.isAudioMuted ?? false
128
128
  }));
@@ -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");
@@ -29,7 +33,7 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
29
33
  // eslint-disable-next-line @typescript-eslint/no-unused-vars
30
34
  const dummyDefaultProps = {
31
35
  audioNotificationProps: {
32
- audioSrc: "assets/audios/newMessageNotification.mp3"
36
+ audioSrc: _Audios.NewMessageNotificationSoundBase64
33
37
  },
34
38
  callingContainerProps: {
35
39
  controlProps: {
@@ -384,7 +388,7 @@ const dummyDefaultProps = {
384
388
  margin: "-2px -2px -2px -3px",
385
389
  justifyContent: "center",
386
390
  backgroundSize: "65% 65%",
387
- backgroundImage: "assets/imgs/chat.svg",
391
+ backgroundImage: `url(${_omnichannelChatComponents.ModernChatIconBase64})`,
388
392
  display: "flex",
389
393
  backgroundRepeat: "no-repeat",
390
394
  backgroundPosition: "center"
@@ -905,7 +909,7 @@ const dummyDefaultProps = {
905
909
  },
906
910
  headerIconProps: {
907
911
  id: "oc-lcw-header-icon",
908
- src: "assets/imgs/chatIcon.svg",
912
+ src: _omnichannelChatComponents.ModernChatIconBase64,
909
913
  alt: "Chat Icon",
910
914
  className: undefined
911
915
  },
@@ -1030,7 +1034,7 @@ const dummyDefaultProps = {
1030
1034
  alignSelf: "auto"
1031
1035
  },
1032
1036
  iconImageProps: {
1033
- src: "assets/imgs/chat.svg",
1037
+ src: "",
1034
1038
  imageFit: 0,
1035
1039
  width: "86px",
1036
1040
  height: "86px",
@@ -1238,7 +1242,7 @@ const dummyDefaultProps = {
1238
1242
  },
1239
1243
  headerContainerStyleProps: {
1240
1244
  backgroundColor: "rgb(49, 95, 162)",
1241
- backgroundImage: "assets/imgs/Proactive_banner.png",
1245
+ backgroundImage: `url(${_omnichannelChatComponents.ProactiveChatBannerBase64})`,
1242
1246
  backgroundPosition: "initial",
1243
1247
  backgroundRepeat: "no-repeat",
1244
1248
  borderTopLeftRadius: "inherit",
@@ -1266,7 +1270,7 @@ const dummyDefaultProps = {
1266
1270
  fontWeight: "600"
1267
1271
  },
1268
1272
  closeButtonStyleProps: {
1269
- backgroundImage: "assets/imgs/closeChatButton.svg",
1273
+ backgroundImage: `url(${_omnichannelChatComponents.CloseChatButtonIconBase64})`,
1270
1274
  backgroundPosition: "center",
1271
1275
  backgroundRepeat: "no-repeat",
1272
1276
  color: "#605e5c",
@@ -1389,7 +1393,7 @@ const dummyDefaultProps = {
1389
1393
  lineHeight: "19px"
1390
1394
  },
1391
1395
  iconStyleProps: {
1392
- backgroundImage: "assets/imgs//ChatReconnectPopupIcon.png",
1396
+ backgroundImage: `url(${_omnichannelChatComponents.ChatReconnectIconBase64})`,
1393
1397
  backgroundPosition: "center",
1394
1398
  backgroundRepeat: "no-repeat",
1395
1399
  backgroundSize: "200px",