@microsoft/omnichannel-chat-widget 1.0.5-main.d908c85 → 1.0.6-main.0c19ff3

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 (47) hide show
  1. package/lib/cjs/common/Constants.js +1 -0
  2. package/lib/cjs/common/telemetry/TelemetryHelper.js +19 -17
  3. package/lib/cjs/common/utils.js +17 -2
  4. package/lib/cjs/components/footerstateful/FooterStateful.js +2 -2
  5. package/lib/cjs/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.js +21 -12
  6. package/lib/cjs/components/footerstateful/downloadtranscriptstateful/interfaces/IWebChatTranscriptConfig.js +1 -0
  7. package/lib/cjs/components/livechatwidget/common/createDownloadTranscriptProps.js +27 -0
  8. package/lib/cjs/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +9 -1
  9. package/lib/cjs/components/livechatwidget/common/startChat.js +27 -12
  10. package/lib/cjs/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +36 -28
  11. package/lib/cjs/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +6 -0
  12. package/lib/cjs/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +5 -1
  13. package/lib/cjs/components/webchatcontainerstateful/WebChatContainerStateful.js +21 -11
  14. package/lib/cjs/components/webchatcontainerstateful/common/defaultStyles/defaultAdaptiveCardStyles.js +3 -1
  15. package/lib/cjs/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultSentMessageAnchorStyles.js +10 -0
  16. package/lib/cjs/plugins/createChatTranscript.js +548 -0
  17. package/lib/esm/common/Constants.js +1 -0
  18. package/lib/esm/common/telemetry/TelemetryHelper.js +19 -17
  19. package/lib/esm/common/utils.js +15 -1
  20. package/lib/esm/components/footerstateful/FooterStateful.js +2 -2
  21. package/lib/esm/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.js +22 -13
  22. package/lib/esm/components/footerstateful/downloadtranscriptstateful/interfaces/IWebChatTranscriptConfig.js +1 -0
  23. package/lib/esm/components/livechatwidget/common/createDownloadTranscriptProps.js +20 -0
  24. package/lib/esm/components/livechatwidget/common/defaultProps/dummyDefaultProps.js +9 -1
  25. package/lib/esm/components/livechatwidget/common/startChat.js +27 -12
  26. package/lib/esm/components/livechatwidget/livechatwidgetstateful/LiveChatWidgetStateful.js +36 -28
  27. package/lib/esm/components/prechatsurveypanestateful/PreChatSurveyPaneStateful.js +6 -0
  28. package/lib/esm/components/proactivechatpanestateful/ProactiveChatPaneStateful.js +5 -1
  29. package/lib/esm/components/webchatcontainerstateful/WebChatContainerStateful.js +21 -11
  30. package/lib/esm/components/webchatcontainerstateful/common/defaultStyles/defaultAdaptiveCardStyles.js +3 -1
  31. package/lib/esm/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultSentMessageAnchorStyles.js +3 -0
  32. package/lib/esm/plugins/createChatTranscript.js +543 -0
  33. package/lib/types/common/Constants.d.ts +1 -0
  34. package/lib/types/common/telemetry/TelemetryHelper.d.ts +3 -3
  35. package/lib/types/common/telemetry/definitions/Contracts.d.ts +1 -0
  36. package/lib/types/common/telemetry/definitions/Payload.d.ts +1 -0
  37. package/lib/types/common/utils.d.ts +1 -0
  38. package/lib/types/components/footerstateful/downloadtranscriptstateful/DownloadTranscriptStateful.d.ts +2 -1
  39. package/lib/types/components/footerstateful/downloadtranscriptstateful/interfaces/IDownloadTranscriptProps.d.ts +5 -0
  40. package/lib/types/components/footerstateful/downloadtranscriptstateful/interfaces/IWebChatTranscriptConfig.d.ts +13 -0
  41. package/lib/types/components/livechatwidget/common/createDownloadTranscriptProps.d.ts +24 -0
  42. package/lib/types/components/webchatcontainerstateful/interfaces/IAdaptiveCardStyles.d.ts +2 -0
  43. package/lib/types/components/webchatcontainerstateful/interfaces/IRenderingMiddlewareProps.d.ts +1 -0
  44. package/lib/types/components/webchatcontainerstateful/interfaces/IWebChatProps.d.ts +1 -0
  45. package/lib/types/components/webchatcontainerstateful/webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultSentMessageAnchorStyles.d.ts +2 -0
  46. package/lib/types/plugins/createChatTranscript.d.ts +2 -0
  47. package/package.json +3 -3
