@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.
- package/lib/cjs/assets/Icons.js +4 -2
- package/lib/cjs/common/Constants.js +15 -1
- package/lib/cjs/common/telemetry/TelemetryConstants.js +4 -0
- package/lib/cjs/components/livechatwidget/common/endChat.js +53 -4
- package/lib/cjs/components/livechatwidget/common/initWebChatComposer.js +9 -7
- package/lib/cjs/components/livechatwidget/common/startChat.js +1 -1
- package/lib/cjs/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +24 -4
- package/lib/cjs/components/notificationpanestateful/NotificationPaneStateful.js +177 -0
- package/lib/cjs/components/notificationpanestateful/defaultProps/defaultChatDisconnectControlProps.js +41 -0
- package/lib/cjs/components/notificationpanestateful/defaultProps/defaultChatDisconnectStyleProps.js +98 -0
- package/lib/cjs/components/notificationpanestateful/interfaces/INotificationPaneStatefulProps.js +1 -0
- package/lib/cjs/components/webchatcontainerstateful/common/mockchatsdk.js +3 -0
- package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/toastMiddleware.js +35 -0
- package/lib/esm/assets/Icons.js +2 -1
- package/lib/esm/common/Constants.js +13 -0
- package/lib/esm/common/telemetry/TelemetryConstants.js +4 -0
- package/lib/esm/components/livechatwidget/common/endChat.js +51 -3
- package/lib/esm/components/livechatwidget/common/initWebChatComposer.js +9 -7
- package/lib/esm/components/livechatwidget/common/startChat.js +1 -1
- package/lib/esm/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +24 -4
- package/lib/esm/components/notificationpanestateful/NotificationPaneStateful.js +167 -0
- package/lib/esm/components/notificationpanestateful/defaultProps/defaultChatDisconnectControlProps.js +34 -0
- package/lib/esm/components/notificationpanestateful/defaultProps/defaultChatDisconnectStyleProps.js +91 -0
- package/lib/esm/components/notificationpanestateful/interfaces/INotificationPaneStatefulProps.js +1 -0
- package/lib/esm/components/webchatcontainerstateful/common/mockchatsdk.js +3 -0
- package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/toastMiddleware.js +28 -0
- package/lib/types/assets/Icons.d.ts +1 -0
- package/lib/types/common/Constants.d.ts +14 -0
- package/lib/types/common/telemetry/TelemetryConstants.d.ts +2 -0
- package/lib/types/components/livechatwidget/common/endChat.d.ts +1 -0
- package/lib/types/components/livechatwidget/common/initWebChatComposer.d.ts +1 -1
- package/lib/types/components/livechatwidget/interfaces/ILiveChatWidgetProps.d.ts +2 -0
- package/lib/types/components/notificationpanestateful/NotificationPaneStateful.d.ts +3 -0
- package/lib/types/components/notificationpanestateful/defaultProps/defaultChatDisconnectControlProps.d.ts +2 -0
- package/lib/types/components/notificationpanestateful/defaultProps/defaultChatDisconnectStyleProps.d.ts +2 -0
- package/lib/types/components/notificationpanestateful/interfaces/INotificationPaneStatefulProps.d.ts +13 -0
- package/lib/types/components/webchatcontainerstateful/common/mockchatsdk.d.ts +1 -0
- package/lib/types/components/webchatcontainerstateful/interfaces/IRenderingMiddlewareProps.d.ts +1 -0
- package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/toastMiddleware.d.ts +3 -0
- 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;
|
package/lib/types/components/notificationpanestateful/interfaces/INotificationPaneStatefulProps.d.ts
ADDED
|
@@ -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
|
+
}
|
package/lib/types/components/webchatcontainerstateful/interfaces/IRenderingMiddlewareProps.d.ts
CHANGED
|
@@ -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.
|
|
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.
|
|
78
|
-
"@microsoft/omnichannel-chat-sdk": "1.4.
|
|
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",
|