@microsoft/omnichannel-chat-widget 1.2.4-main.9847fc4 → 1.3.1-main.57e27d3

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 (40) hide show
  1. package/lib/cjs/assets/Icons.js +4 -2
  2. package/lib/cjs/common/Constants.js +15 -1
  3. package/lib/cjs/common/telemetry/TelemetryConstants.js +4 -0
  4. package/lib/cjs/components/livechatwidget/common/endChat.js +53 -4
  5. package/lib/cjs/components/livechatwidget/common/initWebChatComposer.js +9 -7
  6. package/lib/cjs/components/livechatwidget/common/startChat.js +1 -1
  7. package/lib/cjs/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +24 -4
  8. package/lib/cjs/components/notificationpanestateful/NotificationPaneStateful.js +177 -0
  9. package/lib/cjs/components/notificationpanestateful/defaultProps/defaultChatDisconnectControlProps.js +41 -0
  10. package/lib/cjs/components/notificationpanestateful/defaultProps/defaultChatDisconnectStyleProps.js +98 -0
  11. package/lib/cjs/components/notificationpanestateful/interfaces/INotificationPaneStatefulProps.js +1 -0
  12. package/lib/cjs/components/webchatcontainerstateful/common/mockchatsdk.js +3 -0
  13. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/toastMiddleware.js +35 -0
  14. package/lib/esm/assets/Icons.js +2 -1
  15. package/lib/esm/common/Constants.js +13 -0
  16. package/lib/esm/common/telemetry/TelemetryConstants.js +4 -0
  17. package/lib/esm/components/livechatwidget/common/endChat.js +51 -3
  18. package/lib/esm/components/livechatwidget/common/initWebChatComposer.js +9 -7
  19. package/lib/esm/components/livechatwidget/common/startChat.js +1 -1
  20. package/lib/esm/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +24 -4
  21. package/lib/esm/components/notificationpanestateful/NotificationPaneStateful.js +167 -0
  22. package/lib/esm/components/notificationpanestateful/defaultProps/defaultChatDisconnectControlProps.js +34 -0
  23. package/lib/esm/components/notificationpanestateful/defaultProps/defaultChatDisconnectStyleProps.js +91 -0
  24. package/lib/esm/components/notificationpanestateful/interfaces/INotificationPaneStatefulProps.js +1 -0
  25. package/lib/esm/components/webchatcontainerstateful/common/mockchatsdk.js +3 -0
  26. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/toastMiddleware.js +28 -0
  27. package/lib/types/assets/Icons.d.ts +1 -0
  28. package/lib/types/common/Constants.d.ts +14 -0
  29. package/lib/types/common/telemetry/TelemetryConstants.d.ts +2 -0
  30. package/lib/types/components/livechatwidget/common/endChat.d.ts +1 -0
  31. package/lib/types/components/livechatwidget/common/initWebChatComposer.d.ts +1 -1
  32. package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetProps.d.ts +2 -0
  33. package/lib/types/components/notificationpanestateful/NotificationPaneStateful.d.ts +3 -0
  34. package/lib/types/components/notificationpanestateful/defaultProps/defaultChatDisconnectControlProps.d.ts +2 -0
  35. package/lib/types/components/notificationpanestateful/defaultProps/defaultChatDisconnectStyleProps.d.ts +2 -0
  36. package/lib/types/components/notificationpanestateful/interfaces/INotificationPaneStatefulProps.d.ts +13 -0
  37. package/lib/types/components/webchatcontainerstateful/common/mockchatsdk.d.ts +1 -0
  38. package/lib/types/components/webchatcontainerstateful/interfaces/IRenderingMiddlewareProps.d.ts +1 -0
  39. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/toastMiddleware.d.ts +3 -0
  40. package/package.json +3 -3
@@ -0,0 +1,28 @@
1
+ import React from "react";
2
+ import { NotificationScenarios } from "../../enums/NotificationScenarios";
3
+ import NotificationPaneStateful from "../../../../notificationpanestateful/NotificationPaneStateful";
4
+
5
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
6
+ const createToastMiddleware = (notificationPaneProps, endChat) => {
7
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any, react/display-name
8
+ const toastMiddleware = () => next => card => {
9
+ const {
10
+ notification
11
+ } = card;
12
+ if (notificationPaneProps) {
13
+ if (notification.id === NotificationScenarios.ChatDisconnect) {
14
+ return /*#__PURE__*/React.createElement(NotificationPaneStateful, {
15
+ notificationPaneProps: notificationPaneProps,
16
+ notificationScenarioType: NotificationScenarios.ChatDisconnect,
17
+ endChat: endChat
18
+ });
19
+ }
20
+
21
+ // TODO: additional notification scenarios to be added...
22
+ }
23
+
24
+ return next(card);
25
+ };
26
+ return toastMiddleware;
27
+ };
28
+ export default createToastMiddleware;
@@ -10,3 +10,4 @@ export declare const VideoIcon = "
10
10
  export declare const VisioIcon = "";