@@ -7,22 +7,23 @@ exports.default = exports.WebChatContainerStateful = void 0;
7
7
  var _react = require("@fluentui/react");
8
8
  var _TelemetryConstants = require("../../common/telemetry/TelemetryConstants");
9
9
  var _react2 = _interopRequireWildcard(require("react"));
10
- var _botframeworkWebchat = require("botframework-webchat");
10
+ var _BotMagicCodeStore = require("./webchatcontroller/BotMagicCodeStore");
11
11
  var _broadcastChannel = require("broadcast-channel");
12
+ var _botframeworkWebchat = require("botframework-webchat");
13
+ var _Constants = require("../../common/Constants");
12
14
  var _LiveChatWidgetActionType = require("../../contexts/common/LiveChatWidgetActionType");
13
15
  var _TelemetryHelper = require("../../common/telemetry/TelemetryHelper");
14
- var _defaultMiddlewareLocalizedTexts = require("./common/defaultProps/defaultMiddlewareLocalizedTexts");
15
- var _defaultWebChatContainerStatefulProps = require("./common/defaultProps/defaultWebChatContainerStatefulProps");
16
- var _utils = require("../../common/utils");
17
- var _ = require("../..");
18
16
  var _WebChatActionType = require("./webchatcontroller/enums/WebChatActionType");
19
17
  var _WebChatStoreLoader = require("./webchatcontroller/WebChatStoreLoader");
20
- var _Constants = require("../../common/Constants");
21
- var _BotMagicCodeStore = require("./webchatcontroller/BotMagicCodeStore");
22
18
  var _defaultAdaptiveCardStyles = require("./common/defaultStyles/defaultAdaptiveCardStyles");
19
+ var _defaultMiddlewareLocalizedTexts = require("./common/defaultProps/defaultMiddlewareLocalizedTexts");
23
20
  var _defaultReceivedMessageAnchorStyles = require("./webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultReceivedMessageAnchorStyles");
24
- var _defaultUserMessageBoxStyles = require("./webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultUserMessageBoxStyles");
25
21
  var _defaultSystemMessageBoxStyles = require("./webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultSystemMessageBoxStyles");
22
+ var _defaultUserMessageBoxStyles = require("./webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultUserMessageBoxStyles");
23
+ var _defaultWebChatContainerStatefulProps = require("./common/defaultProps/defaultWebChatContainerStatefulProps");
24
+ var _utils = require("../../common/utils");
25
+ var _ = require("../..");
26
+ var _defaultSentMessageAnchorStyles = require("./webchatcontroller/middlewares/renderingmiddlewares/defaultStyles/defaultSentMessageAnchorStyles");
26
27
  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); }
27
28
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
28
29
  const broadcastChannelMessageEvent = "message";
@@ -51,7 +52,7 @@ const createMagicCodeSuccessResponse = signin => {
51
52
  };
52
53
  };
