botframework-webchat-component 4.15.0 → 4.15.2-main.20220413.d89850f

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 (125) hide show
  1. package/lib/Activity/CarouselLayout.js +3 -3
  2. package/lib/Activity/Speak.d.ts +2 -2
  3. package/lib/Activity/Speak.d.ts.map +1 -1
  4. package/lib/Activity/Speak.js +14 -7
  5. package/lib/Activity/StackedLayout.d.ts +5 -3
  6. package/lib/Activity/StackedLayout.d.ts.map +1 -1
  7. package/lib/Activity/StackedLayout.js +15 -20
  8. package/lib/Attachment/FileContent.js +2 -2
  9. package/lib/BasicSendBox.d.ts.map +1 -1
  10. package/lib/BasicSendBox.js +7 -8
  11. package/lib/BasicToast.js +1 -1
  12. package/lib/BasicToaster.js +1 -1
  13. package/lib/BasicTranscript.d.ts.map +1 -1
  14. package/lib/BasicTranscript.js +30 -15
  15. package/lib/BasicTypingIndicator.js +1 -1
  16. package/lib/Composer.js +3 -3
  17. package/lib/ConnectivityStatus/Connecting.js +1 -1
  18. package/lib/Dictation.js +1 -1
  19. package/lib/Middleware/Activity/createCoreMiddleware.d.ts.map +1 -1
  20. package/lib/Middleware/Activity/createCoreMiddleware.js +9 -12
  21. package/lib/Middleware/ActivityStatus/SendStatus/SendFailedRetry.js +1 -1
  22. package/lib/Middleware/ActivityStatus/SendStatus/SendStatus.d.ts +2 -2
  23. package/lib/Middleware/ActivityStatus/SendStatus/SendStatus.d.ts.map +1 -1
  24. package/lib/Middleware/ActivityStatus/SendStatus/SendStatus.js +4 -3
  25. package/lib/Middleware/ActivityStatus/Timestamp.d.ts +2 -2
  26. package/lib/Middleware/ActivityStatus/Timestamp.d.ts.map +1 -1
  27. package/lib/Middleware/ActivityStatus/Timestamp.js +4 -2
  28. package/lib/Middleware/ActivityStatus/createSendStatusMiddleware.js +2 -2
  29. package/lib/ReactWebChat.js +2 -2
  30. package/lib/ScreenReaderActivity.js +1 -1
  31. package/lib/ScreenReaderText.js +1 -1
  32. package/lib/SendBox/AutoResizeTextArea.js +1 -1
  33. package/lib/SendBox/IconButton.js +1 -1
  34. package/lib/SendBox/MicrophoneButton.js +1 -1
  35. package/lib/SendBox/SendButton.js +1 -1
  36. package/lib/SendBox/SuggestedAction.js +2 -2
  37. package/lib/SendBox/SuggestedActions.js +2 -2
  38. package/lib/SendBox/TextBox.js +3 -3
  39. package/lib/SendBox/UploadButton.js +3 -3
  40. package/lib/Styles/StyleSet/Bubble.js +2 -2
  41. package/lib/Styles/StyleSet/CarouselFilmStrip.js +2 -2
  42. package/lib/Styles/StyleSet/CarouselFilmStripAttachment.js +2 -2
  43. package/lib/Styles/createStyleSet.d.ts +1 -1
  44. package/lib/Styles/createStyleSet.js +2 -2
  45. package/lib/Transcript/ActivityRow.d.ts +2 -2
  46. package/lib/Transcript/ActivityRow.d.ts.map +1 -1
  47. package/lib/Transcript/ActivityRow.js +4 -2
  48. package/lib/Transcript/ActivityTextAlt.js +1 -1
  49. package/lib/Transcript/FocusTrap.js +1 -1
  50. package/lib/Transcript/KeyboardHelp.js +1 -1
  51. package/lib/Transcript/LiveRegionTranscript.d.ts.map +1 -1
  52. package/lib/Transcript/LiveRegionTranscript.js +22 -7
  53. package/lib/Transcript/useActivityAccessibleName.d.ts +2 -2
  54. package/lib/Transcript/useActivityAccessibleName.d.ts.map +1 -1
  55. package/lib/Transcript/useActivityAccessibleName.js +2 -2
  56. package/lib/Transcript/useTypistNames.d.ts +3 -0
  57. package/lib/Transcript/useTypistNames.d.ts.map +1 -0
  58. package/lib/Transcript/useTypistNames.js +61 -0
  59. package/lib/Utils/AccessKeySink/Surface.js +1 -1
  60. package/lib/Utils/AccessibleButton.js +1 -1
  61. package/lib/Utils/AccessibleInputText.js +1 -1
  62. package/lib/Utils/AccessibleTextArea.js +1 -1
  63. package/lib/Utils/CroppedImage.js +1 -1
  64. package/lib/Utils/FocusRedirector.js +1 -1
  65. package/lib/Utils/InlineMarkdown.js +3 -3
  66. package/lib/Utils/TypeFocusSink/FocusBox.js +1 -1
  67. package/lib/Utils/addTargetBlankToHyperlinksMarkdown.js +2 -2
  68. package/lib/Utils/downscaleImageToDataURL/index.js +1 -1
  69. package/lib/Utils/getActivityUniqueId.js +1 -1
  70. package/lib/connectToWebChat.js +2 -2
  71. package/lib/hooks/internal/BypassSpeechSynthesisPonyfill.js +3 -3
  72. package/lib/hooks/internal/useMemoize.d.ts +1 -1
  73. package/lib/hooks/internal/useMemoize.d.ts.map +1 -1
  74. package/lib/hooks/internal/useMemoize.js +1 -1
  75. package/lib/hooks/useObserveTranscriptFocus.d.ts +2 -2
  76. package/lib/hooks/useObserveTranscriptFocus.d.ts.map +1 -1
  77. package/lib/hooks/useObserveTranscriptFocus.js +1 -1
  78. package/lib/hooks/useSendFiles.d.ts.map +1 -1
  79. package/lib/hooks/useSendFiles.js +4 -4
  80. package/lib/index.d.ts +3 -3
  81. package/lib/index.js +5 -5
  82. package/lib/providers/ActivityTree/ActivityTreeComposer.d.ts.map +1 -1
  83. package/lib/providers/ActivityTree/ActivityTreeComposer.js +2 -2
  84. package/lib/providers/ActivityTree/private/types.d.ts +2 -2
  85. package/lib/providers/ActivityTree/private/types.d.ts.map +1 -1
  86. package/lib/providers/ActivityTree/private/useActivitiesWithRenderer.d.ts +2 -2
  87. package/lib/providers/ActivityTree/private/useActivitiesWithRenderer.d.ts.map +1 -1
  88. package/lib/providers/ActivityTree/private/useActivitiesWithRenderer.js +1 -1
  89. package/lib/providers/ActivityTree/private/useActivityTreeWithRenderer.d.ts.map +1 -1
  90. package/lib/providers/ActivityTree/private/useActivityTreeWithRenderer.js +1 -1
  91. package/lib/providers/LiveRegionTwin/LiveRegionTwinComposer.d.ts +2 -0
  92. package/lib/providers/LiveRegionTwin/LiveRegionTwinComposer.d.ts.map +1 -1
  93. package/lib/providers/LiveRegionTwin/LiveRegionTwinComposer.js +10 -6
  94. package/lib/providers/LiveRegionTwin/private/LiveRegionTwinContainer.d.ts +1 -0
  95. package/lib/providers/LiveRegionTwin/private/LiveRegionTwinContainer.d.ts.map +1 -1
  96. package/lib/providers/LiveRegionTwin/private/LiveRegionTwinContainer.js +22 -8
  97. package/lib/providers/TranscriptFocus/TranscriptFocusComposer.js +1 -1
  98. package/package.json +24 -20
  99. package/src/Activity/Speak.tsx +21 -18
  100. package/src/Activity/StackedLayout.tsx +20 -26
  101. package/src/Attachment/FileContent.tsx +1 -1
  102. package/src/BasicSendBox.tsx +3 -2
  103. package/src/BasicTranscript.tsx +29 -13
  104. package/src/Middleware/Activity/createCoreMiddleware.tsx +5 -10
  105. package/src/Middleware/ActivityStatus/SendStatus/SendStatus.tsx +5 -3
  106. package/src/Middleware/ActivityStatus/Timestamp.tsx +5 -3
  107. package/src/SendBox/SuggestedAction.tsx +1 -1
  108. package/src/SendBox/SuggestedActions.tsx +1 -1
  109. package/src/Transcript/ActivityRow.tsx +4 -5
  110. package/src/Transcript/ActivityTextAlt.tsx +2 -3
  111. package/src/Transcript/LiveRegionTranscript.tsx +27 -12
  112. package/src/Transcript/useActivityAccessibleName.ts +3 -4
  113. package/src/Transcript/useTypistNames.ts +37 -0
  114. package/src/Utils/getActivityUniqueId.ts +2 -2
  115. package/src/hooks/internal/useMemoize.ts +6 -6
  116. package/src/hooks/useObserveTranscriptFocus.ts +2 -2
  117. package/src/hooks/useSendFiles.ts +7 -5
  118. package/src/providers/ActivityTree/ActivityTreeComposer.tsx +2 -2
  119. package/src/providers/ActivityTree/private/types.ts +2 -2
  120. package/src/providers/ActivityTree/private/useActivitiesWithRenderer.ts +4 -6
  121. package/src/providers/ActivityTree/private/useActivityTreeWithRenderer.ts +6 -11
  122. package/src/providers/LiveRegionTwin/LiveRegionTwinComposer.tsx +10 -3
  123. package/src/providers/LiveRegionTwin/private/LiveRegionTwinContainer.tsx +22 -6
  124. package/lib/Middleware/GroupActivities/createCoreMiddleware.js +0 -69
  125. package/src/Middleware/GroupActivities/createCoreMiddleware.js +0 -57
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
4
 
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
@@ -31,9 +31,9 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
31
31
 
32
32
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
33
33
 
34
- function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
34
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
35
35
 
36
- function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
36
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
37
37
 
38
38
  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; }
39
39
 
@@ -1,8 +1,8 @@
1
- import { DirectLineActivity } from 'botframework-webchat-core';
2
1
  import { FC } from 'react';
2
+ import type { WebChatActivity } from 'botframework-webchat-core';
3
3
  declare const connectSpeakActivity: (...selectors: any[]) => any;
4
4
  declare type SpeakProps = {
5
- activity: DirectLineActivity;
5
+ activity: WebChatActivity;
6
6
  };
7
7
  declare const Speak: FC<SpeakProps>;
8
8
  export default Speak;