11
11
  export declare const WordIcon = "";
12
12
  export declare const AlertIcon = "";
13
+ export declare const NotificationAlertIcon = "";
@@ -217,6 +217,20 @@ export declare class TranscriptConstants {
217
217
  static readonly AgentDialogColor = "#2266E3";
218
218
  static readonly AgentFontColor = "white";
219
219
  }
220
+ export declare class NotificationPaneConstants {
221
+ static readonly DefaultNotificationPaneId = "lcw-notification-pane";
222
+ static readonly DismissId = "lcw-notification-pane-dismiss-button";
223
+ static readonly DismissText = "Dismiss";
224
+ static readonly DismissAriaLabel = "Notification dismiss";
225
+ static readonly CloseChatId = "lcw-notification-pane-close-chat-button";
226
+ static readonly CloseChatText = "Close Chat";
227
+ static readonly CloseChatAriaLabel = "Close chat";
228
+ static readonly IconId = "lcw-notification-pane-icon";
229
+ static readonly IconText = "Notification Icon";
230
+ static readonly ChatDisconnectTitleText = "Chat disconnected";
231
+ static readonly ChatDisconnectSubtitleText = "For additional assistance, please close the chat and try again.";
232
+ static readonly ChromeCloseIconName = "ChromeClose";
233
+ }
220
234
  export declare class AriaTelemetryConstants {
221
235
  static readonly GERMANY_ENDPOINT: string;
222
236
  static readonly GCCH_ENDPOINT: string;
@@ -131,6 +131,8 @@ export declare enum TelemetryEvent {
131
131
  ReconnectChatPaneLoaded = "ReconnectChatPaneLoaded",
132
132
  HeaderCloseButtonClicked = "HeaderCloseButtonClicked",
133
133
  HeaderMinimizeButtonClicked = "HeaderMinimizeButtonClicked",
134
+ NotificationCloseChatButtonClicked = "NotificationCloseChatButtonClicked",
135
+ NotificationDismissButtonClicked = "NotificationDismissButtonClicked",
134
136
  DownloadTranscriptButtonClicked = "DownloadTranscriptButtonClicked",
135
137
  EmailTranscriptButtonClicked = "EmailTranscriptButtonClicked",
136
138
  EmailTranscriptCancelButtonClicked = "EmailTranscriptCancelButtonClicked",
@@ -4,4 +4,5 @@ import { ILiveChatWidgetContext } from "../../../contexts/common/ILiveChatWidget
4
4
  import { ILiveChatWidgetProps } from "../interfaces/ILiveChatWidgetProps";
5
5
  declare const prepareEndChat: (props: ILiveChatWidgetProps, chatSDK: any, state: ILiveChatWidgetContext, dispatch: Dispatch<ILiveChatWidgetAction>, setAdapter: any, setWebChatStyles: any, adapter: any, uwid: string) => Promise<void>;
6
6
  declare const endChat: (props: ILiveChatWidgetProps, chatSDK: any, state: ILiveChatWidgetContext, dispatch: Dispatch<ILiveChatWidgetAction>, setAdapter: any, setWebChatStyles: any, adapter: any, skipEndChatSDK?: boolean | undefined, skipCloseChat?: boolean | undefined, postMessageToOtherTab?: boolean | undefined, uwid?: string) => Promise<void>;
7
+ export declare const endVoiceVideoCallIfOngoing: (chatSDK: any, dispatch: Dispatch<ILiveChatWidgetAction>) => Promise<void>;
7
8
  export { prepareEndChat, endChat };
@@ -3,4 +3,4 @@ import { ILiveChatWidgetAction } from "../../../contexts/common/ILiveChatWidgetA
3
3
  import { ILiveChatWidgetContext } from "../../../contexts/common/ILiveChatWidgetContext";
4
4
  import { ILiveChatWidgetProps } from "../interfaces/ILiveChatWidgetProps";
5
5
  import { IWebChatProps } from "../../webchatcontainerstateful/interfaces/IWebChatProps";
6
- export declare const initWebChatComposer: (props: ILiveChatWidgetProps, state: ILiveChatWidgetContext, dispatch: Dispatch<ILiveChatWidgetAction>, chatSDK: any) => IWebChatProps;
6
+ export declare const initWebChatComposer: (props: ILiveChatWidgetProps, state: ILiveChatWidgetContext, dispatch: Dispatch<ILiveChatWidgetAction>, chatSDK: any, endChat: any) => IWebChatProps;
@@ -24,6 +24,7 @@ import { IContextDataStore } from "../../../common/interfaces/IContextDataStore"
24
24
  import { IPostChatSurveyPaneStatefulProps } from "../../postchatsurveypanestateful/interfaces/IPostChatSurveyPaneStatefulProps";
25
25
  import { IScrollBarProps } from "./IScrollBarProps";
26
26
  import { IDraggableChatWidgetProps } from "./IDraggableChatWidgetProps";
27
+ import { INotificationPaneProps } from "@microsoft/omnichannel-chat-components/lib/types/components/notificationpane/interfaces/INotificationPaneProps";
27
28
  export interface ILiveChatWidgetProps {
28
29
  audioNotificationProps?: IAudioNotificationProps;
29
30
  callingContainerProps?: ICallingContainerProps;
@@ -50,6 +51,7 @@ export interface ILiveChatWidgetProps {
50
51
  startChatErrorPaneProps?: IStartChatErrorPaneProps;
51
52
  styleProps?: ILiveChatWidgetStyleProps;
52
53
  telemetryConfig: ITelemetryConfig;
54
+ notificationPaneProps?: INotificationPaneProps;
53
55
  webChatContainerProps?: IWebChatContainerStatefulProps;
54
56
  liveChatContextFromCache?: ILiveChatWidgetContext;
55
57
  contextDataStore?: IContextDataStore;
@@ -0,0 +1,3 @@
1
+ import { INotificationPaneStatefulProps } from "./interfaces/INotificationPaneStatefulProps";
2
+ export declare const NotificationPaneStateful: (props: INotificationPaneStatefulProps) => JSX.Element;
3
+ export default NotificationPaneStateful;
@@ -0,0 +1,2 @@
1
+ import { IChatDisconnectControlProps } from "@microsoft/omnichannel-chat-components/lib/types/components/notificationpane/interfaces/chatdisconnect/IChatDisconnectControlProps";
2
+ export declare const defaultChatDisconnectControlProps: IChatDisconnectControlProps;
@@ -0,0 +1,2 @@
1
+ import { IChatDisconnectStyleProps } from "@microsoft/omnichannel-chat-components/lib/types/components/notificationpane/interfaces/chatdisconnect/IChatDisconnectStyleProps";
2
+ export declare const defaultChatDisconnectStyleProps: IChatDisconnectStyleProps;
@@ -0,0 +1,13 @@
1
+ import { INotificationPaneProps } from "@microsoft/omnichannel-chat-components/lib/types/components/notificationpane/interfaces/INotificationPaneProps";
2
+ export interface INotificationPaneStatefulProps extends INotificationPaneProps {
3
+ notificationPaneProps?: INotificationPaneProps;
4
+ notificationScenarioType?: string;
5
+ /**
6
+ * endChat: Internal Prop injected for triggering end of a chat using chatSDK
7
+ * @param adapter : The chat adapter for the live chat session
8
+ * @param skipEndChatSDK : If set to true endchat will skip chatSDK endChat call
9
+ * @param skipCloseChat : If set to true endchat will skip closing the live chat instance
10
+ * @param postMessageToOtherTab : If set to true endchat will send a message to other tabs(multi-tabs)
11
+ */
12
+ endChat: (adapter: any, skipEndChatSDK?: boolean, skipCloseChat?: boolean, postMessageToOtherTab?: boolean) => Promise<void>;
13
+ }
@@ -27,4 +27,5 @@ export declare class MockChatSDK {
27
27
  getChatReconnectContext(): {
28
28
  reconnectId: string;
29
29
  };
30
+ getVoiceVideoCalling(): null;
30
31
  }
@@ -9,6 +9,7 @@ export interface IRenderingMiddlewareProps {
9
9
  disableGroupActivitiesMiddleware?: boolean;
10
10
  disableTypingIndicatorMiddleware?: boolean;
11
11
  disableThirdPartyCookiesAlert?: boolean;
12
+ disableToastMiddleware?: boolean;
12
13
  hideSendboxOnConversationEnd?: boolean;
13
14
  userMessageStyleProps?: React.CSSProperties;
14
15
  systemMessageStyleProps?: React.CSSProperties;
@@ -0,0 +1,3 @@
1
+ import { INotificationPaneProps } from "@microsoft/omnichannel-chat-components/lib/types/components/notificationpane/interfaces/INotificationPaneProps";
2
+ declare const createToastMiddleware: (notificationPaneProps: INotificationPaneProps | undefined, endChat: any) => () => (next: any) => (card: any) => any;
3
+ export default createToastMiddleware;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@microsoft/omnichannel-chat-widget",
3
- "version": "1.2.4-main.9847fc4",
3
+ "version": "1.3.1-main.57e27d3",
4
4
  "description": "Microsoft Omnichannel Chat Widget",
5
5
  "main": "lib/cjs/index.js",
6
6
  "types": "lib/types/index.d.ts",
@@ -74,8 +74,8 @@
74
74
  "webpack-cli": "^4.9.2"
75
75
  },
76
76
  "dependencies": {
77
- "@microsoft/omnichannel-chat-components": "^1.0.6",
78
- "@microsoft/omnichannel-chat-sdk": "1.4.6",
77
+ "@microsoft/omnichannel-chat-components": "^1.0.7",
78
+ "@microsoft/omnichannel-chat-sdk": "1.4.7",
79
79
  "abort-controller-es5": "^2.0.1",
80
80
  "dompurify": "^2.3.4",
81
81
  "markdown-it": "^12.3.2",