53
54
  const WebChatContainerStateful = props => {
54
- var _props$adaptiveCardSt, _props$renderingMiddl, _props$renderingMiddl2, _props$renderingMiddl3, _props$renderingMiddl4, _props$adaptiveCardSt2, _props$renderingMiddl5, _props$renderingMiddl6, _props$renderingMiddl7, _props$renderingMiddl8;
55
+ var _props$adaptiveCardSt, _props$renderingMiddl, _props$renderingMiddl2, _props$renderingMiddl3, _props$renderingMiddl4, _props$adaptiveCardSt2, _props$adaptiveCardSt3, _props$adaptiveCardSt4, _props$renderingMiddl5, _props$renderingMiddl6, _props$renderingMiddl7, _props$renderingMiddl8, _props$renderingMiddl9, _props$renderingMiddl10;
55
56
  const {
56
57
  BasicWebChat
57
58
  } = _botframeworkWebchat.Components;
@@ -132,7 +133,9 @@ const WebChatContainerStateful = props => {
132
133
  max-width: ${(props === null || props === void 0 ? void 0 : (_props$renderingMiddl3 = props.renderingMiddlewareProps) === null || _props$renderingMiddl3 === void 0 ? void 0 : (_props$renderingMiddl4 = _props$renderingMiddl3.systemMessageBoxStyles) === null || _props$renderingMiddl4 === void 0 ? void 0 : _props$renderingMiddl4.maxWidth) ?? (_defaultSystemMessageBoxStyles.defaultSystemMessageBoxStyles === null || _defaultSystemMessageBoxStyles.defaultSystemMessageBoxStyles === void 0 ? void 0 : _defaultSystemMessageBoxStyles.defaultSystemMessageBoxStyles.maxWidth)}
133
134
  }
134
135
 
135
- div[class="ac-textBlock"]>p{color:${(props === null || props === void 0 ? void 0 : (_props$adaptiveCardSt2 = props.adaptiveCardStyles) === null || _props$adaptiveCardSt2 === void 0 ? void 0 : _props$adaptiveCardSt2.color) ?? _defaultAdaptiveCardStyles.defaultAdaptiveCardStyles.color};}
136
+ div[class="ac-textBlock"]>p{color:${(props === null || props === void 0 ? void 0 : (_props$adaptiveCardSt2 = props.adaptiveCardStyles) === null || _props$adaptiveCardSt2 === void 0 ? void 0 : _props$adaptiveCardSt2.color) ?? _defaultAdaptiveCardStyles.defaultAdaptiveCardStyles.color}; white-space:${(props === null || props === void 0 ? void 0 : (_props$adaptiveCardSt3 = props.adaptiveCardStyles) === null || _props$adaptiveCardSt3 === void 0 ? void 0 : _props$adaptiveCardSt3.textWhiteSpace) ?? _defaultAdaptiveCardStyles.defaultAdaptiveCardStyles.textWhiteSpace}}
137
+
138
+ .webchat__stacked-layout__content .ac-actionSet > .ac-pushButton > div {white-space: ${(props === null || props === void 0 ? void 0 : (_props$adaptiveCardSt4 = props.adaptiveCardStyles) === null || _props$adaptiveCardSt4 === void 0 ? void 0 : _props$adaptiveCardSt4.buttonWhiteSpace) ?? _defaultAdaptiveCardStyles.defaultAdaptiveCardStyles.buttonWhiteSpace} !important;}
136
139
 
137
140
  .ms_lcw_webchat_received_message img.webchat__markdown__external-link-icon {
138
141
  background-image : url() !important;
@@ -152,7 +155,14 @@ const WebChatContainerStateful = props => {
152
155
  .ms_lcw_webchat_received_message a:hover,
153
156
  .ms_lcw_webchat_received_message a:active {
154
157
  color: ${(props === null || props === void 0 ? void 0 : (_props$renderingMiddl7 = props.renderingMiddlewareProps) === null || _props$renderingMiddl7 === void 0 ? void 0 : (_props$renderingMiddl8 = _props$renderingMiddl7.receivedMessageAnchorStyles) === null || _props$renderingMiddl8 === void 0 ? void 0 : _props$renderingMiddl8.color) ?? (_defaultReceivedMessageAnchorStyles.defaultReceivedMessageAnchorStyles === null || _defaultReceivedMessageAnchorStyles.defaultReceivedMessageAnchorStyles === void 0 ? void 0 : _defaultReceivedMessageAnchorStyles.defaultReceivedMessageAnchorStyles.color)};
155
- } `), /*#__PURE__*/_react2.default.createElement(_react.Stack, {
158
+ }
159
+ .ms_lcw_webchat_sent_message a:link,
160
+ .ms_lcw_webchat_sent_message a:visited,
161
+ .ms_lcw_webchat_sent_message a:hover,
162
+ .ms_lcw_webchat_sent_message a:active {
163
+ color: ${(props === null || props === void 0 ? void 0 : (_props$renderingMiddl9 = props.renderingMiddlewareProps) === null || _props$renderingMiddl9 === void 0 ? void 0 : (_props$renderingMiddl10 = _props$renderingMiddl9.sentMessageAnchorStyles) === null || _props$renderingMiddl10 === void 0 ? void 0 : _props$renderingMiddl10.color) ?? (_defaultSentMessageAnchorStyles.defaultSentMessageAnchorStyles === null || _defaultSentMessageAnchorStyles.defaultSentMessageAnchorStyles === void 0 ? void 0 : _defaultSentMessageAnchorStyles.defaultSentMessageAnchorStyles.color)};
164
+ }
165
+ `), /*#__PURE__*/_react2.default.createElement(_react.Stack, {
156
166
  styles: containerStyles
157
167
  }, /*#__PURE__*/_react2.default.createElement(BasicWebChat, null)));
158
168
  };
@@ -6,6 +6,8 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.defaultAdaptiveCardStyles = void 0;
7
7
  const defaultAdaptiveCardStyles = {
8
8
  background: "white",
9
- color: "black"
9
+ color: "black",
10
+ textWhiteSpace: "normal",
11
+ buttonWhiteSpace: "normal"
10
12
  };