@@ -1 +1 @@
1
- {"version":3,"file":"Speak.d.ts","sourceRoot":"","sources":["../../src/Activity/Speak.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAG/D,OAAc,EAAE,EAAE,EAAwB,MAAM,OAAO,CAAC;AAYxD,QAAA,MAAM,oBAAoB,8BAQvB,CAAC;AAEJ,aAAK,UAAU,GAAG;IAChB,QAAQ,EAAE,kBAAkB,CAAC;CAC9B,CAAC;AAEF,QAAA,MAAM,KAAK,EAAE,EAAE,CAAC,UAAU,CAyCzB,CAAC;AAoBF,eAAe,KAAK,CAAC;AAErB,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
1
+ {"version":3,"file":"Speak.d.ts","sourceRoot":"","sources":["../../src/Activity/Speak.tsx"],"names":[],"mappings":"AAEA,OAAc,EAAE,EAAE,EAAwB,MAAM,OAAO,CAAC;AAExD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAWjE,QAAA,MAAM,oBAAoB,8BAQvB,CAAC;AAEJ,aAAK,UAAU,GAAG;IAChB,QAAQ,EAAE,eAAe,CAAC;CAC3B,CAAC;AAEF,QAAA,MAAM,KAAK,EAAE,EAAE,CAAC,UAAU,CAyCzB,CAAC;AAuBF,eAAe,KAAK,CAAC;AAErB,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
4
 
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
@@ -76,6 +76,8 @@ var connectSpeakActivity = function connectSpeakActivity() {
76
76
  exports.connectSpeakActivity = connectSpeakActivity;
77
77
 
78
78
  var Speak = function Speak(_ref3) {
79
+ var _activity$channelData;
80
+
79
81
  var activity = _ref3.activity;
80
82
 
81
83
  var _useStyleOptions = useStyleOptions(),
@@ -88,11 +90,15 @@ var Speak = function Speak(_ref3) {
88
90
  markActivityAsSpoken(activity);
89
91
  }, [activity, markActivityAsSpoken]);
90
92
  var singleLine = (0, _react.useMemo)(function () {
93
+ if (activity.type !== 'message') {
94
+ return false;
95
+ }
96
+
91
97
  var _activity$attachments = activity.attachments,
92
98
  attachments = _activity$attachments === void 0 ? [] : _activity$attachments,
93
99
  speak = activity.speak,
94
100
  text = activity.text;
95
- return !!activity && [speak || text].concat(_toConsumableArray(attachments.filter(function (_ref4) {
101
+ return [speak || text].concat(_toConsumableArray(attachments.filter(function (_ref4) {
96
102
  var contentType = _ref4.contentType;
97
103
  return contentType === 'application/vnd.microsoft.card.adaptive';
98
104
  }).map(function (attachment) {
@@ -103,9 +109,7 @@ var Speak = function Speak(_ref3) {
103
109
  return line;
104
110
  }).join('\r\n');
105
111
  }, [activity]);
106
- var _activity$channelData = activity.channelData;
107
- _activity$channelData = _activity$channelData === void 0 ? {} : _activity$channelData;
108
- var speechSynthesisUtterance = _activity$channelData.speechSynthesisUtterance;
112
+ var speechSynthesisUtterance = activity.type === 'message' && ((_activity$channelData = activity.channelData) === null || _activity$channelData === void 0 ? void 0 : _activity$channelData.speechSynthesisUtterance);
109
113
  return !!activity && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, speechSynthesisUtterance ? /*#__PURE__*/_react.default.createElement(_reactSay.SayUtterance, {
110
114
  onEnd: markAsSpoken,
111
115
  onError: markAsSpoken,
@@ -121,6 +125,8 @@ var Speak = function Speak(_ref3) {
121
125
  };
122
126
 
123
127
  Speak.propTypes = {
128
+ // PropTypes cannot fully capture TypeScript types.
129
+ // @ts-ignore
124
130
  activity: _propTypes.default.shape({
125
131
  attachments: _propTypes.default.arrayOf(_propTypes.default.shape({
126
132
  speak: _propTypes.default.string,
@@ -132,9 +138,10 @@ Speak.propTypes = {
132
138
  speechSynthesisUtterance: _propTypes.default.any
133
139
  }),
134
140
  speak: _propTypes.default.string,
135
- text: _propTypes.default.string
141
+ text: _propTypes.default.string,
142
+ type: _propTypes.default.string.isRequired
136
143
  }).isRequired
137
144
  };
138
145
  var _default = Speak;
139
146
  exports.default = _default;
140
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Activity/Speak.tsx"],"names":["useMarkActivityAsSpoken","hooks","useStyleOptions","useVoiceSelector","connectSpeakActivity","selectors","connectToWebChat","language","markActivity","selectVoice","activity","markAsSpoken","voices","Speak","showSpokenText","markActivityAsSpoken","singleLine","attachments","speak","text","filter","contentType","map","attachment","content","line","join","channelData","speechSynthesisUtterance","propTypes","PropTypes","shape","arrayOf","string","subtitle","title","any","isRequired"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["import { DirectLineActivity } from 'botframework-webchat-core';\nimport { hooks } from 'botframework-webchat-api';\nimport PropTypes from 'prop-types';\nimport React, { FC, useCallback, useMemo } from 'react';\nimport Say, { SayUtterance } from 'react-say';\n\nimport connectToWebChat from '../connectToWebChat';\nimport SayAlt from './SayAlt';\n\nconst { useMarkActivityAsSpoken, useStyleOptions, useVoiceSelector } = hooks;\n\n// TODO: [P4] Consider moving this feature into BasicActivity\n//       And it has better DOM position for showing visual spoken text\n\n// TODO: [P3] We should add a \"spoken\" or \"speakState\" flag to indicate whether this activity is going to speak, or spoken\nconst connectSpeakActivity = (...selectors) =>\n  connectToWebChat(\n    ({ language, markActivity, selectVoice }, { activity }) => ({\n      language,\n      markAsSpoken: () => markActivity(activity, 'speak', false),\n      selectVoice: voices => selectVoice(voices, activity)\n    }),\n    ...selectors\n  );\n\ntype SpeakProps = {\n  activity: DirectLineActivity;\n};\n\nconst Speak: FC<SpeakProps> = ({ activity }) => {\n  const [{ showSpokenText }] = useStyleOptions();\n  const markActivityAsSpoken = useMarkActivityAsSpoken();\n  const selectVoice = useVoiceSelector(activity);\n\n  const markAsSpoken = useCallback(() => {\n    markActivityAsSpoken(activity);\n  }, [activity, markActivityAsSpoken]);\n\n  const singleLine = useMemo(() => {\n    const { attachments = [], speak, text } = activity;\n\n    return (\n      !!activity &&\n      [\n        speak || text,\n        ...attachments\n          .filter(({ contentType }) => contentType === 'application/vnd.microsoft.card.adaptive')\n          .map(attachment => attachment?.content?.speak)\n      ]\n        .filter(line => line)\n        .join('\\r\\n')\n    );\n  }, [activity]);\n\n  const {\n    channelData: { speechSynthesisUtterance } = {}\n  }: { channelData: { speechSynthesisUtterance?: SpeechSynthesisUtterance } } = activity;\n\n  return (\n    !!activity && (\n      <React.Fragment>\n        {speechSynthesisUtterance ? (\n          <SayUtterance onEnd={markAsSpoken} onError={markAsSpoken} utterance={speechSynthesisUtterance} />\n        ) : (\n          <Say onEnd={markAsSpoken} onError={markAsSpoken} text={singleLine} voice={selectVoice} />\n        )}\n        {!!showSpokenText && <SayAlt speak={singleLine} />}\n      </React.Fragment>\n    )\n  );\n};\n\nSpeak.propTypes = {\n  activity: PropTypes.shape({\n    attachments: PropTypes.arrayOf(\n      PropTypes.shape({\n        speak: PropTypes.string,\n        subtitle: PropTypes.string,\n        text: PropTypes.string,\n        title: PropTypes.string\n      })\n    ),\n    channelData: PropTypes.shape({\n      speechSynthesisUtterance: PropTypes.any\n    }),\n    speak: PropTypes.string,\n    text: PropTypes.string\n  }).isRequired\n};\n\nexport default Speak;\n\nexport { connectSpeakActivity };\n"]}
147
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Activity/Speak.tsx"],"names":["useMarkActivityAsSpoken","hooks","useStyleOptions","useVoiceSelector","connectSpeakActivity","selectors","connectToWebChat","language","markActivity","selectVoice","activity","markAsSpoken","voices","Speak","showSpokenText","markActivityAsSpoken","singleLine","type","attachments","speak","text","filter","contentType","map","attachment","content","line","join","speechSynthesisUtterance","channelData","propTypes","PropTypes","shape","arrayOf","string","subtitle","title","any","isRequired"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["import { hooks } from 'botframework-webchat-api';\nimport PropTypes from 'prop-types';\nimport React, { FC, useCallback, useMemo } from 'react';\nimport Say, { SayUtterance } from 'react-say';\nimport type { WebChatActivity } from 'botframework-webchat-core';\n\nimport connectToWebChat from '../connectToWebChat';\nimport SayAlt from './SayAlt';\n\nconst { useMarkActivityAsSpoken, useStyleOptions, useVoiceSelector } = hooks;\n\n// TODO: [P4] Consider moving this feature into BasicActivity\n//       And it has better DOM position for showing visual spoken text\n\n// TODO: [P3] We should add a \"spoken\" or \"speakState\" flag to indicate whether this activity is going to speak, or spoken\nconst connectSpeakActivity = (...selectors) =>\n  connectToWebChat(\n    ({ language, markActivity, selectVoice }, { activity }) => ({\n      language,\n      markAsSpoken: () => markActivity(activity, 'speak', false),\n      selectVoice: voices => selectVoice(voices, activity)\n    }),\n    ...selectors\n  );\n\ntype SpeakProps = {\n  activity: WebChatActivity;\n};\n\nconst Speak: FC<SpeakProps> = ({ activity }) => {\n  const [{ showSpokenText }] = useStyleOptions();\n  const markActivityAsSpoken = useMarkActivityAsSpoken();\n  const selectVoice = useVoiceSelector(activity);\n\n  const markAsSpoken = useCallback(() => {\n    markActivityAsSpoken(activity);\n  }, [activity, markActivityAsSpoken]);\n\n  const singleLine: false | string = useMemo(() => {\n    if (activity.type !== 'message') {\n      return false;\n    }\n\n    const { attachments = [], speak, text } = activity;\n\n    return [\n      speak || text,\n      ...attachments\n        .filter(({ contentType }) => contentType === 'application/vnd.microsoft.card.adaptive')\n        .map(attachment => attachment?.content?.speak)\n    ]\n      .filter(line => line)\n      .join('\\r\\n');\n  }, [activity]);\n\n  const speechSynthesisUtterance: false | SpeechSynthesisUtterance | undefined =\n    activity.type === 'message' && activity.channelData?.speechSynthesisUtterance;\n\n  return (\n    !!activity && (\n      <React.Fragment>\n        {speechSynthesisUtterance ? (\n          <SayUtterance onEnd={markAsSpoken} onError={markAsSpoken} utterance={speechSynthesisUtterance} />\n        ) : (\n          <Say onEnd={markAsSpoken} onError={markAsSpoken} text={singleLine} voice={selectVoice} />\n        )}\n        {!!showSpokenText && <SayAlt speak={singleLine} />}\n      </React.Fragment>\n    )\n  );\n};\n\nSpeak.propTypes = {\n  // PropTypes cannot fully capture TypeScript types.\n  // @ts-ignore\n  activity: PropTypes.shape({\n    attachments: PropTypes.arrayOf(\n      PropTypes.shape({\n        speak: PropTypes.string,\n        subtitle: PropTypes.string,\n        text: PropTypes.string,\n        title: PropTypes.string\n      })\n    ),\n    channelData: PropTypes.shape({\n      speechSynthesisUtterance: PropTypes.any\n    }),\n    speak: PropTypes.string,\n    text: PropTypes.string,\n    type: PropTypes.string.isRequired\n  }).isRequired\n};\n\nexport default Speak;\n\nexport { connectSpeakActivity };\n"]}
@@ -1,15 +1,17 @@
1
- import { DirectLineActivity } from 'botframework-webchat-core';
2
1
  import { RenderAttachment } from 'botframework-webchat-api';
3
2
  import { FC, ReactNode } from 'react';
3
+ import type { WebChatActivity } from 'botframework-webchat-core';
4
4
  declare const connectStackedLayout: (...selectors: any[]) => any;
5
5
  declare type StackedLayoutProps = {
6
- activity: DirectLineActivity;
6
+ activity: WebChatActivity;
7
7
  hideTimestamp?: boolean;
8
8
  renderActivityStatus?: (({ hideTimestamp: boolean }: {
9
9
  hideTimestamp: any;
10
10
  }) => Exclude<ReactNode, boolean | null | undefined>) | false;
11
11
  renderAttachment?: RenderAttachment;
12
- renderAvatar?: (activity: DirectLineActivity) => (() => Exclude<ReactNode, boolean | null | undefined>) | false;
12
+ renderAvatar?: ({ activity: WebChatActivity }: {
13
+ activity: any;
14
+ }) => (() => Exclude<ReactNode, boolean | null | undefined>) | false;
13
15
  showCallout?: boolean;
14
16
  };
15
17
  declare const StackedLayout: FC<StackedLayoutProps>;
@@ -1 +1 @@
1
- {"version":3,"file":"StackedLayout.d.ts","sourceRoot":"","sources":["../../src/Activity/StackedLayout.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAS,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAGnE,OAAc,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AA+D7C,QAAA,MAAM,oBAAoB,8BAmBvB,CAAC;AAEJ,aAAK,kBAAkB,GAAG;IACxB,QAAQ,EAAE,kBAAkB,CAAC;IAC7B,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,oBAAoB,CAAC,EAAE,CAAC,CAAC,EAAE,aAAa,EAAE,OAAO,EAAE;;KAAA,KAAK,OAAO,CAAC,SAAS,EAAE,OAAO,GAAG,IAAI,GAAG,SAAS,CAAC,CAAC,GAAG,KAAK,CAAC;IAChH,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;IACpC,YAAY,CAAC,EAAE,CAAC,QAAQ,EAAE,kBAAkB,KAAK,CAAC,MAAM,OAAO,CAAC,SAAS,EAAE,OAAO,GAAG,IAAI,GAAG,SAAS,CAAC,CAAC,GAAG,KAAK,CAAC;IAChH,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB,CAAC;AAEF,QAAA,MAAM,aAAa,EAAE,EAAE,CAAC,kBAAkB,CA2IzC,CAAC;AAsCF,eAAe,aAAa,CAAC;AAE7B,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
1
+ {"version":3,"file":"StackedLayout.d.ts","sourceRoot":"","sources":["../../src/Activity/StackedLayout.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAS,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAGnE,OAAc,EAAE,EAAE,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAC7C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;AA+DjE,QAAA,MAAM,oBAAoB,8BAmBvB,CAAC;AAEJ,aAAK,kBAAkB,GAAG;IACxB,QAAQ,EAAE,eAAe,CAAC;IAC1B,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,oBAAoB,CAAC,EAAE,CAAC,CAAC,EAAE,aAAa,EAAE,OAAO,EAAE;;KAAA,KAAK,OAAO,CAAC,SAAS,EAAE,OAAO,GAAG,IAAI,GAAG,SAAS,CAAC,CAAC,GAAG,KAAK,CAAC;IAChH,gBAAgB,CAAC,EAAE,gBAAgB,CAAC;IACpC,YAAY,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAE,eAAe,EAAE;;KAAA,KAAK,CAAC,MAAM,OAAO,CAAC,SAAS,EAAE,OAAO,GAAG,IAAI,GAAG,SAAS,CAAC,CAAC,GAAG,KAAK,CAAC;IACjH,WAAW,CAAC,EAAE,OAAO,CAAC;CACvB,CAAC;AAEF,QAAA,MAAM,aAAa,EAAE,EAAE,CAAC,kBAAkB,CAmIzC,CAAC;AAwCF,eAAe,aAAa,CAAC;AAE7B,OAAO,EAAE,oBAAoB,EAAE,CAAC"}
@@ -115,6 +115,8 @@ var connectStackedLayout = function connectStackedLayout() {
115
115
  exports.connectStackedLayout = connectStackedLayout;
116
116
 
117
117
  var StackedLayout = function StackedLayout(_ref3) {
118
+ var _activity$channelData, _activity$channelData2;
119
+
118
120
  var activity = _ref3.activity,
119
121
  hideTimestamp = _ref3.hideTimestamp,
120
122
  renderActivityStatus = _ref3.renderActivityStatus,
@@ -145,20 +147,11 @@ var StackedLayout = function StackedLayout(_ref3) {
145
147
  bubbleNubSize = styleOptions.bubbleNubSize,
146
148
  bubbleFromUserNubOffset = styleOptions.bubbleFromUserNubOffset,
147
149
  bubbleFromUserNubSize = styleOptions.bubbleFromUserNubSize;
148
- var _activity$attachments = activity.attachments,
149
- attachments = _activity$attachments === void 0 ? [] : _activity$attachments,
150
- _activity$channelData = activity.channelData;
151
- _activity$channelData = _activity$channelData === void 0 ? {} : _activity$channelData;
152
- var _activity$channelData2 = _activity$channelData.messageBack;
153
- _activity$channelData2 = _activity$channelData2 === void 0 ? {} : _activity$channelData2;
154
- var messageBackDisplayText = _activity$channelData2.displayText,
155
- _activity$from = activity.from;
156
- _activity$from = _activity$from === void 0 ? {} : _activity$from;
157
- var role = _activity$from.role,
158
- text = activity.text,
159
- textFormat = activity.textFormat;
160
- var activityDisplayText = messageBackDisplayText || text;
161
- var fromUser = role === 'user';
150
+ var isMessage = activity.type === 'message';
151
+ var attachments = isMessage && activity.attachments || [];
152
+ var fromUser = activity.from.role === 'user';
153
+ var messageBackDisplayText = isMessage && ((_activity$channelData = activity.channelData) === null || _activity$channelData === void 0 ? void 0 : (_activity$channelData2 = _activity$channelData.messageBack) === null || _activity$channelData2 === void 0 ? void 0 : _activity$channelData2.displayText) || '';
154
+ var activityDisplayText = isMessage ? messageBackDisplayText || activity.text : '';
162
155
  var attachedAlt = localize(fromUser ? 'ACTIVITY_YOU_ATTACHED_ALT' : 'ACTIVITY_BOT_ATTACHED_ALT');
163
156
  var greetingAlt = (fromUser ? localize('ACTIVITY_YOU_SAID_ALT') : localize('ACTIVITY_BOT_SAID_ALT', botInitials || '')).replace(/[\t-\r \xA0\u1680\u2000-\u200A\u2028\u2029\u202F\u205F\u3000\uFEFF]{2,}/g, ' ');
164
157
  var initials = fromUser ? userInitials : botInitials;
@@ -174,7 +167,7 @@ var StackedLayout = function StackedLayout(_ref3) {
174
167
  var extraTrailing = !hasOtherAvatar && hasOtherNub; // This is for bot message with user nub and no user avatar. And vice versa.
175
168
 
176
169
  var showAvatar = showCallout && hasAvatar && !!renderAvatar;
177
- var showNub = showCallout && hasNub && (topAlignedCallout || !attachments.length);
170
+ var showNub = showCallout && hasNub && (topAlignedCallout || !(attachments !== null && attachments !== void 0 && attachments.length));
178
171
  return /*#__PURE__*/_react.default.createElement("div", {
179
172
  "aria-labelledby": activityDisplayText ? ariaLabelId : undefined,
180
173
  "aria-roledescription": "activity",
@@ -213,10 +206,10 @@ var StackedLayout = function StackedLayout(_ref3) {
213
206
  nub: showNub || (hasAvatar || hasNub ? 'hidden' : false)
214
207
  }, renderAttachment({
215
208
  activity: activity,
216
- attachment: {
209
+ attachment: isMessage ? {
217
210
  content: activityDisplayText,
218
- contentType: (0, _textFormatToContentType.default)(textFormat)
219
- }
211
+ contentType: (0, _textFormatToContentType.default)(activity.textFormat)
212
+ } : undefined
220
213
  }))), attachments.map(function (attachment, index) {
221
214
  return /*#__PURE__*/_react.default.createElement("div", {
222
215
  "aria-roledescription": "attachment",
@@ -264,6 +257,8 @@ StackedLayout.defaultProps = {
264
257
  showCallout: true
265
258
  };
266
259
  StackedLayout.propTypes = {
260
+ // PropTypes cannot fully capture TypeScript types.
261
+ // @ts-ignore
267
262
  activity: _propTypes.default.shape({
268
263
  attachments: _propTypes.default.array,
269
264
  channelData: _propTypes.default.shape({
@@ -275,7 +270,7 @@ StackedLayout.propTypes = {
275
270
  role: _propTypes.default.string.isRequired
276
271
  }).isRequired,
277
272
  text: _propTypes.default.string,
278
- textFormat: _propTypes.default.string,
273
+ textFormat: _propTypes.default.oneOf(['markdown', 'plain', 'xml']),
279
274
  timestamp: _propTypes.default.string,
280
275
  type: _propTypes.default.string.isRequired
281
276
  }).isRequired,
@@ -291,4 +286,4 @@ StackedLayout.propTypes = {
291
286
  };
292
287
  var _default = StackedLayout;
293
288
  exports.default = _default;
294
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Activity/StackedLayout.tsx"],"names":["useAvatarForBot","hooks","useAvatarForUser","useLocalizer","useStyleOptions","ROOT_STYLE","position","display","flexShrink","width","flexDirection","flex","overflow","connectStackedLayout","selectors","connectToWebChat","language","styleSet","options","botAvatarInitials","userAvatarInitials","activity","from","role","undefined","avatarInitials","StackedLayout","hideTimestamp","renderActivityStatus","renderAttachment","renderAvatar","showCallout","styleOptions","botInitials","initials","userInitials","stackedLayoutStyleSet","stackedLayout","ariaLabelId","localize","rootClassName","bubbleNubOffset","bubbleNubSize","bubbleFromUserNubOffset","bubbleFromUserNubSize","attachments","channelData","messageBack","messageBackDisplayText","displayText","text","textFormat","activityDisplayText","fromUser","attachedAlt","greetingAlt","replace","nubOffset","nubSize","otherInitials","otherNubSize","hasAvatar","hasOtherAvatar","hasNub","hasOtherNub","topAlignedCallout","extraTrailing","showAvatar","showNub","length","attachment","content","contentType","map","index","defaultProps","propTypes","PropTypes","shape","array","string","isRequired","timestamp","type","bool","oneOfType","oneOf","func"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["/* eslint complexity: [\"error\", 30] */\n\nimport { DirectLineActivity } from 'botframework-webchat-core';\nimport { hooks, RenderAttachment } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, { FC, ReactNode } from 'react';\n\nimport Bubble from './Bubble';\nimport connectToWebChat from '../connectToWebChat';\nimport isZeroOrPositive from '../Utils/isZeroOrPositive';\nimport ScreenReaderText from '../ScreenReaderText';\nimport textFormatToContentType from '../Utils/textFormatToContentType';\nimport useStyleSet from '../hooks/useStyleSet';\nimport useStyleToEmotionObject from '../hooks/internal/useStyleToEmotionObject';\n\nimport useUniqueId from '../hooks/internal/useUniqueId';\n\nconst { useAvatarForBot, useAvatarForUser, useLocalizer, useStyleOptions } = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__stacked-layout': {\n    position: 'relative', // This is to keep screen reader text in the destinated area.\n\n    '& .webchat__stacked-layout__attachment-row, & .webchat__stacked-layout__main, & .webchat__stacked-layout__message-row, & .webchat__stacked-layout__status':\n      {\n        display: 'flex'\n      },\n\n    '& .webchat__stacked-layout__alignment-pad': {\n      flexShrink: 0\n    },\n\n    '& .webchat__stacked-layout__attachment': {\n      width: '100%'\n    },\n\n    '& .webchat__stacked-layout__avatar-gutter': {\n      display: 'flex',\n      flexDirection: 'column',\n      flexShrink: 0\n    },\n\n    '&.webchat__stacked-layout--from-user': {\n      '& .webchat__stacked-layout__attachment-row, & .webchat__stacked-layout__main, & .webchat__stacked-layout__message-row, & .webchat__stacked-layout__status':\n        {\n          flexDirection: 'row-reverse'\n        }\n    },\n\n    '& .webchat__stacked-layout__content': {\n      flex: 1,\n\n      // This is for bottom aligning an avatar with a message bubble shorter than the avatar.\n      // Related to the test at activityGrouping.avatarMiddleware.atBottom.js.\n      display: 'flex',\n      flexDirection: 'column',\n\n      // This \"overflow: hidden\" is to make sure text overflow will get clipped correctly.\n      // Related to the test at basic.js \"long URLs with keep-all\".\n      overflow: 'hidden'\n    },\n\n    '& .webchat__stacked-layout__nub-pad': {\n      flexShrink: 0\n    }\n  }\n};\n\nconst connectStackedLayout = (...selectors) =>\n  connectToWebChat(\n    (\n      {\n        language,\n        styleSet: {\n          options: { botAvatarInitials, userAvatarInitials }\n        }\n      },\n      { activity: { from: { role = undefined } = {} } = {} }\n    ) => ({\n      avatarInitials: role === 'user' ? userAvatarInitials : botAvatarInitials,\n      language,\n\n      // TODO: [P4] We want to deprecate botAvatarInitials/userAvatarInitials because they are not as helpful as avatarInitials\n      botAvatarInitials,\n      userAvatarInitials\n    }),\n    ...selectors\n  );\n\ntype StackedLayoutProps = {\n  activity: DirectLineActivity;\n  hideTimestamp?: boolean;\n  renderActivityStatus?: (({ hideTimestamp: boolean }) => Exclude<ReactNode, boolean | null | undefined>) | false;\n  renderAttachment?: RenderAttachment;\n  renderAvatar?: (activity: DirectLineActivity) => (() => Exclude<ReactNode, boolean | null | undefined>) | false;\n  showCallout?: boolean;\n};\n\nconst StackedLayout: FC<StackedLayoutProps> = ({\n  activity,\n  hideTimestamp,\n  renderActivityStatus,\n  renderAttachment,\n  renderAvatar,\n  showCallout\n}) => {\n  const [styleOptions] = useStyleOptions();\n  const [{ initials: botInitials }] = useAvatarForBot();\n  const [{ initials: userInitials }] = useAvatarForUser();\n  const [{ stackedLayout: stackedLayoutStyleSet }] = useStyleSet();\n  const ariaLabelId = useUniqueId('webchat__stacked-layout__id');\n  const localize = useLocalizer();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n\n  const { bubbleNubOffset, bubbleNubSize, bubbleFromUserNubOffset, bubbleFromUserNubSize } = styleOptions;\n\n  const {\n    attachments = [],\n    channelData: { messageBack: { displayText: messageBackDisplayText } = {} } = {},\n    from: { role } = {},\n    text,\n    textFormat\n  }: {\n    attachments?: [];\n    channelData?: { messageBack?: { displayText?: string } };\n    from?: { role?: 'bot' | 'user' };\n    text?: string;\n    textFormat?: string;\n  } = activity;\n\n  const activityDisplayText = messageBackDisplayText || text;\n  const fromUser = role === 'user';\n\n  const attachedAlt = localize(fromUser ? 'ACTIVITY_YOU_ATTACHED_ALT' : 'ACTIVITY_BOT_ATTACHED_ALT');\n  const greetingAlt = (\n    fromUser ? localize('ACTIVITY_YOU_SAID_ALT') : localize('ACTIVITY_BOT_SAID_ALT', botInitials || '')\n  ).replace(/\\s{2,}/gu, ' ');\n\n  const initials = fromUser ? userInitials : botInitials;\n  const nubOffset = fromUser ? bubbleFromUserNubOffset : bubbleNubOffset;\n  const nubSize = fromUser ? bubbleFromUserNubSize : bubbleNubSize;\n  const otherInitials = fromUser ? botInitials : userInitials;\n  const otherNubSize = fromUser ? bubbleNubSize : bubbleFromUserNubSize;\n\n  const hasAvatar = initials || typeof initials === 'string';\n  const hasOtherAvatar = otherInitials || typeof otherInitials === 'string';\n  const hasNub = typeof nubSize === 'number';\n  const hasOtherNub = typeof otherNubSize === 'number';\n  const topAlignedCallout = isZeroOrPositive(nubOffset);\n\n  const extraTrailing = !hasOtherAvatar && hasOtherNub; // This is for bot message with user nub and no user avatar. And vice versa.\n\n  const showAvatar = showCallout && hasAvatar && !!renderAvatar;\n  const showNub = showCallout && hasNub && (topAlignedCallout || !attachments.length);\n\n  return (\n    <div\n      aria-labelledby={activityDisplayText ? ariaLabelId : undefined}\n      aria-roledescription=\"activity\"\n      className={classNames('webchat__stacked-layout', rootClassName, stackedLayoutStyleSet + '', {\n        'webchat__stacked-layout--extra-trailing': extraTrailing,\n        'webchat__stacked-layout--from-user': fromUser,\n        'webchat__stacked-layout--hide-avatar': hasAvatar && !showAvatar,\n        'webchat__stacked-layout--hide-nub': hasNub && !showNub,\n        'webchat__stacked-layout--no-message': !activityDisplayText,\n        'webchat__stacked-layout--show-avatar': showAvatar,\n        'webchat__stacked-layout--show-nub': showNub,\n        'webchat__stacked-layout--top-callout': topAlignedCallout\n      })}\n      role=\"group\"\n    >\n      <div className=\"webchat__stacked-layout__main\">\n        <div className=\"webchat__stacked-layout__avatar-gutter\">\n          {showAvatar && renderAvatar && renderAvatar({ activity })}\n        </div>\n        <div className=\"webchat__stacked-layout__content\">\n          {!!activityDisplayText && (\n            <div\n              aria-roledescription=\"message\"\n              className=\"webchat__stacked-layout__message-row\"\n              // Disable \"Prop `id` is forbidden on DOM Nodes\" rule because we are using the ID prop for accessibility.\n              /* eslint-disable-next-line react/forbid-dom-props */\n              id={ariaLabelId}\n              role=\"group\"\n            >\n              <ScreenReaderText text={greetingAlt} />\n              <Bubble\n                className=\"webchat__stacked-layout__message\"\n                fromUser={fromUser}\n                nub={showNub || (hasAvatar || hasNub ? 'hidden' : false)}\n              >\n                {renderAttachment({\n                  activity,\n                  attachment: {\n                    content: activityDisplayText,\n                    contentType: textFormatToContentType(textFormat)\n                  }\n                })}\n              </Bubble>\n            </div>\n          )}\n          {attachments.map((attachment, index) => (\n            <div\n              aria-roledescription=\"attachment\"\n              className={classNames('webchat__stacked-layout__attachment-row', {\n                'webchat__stacked-layout__attachment-row--first': !index\n              })}\n              /* attachments do not have an ID, it is always indexed by number */\n              /* eslint-disable-next-line react/no-array-index-key */\n              key={index}\n              role=\"group\"\n            >\n              <ScreenReaderText text={attachedAlt} />\n              <Bubble\n                className=\"webchat__stacked-layout__attachment\"\n                fromUser={fromUser}\n                /* eslint-disable-next-line react/no-array-index-key */\n                key={index}\n                nub={hasAvatar || hasNub ? 'hidden' : false}\n              >\n                {renderAttachment({ activity, attachment })}\n              </Bubble>\n            </div>\n          ))}\n        </div>\n        <div className=\"webchat__stacked-layout__alignment-pad\" />\n      </div>\n      {typeof renderActivityStatus === 'function' && (\n        <div className=\"webchat__stacked-layout__status\">\n          <div className=\"webchat__stacked-layout__avatar-gutter\" />\n          <div className=\"webchat__stacked-layout__nub-pad\" />\n          {renderActivityStatus({ hideTimestamp })}\n          <div className=\"webchat__stacked-layout__alignment-pad\" />\n        </div>\n      )}\n    </div>\n  );\n};\n\nStackedLayout.defaultProps = {\n  hideTimestamp: false,\n  renderActivityStatus: false,\n  renderAvatar: undefined,\n  showCallout: true\n};\n\nStackedLayout.propTypes = {\n  activity: PropTypes.shape({\n    attachments: PropTypes.array,\n    channelData: PropTypes.shape({\n      messageBack: PropTypes.shape({\n        displayText: PropTypes.string\n      })\n    }),\n    from: PropTypes.shape({\n      role: PropTypes.string.isRequired\n    }).isRequired,\n    text: PropTypes.string,\n    textFormat: PropTypes.string,\n    timestamp: PropTypes.string,\n    type: PropTypes.string.isRequired\n  }).isRequired,\n  hideTimestamp: PropTypes.bool,\n\n  // PropTypes cannot validate precisely with its TypeScript counterpart.\n  // @ts-ignore\n  renderActivityStatus: PropTypes.oneOfType([PropTypes.oneOf([false]), PropTypes.func]),\n  renderAttachment: PropTypes.func.isRequired,\n\n  // PropTypes cannot validate precisely with its TypeScript counterpart.\n  // @ts-ignore\n  renderAvatar: PropTypes.oneOfType([PropTypes.oneOf([false]), PropTypes.func]),\n  showCallout: PropTypes.bool\n};\n\nexport default StackedLayout;\n\nexport { connectStackedLayout };\n"]}
289
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Activity/StackedLayout.tsx"],"names":["useAvatarForBot","hooks","useAvatarForUser","useLocalizer","useStyleOptions","ROOT_STYLE","position","display","flexShrink","width","flexDirection","flex","overflow","connectStackedLayout","selectors","connectToWebChat","language","styleSet","options","botAvatarInitials","userAvatarInitials","activity","from","role","undefined","avatarInitials","StackedLayout","hideTimestamp","renderActivityStatus","renderAttachment","renderAvatar","showCallout","styleOptions","botInitials","initials","userInitials","stackedLayoutStyleSet","stackedLayout","ariaLabelId","localize","rootClassName","bubbleNubOffset","bubbleNubSize","bubbleFromUserNubOffset","bubbleFromUserNubSize","isMessage","type","attachments","fromUser","messageBackDisplayText","channelData","messageBack","displayText","activityDisplayText","text","attachedAlt","greetingAlt","replace","nubOffset","nubSize","otherInitials","otherNubSize","hasAvatar","hasOtherAvatar","hasNub","hasOtherNub","topAlignedCallout","extraTrailing","showAvatar","showNub","length","attachment","content","contentType","textFormat","map","index","defaultProps","propTypes","PropTypes","shape","array","string","isRequired","oneOf","timestamp","bool","oneOfType","func"],"mappings":";;;;;;;AAEA;;AACA;;AACA;;AACA;;AAGA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;;;;;;;;;;;;;;;AAEA,IAAQA,eAAR,GAA6EC,6BAA7E,CAAQD,eAAR;AAAA,IAAyBE,gBAAzB,GAA6ED,6BAA7E,CAAyBC,gBAAzB;AAAA,IAA2CC,YAA3C,GAA6EF,6BAA7E,CAA2CE,YAA3C;AAAA,IAAyDC,eAAzD,GAA6EH,6BAA7E,CAAyDG,eAAzD;AAEA,IAAMC,UAAU,GAAG;AACjB,+BAA6B;AAC3BC,IAAAA,QAAQ,EAAE,UADiB;AACL;AAEtB,iKACE;AACEC,MAAAA,OAAO,EAAE;AADX,KAJyB;AAQ3B,iDAA6C;AAC3CC,MAAAA,UAAU,EAAE;AAD+B,KARlB;AAY3B,8CAA0C;AACxCC,MAAAA,KAAK,EAAE;AADiC,KAZf;AAgB3B,iDAA6C;AAC3CF,MAAAA,OAAO,EAAE,MADkC;AAE3CG,MAAAA,aAAa,EAAE,QAF4B;AAG3CF,MAAAA,UAAU,EAAE;AAH+B,KAhBlB;AAsB3B,4CAAwC;AACtC,mKACE;AACEE,QAAAA,aAAa,EAAE;AADjB;AAFoC,KAtBb;AA6B3B,2CAAuC;AACrCC,MAAAA,IAAI,EAAE,CAD+B;AAGrC;AACA;AACAJ,MAAAA,OAAO,EAAE,MAL4B;AAMrCG,MAAAA,aAAa,EAAE,QANsB;AAQrC;AACA;AACAE,MAAAA,QAAQ,EAAE;AAV2B,KA7BZ;AA0C3B,2CAAuC;AACrCJ,MAAAA,UAAU,EAAE;AADyB;AA1CZ;AADZ,CAAnB;;AAiDA,IAAMK,oBAAoB,GAAG,SAAvBA,oBAAuB;AAAA,oCAAIC,SAAJ;AAAIA,IAAAA,SAAJ;AAAA;;AAAA,SAC3BC,yCACE;AAAA,QAEIC,QAFJ,QAEIA,QAFJ;AAAA,qCAGIC,QAHJ,CAIMC,OAJN;AAAA,QAIiBC,iBAJjB,yBAIiBA,iBAJjB;AAAA,QAIoCC,kBAJpC,yBAIoCA,kBAJpC;AAAA,+BAOIC,QAPJ;AAAA,iDAOoD,EAPpD;AAAA,6CAOgBC,IAPhB;AAAA,2DAO6C,EAP7C;AAAA,oDAOwBC,IAPxB;AAAA,QAOwBA,IAPxB,sCAO+BC,SAP/B;AAAA,WAQM;AACJC,MAAAA,cAAc,EAAEF,IAAI,KAAK,MAAT,GAAkBH,kBAAlB,GAAuCD,iBADnD;AAEJH,MAAAA,QAAQ,EAARA,QAFI;AAIJ;AACAG,MAAAA,iBAAiB,EAAjBA,iBALI;AAMJC,MAAAA,kBAAkB,EAAlBA;AANI,KARN;AAAA,GADF,SAiBKN,SAjBL,EAD2B;AAAA,CAA7B;;;;AA8BA,IAAMY,aAAqC,GAAG,SAAxCA,aAAwC,QAOxC;AAAA;;AAAA,MANJL,QAMI,SANJA,QAMI;AAAA,MALJM,aAKI,SALJA,aAKI;AAAA,MAJJC,oBAII,SAJJA,oBAII;AAAA,MAHJC,gBAGI,SAHJA,gBAGI;AAAA,MAFJC,YAEI,SAFJA,YAEI;AAAA,MADJC,WACI,SADJA,WACI;;AACJ,yBAAuB3B,eAAe,EAAtC;AAAA;AAAA,MAAO4B,YAAP;;AACA,yBAAoChC,eAAe,EAAnD;AAAA;AAAA,MAAmBiC,WAAnB,wBAASC,QAAT;;AACA,0BAAqChC,gBAAgB,EAArD;AAAA;AAAA,MAAmBiC,YAAnB,yBAASD,QAAT;;AACA,qBAAmD,4BAAnD;AAAA;AAAA,MAAwBE,qBAAxB,oBAASC,aAAT;;AACA,MAAMC,WAAW,GAAG,0BAAY,6BAAZ,CAApB;AACA,MAAMC,QAAQ,GAAGpC,YAAY,EAA7B;AACA,MAAMqC,aAAa,GAAG,wCAA0BnC,UAA1B,IAAwC,EAA9D;AAEA,MAAQoC,eAAR,GAA2FT,YAA3F,CAAQS,eAAR;AAAA,MAAyBC,aAAzB,GAA2FV,YAA3F,CAAyBU,aAAzB;AAAA,MAAwCC,uBAAxC,GAA2FX,YAA3F,CAAwCW,uBAAxC;AAAA,MAAiEC,qBAAjE,GAA2FZ,YAA3F,CAAiEY,qBAAjE;AAEA,MAAMC,SAAS,GAAGxB,QAAQ,CAACyB,IAAT,KAAkB,SAApC;AAEA,MAAMC,WAAW,GAAIF,SAAS,IAAIxB,QAAQ,CAAC0B,WAAvB,IAAuC,EAA3D;AACA,MAAMC,QAAQ,GAAG3B,QAAQ,CAACC,IAAT,CAAcC,IAAd,KAAuB,MAAxC;AACA,MAAM0B,sBAA8B,GAAIJ,SAAS,8BAAIxB,QAAQ,CAAC6B,WAAb,oFAAI,sBAAsBC,WAA1B,2DAAI,uBAAmCC,WAAvC,CAAV,IAAiE,EAAxG;AAEA,MAAMC,mBAAmB,GAAGR,SAAS,GAAGI,sBAAsB,IAAI5B,QAAQ,CAACiC,IAAtC,GAA6C,EAAlF;AACA,MAAMC,WAAW,GAAGhB,QAAQ,CAACS,QAAQ,GAAG,2BAAH,GAAiC,2BAA1C,CAA5B;AACA,MAAMQ,WAAW,GAAG,CAClBR,QAAQ,GAAGT,QAAQ,CAAC,uBAAD,CAAX,GAAuCA,QAAQ,CAAC,uBAAD,EAA0BN,WAAW,IAAI,EAAzC,CADrC,EAElBwB,OAFkB,CAEV,0EAFU,EAEE,GAFF,CAApB;AAIA,MAAMvB,QAAQ,GAAGc,QAAQ,GAAGb,YAAH,GAAkBF,WAA3C;AACA,MAAMyB,SAAS,GAAGV,QAAQ,GAAGL,uBAAH,GAA6BF,eAAvD;AACA,MAAMkB,OAAO,GAAGX,QAAQ,GAAGJ,qBAAH,GAA2BF,aAAnD;AACA,MAAMkB,aAAa,GAAGZ,QAAQ,GAAGf,WAAH,GAAiBE,YAA/C;AACA,MAAM0B,YAAY,GAAGb,QAAQ,GAAGN,aAAH,GAAmBE,qBAAhD;AAEA,MAAMkB,SAAS,GAAG5B,QAAQ,IAAI,OAAOA,QAAP,KAAoB,QAAlD;AACA,MAAM6B,cAAc,GAAGH,aAAa,IAAI,OAAOA,aAAP,KAAyB,QAAjE;AACA,MAAMI,MAAM,GAAG,OAAOL,OAAP,KAAmB,QAAlC;AACA,MAAMM,WAAW,GAAG,OAAOJ,YAAP,KAAwB,QAA5C;AACA,MAAMK,iBAAiB,GAAG,+BAAiBR,SAAjB,CAA1B;AAEA,MAAMS,aAAa,GAAG,CAACJ,cAAD,IAAmBE,WAAzC,CAnCI,CAmCkD;;AAEtD,MAAMG,UAAU,GAAGrC,WAAW,IAAI+B,SAAf,IAA4B,CAAC,CAAChC,YAAjD;AACA,MAAMuC,OAAO,GAAGtC,WAAW,IAAIiC,MAAf,KAA0BE,iBAAiB,IAAI,EAACnB,WAAD,aAACA,WAAD,eAACA,WAAW,CAAEuB,MAAd,CAA/C,CAAhB;AAEA,sBACE;AACE,uBAAiBjB,mBAAmB,GAAGf,WAAH,GAAiBd,SADvD;AAEE,4BAAqB,UAFvB;AAGE,IAAA,SAAS,EAAE,yBAAW,yBAAX,EAAsCgB,aAAtC,EAAqDJ,qBAAqB,GAAG,EAA7E,EAAiF;AAC1F,iDAA2C+B,aAD+C;AAE1F,4CAAsCnB,QAFoD;AAG1F,8CAAwCc,SAAS,IAAI,CAACM,UAHoC;AAI1F,2CAAqCJ,MAAM,IAAI,CAACK,OAJ0C;AAK1F,6CAAuC,CAAChB,mBALkD;AAM1F,8CAAwCe,UANkD;AAO1F,2CAAqCC,OAPqD;AAQ1F,8CAAwCH;AARkD,KAAjF,CAHb;AAaE,IAAA,IAAI,EAAC;AAbP,kBAeE;AAAK,IAAA,SAAS,EAAC;AAAf,kBACE;AAAK,IAAA,SAAS,EAAC;AAAf,KACGE,UAAU,IAAItC,YAAd,IAA8BA,YAAY,CAAC;AAAET,IAAAA,QAAQ,EAARA;AAAF,GAAD,CAD7C,CADF,eAIE;AAAK,IAAA,SAAS,EAAC;AAAf,KACG,CAAC,CAACgC,mBAAF,iBACC;AACE,4BAAqB,SADvB;AAEE,IAAA,SAAS,EAAC,sCAFZ,CAGE;;AACA;AAJF;AAKE,IAAA,EAAE,EAAEf,WALN;AAME,IAAA,IAAI,EAAC;AANP,kBAQE,6BAAC,yBAAD;AAAkB,IAAA,IAAI,EAAEkB;AAAxB,IARF,eASE,6BAAC,eAAD;AACE,IAAA,SAAS,EAAC,kCADZ;AAEE,IAAA,QAAQ,EAAER,QAFZ;AAGE,IAAA,GAAG,EAAEqB,OAAO,KAAKP,SAAS,IAAIE,MAAb,GAAsB,QAAtB,GAAiC,KAAtC;AAHd,KAKGnC,gBAAgB,CAAC;AAChBR,IAAAA,QAAQ,EAARA,QADgB;AAEhBkD,IAAAA,UAAU,EAAE1B,SAAS,GACjB;AACE2B,MAAAA,OAAO,EAAEnB,mBADX;AAEEoB,MAAAA,WAAW,EAAE,sCAAwBpD,QAAQ,CAACqD,UAAjC;AAFf,KADiB,GAKjBlD;AAPY,GAAD,CALnB,CATF,CAFJ,EA4BGuB,WAAW,CAAC4B,GAAZ,CAAgB,UAACJ,UAAD,EAAaK,KAAb;AAAA,wBACf;AACE,8BAAqB,YADvB;AAEE,MAAA,SAAS,EAAE,yBAAW,yCAAX,EAAsD;AAC/D,0DAAkD,CAACA;AADY,OAAtD;AAGX;;AACA;AANF;AAOE,MAAA,GAAG,EAAEA,KAPP;AAQE,MAAA,IAAI,EAAC;AARP,oBAUE,6BAAC,yBAAD;AAAkB,MAAA,IAAI,EAAErB;AAAxB,MAVF,eAWE,6BAAC,eAAD;AACE,MAAA,SAAS,EAAC,qCADZ;AAEE,MAAA,QAAQ,EAAEP;AACV;AAHF;AAIE,MAAA,GAAG,EAAE4B,KAJP;AAKE,MAAA,GAAG,EAAEd,SAAS,IAAIE,MAAb,GAAsB,QAAtB,GAAiC;AALxC,OAOGnC,gBAAgB,CAAC;AAAER,MAAAA,QAAQ,EAARA,QAAF;AAAYkD,MAAAA,UAAU,EAAVA;AAAZ,KAAD,CAPnB,CAXF,CADe;AAAA,GAAhB,CA5BH,CAJF,eAwDE;AAAK,IAAA,SAAS,EAAC;AAAf,IAxDF,CAfF,EAyEG,OAAO3C,oBAAP,KAAgC,UAAhC,iBACC;AAAK,IAAA,SAAS,EAAC;AAAf,kBACE;AAAK,IAAA,SAAS,EAAC;AAAf,IADF,eAEE;AAAK,IAAA,SAAS,EAAC;AAAf,IAFF,EAGGA,oBAAoB,CAAC;AAAED,IAAAA,aAAa,EAAbA;AAAF,GAAD,CAHvB,eAIE;AAAK,IAAA,SAAS,EAAC;AAAf,IAJF,CA1EJ,CADF;AAoFD,CAnID;;AAqIAD,aAAa,CAACmD,YAAd,GAA6B;AAC3BlD,EAAAA,aAAa,EAAE,KADY;AAE3BC,EAAAA,oBAAoB,EAAE,KAFK;AAG3BE,EAAAA,YAAY,EAAEN,SAHa;AAI3BO,EAAAA,WAAW,EAAE;AAJc,CAA7B;AAOAL,aAAa,CAACoD,SAAd,GAA0B;AACxB;AACA;AACAzD,EAAAA,QAAQ,EAAE0D,mBAAUC,KAAV,CAAgB;AACxBjC,IAAAA,WAAW,EAAEgC,mBAAUE,KADC;AAExB/B,IAAAA,WAAW,EAAE6B,mBAAUC,KAAV,CAAgB;AAC3B7B,MAAAA,WAAW,EAAE4B,mBAAUC,KAAV,CAAgB;AAC3B5B,QAAAA,WAAW,EAAE2B,mBAAUG;AADI,OAAhB;AADc,KAAhB,CAFW;AAOxB5D,IAAAA,IAAI,EAAEyD,mBAAUC,KAAV,CAAgB;AACpBzD,MAAAA,IAAI,EAAEwD,mBAAUG,MAAV,CAAiBC;AADH,KAAhB,EAEHA,UATqB;AAUxB7B,IAAAA,IAAI,EAAEyB,mBAAUG,MAVQ;AAWxBR,IAAAA,UAAU,EAAEK,mBAAUK,KAAV,CAAgB,CAAC,UAAD,EAAa,OAAb,EAAsB,KAAtB,CAAhB,CAXY;AAYxBC,IAAAA,SAAS,EAAEN,mBAAUG,MAZG;AAaxBpC,IAAAA,IAAI,EAAEiC,mBAAUG,MAAV,CAAiBC;AAbC,GAAhB,EAcPA,UAjBqB;AAkBxBxD,EAAAA,aAAa,EAAEoD,mBAAUO,IAlBD;AAoBxB;AACA;AACA1D,EAAAA,oBAAoB,EAAEmD,mBAAUQ,SAAV,CAAoB,CAACR,mBAAUK,KAAV,CAAgB,CAAC,KAAD,CAAhB,CAAD,EAA2BL,mBAAUS,IAArC,CAApB,CAtBE;AAuBxB3D,EAAAA,gBAAgB,EAAEkD,mBAAUS,IAAV,CAAeL,UAvBT;AAyBxB;AACA;AACArD,EAAAA,YAAY,EAAEiD,mBAAUQ,SAAV,CAAoB,CAACR,mBAAUK,KAAV,CAAgB,CAAC,KAAD,CAAhB,CAAD,EAA2BL,mBAAUS,IAArC,CAApB,CA3BU;AA4BxBzD,EAAAA,WAAW,EAAEgD,mBAAUO;AA5BC,CAA1B;eA+Be5D,a","sourceRoot":"component:///","sourcesContent":["/* eslint complexity: [\"error\", 50] */\n\nimport { hooks, RenderAttachment } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, { FC, ReactNode } from 'react';\nimport type { WebChatActivity } from 'botframework-webchat-core';\n\nimport Bubble from './Bubble';\nimport connectToWebChat from '../connectToWebChat';\nimport isZeroOrPositive from '../Utils/isZeroOrPositive';\nimport ScreenReaderText from '../ScreenReaderText';\nimport textFormatToContentType from '../Utils/textFormatToContentType';\nimport useStyleSet from '../hooks/useStyleSet';\nimport useStyleToEmotionObject from '../hooks/internal/useStyleToEmotionObject';\n\nimport useUniqueId from '../hooks/internal/useUniqueId';\n\nconst { useAvatarForBot, useAvatarForUser, useLocalizer, useStyleOptions } = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__stacked-layout': {\n    position: 'relative', // This is to keep screen reader text in the destinated area.\n\n    '& .webchat__stacked-layout__attachment-row, & .webchat__stacked-layout__main, & .webchat__stacked-layout__message-row, & .webchat__stacked-layout__status':\n      {\n        display: 'flex'\n      },\n\n    '& .webchat__stacked-layout__alignment-pad': {\n      flexShrink: 0\n    },\n\n    '& .webchat__stacked-layout__attachment': {\n      width: '100%'\n    },\n\n    '& .webchat__stacked-layout__avatar-gutter': {\n      display: 'flex',\n      flexDirection: 'column',\n      flexShrink: 0\n    },\n\n    '&.webchat__stacked-layout--from-user': {\n      '& .webchat__stacked-layout__attachment-row, & .webchat__stacked-layout__main, & .webchat__stacked-layout__message-row, & .webchat__stacked-layout__status':\n        {\n          flexDirection: 'row-reverse'\n        }\n    },\n\n    '& .webchat__stacked-layout__content': {\n      flex: 1,\n\n      // This is for bottom aligning an avatar with a message bubble shorter than the avatar.\n      // Related to the test at activityGrouping.avatarMiddleware.atBottom.js.\n      display: 'flex',\n      flexDirection: 'column',\n\n      // This \"overflow: hidden\" is to make sure text overflow will get clipped correctly.\n      // Related to the test at basic.js \"long URLs with keep-all\".\n      overflow: 'hidden'\n    },\n\n    '& .webchat__stacked-layout__nub-pad': {\n      flexShrink: 0\n    }\n  }\n};\n\nconst connectStackedLayout = (...selectors) =>\n  connectToWebChat(\n    (\n      {\n        language,\n        styleSet: {\n          options: { botAvatarInitials, userAvatarInitials }\n        }\n      },\n      { activity: { from: { role = undefined } = {} } = {} }\n    ) => ({\n      avatarInitials: role === 'user' ? userAvatarInitials : botAvatarInitials,\n      language,\n\n      // TODO: [P4] We want to deprecate botAvatarInitials/userAvatarInitials because they are not as helpful as avatarInitials\n      botAvatarInitials,\n      userAvatarInitials\n    }),\n    ...selectors\n  );\n\ntype StackedLayoutProps = {\n  activity: WebChatActivity;\n  hideTimestamp?: boolean;\n  renderActivityStatus?: (({ hideTimestamp: boolean }) => Exclude<ReactNode, boolean | null | undefined>) | false;\n  renderAttachment?: RenderAttachment;\n  renderAvatar?: ({ activity: WebChatActivity }) => (() => Exclude<ReactNode, boolean | null | undefined>) | false;\n  showCallout?: boolean;\n};\n\nconst StackedLayout: FC<StackedLayoutProps> = ({\n  activity,\n  hideTimestamp,\n  renderActivityStatus,\n  renderAttachment,\n  renderAvatar,\n  showCallout\n}) => {\n  const [styleOptions] = useStyleOptions();\n  const [{ initials: botInitials }] = useAvatarForBot();\n  const [{ initials: userInitials }] = useAvatarForUser();\n  const [{ stackedLayout: stackedLayoutStyleSet }] = useStyleSet();\n  const ariaLabelId = useUniqueId('webchat__stacked-layout__id');\n  const localize = useLocalizer();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n\n  const { bubbleNubOffset, bubbleNubSize, bubbleFromUserNubOffset, bubbleFromUserNubSize } = styleOptions;\n\n  const isMessage = activity.type === 'message';\n\n  const attachments = (isMessage && activity.attachments) || [];\n  const fromUser = activity.from.role === 'user';\n  const messageBackDisplayText: string = (isMessage && activity.channelData?.messageBack?.displayText) || '';\n\n  const activityDisplayText = isMessage ? messageBackDisplayText || activity.text : '';\n  const attachedAlt = localize(fromUser ? 'ACTIVITY_YOU_ATTACHED_ALT' : 'ACTIVITY_BOT_ATTACHED_ALT');\n  const greetingAlt = (\n    fromUser ? localize('ACTIVITY_YOU_SAID_ALT') : localize('ACTIVITY_BOT_SAID_ALT', botInitials || '')\n  ).replace(/\\s{2,}/gu, ' ');\n\n  const initials = fromUser ? userInitials : botInitials;\n  const nubOffset = fromUser ? bubbleFromUserNubOffset : bubbleNubOffset;\n  const nubSize = fromUser ? bubbleFromUserNubSize : bubbleNubSize;\n  const otherInitials = fromUser ? botInitials : userInitials;\n  const otherNubSize = fromUser ? bubbleNubSize : bubbleFromUserNubSize;\n\n  const hasAvatar = initials || typeof initials === 'string';\n  const hasOtherAvatar = otherInitials || typeof otherInitials === 'string';\n  const hasNub = typeof nubSize === 'number';\n  const hasOtherNub = typeof otherNubSize === 'number';\n  const topAlignedCallout = isZeroOrPositive(nubOffset);\n\n  const extraTrailing = !hasOtherAvatar && hasOtherNub; // This is for bot message with user nub and no user avatar. And vice versa.\n\n  const showAvatar = showCallout && hasAvatar && !!renderAvatar;\n  const showNub = showCallout && hasNub && (topAlignedCallout || !attachments?.length);\n\n  return (\n    <div\n      aria-labelledby={activityDisplayText ? ariaLabelId : undefined}\n      aria-roledescription=\"activity\"\n      className={classNames('webchat__stacked-layout', rootClassName, stackedLayoutStyleSet + '', {\n        'webchat__stacked-layout--extra-trailing': extraTrailing,\n        'webchat__stacked-layout--from-user': fromUser,\n        'webchat__stacked-layout--hide-avatar': hasAvatar && !showAvatar,\n        'webchat__stacked-layout--hide-nub': hasNub && !showNub,\n        'webchat__stacked-layout--no-message': !activityDisplayText,\n        'webchat__stacked-layout--show-avatar': showAvatar,\n        'webchat__stacked-layout--show-nub': showNub,\n        'webchat__stacked-layout--top-callout': topAlignedCallout\n      })}\n      role=\"group\"\n    >\n      <div className=\"webchat__stacked-layout__main\">\n        <div className=\"webchat__stacked-layout__avatar-gutter\">\n          {showAvatar && renderAvatar && renderAvatar({ activity })}\n        </div>\n        <div className=\"webchat__stacked-layout__content\">\n          {!!activityDisplayText && (\n            <div\n              aria-roledescription=\"message\"\n              className=\"webchat__stacked-layout__message-row\"\n              // Disable \"Prop `id` is forbidden on DOM Nodes\" rule because we are using the ID prop for accessibility.\n              /* eslint-disable-next-line react/forbid-dom-props */\n              id={ariaLabelId}\n              role=\"group\"\n            >\n              <ScreenReaderText text={greetingAlt} />\n              <Bubble\n                className=\"webchat__stacked-layout__message\"\n                fromUser={fromUser}\n                nub={showNub || (hasAvatar || hasNub ? 'hidden' : false)}\n              >\n                {renderAttachment({\n                  activity,\n                  attachment: isMessage\n                    ? {\n                        content: activityDisplayText,\n                        contentType: textFormatToContentType(activity.textFormat)\n                      }\n                    : undefined\n                })}\n              </Bubble>\n            </div>\n          )}\n          {attachments.map((attachment, index) => (\n            <div\n              aria-roledescription=\"attachment\"\n              className={classNames('webchat__stacked-layout__attachment-row', {\n                'webchat__stacked-layout__attachment-row--first': !index\n              })}\n              /* attachments do not have an ID, it is always indexed by number */\n              /* eslint-disable-next-line react/no-array-index-key */\n              key={index}\n              role=\"group\"\n            >\n              <ScreenReaderText text={attachedAlt} />\n              <Bubble\n                className=\"webchat__stacked-layout__attachment\"\n                fromUser={fromUser}\n                /* eslint-disable-next-line react/no-array-index-key */\n                key={index}\n                nub={hasAvatar || hasNub ? 'hidden' : false}\n              >\n                {renderAttachment({ activity, attachment })}\n              </Bubble>\n            </div>\n          ))}\n        </div>\n        <div className=\"webchat__stacked-layout__alignment-pad\" />\n      </div>\n      {typeof renderActivityStatus === 'function' && (\n        <div className=\"webchat__stacked-layout__status\">\n          <div className=\"webchat__stacked-layout__avatar-gutter\" />\n          <div className=\"webchat__stacked-layout__nub-pad\" />\n          {renderActivityStatus({ hideTimestamp })}\n          <div className=\"webchat__stacked-layout__alignment-pad\" />\n        </div>\n      )}\n    </div>\n  );\n};\n\nStackedLayout.defaultProps = {\n  hideTimestamp: false,\n  renderActivityStatus: false,\n  renderAvatar: undefined,\n  showCallout: true\n};\n\nStackedLayout.propTypes = {\n  // PropTypes cannot fully capture TypeScript types.\n  // @ts-ignore\n  activity: PropTypes.shape({\n    attachments: PropTypes.array,\n    channelData: PropTypes.shape({\n      messageBack: PropTypes.shape({\n        displayText: PropTypes.string\n      })\n    }),\n    from: PropTypes.shape({\n      role: PropTypes.string.isRequired\n    }).isRequired,\n    text: PropTypes.string,\n    textFormat: PropTypes.oneOf(['markdown', 'plain', 'xml']),\n    timestamp: PropTypes.string,\n    type: PropTypes.string.isRequired\n  }).isRequired,\n  hideTimestamp: PropTypes.bool,\n\n  // PropTypes cannot validate precisely with its TypeScript counterpart.\n  // @ts-ignore\n  renderActivityStatus: PropTypes.oneOfType([PropTypes.oneOf([false]), PropTypes.func]),\n  renderAttachment: PropTypes.func.isRequired,\n\n  // PropTypes cannot validate precisely with its TypeScript counterpart.\n  // @ts-ignore\n  renderAvatar: PropTypes.oneOfType([PropTypes.oneOf([false]), PropTypes.func]),\n  showCallout: PropTypes.bool\n};\n\nexport default StackedLayout;\n\nexport { connectStackedLayout };\n"]}
@@ -48,7 +48,7 @@ var ROOT_STYLE = {
48
48
  flexDirection: 'column'
49
49
  }
50
50
  };
51
- var ALLOWED_PROTOCOLS = ['data:', 'http:', 'https:'];
51
+ var ALLOWED_PROTOCOLS = ['blob:', 'data:', 'http:', 'https:'];
52
52
 
53
53
  function isAllowedProtocol(url) {
54
54
  try {
@@ -141,4 +141,4 @@ FileContent.propTypes = {
141
141
  };
142
142
  var _default = FileContent;
143
143
  exports.default = _default;
144
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Attachment/FileContent.tsx"],"names":["useByteFormatter","hooks","useDirection","useLocalizer","ROOT_STYLE","display","flex","flexDirection","ALLOWED_PROTOCOLS","isAllowedProtocol","url","includes","URL","protocol","err","FileContentBadge","downloadIcon","fileName","size","direction","formatByte","localizedSize","defaultProps","undefined","propTypes","PropTypes","bool","string","isRequired","number","FileContent","className","href","fileContentStyleSet","fileContent","localize","localizeBytes","rootClassName","alt"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["import { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, { FC } from 'react';\n\nimport DownloadIcon from './Assets/DownloadIcon';\nimport useStyleSet from '../hooks/useStyleSet';\nimport useStyleToEmotionObject from '../hooks/internal/useStyleToEmotionObject';\n\nconst { useByteFormatter, useDirection, useLocalizer } = hooks;\n\nconst ROOT_STYLE = {\n  display: 'flex',\n\n  '& .webchat__fileContent__buttonLink': {\n    display: 'flex',\n    flex: 1\n  },\n\n  '& .webchat__fileContent__badge': {\n    display: 'flex',\n    flex: 1,\n    flexDirection: 'column'\n  }\n};\n\nconst ALLOWED_PROTOCOLS = ['data:', 'http:', 'https:'];\n\nfunction isAllowedProtocol(url) {\n  try {\n    return ALLOWED_PROTOCOLS.includes(new URL(url).protocol);\n  } catch (err) {\n    return false;\n  }\n}\n\nconst FileContentBadge = ({ downloadIcon, fileName, size }) => {\n  const [direction] = useDirection();\n  const formatByte = useByteFormatter();\n\n  const localizedSize = typeof size === 'number' && formatByte(size);\n\n  return (\n    <React.Fragment>\n      <div aria-hidden={true} className=\"webchat__fileContent__badge\">\n        <div className=\"webchat__fileContent__fileName\">{fileName}</div>\n        {!!localizedSize && <div className=\"webchat__fileContent__size\">{localizedSize}</div>}\n      </div>\n      {downloadIcon && (\n        <DownloadIcon\n          className={classNames(\n            'webchat__fileContent__downloadIcon',\n            direction === 'rtl' && 'webchat__fileContent__downloadIcon--rtl'\n          )}\n          size={1.5}\n        />\n      )}\n    </React.Fragment>\n  );\n};\n\nFileContentBadge.defaultProps = {\n  downloadIcon: false,\n  size: undefined\n};\n\nFileContentBadge.propTypes = {\n  downloadIcon: PropTypes.bool,\n  fileName: PropTypes.string.isRequired,\n  size: PropTypes.number\n};\n\ntype FileContentProps = {\n  className?: string;\n  fileName: string;\n  href?: string;\n  size?: number;\n};\n\nconst FileContent: FC<FileContentProps> = ({ className, href, fileName, size }) => {\n  const [{ fileContent: fileContentStyleSet }] = useStyleSet();\n  const localize = useLocalizer();\n  const localizeBytes = useByteFormatter();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n\n  const localizedSize = typeof size === 'number' && localizeBytes(size);\n\n  href = href && isAllowedProtocol(href) ? href : undefined;\n\n  const alt = localize(\n    href\n      ? localizedSize\n        ? 'FILE_CONTENT_DOWNLOADABLE_WITH_SIZE_ALT'\n        : 'FILE_CONTENT_DOWNLOADABLE_ALT'\n      : localizedSize\n      ? 'FILE_CONTENT_WITH_SIZE_ALT'\n      : 'FILE_CONTENT_ALT',\n    fileName,\n    localizedSize\n  );\n\n  return (\n    <div\n      className={classNames('webchat__fileContent', rootClassName, fileContentStyleSet + '', (className || '') + '')}\n    >\n      {href ? (\n        <a\n          aria-label={alt}\n          className=\"webchat__fileContent__buttonLink\"\n          download={fileName}\n          href={href}\n          rel=\"noopener noreferrer\"\n          target=\"_blank\"\n        >\n          <FileContentBadge downloadIcon={true} fileName={fileName} size={size} />\n        </a>\n      ) : (\n        <FileContentBadge downloadIcon={false} fileName={fileName} size={size} />\n      )}\n    </div>\n  );\n};\n\nFileContent.defaultProps = {\n  className: '',\n  href: undefined,\n  size: undefined\n};\n\nFileContent.propTypes = {\n  className: PropTypes.string,\n  fileName: PropTypes.string.isRequired,\n  href: PropTypes.string,\n  size: PropTypes.number\n};\n\nexport default FileContent;\n"]}
144
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Attachment/FileContent.tsx"],"names":["useByteFormatter","hooks","useDirection","useLocalizer","ROOT_STYLE","display","flex","flexDirection","ALLOWED_PROTOCOLS","isAllowedProtocol","url","includes","URL","protocol","err","FileContentBadge","downloadIcon","fileName","size","direction","formatByte","localizedSize","defaultProps","undefined","propTypes","PropTypes","bool","string","isRequired","number","FileContent","className","href","fileContentStyleSet","fileContent","localize","localizeBytes","rootClassName","alt"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["import { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, { FC } from 'react';\n\nimport DownloadIcon from './Assets/DownloadIcon';\nimport useStyleSet from '../hooks/useStyleSet';\nimport useStyleToEmotionObject from '../hooks/internal/useStyleToEmotionObject';\n\nconst { useByteFormatter, useDirection, useLocalizer } = hooks;\n\nconst ROOT_STYLE = {\n  display: 'flex',\n\n  '& .webchat__fileContent__buttonLink': {\n    display: 'flex',\n    flex: 1\n  },\n\n  '& .webchat__fileContent__badge': {\n    display: 'flex',\n    flex: 1,\n    flexDirection: 'column'\n  }\n};\n\nconst ALLOWED_PROTOCOLS = ['blob:', 'data:', 'http:', 'https:'];\n\nfunction isAllowedProtocol(url) {\n  try {\n    return ALLOWED_PROTOCOLS.includes(new URL(url).protocol);\n  } catch (err) {\n    return false;\n  }\n}\n\nconst FileContentBadge = ({ downloadIcon, fileName, size }) => {\n  const [direction] = useDirection();\n  const formatByte = useByteFormatter();\n\n  const localizedSize = typeof size === 'number' && formatByte(size);\n\n  return (\n    <React.Fragment>\n      <div aria-hidden={true} className=\"webchat__fileContent__badge\">\n        <div className=\"webchat__fileContent__fileName\">{fileName}</div>\n        {!!localizedSize && <div className=\"webchat__fileContent__size\">{localizedSize}</div>}\n      </div>\n      {downloadIcon && (\n        <DownloadIcon\n          className={classNames(\n            'webchat__fileContent__downloadIcon',\n            direction === 'rtl' && 'webchat__fileContent__downloadIcon--rtl'\n          )}\n          size={1.5}\n        />\n      )}\n    </React.Fragment>\n  );\n};\n\nFileContentBadge.defaultProps = {\n  downloadIcon: false,\n  size: undefined\n};\n\nFileContentBadge.propTypes = {\n  downloadIcon: PropTypes.bool,\n  fileName: PropTypes.string.isRequired,\n  size: PropTypes.number\n};\n\ntype FileContentProps = {\n  className?: string;\n  fileName: string;\n  href?: string;\n  size?: number;\n};\n\nconst FileContent: FC<FileContentProps> = ({ className, href, fileName, size }) => {\n  const [{ fileContent: fileContentStyleSet }] = useStyleSet();\n  const localize = useLocalizer();\n  const localizeBytes = useByteFormatter();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n\n  const localizedSize = typeof size === 'number' && localizeBytes(size);\n\n  href = href && isAllowedProtocol(href) ? href : undefined;\n\n  const alt = localize(\n    href\n      ? localizedSize\n        ? 'FILE_CONTENT_DOWNLOADABLE_WITH_SIZE_ALT'\n        : 'FILE_CONTENT_DOWNLOADABLE_ALT'\n      : localizedSize\n      ? 'FILE_CONTENT_WITH_SIZE_ALT'\n      : 'FILE_CONTENT_ALT',\n    fileName,\n    localizedSize\n  );\n\n  return (\n    <div\n      className={classNames('webchat__fileContent', rootClassName, fileContentStyleSet + '', (className || '') + '')}\n    >\n      {href ? (\n        <a\n          aria-label={alt}\n          className=\"webchat__fileContent__buttonLink\"\n          download={fileName}\n          href={href}\n          rel=\"noopener noreferrer\"\n          target=\"_blank\"\n        >\n          <FileContentBadge downloadIcon={true} fileName={fileName} size={size} />\n        </a>\n      ) : (\n        <FileContentBadge downloadIcon={false} fileName={fileName} size={size} />\n      )}\n    </div>\n  );\n};\n\nFileContent.defaultProps = {\n  className: '',\n  href: undefined,\n  size: undefined\n};\n\nFileContent.propTypes = {\n  className: PropTypes.string,\n  fileName: PropTypes.string.isRequired,\n  href: PropTypes.string,\n  size: PropTypes.number\n};\n\nexport default FileContent;\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"BasicSendBox.d.ts","sourceRoot":"","sources":["../src/BasicSendBox.tsx"],"names":[],"mappings":"AAIA,OAAc,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAiClC,iBAAS,+BAA+B,IAAI,CAAC,OAAO,CAAC,CAQpD;AAED,aAAK,iBAAiB,GAAG;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,QAAA,MAAM,YAAY,EAAE,EAAE,CAAC,iBAAiB,CAwCvC,CAAC;AAUF,eAAe,YAAY,CAAC;AAE5B,OAAO,EAAE,+BAA+B,EAAE,CAAC"}
1
+ {"version":3,"file":"BasicSendBox.d.ts","sourceRoot":"","sources":["../src/BasicSendBox.tsx"],"names":[],"mappings":"AAIA,OAAc,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAkClC,iBAAS,+BAA+B,IAAI,CAAC,OAAO,CAAC,CAQpD;AAED,aAAK,iBAAiB,GAAG;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,QAAA,MAAM,YAAY,EAAE,EAAE,CAAC,iBAAiB,CAwCvC,CAAC;AAUF,eAAe,YAAY,CAAC;AAE5B,OAAO,EAAE,+BAA+B,EAAE,CAAC"}
@@ -75,11 +75,10 @@ var ROOT_STYLE = {
75
75
  }
76
76
  }; // TODO: [P3] We should consider exposing core/src/definitions and use it instead
77
77
 
78
- function activityIsSpeakingOrQueuedToSpeak(_ref) {
79
- var _ref$channelData = _ref.channelData;
80
- _ref$channelData = _ref$channelData === void 0 ? {} : _ref$channelData;
81
- var speak = _ref$channelData.speak;
82
- return !!speak;
78
+ function activityIsSpeakingOrQueuedToSpeak(activity) {
79
+ var _activity$channelData;
80
+
81
+ return activity.type === 'message' && ((_activity$channelData = activity.channelData) === null || _activity$channelData === void 0 ? void 0 : _activity$channelData.speak);
83
82
  }
84
83
 
85
84
  function useSendBoxSpeechInterimsVisible() {
@@ -94,8 +93,8 @@ function useSendBoxSpeechInterimsVisible() {
94
93
  return [(dictateState === STARTING || dictateState === DICTATING) && !activities.filter(activityIsSpeakingOrQueuedToSpeak).length];
95
94
  }
96
95
 
97
- var BasicSendBox = function BasicSendBox(_ref2) {
98
- var className = _ref2.className;
96
+ var BasicSendBox = function BasicSendBox(_ref) {
97
+ var className = _ref.className;
99
98
 
100
99
  var _useStyleOptions = useStyleOptions(),
101
100
  _useStyleOptions2 = _slicedToArray(_useStyleOptions, 1),
@@ -158,4 +157,4 @@ BasicSendBox.propTypes = {
158
157
  };
159
158
  var _default = BasicSendBox;
160
159
  exports.default = _default;
161
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/BasicSendBox.tsx"],"names":["Constants","DictateState","DICTATING","STARTING","useActivities","hooks","useDirection","useDictateState","useStyleOptions","ROOT_STYLE","flexShrink","flex","display","activityIsSpeakingOrQueuedToSpeak","channelData","speak","useSendBoxSpeechInterimsVisible","activities","dictateState","filter","length","BasicSendBox","className","hideUploadButton","sendBoxButtonAlignment","sendBoxStyleSet","sendBox","SpeechRecognition","undefined","direction","speechInterimsVisible","styleToEmotionObject","rootClassName","supportSpeechRecognition","buttonClassName","defaultProps","propTypes","PropTypes","string"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["import { Constants } from 'botframework-webchat-core';\nimport { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, { FC } from 'react';\n\nimport DictationInterims from './SendBox/DictationInterims';\nimport MicrophoneButton from './SendBox/MicrophoneButton';\nimport SendButton from './SendBox/SendButton';\nimport SuggestedActions from './SendBox/SuggestedActions';\nimport TextBox from './SendBox/TextBox';\nimport UploadButton from './SendBox/UploadButton';\nimport useStyleSet from './hooks/useStyleSet';\nimport useStyleToEmotionObject from './hooks/internal/useStyleToEmotionObject';\nimport useWebSpeechPonyfill from './hooks/useWebSpeechPonyfill';\n\nconst {\n  DictateState: { DICTATING, STARTING }\n} = Constants;\n\nconst { useActivities, useDirection, useDictateState, useStyleOptions } = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__send-box': {\n    '& .webchat__send-box__button': { flexShrink: 0 },\n    '& .webchat__send-box__dictation-interims': { flex: 10000 },\n    '& .webchat__send-box__main': { display: 'flex' },\n    '& .webchat__send-box__microphone-button': { flex: 1 },\n    '& .webchat__send-box__text-box': { flex: 10000 }\n  }\n};\n\n// TODO: [P3] We should consider exposing core/src/definitions and use it instead\nfunction activityIsSpeakingOrQueuedToSpeak({ channelData: { speak } = {} }: { channelData: { speak?: any } }) {\n  return !!speak;\n}\n\nfunction useSendBoxSpeechInterimsVisible(): [boolean] {\n  const [activities] = useActivities();\n  const [dictateState] = useDictateState();\n\n  return [\n    (dictateState === STARTING || dictateState === DICTATING) &&\n      !activities.filter(activityIsSpeakingOrQueuedToSpeak).length\n  ];\n}\n\ntype BasicSendBoxProps = {\n  className?: string;\n};\n\nconst BasicSendBox: FC<BasicSendBoxProps> = ({ className }) => {\n  const [{ hideUploadButton, sendBoxButtonAlignment }] = useStyleOptions();\n  const [{ sendBox: sendBoxStyleSet }] = useStyleSet();\n  const [{ SpeechRecognition = undefined } = {}] = useWebSpeechPonyfill();\n  const [direction] = useDirection();\n  const [speechInterimsVisible] = useSendBoxSpeechInterimsVisible();\n  const styleToEmotionObject = useStyleToEmotionObject();\n\n  const rootClassName = styleToEmotionObject(ROOT_STYLE) + '';\n\n  const supportSpeechRecognition = !!SpeechRecognition;\n\n  const buttonClassName = classNames('webchat__send-box__button', {\n    'webchat__send-box__button--align-bottom': sendBoxButtonAlignment === 'bottom',\n    'webchat__send-box__button--align-stretch': sendBoxButtonAlignment !== 'bottom' && sendBoxButtonAlignment !== 'top',\n    'webchat__send-box__button--align-top': sendBoxButtonAlignment === 'top'\n  });\n\n  return (\n    <div\n      className={classNames('webchat__send-box', sendBoxStyleSet + '', rootClassName + '', (className || '') + '')}\n      dir={direction}\n      role=\"form\"\n    >\n      <SuggestedActions />\n      <div className=\"webchat__send-box__main\">\n        {!hideUploadButton && <UploadButton className={buttonClassName} />}\n        {speechInterimsVisible ? (\n          <DictationInterims className=\"webchat__send-box__dictation-interims\" />\n        ) : (\n          <TextBox className=\"webchat__send-box__text-box\" />\n        )}\n        {supportSpeechRecognition ? (\n          <MicrophoneButton className={classNames(buttonClassName, 'webchat__send-box__microphone-button')} />\n        ) : (\n          <SendButton className={buttonClassName} />\n        )}\n      </div>\n    </div>\n  );\n};\n\nBasicSendBox.defaultProps = {\n  className: ''\n};\n\nBasicSendBox.propTypes = {\n  className: PropTypes.string\n};\n\nexport default BasicSendBox;\n\nexport { useSendBoxSpeechInterimsVisible };\n"]}
160
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/BasicSendBox.tsx"],"names":["Constants","DictateState","DICTATING","STARTING","useActivities","hooks","useDirection","useDictateState","useStyleOptions","ROOT_STYLE","flexShrink","flex","display","activityIsSpeakingOrQueuedToSpeak","activity","type","channelData","speak","useSendBoxSpeechInterimsVisible","activities","dictateState","filter","length","BasicSendBox","className","hideUploadButton","sendBoxButtonAlignment","sendBoxStyleSet","sendBox","SpeechRecognition","undefined","direction","speechInterimsVisible","styleToEmotionObject","rootClassName","supportSpeechRecognition","buttonClassName","defaultProps","propTypes","PropTypes","string"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["import { Constants } from 'botframework-webchat-core';\nimport { hooks } from 'botframework-webchat-api';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport React, { FC } from 'react';\nimport type { WebChatActivity } from 'botframework-webchat-core';\n\nimport DictationInterims from './SendBox/DictationInterims';\nimport MicrophoneButton from './SendBox/MicrophoneButton';\nimport SendButton from './SendBox/SendButton';\nimport SuggestedActions from './SendBox/SuggestedActions';\nimport TextBox from './SendBox/TextBox';\nimport UploadButton from './SendBox/UploadButton';\nimport useStyleSet from './hooks/useStyleSet';\nimport useStyleToEmotionObject from './hooks/internal/useStyleToEmotionObject';\nimport useWebSpeechPonyfill from './hooks/useWebSpeechPonyfill';\n\nconst {\n  DictateState: { DICTATING, STARTING }\n} = Constants;\n\nconst { useActivities, useDirection, useDictateState, useStyleOptions } = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__send-box': {\n    '& .webchat__send-box__button': { flexShrink: 0 },\n    '& .webchat__send-box__dictation-interims': { flex: 10000 },\n    '& .webchat__send-box__main': { display: 'flex' },\n    '& .webchat__send-box__microphone-button': { flex: 1 },\n    '& .webchat__send-box__text-box': { flex: 10000 }\n  }\n};\n\n// TODO: [P3] We should consider exposing core/src/definitions and use it instead\nfunction activityIsSpeakingOrQueuedToSpeak(activity: WebChatActivity) {\n  return activity.type === 'message' && activity.channelData?.speak;\n}\n\nfunction useSendBoxSpeechInterimsVisible(): [boolean] {\n  const [activities] = useActivities();\n  const [dictateState] = useDictateState();\n\n  return [\n    (dictateState === STARTING || dictateState === DICTATING) &&\n      !activities.filter(activityIsSpeakingOrQueuedToSpeak).length\n  ];\n}\n\ntype BasicSendBoxProps = {\n  className?: string;\n};\n\nconst BasicSendBox: FC<BasicSendBoxProps> = ({ className }) => {\n  const [{ hideUploadButton, sendBoxButtonAlignment }] = useStyleOptions();\n  const [{ sendBox: sendBoxStyleSet }] = useStyleSet();\n  const [{ SpeechRecognition = undefined } = {}] = useWebSpeechPonyfill();\n  const [direction] = useDirection();\n  const [speechInterimsVisible] = useSendBoxSpeechInterimsVisible();\n  const styleToEmotionObject = useStyleToEmotionObject();\n\n  const rootClassName = styleToEmotionObject(ROOT_STYLE) + '';\n\n  const supportSpeechRecognition = !!SpeechRecognition;\n\n  const buttonClassName = classNames('webchat__send-box__button', {\n    'webchat__send-box__button--align-bottom': sendBoxButtonAlignment === 'bottom',\n    'webchat__send-box__button--align-stretch': sendBoxButtonAlignment !== 'bottom' && sendBoxButtonAlignment !== 'top',\n    'webchat__send-box__button--align-top': sendBoxButtonAlignment === 'top'\n  });\n\n  return (\n    <div\n      className={classNames('webchat__send-box', sendBoxStyleSet + '', rootClassName + '', (className || '') + '')}\n      dir={direction}\n      role=\"form\"\n    >\n      <SuggestedActions />\n      <div className=\"webchat__send-box__main\">\n        {!hideUploadButton && <UploadButton className={buttonClassName} />}\n        {speechInterimsVisible ? (\n          <DictationInterims className=\"webchat__send-box__dictation-interims\" />\n        ) : (\n          <TextBox className=\"webchat__send-box__text-box\" />\n        )}\n        {supportSpeechRecognition ? (\n          <MicrophoneButton className={classNames(buttonClassName, 'webchat__send-box__microphone-button')} />\n        ) : (\n          <SendButton className={buttonClassName} />\n        )}\n      </div>\n    </div>\n  );\n};\n\nBasicSendBox.defaultProps = {\n  className: ''\n};\n\nBasicSendBox.propTypes = {\n  className: PropTypes.string\n};\n\nexport default BasicSendBox;\n\nexport { useSendBoxSpeechInterimsVisible };\n"]}
package/lib/BasicToast.js CHANGED
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
4
 
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
4
 
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
@@ -1 +1 @@
1
- {"version":3,"file":"BasicTranscript.d.ts","sourceRoot":"","sources":["../src/BasicTranscript.tsx"],"names":[],"mappings":"AAkBA,OAAO,KAAK,EAAyD,GAAG,EAAE,MAAM,OAAO,CAAC;AA+zBxF,aAAK,oBAAoB,GAAG;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,QAAA,MAAM,eAAe,EAAE,GAAG,CAAC,oBAAoB,CAc9C,CAAC;AAUF,eAAe,eAAe,CAAC"}
1
+ {"version":3,"file":"BasicTranscript.d.ts","sourceRoot":"","sources":["../src/BasicTranscript.tsx"],"names":[],"mappings":"AAiBA,OAAO,KAAK,EAAyD,GAAG,EAAE,MAAM,OAAO,CAAC;AAg1BxF,aAAK,oBAAoB,GAAG;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,QAAA,MAAM,eAAe,EAAE,GAAG,CAAC,oBAAoB,CAc9C,CAAC;AAUF,eAAe,eAAe,CAAC"}