11
13
  exports.defaultAdaptiveCardStyles = defaultAdaptiveCardStyles;
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.defaultSentMessageAnchorStyles = void 0;
7
+ const defaultSentMessageAnchorStyles = {
8
+ color: "blue"
9
+ };
10
+ exports.defaultSentMessageAnchorStyles = defaultSentMessageAnchorStyles;
@@ -0,0 +1,548 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ var _utils = require("../common/utils");
8
+ function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
9
+ function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
10
+ function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
11
+ class TranscriptHTMLBuilder {
12
+ // eslint-disable-line @typescript-eslint/no-explicit-any
13
+
14
+ constructor(options) {
15
+ var _this$options, _this$options2, _this$options3, _this$options4, _this$options5, _this$options6, _this$options7, _this$options8, _this$options9, _this$options10, _this$options11;
16
+ _defineProperty(this, "options", void 0);
17
+ _defineProperty(this, "pageTitle", "Customer Transcript");
18
+ _defineProperty(this, "attachmentMessage", "The following attachment was uploaded during the conversation: ");
19
+ _defineProperty(this, "networkOnlineMessage", "Connection restored. Please refresh the page");
20
+ _defineProperty(this, "networkOfflineMessage", "Network Error. Please make sure you are connected to the internet.");
21
+ _defineProperty(this, "transcriptBackgroundColor", "#FFF");
22
+ _defineProperty(this, "agentAvatarBackgroundColor", "#E8E8E8");
23
+ _defineProperty(this, "agentAvatarFontColor", "#000");
24
+ _defineProperty(this, "customerAvatarBackgroundColor", "#2266E3");
25
+ _defineProperty(this, "customerAvatarFontColor", "#FFF");
26
+ _defineProperty(this, "disableMarkdownMessageFormatting", false);
27
+ _defineProperty(this, "disableNewLineMarkdownSupport", false);
28
+ // eslint-disable-line @typescript-eslint/no-explicit-any
29
+ this.options = options;
30
+ if (!this.options || !this.options.messages) {
31
+ this.options.messages = [];
32
+ }
33
+ if ((_this$options = this.options) !== null && _this$options !== void 0 && _this$options.pageTitle) {
34
+ this.pageTitle = this.options.pageTitle;
35
+ }
36
+ if ((_this$options2 = this.options) !== null && _this$options2 !== void 0 && _this$options2.attachmentMessage) {
37
+ this.attachmentMessage = this.options.attachmentMessage;
38
+ }
39
+ if ((_this$options3 = this.options) !== null && _this$options3 !== void 0 && _this$options3.networkOnlineMessage) {
40
+ this.networkOnlineMessage = this.options.networkOnlineMessage;
41
+ }
42
+ if ((_this$options4 = this.options) !== null && _this$options4 !== void 0 && _this$options4.networkOfflineMessage) {
43
+ this.networkOfflineMessage = this.options.networkOfflineMessage;
44
+ }
45
+ if ((_this$options5 = this.options) !== null && _this$options5 !== void 0 && _this$options5.transcriptBackgroundColor) {
46
+ this.transcriptBackgroundColor = this.options.transcriptBackgroundColor;
47
+ }
48
+ if ((_this$options6 = this.options) !== null && _this$options6 !== void 0 && _this$options6.agentAvatarBackgroundColor) {
49
+ this.agentAvatarBackgroundColor = this.options.agentAvatarBackgroundColor;
50
+ }
51
+ if ((_this$options7 = this.options) !== null && _this$options7 !== void 0 && _this$options7.agentAvatarFontColor) {
52
+ this.agentAvatarFontColor = this.options.agentAvatarFontColor;
53
+ }
54
+ if ((_this$options8 = this.options) !== null && _this$options8 !== void 0 && _this$options8.customerAvatarBackgroundColor) {
55
+ this.customerAvatarBackgroundColor = this.options.customerAvatarBackgroundColor;
56
+ }
57
+ if ((_this$options9 = this.options) !== null && _this$options9 !== void 0 && _this$options9.customerAvatarFontColor) {
58
+ this.customerAvatarFontColor = this.options.customerAvatarFontColor;
59
+ }
60
+ if ((_this$options10 = this.options) !== null && _this$options10 !== void 0 && _this$options10.disableMarkdownMessageFormatting) {
61
+ this.disableMarkdownMessageFormatting = this.options.disableMarkdownMessageFormatting;
62
+ }
63
+ if ((_this$options11 = this.options) !== null && _this$options11 !== void 0 && _this$options11.disableNewLineMarkdownSupport) {
64
+ this.disableNewLineMarkdownSupport = this.options.disableNewLineMarkdownSupport;
65
+ }
66
+ }
67
+ createTitleElement() {
68
+ const htmlData = `<title> ${this.pageTitle} </title>`;
69
+ return htmlData;
70
+ }
71
+ createExternalScriptElements() {
72
+ const htmlData = `
73
+ <script src="https://cdn.botframework.com/botframework-webchat/4.15.7/webchat.js"><\/script>
74
+ <script src="https://cdnjs.cloudflare.com/ajax/libs/rxjs/7.8.0/rxjs.umd.min.js" integrity="sha512-v0/YVjBcbjLN6scjmmJN+h86koeB7JhY4/2YeyA5l+rTdtKLv0VbDBNJ32rxJpsaW1QGMd1Z16lsLOSGI38Rbg==" crossorigin="anonymous" referrerpolicy="no-referrer"><\/script>
75
+ <script src="https://unpkg.com/react@18.2.0/umd/react.production.min.js"><\/script>
76
+ <script src="https://unpkg.com/react-dom@18.2.0/umd/react-dom.production.min.js"><\/script>
77
+ <script src="https://cdn.jsdelivr.net/npm/markdown-it@13.0.1/dist/markdown-it.min.js" integrity="sha256-hNyljag6giCsjv/yKmxK8/VeHzvMDvc5u8AzmRvm1BI=" crossorigin="anonymous"><\/script>
78
+ `;
79
+ return htmlData;
80
+ }
81
+ createHeadElement() {
82
+ const htmlData = `
83
+ <head>
84
+ ${this.createTitleElement()}
85
+ ${this.createExternalScriptElements()}
86
+ <script>
87
+ function shareObservable(observable) {
88
+ let observers = [];
89
+ let subscription;
90
+
91
+ return new Observable(observer => {
92
+ if (!subscription) {
93
+ subscription = observable.subscribe({
94
+ complete() {
95
+ observers.forEach(observer => observer.complete());
96
+ },
97
+ error(err) {
98
+ observers.forEach(observer => observer.error(err));
99
+ },
100
+ next(value) {
101
+ observers.forEach(observer => observer.next(value));
102
+ }
103
+ });
104
+ }
105
+
106
+ observers.push(observer);
107
+
108
+ return () => {
109
+ observers = observers.filter(o => o !== observer);
110
+
111
+ if (!observers.length) {
112
+ subscription.unsubscribe();
113
+ subscription = null;
114
+ }
115
+ };
116
+ });
117
+ }
118
+ <\/script>
119
+ <script>
120
+ const messages = ${JSON.stringify(this.options.messages)};
121
+ const disableMarkdownMessageFormatting = ${this.disableMarkdownMessageFormatting};
122
+ const disableNewLineMarkdownSupport = ${this.disableNewLineMarkdownSupport};
123
+ <\/script>
124
+ <script>
125
+ class Translator {
126
+ static convertTranscriptMessageToActivity(message) {
127
+ const {created, isControlMessage, content, tags, from, attachments, amsMetadata, amsReferences} = message;
128
+ const activity = {
129
+ from: {
130
+ role: 'bot'
131
+ },
132
+ type: 'message'
133
+ };
134
+
135
+ // Ignore control messages
136
+ if (isControlMessage) {
137
+ return false;
138
+ }
139
+
140
+ if (tags) {
141
+ const formattedTags = tags.split(',');
142
+
143
+ // Ignore system message
144
+ if (formattedTags.includes('system')) {
145
+ return false;
146
+ }
147
+
148
+ // Ignore hidden message
149
+ if (formattedTags.includes('Hidden')) {
150
+ return false;
151
+ }
152
+ }
153
+
154
+ // Add C1 user display name
155
+ if (from && from.user && from.user.displayName) {
156
+ activity.from.name = from.user.displayName;
157
+ }
158
+
159
+ // Add C2 user display name
160
+ if (from && from.application && from.application.displayName && from.application.displayName === 'Customer') {
161
+ activity.from = {
162
+ role: 'user',
163
+ name: from.application.displayName
164
+ };
165
+ }
166
+
167
+ // Attachments
168
+ if (amsReferences && amsMetadata) {
169
+ const metadata = JSON.parse(amsMetadata);
170
+ const { fileName } = metadata[0];
171
+ const text = \`${this.attachmentMessage}\${fileName}\`;
172
+
173
+ if (message.attachments && message.attachments.length > 0 && message.contentUrl) {
174
+ activity.attachments = message.attachments;
175
+ activity.attachments[0].contentUrl = message.contentUrl;
176
+ activity.attachments[0].thumbnailUrl = message.contentUrl;
177
+ };
178
+
179
+ return {
180
+ ...activity,
181
+ text,
182
+ timestamp: created
183
+ }
184
+ }
185
+
186
+ // Message
187
+ if (content) {
188
+ // Adaptive card formatting
189
+ if (content.includes('"text"') && content.includes('"attachments"') && content.includes('"suggestedActions"')) {
190
+ try {
191
+ const partialActivity = JSON.parse(content);
192
+ return {
193
+ ...activity,
194
+ ...partialActivity,
195
+ timestamp: created
196
+ };
197
+ } catch {
198
+
199
+ }
200
+ }
201
+ }
202
+
203
+ return {
204
+ ...activity,
205
+ text: content,
206
+ timestamp: created
207
+ };
208
+ }
209
+ }
210
+ <\/script>
211
+ <script>
212
+ class TranscriptAdapter {
213
+ constructor() {
214
+ this.connectionStatus$ = new window.rxjs.BehaviorSubject(0); // Uninitialized
215
+ this.activity$ = shareObservable(new Observable((observer) => {
216
+ this.activityObserver = observer;
217
+
218
+ this.connectionStatus$.next(1); // Connecting
219
+ this.connectionStatus$.next(2); // Online
220
+
221
+ // Retrieve messages
222
+ if (messages) {
223
+ setTimeout(() => { // setTimeout is needed due to some WebChat issues
224
+ messages.map((message) => {
225
+ this.activityObserver.next({
226
+ ...Translator.convertTranscriptMessageToActivity(message),
227
+ type: 'message'
228
+ });
229
+ });
230
+ }, 1);
231
+ }
232
+ }));
233
+ }
234
+ }
235
+ <\/script>
236
+ <style>
237
+ body {
238
+ margin: 0;
239
+ }
240
+
241
+ .message-name {
242
+ font-family: Segoe UI,SegoeUI,Helvetica Neue,Helvetica,Arial,sans-serif;
243
+ font-weight: 700;
244
+ font-size: 10px;
245
+ }
246
+
247
+ .message-timestamp {
248
+ font-family: Segoe UI,SegoeUI,Helvetica Neue,Helvetica,Arial,sans-serif;
249
+ font-weight: 500;
250
+ font-size: 10px;
251
+ }
252
+
253
+ .avatar {
254
+ width: 40px;
255
+ height: 40px;
256
+ border-radius: 50%;
257
+ text-align: center;
258
+ }
259
+
260
+ .avatar--bot {
261
+ background-color: ${this.agentAvatarBackgroundColor};
262
+ }
263
+
264
+ .avatar--user {
265
+ background-color: ${this.customerAvatarBackgroundColor};
266
+ }
267
+
268
+ .avatar > p {
269
+ font-weight: 600;
270
+ text-align: center;
271
+ line-height: 0.5;
272
+ font-family: "Segoe UI", Arial, sans-serif;
273
+ }
274
+
275
+ .avatar--bot > p {
276
+ color: ${this.agentAvatarFontColor};
277
+ }
278
+
279
+ .avatar--user > p {
280
+ color: ${this.customerAvatarFontColor};
281
+ }
282
+
283
+ .webchat__bubble__content>div.ms_lcw_webchat_adaptive_card {
284
+ background-color: #FFF;
285
+ }
286
+
287
+ div[class="ac-textBlock"] {
288
+ color: #000 !important;
289
+ }
290
+
291
+ .ms_lcw_webchat_received_message a:link, .ms_lcw_webchat_received_message a:visited, .ms_lcw_webchat_received_message a:hover, .ms_lcw_webchat_received_message a:active {
292
+ color: #FFF;
293
+ }
294
+ <\/style>
295
+ </head>
296
+ `;
297
+ return htmlData;
298
+ }
299
+ createBodyElement() {
300
+ const htmlData = `
301
+ <body>
302
+ <script>
303
+ if (!navigator.onLine) {
304
+ const offlineText = \`${this.networkOfflineMessage}\`;
305
+ document.body.innerHTML = offlineText;
306
+ }
307
+
308
+ window.addEventListener("online", () => {
309
+ document.body.innerHTML = \`${this.networkOnlineMessage} <button onclick="window.location.reload()"> Refresh </button>\`;
310
+ });
311
+ <\/script>
312
+ <div id="transcript"></div>
313
+ <script>
314
+ const getIconText = (text) => {
315
+ if (text) {
316
+ const initials = text.split(/\\s/).reduce((response, word) => response += word.slice(0, 1), '');
317
+ if (initials.length > 1) {
318
+ return initials.substring(0, 2).toUpperCase();
319
+ } else {
320
+ return text.substring(0, 2).toUpperCase();
321
+ }
322
+ }
323
+
324
+ return "";
325
+ }
326
+
327
+ const activityMiddleware = () => (next) => (...args) => {
328
+ const [card] = args;
329
+
330
+ if (card.activity) {
331
+ if (card.activity.from && card.activity.from.role === "channel") {
332
+ return () => false;
333
+ }
334
+
335
+ // Incoming text message
336
+ if (card.activity.text && card.activity.from && card.activity.from.role !== "user") {
337
+ return (...renderArgs) => (React.createElement(
338
+ 'div',
339
+ {className: 'ms_lcw_webchat_received_message'},
340
+ next(...args)(...renderArgs)
341
+ ))
342
+ }
343
+ }
344
+
345
+ return next(...args);
346
+ };
347
+
348
+ const activityStatusMiddleware = () => (next) => (...args) => {
349
+ const [card] = args;
350
+ const {activity} = card;
351
+
352
+ if (activity) {
353
+ const {from, timestamp} = activity;
354
+
355
+ const nameElement = React.createElement(
356
+ 'span',
357
+ {className: 'message-name'},
358
+ from.name
359
+ );
360
+
361
+ const formattedDate = new Date(timestamp);
362
+ const formattedTimeString = formattedDate.toLocaleTimeString("en-us", { year: "numeric", month:"numeric", day:"numeric", hour: "2-digit", minute: "2-digit"});
363
+
364
+ const timestampElement = React.createElement(
365
+ 'span',
366
+ {className: 'message-timestamp'},
367
+ formattedTimeString
368
+ );
369
+
370
+ return from.name && timestamp && React.createElement('span', null, nameElement, ' - ', timestampElement)
371
+ }
372
+
373
+ return next(...args);
374
+ };
375
+
376
+ const avatarMiddleware = () => (next) => (...args) => {
377
+ const [card] = args;
378
+ const {fromUser, activity} = card;
379
+ const initials = getIconText(activity.from.name);
380
+
381
+ const avatarElement = React.createElement(
382
+ "div",
383
+ {className: fromUser? "avatar avatar--user": "avatar avatar--bot"},
384
+ React.createElement(
385
+ "p",
386
+ null,
387
+ \`\${initials}\`
388
+ )
389
+ );
390
+
391
+ return avatarElement;
392
+ }
393
+
394
+ const attachmentMiddleware = () => (next) => (...args) => {
395
+ const [card] = args;
396
+ const {activity} = card;
397
+
398
+ if (activity) {
399
+ const { activity: { attachments }, attachment } = card;
400
+
401
+ // No attachment
402
+ if (!attachments || !attachments.length || !attachment) {
403
+ return next(...args);
404
+ }
405
+
406
+ let { content, contentType } = attachment || { content: "", contentType: "" };
407
+
408
+ // Adaptive card
409
+ if (contentType.startsWith("application/vnd.microsoft.card")) {
410
+ const adaptiveCardElement = React.createElement(
411
+ "div",
412
+ {className: 'ms_lcw_webchat_adaptive_card'},
413
+ next(...args)
414
+ );
415
+
416
+ return adaptiveCardElement;
417
+ }
418
+ }
419
+
420
+ return next(...args);
421
+ }
422
+
423
+ const createMarkdown = (disableMarkdownMessageFormatting, disableNewLineMarkdownSupport) => {
424
+ let markdown;
425
+ if (!disableMarkdownMessageFormatting) {
426
+ markdown = new window.markdownit(
427
+ "default",
428
+ {
429
+ html: true,
430
+ linkify: true,
431
+ breaks: (!disableNewLineMarkdownSupport)
432
+ }
433
+ );
434
+ } else {
435
+ markdown = new window.markdownit(
436
+ "zero",
437
+ {
438
+ html: true,
439
+ linkify: true,
440
+ breaks: (!disableNewLineMarkdownSupport)
441
+ }
442
+ );
443
+
444
+ markdown.enable([
445
+ "entity",
446
+ "linkify",
447
+ "html_block",
448
+ "html_inline",
449
+ "newline"
450
+ ]);
451
+ }
452
+
453
+ return markdown;
454
+ };
455
+
456
+ const markdown = createMarkdown(disableMarkdownMessageFormatting, disableNewLineMarkdownSupport);
457
+ const renderMarkdown = (text) => {
458
+ const render = disableNewLineMarkdownSupport? markdown.renderInline.bind(markdown): markdown.render.bind(markdown);
459
+ text = render(text);
460
+ return text;
461
+ };
462
+
463
+ const adapter = new TranscriptAdapter();
464
+ const styleOptions = {
465
+ hideSendBox: true,
466
+ backgroundColor: '${this.transcriptBackgroundColor}',
467
+ bubbleBackground: '${this.agentAvatarBackgroundColor}',
468
+ bubbleTextColor: '${this.agentAvatarFontColor}',
469
+ bubbleBorderRadius: 12,
470
+ bubbleNubSize: 1,
471
+ bubbleFromUserBackground: '${this.customerAvatarBackgroundColor}',
472
+ bubbleFromUserTextColor: '${this.customerAvatarFontColor}',
473
+ bubbleFromUserBorderRadius: 12,
474
+ bubbleFromUserNubSize: 1,
475
+ botAvatarInitials: 'C1',
476
+ userAvatarInitials: 'C2'
477
+ };
478
+
479
+ window.WebChat.renderWebChat({
480
+ directLine: adapter,
481
+ styleOptions,
482
+ activityMiddleware,
483
+ activityStatusMiddleware,
484
+ avatarMiddleware,
485
+ attachmentMiddleware,
486
+ renderMarkdown
487
+ },
488
+ document.getElementById('transcript'));
489
+ <\/script>
490
+ </body>
491
+ `;
492
+ return htmlData;
493
+ }
494
+ createHTML() {
495
+ const htmlData = `
496
+ <html>
497
+ ${this.createHeadElement()}
498
+ ${this.createBodyElement()}
499
+ </html>
500
+ `;
501
+ return htmlData;
502
+ }
503
+ }
504
+ const createChatTranscript = async function (transcript, chatSDK) {
505
+ let renderAttachments = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
506
+ let transcriptOptions = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : {};
507
+ // eslint-disable-line @typescript-eslint/no-explicit-any
508
+ const transcriptMessages = JSON.parse(transcript);
509
+ const convertBlobToBase64 = async blob => {
510
+ return new Promise(resolve => {
511
+ const reader = new FileReader();
512
+ reader.onloadend = () => resolve(reader.result);
513
+ reader.readAsDataURL(blob);
514
+ });
515
+ };
516
+ let messages = transcriptMessages;
517
+ if (renderAttachments) {
518
+ messages = await Promise.all(transcriptMessages.map(async message => {
519
+ // eslint-disable-line @typescript-eslint/no-explicit-any
520
+ const {
521
+ amsReferences,
522
+ amsMetadata
523
+ } = message;
524
+ if (amsReferences && amsMetadata) {
525
+ const references = JSON.parse(amsReferences);
526
+ const metadata = JSON.parse(amsMetadata);
527
+ const fileMetadata = {
528
+ id: references[0],
529
+ type: metadata[0].contentType
530
+ };
531
+ const blob = await chatSDK.downloadFileAttachment(fileMetadata);
532
+ const base64 = await convertBlobToBase64(blob);
533
+ message.contentUrl = base64;
534
+ }
535
+ return message;
536
+ }));
537
+ }
538
+ const options = {
539
+ ...transcriptOptions,
540
+ messages
541
+ };
542
+ const htmlBuilder = new TranscriptHTMLBuilder(options);
543
+ const text = htmlBuilder.createHTML();
544
+ const fileName = `${transcriptOptions.fileName || "transcript"}.html`;
545
+ (0, _utils.createFileAndDownload)(fileName, text, "text/html");
546
+ };
547
+ var _default = createChatTranscript;
548
+ exports.default = _default;
@@ -143,6 +143,7 @@ _defineProperty(HtmlAttributeNames, "listItem", "LI");
143
143
  _defineProperty(HtmlAttributeNames, "unorderedList", "UL");
144
144
  _defineProperty(HtmlAttributeNames, "div", "div");
145
145
  _defineProperty(HtmlAttributeNames, "aTagName", "a");
146
+ _defineProperty(HtmlAttributeNames, "pTagName", "p");
146
147
  _defineProperty(HtmlAttributeNames, "noopenerTag", "noopener");
147
148
  _defineProperty(HtmlAttributeNames, "noreferrerTag", "noreferrer");
148
149
  _defineProperty(HtmlAttributeNames, "adaptiveCardClassName", "ac-adaptiveCard");