botframework-webchat-component 4.13.0 → 4.14.2

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 (451) hide show
  1. package/.eslintignore +1 -9
  2. package/.eslintrc.yml +6 -0
  3. package/lib/Activity/Avatar.d.ts +10 -0
  4. package/lib/Activity/Avatar.d.ts.map +1 -0
  5. package/lib/Activity/Avatar.js +2 -1
  6. package/lib/Activity/Bubble.d.ts +11 -0
  7. package/lib/Activity/Bubble.d.ts.map +1 -0
  8. package/lib/Activity/Bubble.js +2 -2
  9. package/lib/Activity/CarouselFilmStrip.js +20 -30
  10. package/lib/Activity/CarouselFilmStripAttachment.js +120 -0
  11. package/lib/Activity/CarouselLayout.js +5 -5
  12. package/lib/Activity/Speak.d.ts +10 -0
  13. package/lib/Activity/Speak.d.ts.map +1 -0
  14. package/lib/Activity/Speak.js +10 -12
  15. package/lib/Activity/StackedLayout.d.ts +18 -0
  16. package/lib/Activity/StackedLayout.d.ts.map +1 -0
  17. package/lib/Activity/StackedLayout.js +18 -14
  18. package/lib/Assets/TypingAnimation.js +2 -2
  19. package/lib/Attachment/Assets/DownloadIcon.js +3 -1
  20. package/lib/Attachment/AudioAttachment.js +2 -2
  21. package/lib/Attachment/AudioContent.d.ts +11 -0
  22. package/lib/Attachment/AudioContent.d.ts.map +1 -0
  23. package/lib/Attachment/AudioContent.js +4 -4
  24. package/lib/Attachment/FileContent.d.ts +10 -0
  25. package/lib/Attachment/FileContent.d.ts.map +1 -0
  26. package/lib/Attachment/FileContent.js +4 -9
  27. package/lib/Attachment/HTMLVideoContent.d.ts +11 -0
  28. package/lib/Attachment/HTMLVideoContent.d.ts.map +1 -0
  29. package/lib/Attachment/HTMLVideoContent.js +2 -2
  30. package/lib/Attachment/ImageContent.d.ts +8 -0
  31. package/lib/Attachment/ImageContent.d.ts.map +1 -0
  32. package/lib/Attachment/ImageContent.js +2 -2
  33. package/lib/Attachment/TextContent.d.ts +8 -0
  34. package/lib/Attachment/TextContent.d.ts.map +1 -0
  35. package/lib/Attachment/TextContent.js +4 -4
  36. package/lib/Attachment/VideoAttachment.js +2 -2
  37. package/lib/Attachment/VideoContent.d.ts +11 -0
  38. package/lib/Attachment/VideoContent.d.ts.map +1 -0
  39. package/lib/Attachment/VideoContent.js +1 -1
  40. package/lib/Attachment/VimeoContent.d.ts +10 -0
  41. package/lib/Attachment/VimeoContent.d.ts.map +1 -0
  42. package/lib/Attachment/VimeoContent.js +8 -8
  43. package/lib/Attachment/YouTubeContent.d.ts +10 -0
  44. package/lib/Attachment/YouTubeContent.d.ts.map +1 -0
  45. package/lib/Attachment/YouTubeContent.js +5 -5
  46. package/lib/Avatar/ImageAvatar.js +2 -2
  47. package/lib/Avatar/InitialsAvatar.js +2 -2
  48. package/lib/BasicConnectivityStatus.js +2 -2
  49. package/lib/BasicSendBox.d.ts +9 -0
  50. package/lib/BasicSendBox.d.ts.map +1 -0
  51. package/lib/BasicSendBox.js +6 -5
  52. package/lib/BasicToast.js +4 -4
  53. package/lib/BasicToaster.js +4 -4
  54. package/lib/BasicTranscript.js +143 -123
  55. package/lib/BasicTypingIndicator.d.ts +5 -0
  56. package/lib/BasicTypingIndicator.d.ts.map +1 -0
  57. package/lib/BasicTypingIndicator.js +2 -2
  58. package/lib/BasicWebChat.d.ts +9 -0
  59. package/lib/BasicWebChat.d.ts.map +1 -0
  60. package/lib/BasicWebChat.js +6 -4
  61. package/lib/Composer.d.ts +23 -0
  62. package/lib/Composer.d.ts.map +1 -0
  63. package/lib/Composer.js +33 -55
  64. package/lib/ConnectivityStatus/Assets/ErrorNotificationIcon.js +2 -2
  65. package/lib/ConnectivityStatus/Assets/SpinnerAnimation.js +2 -2
  66. package/lib/ConnectivityStatus/Assets/WarningNotificationIcon.js +2 -2
  67. package/lib/ConnectivityStatus/Connected.js +1 -1
  68. package/lib/ConnectivityStatus/Connecting.js +4 -4
  69. package/lib/ConnectivityStatus/FailedToConnect.js +2 -2
  70. package/lib/ConnectivityStatus/JavaScriptError.js +2 -2
  71. package/lib/Dictation.js +13 -4
  72. package/lib/ErrorBox.d.ts +8 -0
  73. package/lib/ErrorBox.d.ts.map +1 -0
  74. package/lib/ErrorBox.js +2 -2
  75. package/lib/Middleware/Activity/createCoreMiddleware.d.ts +3 -0
  76. package/lib/Middleware/Activity/createCoreMiddleware.d.ts.map +1 -0
  77. package/lib/Middleware/Activity/createCoreMiddleware.js +1 -1
  78. package/lib/Middleware/ActivityStatus/AbsoluteTime.js +1 -1
  79. package/lib/Middleware/ActivityStatus/RelativeTime.js +1 -1
  80. package/lib/Middleware/ActivityStatus/SendStatus/SendFailedRetry.js +3 -3
  81. package/lib/Middleware/ActivityStatus/SendStatus/SendStatus.d.ts +11 -0
  82. package/lib/Middleware/ActivityStatus/SendStatus/SendStatus.d.ts.map +1 -0
  83. package/lib/Middleware/ActivityStatus/SendStatus/SendStatus.js +4 -4
  84. package/lib/Middleware/ActivityStatus/Timestamp.d.ts +9 -0
  85. package/lib/Middleware/ActivityStatus/Timestamp.d.ts.map +1 -0
  86. package/lib/Middleware/ActivityStatus/Timestamp.js +2 -2
  87. package/lib/Middleware/ActivityStatus/createCoreMiddleware.d.ts +3 -0
  88. package/lib/Middleware/ActivityStatus/createCoreMiddleware.d.ts.map +1 -0
  89. package/lib/Middleware/ActivityStatus/createCoreMiddleware.js +1 -1
  90. package/lib/Middleware/ActivityStatus/createSendStatusMiddleware.js +5 -3
  91. package/lib/Middleware/ActivityStatus/createTimestampMiddleware.js +1 -1
  92. package/lib/Middleware/Attachment/createCoreMiddleware.d.ts +3 -0
  93. package/lib/Middleware/Attachment/createCoreMiddleware.d.ts.map +1 -0
  94. package/lib/Middleware/Attachment/createCoreMiddleware.js +9 -9
  95. package/lib/Middleware/AttachmentForScreenReader/AudioAttachment.js +1 -1
  96. package/lib/Middleware/AttachmentForScreenReader/FileAttachment.js +1 -1
  97. package/lib/Middleware/AttachmentForScreenReader/ImageAttachment.js +1 -1
  98. package/lib/Middleware/AttachmentForScreenReader/TextAttachment.js +1 -1
  99. package/lib/Middleware/AttachmentForScreenReader/VideoAttachment.js +1 -1
  100. package/lib/Middleware/AttachmentForScreenReader/createCoreMiddleware.d.ts +3 -0
  101. package/lib/Middleware/AttachmentForScreenReader/createCoreMiddleware.d.ts.map +1 -0
  102. package/lib/Middleware/AttachmentForScreenReader/createCoreMiddleware.js +9 -5
  103. package/lib/Middleware/Avatar/createCoreMiddleware.d.ts +11 -0
  104. package/lib/Middleware/Avatar/createCoreMiddleware.d.ts.map +1 -0
  105. package/lib/Middleware/Avatar/createCoreMiddleware.js +2 -2
  106. package/lib/Middleware/CardAction/createCoreMiddleware.js +2 -2
  107. package/lib/Middleware/GroupActivities/createCoreMiddleware.js +1 -1
  108. package/lib/Middleware/ScrollToEndButton/ScrollToEndButton.js +71 -0
  109. package/lib/Middleware/ScrollToEndButton/createScrollToEndButtonMiddleware.d.ts +3 -0
  110. package/lib/Middleware/ScrollToEndButton/createScrollToEndButtonMiddleware.d.ts.map +1 -0
  111. package/lib/Middleware/ScrollToEndButton/createScrollToEndButtonMiddleware.js +27 -0
  112. package/lib/Middleware/Toast/createCoreMiddleware.d.ts +4 -0
  113. package/lib/Middleware/Toast/createCoreMiddleware.d.ts.map +1 -0
  114. package/lib/Middleware/Toast/createCoreMiddleware.js +1 -1
  115. package/lib/Middleware/TypingIndicator/createCoreMiddleware.d.ts +3 -0
  116. package/lib/Middleware/TypingIndicator/createCoreMiddleware.d.ts.map +1 -0
  117. package/lib/Middleware/TypingIndicator/createCoreMiddleware.js +3 -2
  118. package/lib/ReactWebChat.d.ts +10 -0
  119. package/lib/ReactWebChat.d.ts.map +1 -0
  120. package/lib/ReactWebChat.js +19 -7
  121. package/lib/ScreenReaderActivity.js +64 -45
  122. package/lib/SendBox/Assets/AttachmentIcon.js +3 -1
  123. package/lib/SendBox/Assets/MicrophoneIcon.js +3 -1
  124. package/lib/SendBox/Assets/SendIcon.js +2 -2
  125. package/lib/SendBox/AutoResizeTextArea.d.ts +23 -0
  126. package/lib/SendBox/AutoResizeTextArea.d.ts.map +1 -0
  127. package/lib/SendBox/AutoResizeTextArea.js +6 -6
  128. package/lib/SendBox/DictationInterims.d.ts +9 -0
  129. package/lib/SendBox/DictationInterims.d.ts.map +1 -0
  130. package/lib/SendBox/DictationInterims.js +2 -2
  131. package/lib/SendBox/IconButton.js +2 -2
  132. package/lib/SendBox/MicrophoneButton.d.ts +11 -0
  133. package/lib/SendBox/MicrophoneButton.d.ts.map +1 -0
  134. package/lib/SendBox/MicrophoneButton.js +25 -24
  135. package/lib/SendBox/SendButton.d.ts +9 -0
  136. package/lib/SendBox/SendButton.d.ts.map +1 -0
  137. package/lib/SendBox/SendButton.js +7 -5
  138. package/lib/SendBox/SuggestedAction.js +5 -9
  139. package/lib/SendBox/SuggestedActions.d.ts +5 -0
  140. package/lib/SendBox/SuggestedActions.d.ts.map +1 -0
  141. package/lib/SendBox/SuggestedActions.js +10 -7
  142. package/lib/SendBox/TextBox.d.ts +28 -0
  143. package/lib/SendBox/TextBox.d.ts.map +1 -0
  144. package/lib/SendBox/TextBox.js +12 -7
  145. package/lib/SendBox/UploadButton.d.ts +9 -0
  146. package/lib/SendBox/UploadButton.d.ts.map +1 -0
  147. package/lib/SendBox/UploadButton.js +5 -5
  148. package/lib/Styles/StyleSet/Activities.d.ts +5 -0
  149. package/lib/Styles/StyleSet/Activities.d.ts.map +1 -0
  150. package/lib/Styles/StyleSet/AudioAttachment.d.ts +6 -0
  151. package/lib/Styles/StyleSet/AudioAttachment.d.ts.map +1 -0
  152. package/lib/Styles/StyleSet/AudioContent.d.ts +4 -0
  153. package/lib/Styles/StyleSet/AudioContent.d.ts.map +1 -0
  154. package/lib/Styles/StyleSet/AutoResizeTextArea.d.ts +37 -0
  155. package/lib/Styles/StyleSet/AutoResizeTextArea.d.ts.map +1 -0
  156. package/lib/Styles/StyleSet/Avatar.d.ts +9 -0
  157. package/lib/Styles/StyleSet/Avatar.d.ts.map +1 -0
  158. package/lib/Styles/StyleSet/BasicTranscript.d.ts +77 -0
  159. package/lib/Styles/StyleSet/BasicTranscript.d.ts.map +1 -0
  160. package/lib/Styles/StyleSet/Bubble.d.ts +5 -0
  161. package/lib/Styles/StyleSet/Bubble.d.ts.map +1 -0
  162. package/lib/Styles/StyleSet/Bubble.js +1 -1
  163. package/lib/Styles/StyleSet/CarouselFilmStrip.d.ts +5 -0
  164. package/lib/Styles/StyleSet/CarouselFilmStrip.d.ts.map +1 -0
  165. package/lib/Styles/StyleSet/CarouselFilmStrip.js +2 -18
  166. package/lib/Styles/StyleSet/CarouselFilmStripAttachment.d.ts +3 -0
  167. package/lib/Styles/StyleSet/CarouselFilmStripAttachment.d.ts.map +1 -0
  168. package/lib/Styles/StyleSet/CarouselFilmStripAttachment.js +63 -0
  169. package/lib/Styles/StyleSet/CarouselFlipper.d.ts +27 -0
  170. package/lib/Styles/StyleSet/CarouselFlipper.d.ts.map +1 -0
  171. package/lib/Styles/StyleSet/ConnectivityNotification.d.ts +13 -0
  172. package/lib/Styles/StyleSet/ConnectivityNotification.d.ts.map +1 -0
  173. package/lib/Styles/StyleSet/DictationInterims.d.ts +13 -0
  174. package/lib/Styles/StyleSet/DictationInterims.d.ts.map +1 -0
  175. package/lib/Styles/StyleSet/ErrorBox.d.ts +33 -0
  176. package/lib/Styles/StyleSet/ErrorBox.d.ts.map +1 -0
  177. package/lib/Styles/StyleSet/ErrorNotification.d.ts +23 -0
  178. package/lib/Styles/StyleSet/ErrorNotification.d.ts.map +1 -0
  179. package/lib/Styles/StyleSet/FileContent.d.ts +32 -0
  180. package/lib/Styles/StyleSet/FileContent.d.ts.map +1 -0
  181. package/lib/Styles/StyleSet/ImageAvatar.d.ts +7 -0
  182. package/lib/Styles/StyleSet/ImageAvatar.d.ts.map +1 -0
  183. package/lib/Styles/StyleSet/InitialsAvatar.d.ts +19 -0
  184. package/lib/Styles/StyleSet/InitialsAvatar.d.ts.map +1 -0
  185. package/lib/Styles/StyleSet/MicrophoneButton.d.ts +13 -0
  186. package/lib/Styles/StyleSet/MicrophoneButton.d.ts.map +1 -0
  187. package/lib/Styles/StyleSet/Root.d.ts +8 -0
  188. package/lib/Styles/StyleSet/Root.d.ts.map +1 -0
  189. package/lib/Styles/StyleSet/ScrollToEndButton.d.ts +36 -0
  190. package/lib/Styles/StyleSet/ScrollToEndButton.d.ts.map +1 -0
  191. package/lib/Styles/StyleSet/ScrollToEndButton.js +36 -34
  192. package/lib/Styles/StyleSet/SendBox.d.ts +24 -0
  193. package/lib/Styles/StyleSet/SendBox.d.ts.map +1 -0
  194. package/lib/Styles/StyleSet/SendBoxButton.d.ts +33 -0
  195. package/lib/Styles/StyleSet/SendBoxButton.d.ts.map +1 -0
  196. package/lib/Styles/StyleSet/SendBoxTextBox.d.ts +41 -0
  197. package/lib/Styles/StyleSet/SendBoxTextBox.d.ts.map +1 -0
  198. package/lib/Styles/StyleSet/SendStatus.d.ts +8 -0
  199. package/lib/Styles/StyleSet/SendStatus.d.ts.map +1 -0
  200. package/lib/Styles/StyleSet/SingleAttachmentActivity.d.ts +11 -0
  201. package/lib/Styles/StyleSet/SingleAttachmentActivity.d.ts.map +1 -0
  202. package/lib/Styles/StyleSet/SpinnerAnimation.d.ts +15 -0
  203. package/lib/Styles/StyleSet/SpinnerAnimation.d.ts.map +1 -0
  204. package/lib/Styles/StyleSet/StackedLayout.d.ts +63 -0
  205. package/lib/Styles/StyleSet/StackedLayout.d.ts.map +1 -0
  206. package/lib/Styles/StyleSet/SuggestedAction.d.ts +49 -0
  207. package/lib/Styles/StyleSet/SuggestedAction.d.ts.map +1 -0
  208. package/lib/Styles/StyleSet/SuggestedAction.js +2 -2
  209. package/lib/Styles/StyleSet/SuggestedActions.d.ts +118 -0
  210. package/lib/Styles/StyleSet/SuggestedActions.d.ts.map +1 -0
  211. package/lib/Styles/StyleSet/TextContent.d.ts +28 -0
  212. package/lib/Styles/StyleSet/TextContent.d.ts.map +1 -0
  213. package/lib/Styles/StyleSet/Toast.d.ts +65 -0
  214. package/lib/Styles/StyleSet/Toast.d.ts.map +1 -0
  215. package/lib/Styles/StyleSet/Toaster.d.ts +111 -0
  216. package/lib/Styles/StyleSet/Toaster.d.ts.map +1 -0
  217. package/lib/Styles/StyleSet/TypingAnimation.d.ts +8 -0
  218. package/lib/Styles/StyleSet/TypingAnimation.d.ts.map +1 -0
  219. package/lib/Styles/StyleSet/TypingIndicator.d.ts +11 -0
  220. package/lib/Styles/StyleSet/TypingIndicator.d.ts.map +1 -0
  221. package/lib/Styles/StyleSet/UploadButton.d.ts +14 -0
  222. package/lib/Styles/StyleSet/UploadButton.d.ts.map +1 -0
  223. package/lib/Styles/StyleSet/VideoAttachment.d.ts +2 -0
  224. package/lib/Styles/StyleSet/VideoAttachment.d.ts.map +1 -0
  225. package/lib/Styles/StyleSet/VideoContent.d.ts +6 -0
  226. package/lib/Styles/StyleSet/VideoContent.d.ts.map +1 -0
  227. package/lib/Styles/StyleSet/VimeoContent.d.ts +7 -0
  228. package/lib/Styles/StyleSet/VimeoContent.d.ts.map +1 -0
  229. package/lib/Styles/StyleSet/WarningNotification.d.ts +22 -0
  230. package/lib/Styles/StyleSet/WarningNotification.d.ts.map +1 -0
  231. package/lib/Styles/StyleSet/YouTubeContent.d.ts +7 -0
  232. package/lib/Styles/StyleSet/YouTubeContent.d.ts.map +1 -0
  233. package/lib/Styles/createStyleSet.d.ts +1103 -0
  234. package/lib/Styles/createStyleSet.d.ts.map +1 -0
  235. package/lib/Styles/createStyleSet.js +44 -41
  236. package/lib/Styles/mirrorStyle.js +2 -2
  237. package/lib/Toast/CollapseIcon.js +3 -1
  238. package/lib/Toast/DismissIcon.js +3 -1
  239. package/lib/Toast/ExpandIcon.js +3 -1
  240. package/lib/Toast/NotificationIcon.js +1 -1
  241. package/lib/Toast/createToastMiddleware.d.ts +4 -0
  242. package/lib/Toast/createToastMiddleware.d.ts.map +1 -0
  243. package/lib/Toast/createToastMiddleware.js +2 -2
  244. package/lib/Utils/AccessKeySink/Surface.js +7 -5
  245. package/lib/Utils/AccessibleButton.js +6 -4
  246. package/lib/Utils/AccessibleInputText.d.ts +21 -0
  247. package/lib/Utils/AccessibleInputText.d.ts.map +1 -0
  248. package/lib/Utils/AccessibleInputText.js +29 -25
  249. package/lib/Utils/AccessibleTextArea.d.ts +20 -0
  250. package/lib/Utils/AccessibleTextArea.d.ts.map +1 -0
  251. package/lib/Utils/AccessibleTextArea.js +35 -24
  252. package/lib/Utils/CroppedImage.js +2 -2
  253. package/lib/Utils/Fade.js +2 -2
  254. package/lib/Utils/FocusRedirector.js +3 -3
  255. package/lib/Utils/InlineMarkdown.js +6 -6
  256. package/lib/Utils/TypeFocusSink/FocusBox.js +6 -4
  257. package/lib/Utils/TypeFocusSink/getTabIndex.d.ts +2 -0
  258. package/lib/Utils/TypeFocusSink/getTabIndex.d.ts.map +1 -0
  259. package/lib/Utils/TypeFocusSink/getTabIndex.js +1 -1
  260. package/lib/Utils/TypeFocusSink/navigableEvent.js +1 -1
  261. package/lib/Utils/activityAltText.js +100 -0
  262. package/lib/Utils/addTargetBlankToHyperlinksMarkdown.js +1 -1
  263. package/lib/Utils/createCustomEvent.js +1 -1
  264. package/lib/Utils/debounce.js +1 -1
  265. package/lib/Utils/detectBrowser.js +1 -1
  266. package/lib/Utils/downscaleImageToDataURL/downscaleImageToDataURLUsingWorker.js +2 -2
  267. package/lib/Utils/downscaleImageToDataURL/index.js +2 -2
  268. package/lib/Utils/filterMap.js +1 -1
  269. package/lib/Utils/findLastIndex.js +2 -2
  270. package/lib/Utils/mapMap.js +1 -1
  271. package/lib/Utils/readDataURIToBlob.js +2 -2
  272. package/lib/Utils/singleToArray.js +1 -1
  273. package/lib/connectToWebChat.js +5 -3
  274. package/lib/hooks/index.d.ts +21 -0
  275. package/lib/hooks/index.d.ts.map +1 -0
  276. package/lib/hooks/index.js +1 -1
  277. package/lib/hooks/internal/BypassSpeechSynthesisPonyfill.js +97 -39
  278. package/lib/hooks/internal/UITracker.js +2 -2
  279. package/lib/hooks/internal/useAcknowledgedActivity.js +2 -2
  280. package/lib/hooks/internal/useDispatchScrollPosition.js +1 -1
  281. package/lib/hooks/internal/useDispatchTranscriptFocus.js +1 -1
  282. package/lib/hooks/internal/useEnterKeyHint.js +1 -1
  283. package/lib/hooks/internal/useForceRender.js +2 -2
  284. package/lib/hooks/internal/useForceRenderAtInterval.js +2 -2
  285. package/lib/hooks/internal/useInternalRenderMarkdownInline.js +1 -1
  286. package/lib/hooks/internal/useLocalizeAccessKey.js +2 -2
  287. package/lib/hooks/internal/useMemoize.js +2 -2
  288. package/lib/hooks/internal/useNavigatorPlatform.js +1 -1
  289. package/lib/hooks/internal/useNonce.js +1 -1
  290. package/lib/hooks/internal/useRegisterFocusSendBox.js +1 -1
  291. package/lib/hooks/internal/useRegisterFocusTranscript.js +1 -1
  292. package/lib/hooks/internal/useRegisterScrollRelative.js +1 -1
  293. package/lib/hooks/internal/useRegisterScrollTo.js +1 -1
  294. package/lib/hooks/internal/useRegisterScrollToEnd.js +1 -1
  295. package/lib/hooks/internal/useReplaceEmoticon.js +2 -2
  296. package/lib/hooks/internal/useResumeAudioContext.js +33 -0
  297. package/lib/hooks/internal/useScrollRelative.js +1 -1
  298. package/lib/hooks/internal/useSettableDictateAbortable.js +1 -1
  299. package/lib/hooks/internal/useSuggestedActionsAccessKey.js +1 -1
  300. package/lib/hooks/internal/useUniqueId.d.ts +2 -0
  301. package/lib/hooks/internal/useUniqueId.d.ts.map +1 -0
  302. package/lib/hooks/internal/useUniqueId.js +1 -1
  303. package/lib/hooks/useDictateAbortable.d.ts +2 -0
  304. package/lib/hooks/useDictateAbortable.d.ts.map +1 -0
  305. package/lib/hooks/useDictateAbortable.js +2 -2
  306. package/lib/hooks/useFocus.d.ts +2 -0
  307. package/lib/hooks/useFocus.d.ts.map +1 -0
  308. package/lib/hooks/useFocus.js +1 -1
  309. package/lib/hooks/useFocusSendBox.d.ts +3 -0
  310. package/lib/hooks/useFocusSendBox.d.ts.map +1 -0
  311. package/lib/hooks/useFocusSendBox.js +2 -1
  312. package/lib/hooks/useObserveScrollPosition.d.ts +3 -0
  313. package/lib/hooks/useObserveScrollPosition.d.ts.map +1 -0
  314. package/lib/hooks/useObserveScrollPosition.js +2 -2
  315. package/lib/hooks/useObserveTranscriptFocus.d.ts +5 -0
  316. package/lib/hooks/useObserveTranscriptFocus.d.ts.map +1 -0
  317. package/lib/hooks/useObserveTranscriptFocus.js +2 -2
  318. package/lib/hooks/useRenderMarkdownAsHTML.d.ts +5 -0
  319. package/lib/hooks/useRenderMarkdownAsHTML.d.ts.map +1 -0
  320. package/lib/hooks/useRenderMarkdownAsHTML.js +2 -2
  321. package/lib/hooks/useScrollDown.d.ts +4 -0
  322. package/lib/hooks/useScrollDown.d.ts.map +1 -0
  323. package/lib/hooks/useScrollDown.js +1 -1
  324. package/lib/hooks/useScrollTo.d.ts +5 -0
  325. package/lib/hooks/useScrollTo.d.ts.map +1 -0
  326. package/lib/hooks/useScrollTo.js +1 -1
  327. package/lib/hooks/useScrollToEnd.d.ts +2 -0
  328. package/lib/hooks/useScrollToEnd.d.ts.map +1 -0
  329. package/lib/hooks/useScrollToEnd.js +1 -1
  330. package/lib/hooks/useScrollUp.d.ts +4 -0
  331. package/lib/hooks/useScrollUp.d.ts.map +1 -0
  332. package/lib/hooks/useScrollUp.js +1 -1
  333. package/lib/hooks/useSendFiles.d.ts +2 -0
  334. package/lib/hooks/useSendFiles.d.ts.map +1 -0
  335. package/lib/hooks/useSendFiles.js +3 -3
  336. package/lib/hooks/useStyleSet.d.ts +2 -0
  337. package/lib/hooks/useStyleSet.d.ts.map +1 -0
  338. package/lib/hooks/useStyleSet.js +1 -1
  339. package/lib/hooks/useWebSpeechPonyfill.d.ts +3 -0
  340. package/lib/hooks/useWebSpeechPonyfill.d.ts.map +1 -0
  341. package/lib/hooks/useWebSpeechPonyfill.js +1 -1
  342. package/lib/index.d.ts +209 -22
  343. package/lib/index.d.ts.map +1 -1
  344. package/lib/index.js +19 -19
  345. package/lib/tsconfig.json +1 -1
  346. package/lib/types/ScrollPosition.d.ts +6 -0
  347. package/lib/types/ScrollPosition.d.ts.map +1 -0
  348. package/lib/types/ScrollPosition.js +2 -0
  349. package/package.json +38 -38
  350. package/src/Activity/{Avatar.js → Avatar.tsx} +9 -2
  351. package/src/Activity/{Bubble.js → Bubble.tsx} +10 -2
  352. package/src/Activity/CarouselFilmStrip.js +20 -29
  353. package/src/Activity/CarouselFilmStripAttachment.js +92 -0
  354. package/src/Activity/{Speak.js → Speak.tsx} +12 -5
  355. package/src/Activity/{StackedLayout.js → StackedLayout.tsx} +36 -11
  356. package/src/Attachment/Assets/DownloadIcon.js +8 -1
  357. package/src/Attachment/{AudioContent.js → AudioContent.tsx} +12 -3
  358. package/src/Attachment/{FileContent.js → FileContent.tsx} +10 -7
  359. package/src/Attachment/{HTMLVideoContent.js → HTMLVideoContent.tsx} +10 -2
  360. package/src/Attachment/{ImageContent.js → ImageContent.tsx} +7 -2
  361. package/src/Attachment/{TextContent.js → TextContent.tsx} +14 -7
  362. package/src/Attachment/{VideoContent.js → VideoContent.tsx} +10 -2
  363. package/src/Attachment/{VimeoContent.js → VimeoContent.tsx} +15 -8
  364. package/src/Attachment/{YouTubeContent.js → YouTubeContent.tsx} +12 -5
  365. package/src/{BasicSendBox.js → BasicSendBox.tsx} +9 -5
  366. package/src/BasicToaster.js +4 -4
  367. package/src/BasicTranscript.js +114 -98
  368. package/src/{BasicTypingIndicator.js → BasicTypingIndicator.tsx} +1 -1
  369. package/src/{BasicWebChat.js → BasicWebChat.tsx} +13 -4
  370. package/src/{Composer.js → Composer.tsx} +41 -42
  371. package/src/Dictation.js +13 -4
  372. package/src/{ErrorBox.js → ErrorBox.tsx} +7 -2
  373. package/src/Middleware/Activity/{createCoreMiddleware.js → createCoreMiddleware.tsx} +2 -1
  374. package/src/Middleware/ActivityStatus/SendStatus/{SendStatus.js → SendStatus.tsx} +8 -3
  375. package/src/Middleware/ActivityStatus/{Timestamp.js → Timestamp.tsx} +8 -2
  376. package/src/Middleware/ActivityStatus/{createCoreMiddleware.js → createCoreMiddleware.tsx} +3 -1
  377. package/src/Middleware/ActivityStatus/createSendStatusMiddleware.js +8 -6
  378. package/src/Middleware/ActivityStatus/createTimestampMiddleware.js +10 -8
  379. package/src/Middleware/Attachment/{createCoreMiddleware.js → createCoreMiddleware.tsx} +8 -7
  380. package/src/Middleware/AttachmentForScreenReader/{createCoreMiddleware.js → createCoreMiddleware.tsx} +4 -3
  381. package/src/Middleware/Avatar/{createCoreMiddleware.js → createCoreMiddleware.tsx} +10 -3
  382. package/src/Middleware/CardAction/createCoreMiddleware.js +43 -41
  383. package/src/Middleware/GroupActivities/createCoreMiddleware.js +6 -4
  384. package/src/Middleware/ScrollToEndButton/ScrollToEndButton.js +45 -0
  385. package/src/Middleware/ScrollToEndButton/createScrollToEndButtonMiddleware.ts +17 -0
  386. package/src/Middleware/Toast/{createCoreMiddleware.js → createCoreMiddleware.tsx} +3 -1
  387. package/src/Middleware/TypingIndicator/{createCoreMiddleware.js → createCoreMiddleware.tsx} +3 -4
  388. package/src/{ReactWebChat.js → ReactWebChat.tsx} +25 -7
  389. package/src/ScreenReaderActivity.js +47 -37
  390. package/src/SendBox/Assets/AttachmentIcon.js +1 -1
  391. package/src/SendBox/Assets/MicrophoneIcon.js +1 -1
  392. package/src/SendBox/{AutoResizeTextArea.js → AutoResizeTextArea.tsx} +30 -4
  393. package/src/SendBox/{DictationInterims.js → DictationInterims.tsx} +6 -2
  394. package/src/SendBox/{MicrophoneButton.js → MicrophoneButton.tsx} +35 -25
  395. package/src/SendBox/{SendButton.js → SendButton.tsx} +8 -3
  396. package/src/SendBox/SuggestedAction.js +1 -15
  397. package/src/SendBox/{SuggestedActions.js → SuggestedActions.tsx} +42 -21
  398. package/src/SendBox/{TextBox.js → TextBox.tsx} +21 -7
  399. package/src/SendBox/{UploadButton.js → UploadButton.tsx} +7 -3
  400. package/src/Styles/StyleSet/CarouselFilmStrip.ts +0 -20
  401. package/src/Styles/StyleSet/CarouselFilmStripAttachment.ts +56 -0
  402. package/src/Styles/StyleSet/ScrollToEndButton.ts +33 -31
  403. package/src/Styles/StyleSet/SuggestedAction.ts +1 -1
  404. package/src/Styles/createStyleSet.ts +41 -39
  405. package/src/Toast/CollapseIcon.js +9 -1
  406. package/src/Toast/DismissIcon.js +9 -1
  407. package/src/Toast/ExpandIcon.js +9 -1
  408. package/src/Toast/{createToastMiddleware.js → createToastMiddleware.tsx} +3 -2
  409. package/src/Utils/{AccessibleInputText.js → AccessibleInputText.tsx} +48 -5
  410. package/src/Utils/{AccessibleTextArea.js → AccessibleTextArea.tsx} +67 -6
  411. package/src/Utils/TypeFocusSink/FocusBox.js +4 -4
  412. package/src/Utils/TypeFocusSink/getTabIndex.ts +1 -1
  413. package/src/Utils/activityAltText.ts +135 -0
  414. package/src/Utils/findLastIndex.spec.js +2 -0
  415. package/src/Utils/intersectionOf.spec.js +2 -0
  416. package/src/Utils/mapMap.spec.js +2 -0
  417. package/src/Utils/removeInline.spec.js +2 -0
  418. package/src/Utils/{singleToArray.js → singleToArray.ts} +1 -1
  419. package/src/Utils/walkMarkdownTokens.spec.js +3 -3
  420. package/src/hooks/{index.js → index.ts} +1 -0
  421. package/src/hooks/internal/BypassSpeechSynthesisPonyfill.js +68 -17
  422. package/src/hooks/internal/useMemoize.spec.js +2 -0
  423. package/src/hooks/internal/useResumeAudioContext.ts +7 -0
  424. package/src/hooks/internal/useScrollRelative.js +4 -3
  425. package/src/hooks/internal/{useUniqueId.js → useUniqueId.ts} +1 -1
  426. package/src/hooks/{useDictateAbortable.js → useDictateAbortable.ts} +1 -1
  427. package/src/hooks/{useFocus.js → useFocus.ts} +1 -1
  428. package/src/hooks/{useFocusSendBox.js → useFocusSendBox.ts} +2 -1
  429. package/src/hooks/{useObserveScrollPosition.js → useObserveScrollPosition.ts} +6 -1
  430. package/src/hooks/{useObserveTranscriptFocus.js → useObserveTranscriptFocus.ts} +6 -1
  431. package/src/hooks/{useRenderMarkdownAsHTML.js → useRenderMarkdownAsHTML.ts} +6 -2
  432. package/src/hooks/{useScrollDown.js → useScrollDown.ts} +1 -1
  433. package/src/hooks/{useScrollTo.js → useScrollTo.ts} +5 -1
  434. package/src/hooks/{useScrollToEnd.js → useScrollToEnd.ts} +1 -1
  435. package/src/hooks/{useScrollUp.js → useScrollUp.ts} +1 -1
  436. package/src/hooks/{useSendFiles.js → useSendFiles.ts} +3 -2
  437. package/src/hooks/{useStyleSet.js → useStyleSet.ts} +1 -1
  438. package/src/hooks/useWebSpeechPonyfill.ts +7 -0
  439. package/src/index.ts +7 -11
  440. package/src/tsconfig.json +1 -1
  441. package/src/types/ScrollPosition.ts +6 -0
  442. package/lib/Activity/ScrollToEndButton.js +0 -81
  443. package/lib/Attachment/Assets/ErrorIcon.js +0 -22
  444. package/lib/Utils/remarkStripMarkdown.js +0 -26
  445. package/lib/hooks/internal/useStripMarkdown.js +0 -19
  446. package/src/Activity/ScrollToEndButton.js +0 -58
  447. package/src/Attachment/Assets/ErrorIcon.js +0 -9
  448. package/src/Utils/remarkStripMarkdown.js +0 -13
  449. package/src/hooks/internal/useStripMarkdown.js +0 -7
  450. package/src/hooks/useWebSpeechPonyfill.js +0 -5
  451. package/src/index.tsx +0 -35
@@ -41,8 +41,6 @@ var _ScreenReaderActivity = _interopRequireDefault(require("./ScreenReaderActivi
41
41
 
42
42
  var _ScreenReaderText = _interopRequireDefault(require("./ScreenReaderText"));
43
43
 
44
- var _ScrollToEndButton = _interopRequireDefault(require("./Activity/ScrollToEndButton"));
45
-
46
44
  var _Speak = _interopRequireDefault(require("./Activity/Speak"));
47
45
 
48
46
  var _tabbableElements = _interopRequireDefault(require("./Utils/tabbableElements"));
@@ -71,13 +69,13 @@ var _useStyleToEmotionObject = _interopRequireDefault(require("./hooks/internal/
71
69
 
72
70
  var _useUniqueId = _interopRequireDefault(require("./hooks/internal/useUniqueId"));
73
71
 
74
- function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
72
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
75
73
 
76
- function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (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; }
74
+ 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; }
77
75
 
78
76
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
79
77
 
80
- 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; }
78
+ 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; }
81
79
 
82
80
  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; }
83
81
 
@@ -87,7 +85,7 @@ function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableTo
87
85
 
88
86
  function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
89
87
 
90
- function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }
88
+ function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
91
89
 
92
90
  function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
93
91
 
@@ -99,7 +97,7 @@ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o =
99
97
 
100
98
  function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
101
99
 
102
- function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
100
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
103
101
 
104
102
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
105
103
 
@@ -107,6 +105,7 @@ var useActivities = _botframeworkWebchatApi.hooks.useActivities,
107
105
  useCreateActivityRenderer = _botframeworkWebchatApi.hooks.useCreateActivityRenderer,
108
106
  useCreateActivityStatusRenderer = _botframeworkWebchatApi.hooks.useCreateActivityStatusRenderer,
109
107
  useCreateAvatarRenderer = _botframeworkWebchatApi.hooks.useCreateAvatarRenderer,
108
+ useCreateScrollToEndButtonRenderer = _botframeworkWebchatApi.hooks.useCreateScrollToEndButtonRenderer,
110
109
  useDirection = _botframeworkWebchatApi.hooks.useDirection,
111
110
  useGroupActivities = _botframeworkWebchatApi.hooks.useGroupActivities,
112
111
  useLocalizer = _botframeworkWebchatApi.hooks.useLocalizer,
@@ -318,6 +317,8 @@ var InternalTranscript = function InternalTranscript(_ref) {
318
317
  var firstInSenderGroup = !indexWithinSenderGroup;
319
318
  var lastInSenderGroup = indexWithinSenderGroup === activitiesWithSameSender.length - 1;
320
319
  activitiesWithSameSenderAndStatus.forEach(function (activity, indexWithinSenderAndStatusGroup) {
320
+ var _activity$channelData, _activity$channelData2, _activity$channelData3, _activity$channelData4, _activity$channelData5;
321
+
321
322
  // We only show the timestamp at the end of the sender group. But we always show the "Send failed, retry" prompt.
322
323
  var renderActivityStatus = createActivityStatusRenderer({
323
324
  activity: activity
@@ -331,13 +332,10 @@ var InternalTranscript = function InternalTranscript(_ref) {
331
332
  renderActivity = _activitiesWithRender.renderActivity;
332
333
 
333
334
  var key = (0, _getActivityUniqueId.default)(activity) || renderingElements.length;
334
- var _activity$channelData = activity.channelData;
335
- _activity$channelData = _activity$channelData === void 0 ? {} : _activity$channelData;
336
- var _activity$channelData2 = _activity$channelData.messageBack;
337
- _activity$channelData2 = _activity$channelData2 === void 0 ? {} : _activity$channelData2;
338
- var messageBackDisplayText = _activity$channelData2.displayText,
339
- role = activity.from.role,
340
- text = activity.text;
335
+ var baseAltText = typeof (activity === null || activity === void 0 ? void 0 : (_activity$channelData = activity.channelData) === null || _activity$channelData === void 0 ? void 0 : _activity$channelData['webchat:fallback-text']) === 'string' ? activity === null || activity === void 0 ? void 0 : (_activity$channelData2 = activity.channelData) === null || _activity$channelData2 === void 0 ? void 0 : _activity$channelData2['webchat:fallback-text'] : (activity === null || activity === void 0 ? void 0 : (_activity$channelData3 = activity.channelData) === null || _activity$channelData3 === void 0 ? void 0 : (_activity$channelData4 = _activity$channelData3.messageBack) === null || _activity$channelData4 === void 0 ? void 0 : _activity$channelData4.displayText) || activity.text; // If "webchat:fallback-text" field is set to empty string, the activity must not be narrated.
336
+
337
+ var supportScreenReader = (activity === null || activity === void 0 ? void 0 : (_activity$channelData5 = activity.channelData) === null || _activity$channelData5 === void 0 ? void 0 : _activity$channelData5['webchat:fallback-text']) !== '';
338
+ var role = activity.from.role;
341
339
  var topSideNub = role === 'user' ? topSideUserNub : topSideBotNub;
342
340
  var showCallout; // Depending on the "showAvatarInGroup" setting, the avatar will render in different positions.
343
341
 
@@ -408,15 +406,16 @@ var InternalTranscript = function InternalTranscript(_ref) {
408
406
  // retry prompt. And show the screen reader version of the timestamp.
409
407
  hideTimestamp: hideAllTimestamps || indexWithinSenderAndStatusGroup !== activitiesWithSameSenderAndStatus.length - 1,
410
408
  key: key,
411
- // When "liveRegionKey" changes, it will show up in the live region momentarily.
412
- liveRegionKey: key + '|' + (messageBackDisplayText || text),
409
+ // When "liveRegionKey" changes or contents that made up the alt text changed, it will show up in the live region momentarily.
410
+ liveRegionKey: key + '|' + baseAltText,
413
411
  renderActivity: renderActivity,
414
412
  renderActivityStatus: renderActivityStatus,
415
413
  renderAvatar: renderAvatar,
416
414
  role: role,
417
415
  // TODO: [P2] #2858 We should use core/definitions/speakingActivity for this predicate instead
418
416
  shouldSpeak: activity.channelData && activity.channelData.speak,
419
- showCallout: showCallout
417
+ showCallout: showCallout,
418
+ supportScreenReader: supportScreenReader
420
419
  });
421
420
  });
422
421
  });
@@ -509,6 +508,11 @@ var InternalTranscript = function InternalTranscript(_ref) {
509
508
  }
510
509
  }
511
510
  }, [activityElementsRef, rootElementRef, scrollToBottomScrollTo]);
511
+ var scrollToEnd = (0, _react.useCallback)(function () {
512
+ return scrollToBottomScrollToEnd({
513
+ behavior: 'smooth'
514
+ });
515
+ }, [scrollToBottomScrollToEnd]);
512
516
  var scrollRelative = (0, _react.useCallback)(function (direction) {
513
517
  var _ref10 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
514
518
  displacement = _ref10.displacement;
@@ -537,7 +541,7 @@ var InternalTranscript = function InternalTranscript(_ref) {
537
541
  // We call `useRegisterScrollXXX` to register a callback function, the `useScrollXXX` will multiplex the call into each instance of <BasicTranscript>.
538
542
 
539
543
  (0, _useRegisterScrollTo.default)(scrollTo);
540
- (0, _useRegisterScrollToEnd.default)(scrollToBottomScrollToEnd);
544
+ (0, _useRegisterScrollToEnd.default)(scrollToEnd);
541
545
  (0, _useRegisterScrollRelative.default)(scrollRelative);
542
546
  var dispatchScrollPosition = (0, _useDispatchScrollPosition.default)();
543
547
  var patchedDispatchScrollPosition = (0, _react.useMemo)(function () {
@@ -824,9 +828,12 @@ var InternalTranscript = function InternalTranscript(_ref) {
824
828
  "aria-relevant": "additions",
825
829
  "aria-roledescription": transcriptRoleDescription,
826
830
  role: "log"
827
- }, renderingElements.map(function (_ref23) {
828
- var activity = _ref23.activity,
829
- liveRegionKey = _ref23.liveRegionKey;
831
+ }, renderingElements.filter(function (_ref23) {
832
+ var supportScreenReader = _ref23.supportScreenReader;
833
+ return supportScreenReader;
834
+ }).map(function (_ref24) {
835
+ var activity = _ref24.activity,
836
+ liveRegionKey = _ref24.liveRegionKey;
830
837
  return /*#__PURE__*/_react.default.createElement(_Fade.default, {
831
838
  fadeAfter: internalLiveRegionFadeAfter,
832
839
  key: liveRegionKey
@@ -840,27 +847,28 @@ var InternalTranscript = function InternalTranscript(_ref) {
840
847
  onFocusActivity: handleFocusActivity,
841
848
  onFocusFiller: handleFocusFiller,
842
849
  terminatorRef: terminatorRef
843
- }, renderingElements.map(function (_ref24, index) {
844
- var activity = _ref24.activity,
845
- callbackRef = _ref24.callbackRef,
846
- focusActivity = _ref24.focusActivity,
847
- handleFocus = _ref24.handleFocus,
848
- handleKeyDown = _ref24.handleKeyDown,
849
- handleMouseDownCapture = _ref24.handleMouseDownCapture,
850
- hideTimestamp = _ref24.hideTimestamp,
851
- key = _ref24.key,
852
- renderActivity = _ref24.renderActivity,
853
- renderActivityStatus = _ref24.renderActivityStatus,
854
- renderAvatar = _ref24.renderAvatar,
855
- role = _ref24.role,
856
- shouldSpeak = _ref24.shouldSpeak,
857
- showCallout = _ref24.showCallout;
858
-
859
- var _ref25 = activityElementsRef.current.find(function (entry) {
850
+ }, renderingElements.map(function (_ref25, index) {
851
+ var activity = _ref25.activity,
852
+ callbackRef = _ref25.callbackRef,
853
+ focusActivity = _ref25.focusActivity,
854
+ handleFocus = _ref25.handleFocus,
855
+ handleKeyDown = _ref25.handleKeyDown,
856
+ handleMouseDownCapture = _ref25.handleMouseDownCapture,
857
+ hideTimestamp = _ref25.hideTimestamp,
858
+ key = _ref25.key,
859
+ renderActivity = _ref25.renderActivity,
860
+ renderActivityStatus = _ref25.renderActivityStatus,
861
+ renderAvatar = _ref25.renderAvatar,
862
+ role = _ref25.role,
863
+ shouldSpeak = _ref25.shouldSpeak,
864
+ showCallout = _ref25.showCallout,
865
+ supportScreenReader = _ref25.supportScreenReader;
866
+
867
+ var _ref26 = activityElementsRef.current.find(function (entry) {
860
868
  return entry.activity === activity;
861
869
  }) || {},
862
- ariaLabelID = _ref25.ariaLabelID,
863
- element = _ref25.element;
870
+ ariaLabelID = _ref26.ariaLabelID,
871
+ element = _ref26.element;
864
872
 
865
873
  var activeDescendant = focusedActivityKey === key;
866
874
  var isContentInteractive = !!(element ? (0, _tabbableElements.default)(element.querySelector('.webchat__basic-transcript__activity-box')).length : 0);
@@ -880,7 +888,7 @@ var InternalTranscript = function InternalTranscript(_ref) {
880
888
  onKeyDown: handleKeyDown,
881
889
  onMouseDownCapture: handleMouseDownCapture,
882
890
  ref: callbackRef
883
- }, /*#__PURE__*/_react.default.createElement(_ScreenReaderActivity.default, {
891
+ }, supportScreenReader && /*#__PURE__*/_react.default.createElement(_ScreenReaderActivity.default, {
884
892
  activity: activity,
885
893
  id: ariaLabelID,
886
894
  renderAttachments: false
@@ -934,8 +942,8 @@ InternalTranscript.propTypes = {
934
942
  className: _propTypes.default.string
935
943
  };
936
944
 
937
- var InternalScreenReaderTranscript = function InternalScreenReaderTranscript(_ref26) {
938
- var renderingElements = _ref26.renderingElements;
945
+ var InternalScreenReaderTranscript = function InternalScreenReaderTranscript(_ref27) {
946
+ var renderingElements = _ref27.renderingElements;
939
947
  var localize = useLocalizer();
940
948
 
941
949
  var _useStyleOptions3 = useStyleOptions(),
@@ -949,9 +957,9 @@ var InternalScreenReaderTranscript = function InternalScreenReaderTranscript(_re
949
957
  "aria-relevant": "additions",
950
958
  "aria-roledescription": transcriptRoleDescription,
951
959
  role: "log"
952
- }, renderingElements.map(function (_ref27) {
953
- var activity = _ref27.activity,
954
- liveRegionKey = _ref27.liveRegionKey;
960
+ }, renderingElements.map(function (_ref28) {
961
+ var activity = _ref28.activity,
962
+ liveRegionKey = _ref28.liveRegionKey;
955
963
  return /*#__PURE__*/_react.default.createElement(_Fade.default, {
956
964
  fadeAfter: internalLiveRegionFadeAfter,
957
965
  key: liveRegionKey
@@ -970,40 +978,46 @@ InternalScreenReaderTranscript.propTypes = {
970
978
  })).isRequired
971
979
  }; // Separating high-frequency hooks to improve performance.
972
980
 
973
- var InternalTranscriptScrollable = function InternalTranscriptScrollable(_ref28) {
974
- var activities = _ref28.activities,
975
- children = _ref28.children,
976
- onFocusActivity = _ref28.onFocusActivity,
977
- onFocusFiller = _ref28.onFocusFiller,
978
- terminatorRef = _ref28.terminatorRef;
981
+ var InternalTranscriptScrollable = function InternalTranscriptScrollable(_ref29) {
982
+ var activities = _ref29.activities,
983
+ children = _ref29.children,
984
+ onFocusActivity = _ref29.onFocusActivity,
985
+ onFocusFiller = _ref29.onFocusFiller,
986
+ terminatorRef = _ref29.terminatorRef;
979
987
 
980
988
  var _useStyleSet3 = (0, _useStyleSet5.default)(),
981
989
  _useStyleSet4 = _slicedToArray(_useStyleSet3, 1),
982
990
  activitiesStyleSet = _useStyleSet4[0].activities;
983
991
 
984
- var _useStyleOptions5 = useStyleOptions(),
985
- _useStyleOptions6 = _slicedToArray(_useStyleOptions5, 1),
986
- hideScrollToEndButton = _useStyleOptions6[0].hideScrollToEndButton;
987
-
988
992
  var _useAnimatingToEnd = (0, _reactScrollToBottom.useAnimatingToEnd)(),
989
993
  _useAnimatingToEnd2 = _slicedToArray(_useAnimatingToEnd, 1),
990
994
  animatingToEnd = _useAnimatingToEnd2[0];
991
995
 
996
+ var _useAtEnd = (0, _reactScrollToBottom.useAtEnd)(),
997
+ _useAtEnd2 = _slicedToArray(_useAtEnd, 1),
998
+ atEnd = _useAtEnd2[0];
999
+
992
1000
  var _useSticky = (0, _reactScrollToBottom.useSticky)(),
993
1001
  _useSticky2 = _slicedToArray(_useSticky, 1),
994
1002
  sticky = _useSticky2[0];
995
1003
 
1004
+ var _useStyleOptions5 = useStyleOptions(),
1005
+ _useStyleOptions6 = _slicedToArray(_useStyleOptions5, 1),
1006
+ styleOptions = _useStyleOptions6[0];
1007
+
996
1008
  var lastVisibleActivityId = (0, _getActivityUniqueId.default)(activities[activities.length - 1] || {}); // Activity ID of the last visible activity in the list.
997
1009
 
998
1010
  var localize = useLocalizer();
999
- var scrollToEndButtonRef = (0, _react.useRef)();
1011
+ var scrollToEnd = (0, _reactScrollToBottom.useScrollToEnd)();
1000
1012
  var lastReadActivityIdRef = (0, _react.useRef)(lastVisibleActivityId);
1001
1013
  var transcriptRoleDescription = localize('TRANSCRIPT_ARIA_ROLE_ALT');
1002
- var allActivitiesRead = lastVisibleActivityId === lastReadActivityIdRef.current;
1003
1014
  var handleScrollToEndButtonClick = (0, _react.useCallback)(function () {
1004
- // After the "New message" button is clicked, focus on the first unread activity.
1005
- var index = activities.findIndex(function (_ref29) {
1006
- var id = _ref29.id;
1015
+ scrollToEnd({
1016
+ behavior: 'smooth'
1017
+ }); // After the "New message" button is clicked, focus on the first unread activity.
1018
+
1019
+ var index = activities.findIndex(function (_ref30) {
1020
+ var id = _ref30.id;
1007
1021
  return id === lastReadActivityIdRef.current;
1008
1022
  });
1009
1023
 
@@ -1017,46 +1031,26 @@ var InternalTranscriptScrollable = function InternalTranscriptScrollable(_ref28)
1017
1031
 
1018
1032
  var current = terminatorRef.current;
1019
1033
  current && current.focus();
1020
- }, [activities, lastReadActivityIdRef, onFocusActivity, terminatorRef]);
1034
+ }, [activities, lastReadActivityIdRef, onFocusActivity, scrollToEnd, terminatorRef]);
1021
1035
 
1022
- if (sticky) {
1023
- // If it is sticky, the user is at the bottom of the transcript, everything is read.
1036
+ if (atEnd || sticky) {
1037
+ // If it is sticky or at the end, the user is at the bottom of the transcript, everything is read.
1024
1038
  // So mark the activity ID as read.
1025
1039
  lastReadActivityIdRef.current = lastVisibleActivityId;
1026
- } // Finds where we should render the "New messages" button, in index. Returns -1 to hide the button.
1027
-
1028
-
1029
- var renderSeparatorAfterIndex = (0, _react.useMemo)(function () {
1030
- // Don't show the button if:
1031
- // - All activities have been read
1032
- // - Currently animating towards bottom
1033
- // - "New messages" button must not flash when: 1. Type "help", 2. Scroll to top, 3. Type "help" again, 4. Expect the "New messages" button not flashy
1034
- // - Hidden by style options
1035
- // - It is already at the bottom (sticky)
1036
- // Any changes to this logic, verify:
1037
- // - "New messages" button should persist while programmatically scrolling to mid-point of the transcript:
1038
- // 1. Type "help"
1039
- // 2. Type "proactive", then immediately scroll to top
1040
- // Expect: the "New messages" button should appear
1041
- // 3. Run hook "useScrollTo({ scrollTop: 500 })"
1042
- // Expect: when the scroll is animating to 500px, the "New messages" button should kept on the screen
1043
- // - "New messages" button must not flashy:
1044
- // 1. Type "help"
1045
- // 2. Scroll to top
1046
- // Expect: no "New messages" button is shown
1047
- // 3. Type "help" again
1048
- // Expect: "New messages" button must not flash-appear
1049
- if (allActivitiesRead || animatingToEnd || hideScrollToEndButton || sticky) {
1050
- return -1;
1051
- }
1040
+ }
1052
1041
 
1053
- return activities.findIndex(function (activity) {
1042
+ var ScrollToEndButton = useCreateScrollToEndButtonRenderer()({
1043
+ atEnd: animatingToEnd || atEnd || sticky,
1044
+ styleOptions: styleOptions,
1045
+ // Unread means:
1046
+ // 1. Last read is not the last one in the transcript, and;
1047
+ // 2. Last read is still in the transcript.
1048
+ unread: lastVisibleActivityId !== lastReadActivityIdRef.current && !!~activities.findIndex(function (activity) {
1054
1049
  return (0, _getActivityUniqueId.default)(activity) === lastReadActivityIdRef.current;
1055
- });
1056
- }, [activities, allActivitiesRead, animatingToEnd, hideScrollToEndButton, lastReadActivityIdRef, sticky]);
1057
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, renderSeparatorAfterIndex !== -1 && /*#__PURE__*/_react.default.createElement(_ScrollToEndButton.default, {
1058
- onClick: handleScrollToEndButtonClick,
1059
- ref: scrollToEndButtonRef
1050
+ })
1051
+ });
1052
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, ScrollToEndButton && /*#__PURE__*/_react.default.createElement(ScrollToEndButton, {
1053
+ onClick: handleScrollToEndButtonClick
1060
1054
  }), !!_react.default.Children.count(children) && /*#__PURE__*/_react.default.createElement(_FocusRedirector.default, {
1061
1055
  className: "webchat__basic-transcript__sentinel",
1062
1056
  redirectRef: terminatorRef
@@ -1081,9 +1075,9 @@ InternalTranscriptScrollable.propTypes = {
1081
1075
  terminatorRef: _propTypes.default.any.isRequired
1082
1076
  };
1083
1077
 
1084
- var SetScroller = function SetScroller(_ref30) {
1085
- var activityElementsRef = _ref30.activityElementsRef,
1086
- scrollerRef = _ref30.scrollerRef;
1078
+ var SetScroller = function SetScroller(_ref31) {
1079
+ var activityElementsRef = _ref31.activityElementsRef,
1080
+ scrollerRef = _ref31.scrollerRef;
1087
1081
 
1088
1082
  var _useStyleOptions7 = useStyleOptions(),
1089
1083
  _useStyleOptions8 = _slicedToArray(_useStyleOptions7, 1),
@@ -1093,45 +1087,71 @@ var SetScroller = function SetScroller(_ref30) {
1093
1087
  autoScrollSnapOnPage = _useStyleOptions8$.autoScrollSnapOnPage,
1094
1088
  autoScrollSnapOnPageOffset = _useStyleOptions8$.autoScrollSnapOnPageOffset;
1095
1089
 
1090
+ var _useActivities3 = useActivities(),
1091
+ _useActivities4 = _slicedToArray(_useActivities3, 1),
1092
+ activities = _useActivities4[0];
1093
+
1096
1094
  var _useAcknowledgedActiv3 = (0, _useAcknowledgedActivity.default)(),
1097
1095
  _useAcknowledgedActiv4 = _slicedToArray(_useAcknowledgedActiv3, 1),
1098
1096
  lastAcknowledgedActivity = _useAcknowledgedActiv4[0];
1099
1097
 
1098
+ var activitiesRef = (0, _react.useRef)(activities);
1100
1099
  var lastAcknowledgedActivityRef = (0, _react.useRef)(lastAcknowledgedActivity);
1100
+ activitiesRef.current = activities;
1101
1101
  lastAcknowledgedActivityRef.current = lastAcknowledgedActivity;
1102
- scrollerRef.current = (0, _react.useCallback)(function (_ref31) {
1103
- var offsetHeight = _ref31.offsetHeight,
1104
- scrollTop = _ref31.scrollTop;
1102
+ scrollerRef.current = (0, _react.useCallback)(function (_ref32) {
1103
+ var offsetHeight = _ref32.offsetHeight,
1104
+ scrollTop = _ref32.scrollTop;
1105
1105
  var patchedAutoScrollSnapOnActivity = typeof autoScrollSnapOnActivity === 'number' ? Math.max(0, autoScrollSnapOnActivity) : autoScrollSnapOnActivity ? 1 : 0;
1106
1106
  var patchedAutoScrollSnapOnPage = typeof autoScrollSnapOnPage === 'number' ? Math.max(0, Math.min(1, autoScrollSnapOnPage)) : autoScrollSnapOnPage ? 1 : 0;
1107
1107
  var patchedAutoScrollSnapOnActivityOffset = typeof autoScrollSnapOnActivityOffset === 'number' ? autoScrollSnapOnActivityOffset : 0;
1108
1108
  var patchedAutoScrollSnapOnPageOffset = typeof autoScrollSnapOnPageOffset === 'number' ? autoScrollSnapOnPageOffset : 0;
1109
1109
 
1110
1110
  if (patchedAutoScrollSnapOnActivity || patchedAutoScrollSnapOnPage) {
1111
+ var _activities = activitiesRef.current;
1112
+ var activityElements = activityElementsRef.current;
1111
1113
  var _lastAcknowledgedActivity = lastAcknowledgedActivityRef.current;
1112
1114
  var values = [];
1113
1115
 
1114
- if (patchedAutoScrollSnapOnActivity) {
1115
- var _ref32 = activityElementsRef.current[activityElementsRef.current.findIndex(function (_ref33) {
1116
- var activity = _ref33.activity;
1117
- return activity === _lastAcknowledgedActivity;
1118
- }) + patchedAutoScrollSnapOnActivity] || {},
1119
- nthUnacknowledgedActivityElement = _ref32.element;
1116
+ var lastAcknowledgedActivityIndex = _activities.indexOf(_lastAcknowledgedActivity);
1117
+
1118
+ if (~lastAcknowledgedActivityIndex) {
1119
+ // The activity that we acknowledged could be not rendered, such as post back activity.
1120
+ // When calculating scroll snap, we can only base on the first unacknowledged-and-rendering activity.
1121
+ var firstUnacknowledgedActivityElementIndex = -1;
1122
+
1123
+ var _loop2 = function _loop2(index, length) {
1124
+ var activity = _activities[index];
1125
+ var activityElementIndex = activityElements.findIndex(function (entry) {
1126
+ return entry.activity === activity;
1127
+ });
1128
+
1129
+ if (~activityElementIndex) {
1130
+ firstUnacknowledgedActivityElementIndex = activityElementIndex;
1131
+ return "break";
1132
+ }
1133
+ };
1134
+
1135
+ for (var index = lastAcknowledgedActivityIndex + 1, length = _activities.length; index < length; index++) {
1136
+ var _ret = _loop2(index, length);
1120
1137
 
1121
- if (nthUnacknowledgedActivityElement) {
1122
- values.push(nthUnacknowledgedActivityElement.offsetTop + nthUnacknowledgedActivityElement.offsetHeight - offsetHeight - scrollTop + patchedAutoScrollSnapOnActivityOffset);
1138
+ if (_ret === "break") break;
1123
1139
  }
1124
- }
1125
1140
 
1126
- if (patchedAutoScrollSnapOnPage) {
1127
- var _ref34 = activityElementsRef.current[activityElementsRef.current.findIndex(function (_ref35) {
1128
- var activity = _ref35.activity;
1129
- return activity === _lastAcknowledgedActivity;
1130
- }) + 1] || {},
1131
- firstUnacknowledgedActivityElement = _ref34.element;
1141
+ if (~firstUnacknowledgedActivityElementIndex) {
1142
+ if (patchedAutoScrollSnapOnActivity) {
1143
+ // Gets the activity element which we should snap to.
1144
+ var nthUnacknowledgedActivityElement = activityElements[firstUnacknowledgedActivityElementIndex + patchedAutoScrollSnapOnActivity - 1].element;
1132
1145
 
1133
- if (firstUnacknowledgedActivityElement) {
1134
- values.push(firstUnacknowledgedActivityElement.offsetTop - scrollTop - offsetHeight * (1 - patchedAutoScrollSnapOnPage) + patchedAutoScrollSnapOnPageOffset);
1146
+ if (nthUnacknowledgedActivityElement) {
1147
+ values.push(nthUnacknowledgedActivityElement.offsetTop + nthUnacknowledgedActivityElement.offsetHeight - offsetHeight - scrollTop + patchedAutoScrollSnapOnActivityOffset);
1148
+ }
1149
+ }
1150
+
1151
+ if (patchedAutoScrollSnapOnPage) {
1152
+ var firstUnacknowledgedActivityElement = activityElements[firstUnacknowledgedActivityElementIndex].element;
1153
+ values.push(firstUnacknowledgedActivityElement.offsetTop - scrollTop - offsetHeight * (1 - patchedAutoScrollSnapOnPage) + patchedAutoScrollSnapOnPageOffset);
1154
+ }
1135
1155
  }
1136
1156
  }
1137
1157
 
@@ -1141,12 +1161,12 @@ var SetScroller = function SetScroller(_ref30) {
1141
1161
  }
1142
1162
 
1143
1163
  return Infinity;
1144
- }, [activityElementsRef, autoScrollSnapOnActivity, autoScrollSnapOnActivityOffset, autoScrollSnapOnPage, autoScrollSnapOnPageOffset, lastAcknowledgedActivityRef]);
1164
+ }, [activitiesRef, activityElementsRef, autoScrollSnapOnActivity, autoScrollSnapOnActivityOffset, autoScrollSnapOnPage, autoScrollSnapOnPageOffset, lastAcknowledgedActivityRef]);
1145
1165
  return false;
1146
1166
  };
1147
1167
 
1148
- var BasicTranscript = function BasicTranscript(_ref36) {
1149
- var className = _ref36.className;
1168
+ var BasicTranscript = function BasicTranscript(_ref33) {
1169
+ var className = _ref33.className;
1150
1170
  var activityElementsRef = (0, _react.useRef)([]);
1151
1171
  var scrollerRef = (0, _react.useRef)(function () {
1152
1172
  return Infinity;
@@ -1173,4 +1193,4 @@ BasicTranscript.propTypes = {
1173
1193
  };
1174
1194
  var _default = BasicTranscript;
1175
1195
  exports.default = _default;
1176
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/BasicTranscript.js"],"names":["useActivities","hooks","useCreateActivityRenderer","useCreateActivityStatusRenderer","useCreateAvatarRenderer","useDirection","useGroupActivities","useLocalizer","useStyleOptions","ROOT_STYLE","display","flexDirection","overflow","position","flex","overflowX","WebkitOverflowScrolling","listStyleType","validateAllActivitiesTagged","activities","bins","every","activity","some","bin","includes","InternalTranscript","activityElementsRef","className","basicTranscriptStyleSet","basicTranscript","bubbleFromUserNubOffset","bubbleNubOffset","groupTimestamp","internalLiveRegionFadeAfter","showAvatarInGroup","focusedActivityKey","setFocusedActivityKey","direction","createActivityRenderer","createActivityStatusRenderer","createAvatarRenderer","focus","groupActivities","localize","rootClassName","rootElementRef","terminatorRef","activityInteractiveAlt","terminatorText","transcriptAriaLabel","transcriptRoleDescription","hideAllTimestamps","createActivityRendererWithLiteralArgs","nextVisibleActivity","activitiesWithRenderer","createActivityRendererWithLiteralArgsMemoized","index","length","renderActivity","splice","visibleActivities","map","activitiesGroupBySender","sender","activitiesGroupByStatus","status","console","warn","activityTree","visibleActivitiesPendingGrouping","senderTree","activitiesWithSameSender","find","push","forEach","activitiesWithSameStatus","activitiesWithSameSenderAndStatus","removeInline","renderingElements","topSideBotNub","topSideUserNub","firstActivity","renderAvatar","indexWithinSenderGroup","firstInSenderGroup","lastInSenderGroup","indexWithinSenderAndStatusGroup","renderActivityStatus","firstInSenderAndStatusGroup","lastInSenderAndStatusGroup","entry","key","channelData","messageBack","messageBackDisplayText","displayText","role","from","text","topSideNub","showCallout","focusActivity","rootElement","current","callbackRef","activityElement","activityID","id","element","handleFocus","handleKeyDown","event","preventDefault","stopPropagation","handleMouseDownCapture","target","tabIndex","getAttribute","hideTimestamp","liveRegionKey","shouldSpeak","speak","activityElements","elementId","existingEntry","ariaLabelID","toString","substr","focused","lastElement","renderingActivities","scrollToBottomScrollTo","scrollToBottomScrollToEnd","scrollTo","behavior","Error","scrollTop","scrollableElement","querySelector","getClientRects","activityElementHeight","height","activityElementY","y","scrollableHeight","activityElementOffsetTop","Math","min","scrollRelative","displacement","scrollable","nextScrollTop","offsetHeight","max","scrollHeight","dispatchScrollPosition","patchedDispatchScrollPosition","reverse","lastInteractedActivity","indexOfLastInteractedActivity","indexOf","activeDescendantElementId","scrollActiveDescendantIntoView","activeDescendant","document","getElementById","contains","activeElement","documentElement","style","scrollIntoView","block","scrollTopAtTopSide","offsetTop","scrollTopAtBottomSide","handleTranscriptFocus","currentTarget","undefined","focusRelativeActivity","delta","isNaN","findIndex","nextIndex","nextFocusedActivity","handleTranscriptKeyDown","fromEndOfTranscriptIndicator","fromTranscript","handled","Infinity","focusedActivityEntry","focusedActivityElement","filter","firstTabbableElement","labelId","setBottommostFocusedActivityKeyIfNeeded","lastActivityKey","handleTranscriptKeyDownCapture","altKey","ctrlKey","metaKey","focusTranscriptCallback","handleFocusActivity","dispatchTranscriptFocus","focusedActivity","handleFocusFiller","isContentInteractive","defaultProps","propTypes","PropTypes","shape","array","isRequired","string","InternalScreenReaderTranscript","arrayOf","any","InternalTranscriptScrollable","children","onFocusActivity","onFocusFiller","activitiesStyleSet","hideScrollToEndButton","animatingToEnd","sticky","lastVisibleActivityId","scrollToEndButtonRef","lastReadActivityIdRef","allActivitiesRead","handleScrollToEndButtonClick","firstUnreadActivity","renderSeparatorAfterIndex","React","Children","count","func","SetScroller","scrollerRef","autoScrollSnapOnActivity","autoScrollSnapOnActivityOffset","autoScrollSnapOnPage","autoScrollSnapOnPageOffset","lastAcknowledgedActivity","lastAcknowledgedActivityRef","patchedAutoScrollSnapOnActivity","patchedAutoScrollSnapOnPage","patchedAutoScrollSnapOnActivityOffset","patchedAutoScrollSnapOnPageOffset","values","nthUnacknowledgedActivityElement","firstUnacknowledgedActivityElement","reduce","minValue","value","BasicTranscript","scroller"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["/* eslint no-magic-numbers: [\"error\", { \"ignore\": [-1, 0, 1, 2, 5, 36] }] */\n\nimport { hooks } from 'botframework-webchat-api';\nimport {\n  Composer as ReactScrollToBottomComposer,\n  Panel as ReactScrollToBottomPanel,\n  useAnimatingToEnd,\n  useObserveScrollPosition,\n  useScrollTo,\n  useScrollToEnd,\n  useSticky\n} from 'react-scroll-to-bottom';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport random from 'math-random';\nimport React, { useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport BasicTypingIndicator from './BasicTypingIndicator';\nimport Fade from './Utils/Fade';\nimport FocusRedirector from './Utils/FocusRedirector';\nimport getActivityUniqueId from './Utils/getActivityUniqueId';\nimport getTabIndex from './Utils/TypeFocusSink/getTabIndex';\nimport inputtableKey from './Utils/TypeFocusSink/inputtableKey';\nimport intersectionOf from './Utils/intersectionOf';\nimport isZeroOrPositive from './Utils/isZeroOrPositive';\nimport removeInline from './Utils/removeInline';\nimport ScreenReaderActivity from './ScreenReaderActivity';\nimport ScreenReaderText from './ScreenReaderText';\nimport ScrollToEndButton from './Activity/ScrollToEndButton';\nimport SpeakActivity from './Activity/Speak';\nimport tabbableElements from './Utils/tabbableElements';\nimport useAcknowledgedActivity from './hooks/internal/useAcknowledgedActivity';\nimport useDispatchScrollPosition from './hooks/internal/useDispatchScrollPosition';\nimport useDispatchTranscriptFocus from './hooks/internal/useDispatchTranscriptFocus';\nimport useFocus from './hooks/useFocus';\nimport useMemoize from './hooks/internal/useMemoize';\nimport useRegisterFocusTranscript from './hooks/internal/useRegisterFocusTranscript';\nimport useRegisterScrollRelative from './hooks/internal/useRegisterScrollRelative';\nimport useRegisterScrollTo from './hooks/internal/useRegisterScrollTo';\nimport useRegisterScrollToEnd from './hooks/internal/useRegisterScrollToEnd';\nimport useStyleSet from './hooks/useStyleSet';\nimport useStyleToEmotionObject from './hooks/internal/useStyleToEmotionObject';\nimport useUniqueId from './hooks/internal/useUniqueId';\n\nconst {\n  useActivities,\n  useCreateActivityRenderer,\n  useCreateActivityStatusRenderer,\n  useCreateAvatarRenderer,\n  useDirection,\n  useGroupActivities,\n  useLocalizer,\n  useStyleOptions\n} = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__basic-transcript': {\n    display: 'flex',\n    flexDirection: 'column',\n    overflow: 'hidden',\n    // Make sure to set \"position: relative\" here to form another stacking context for the scroll-to-end button.\n    // Stacking context help isolating elements that use \"z-index\" from global pollution.\n    // https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Positioning/Understanding_z_index/The_stacking_context\n    position: 'relative',\n\n    '& .webchat__basic-transcript__filler': {\n      flex: 1\n    },\n\n    '& .webchat__basic-transcript__scrollable': {\n      display: 'flex',\n      flexDirection: 'column',\n      overflowX: 'hidden',\n      WebkitOverflowScrolling: 'touch'\n    },\n\n    '& .webchat__basic-transcript__transcript': {\n      listStyleType: 'none'\n    }\n  }\n};\n\nfunction validateAllActivitiesTagged(activities, bins) {\n  return activities.every(activity => bins.some(bin => bin.includes(activity)));\n}\n\nconst InternalTranscript = ({ activityElementsRef, className }) => {\n  const [{ basicTranscript: basicTranscriptStyleSet }] = useStyleSet();\n  const [\n    { bubbleFromUserNubOffset, bubbleNubOffset, groupTimestamp, internalLiveRegionFadeAfter, showAvatarInGroup }\n  ] = useStyleOptions();\n  const [focusedActivityKey, setFocusedActivityKey] = useState();\n  const [activities] = useActivities();\n  const [direction] = useDirection();\n  const createActivityRenderer = useCreateActivityRenderer();\n  const createActivityStatusRenderer = useCreateActivityStatusRenderer();\n  const createAvatarRenderer = useCreateAvatarRenderer();\n  const focus = useFocus();\n  const groupActivities = useGroupActivities();\n  const localize = useLocalizer();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n  const rootElementRef = useRef();\n  const terminatorRef = useRef();\n\n  const activityInteractiveAlt = localize('ACTIVITY_INTERACTIVE_LABEL_ALT');\n  const terminatorText = localize('TRANSCRIPT_TERMINATOR_TEXT');\n  const transcriptAriaLabel = localize('TRANSCRIPT_ARIA_LABEL_ALT');\n  const transcriptRoleDescription = localize('TRANSCRIPT_ARIA_ROLE_ALT');\n\n  const hideAllTimestamps = groupTimestamp === false;\n\n  // Gets renderer for every activity.\n  // Activities that are not visible will return a falsy renderer.\n\n  // Converted from createActivityRenderer({ activity, nextVisibleActivity }) to createActivityRenderer(activity, nextVisibleActivity).\n  // This is for the memoization function to cache the arguments. Memoizer can only cache literal arguments.\n  const createActivityRendererWithLiteralArgs = useCallback(\n    (activity, nextVisibleActivity) => createActivityRenderer({ activity, nextVisibleActivity }),\n    [createActivityRenderer]\n  );\n\n  // Create a memoized context of the createActivityRenderer function.\n  const activitiesWithRenderer = useMemoize(\n    createActivityRendererWithLiteralArgs,\n    createActivityRendererWithLiteralArgsMemoized => {\n      // All calls to createActivityRendererWithLiteralArgsMemoized() in this function will be memoized (LRU = 1).\n      // In the next render cycle, calls to createActivityRendererWithLiteralArgsMemoized() might return the memoized result instead.\n      // This is an improvement to React useMemo(), because it only allows 1 memoization.\n      // useMemoize() allows any number of memoization.\n\n      const activitiesWithRenderer = [];\n      let nextVisibleActivity;\n\n      for (let index = activities.length - 1; index >= 0; index--) {\n        const activity = activities[index];\n        const renderActivity = createActivityRendererWithLiteralArgsMemoized(activity, nextVisibleActivity);\n\n        if (renderActivity) {\n          activitiesWithRenderer.splice(0, 0, {\n            activity,\n            renderActivity\n          });\n\n          nextVisibleActivity = activity;\n        }\n      }\n\n      return activitiesWithRenderer;\n    },\n    [activities]\n  );\n\n  const visibleActivities = useMemo(() => activitiesWithRenderer.map(({ activity }) => activity), [\n    activitiesWithRenderer\n  ]);\n\n  // Tag activities based on types.\n  // The default implementation tag into 2 types: sender and status.\n\n  const { activitiesGroupBySender, activitiesGroupByStatus } = useMemo(() => {\n    const { sender: activitiesGroupBySender, status: activitiesGroupByStatus } = groupActivities({\n      activities: visibleActivities\n    });\n\n    if (!validateAllActivitiesTagged(visibleActivities, activitiesGroupBySender)) {\n      console.warn(\n        'botframework-webchat: Not every activities are grouped in the \"sender\" property. Please fix \"groupActivitiesMiddleware\" and group every activities.'\n      );\n    }\n\n    if (!validateAllActivitiesTagged(visibleActivities, activitiesGroupByStatus)) {\n      console.warn(\n        'botframework-webchat: Not every activities are grouped in the \"status\" property. Please fix \"groupActivitiesMiddleware\" and group every activities.'\n      );\n    }\n\n    return {\n      activitiesGroupBySender,\n      activitiesGroupByStatus\n    };\n  }, [groupActivities, visibleActivities]);\n\n  // Create a tree of activities with 2 dimensions: sender, followed by status.\n\n  const activityTree = useMemo(() => {\n    const visibleActivitiesPendingGrouping = [...visibleActivities];\n    const activityTree = [];\n\n    while (visibleActivitiesPendingGrouping.length) {\n      const [activity] = visibleActivitiesPendingGrouping;\n      const senderTree = [];\n      const activitiesWithSameSender = activitiesGroupBySender.find(activities => activities.includes(activity));\n\n      activityTree.push(senderTree);\n\n      activitiesWithSameSender.forEach(activity => {\n        const activitiesWithSameStatus = activitiesGroupByStatus.find(activities => activities.includes(activity));\n\n        const activitiesWithSameSenderAndStatus = intersectionOf(\n          visibleActivitiesPendingGrouping,\n          activitiesWithSameSender,\n          activitiesWithSameStatus\n        );\n\n        if (activitiesWithSameSenderAndStatus.length) {\n          senderTree.push(activitiesWithSameSenderAndStatus);\n          removeInline(visibleActivitiesPendingGrouping, ...activitiesWithSameSenderAndStatus);\n        }\n      });\n    }\n\n    // Assertion: All activities in visibleActivities, must be assigned to the activityTree\n    if (\n      !visibleActivities.every(activity =>\n        activityTree.some(activitiesWithSameSender =>\n          activitiesWithSameSender.some(activitiesWithSameSenderAndStatus =>\n            activitiesWithSameSenderAndStatus.includes(activity)\n          )\n        )\n      )\n    ) {\n      console.warn('botframework-webchat internal: Not all visible activities are grouped in the activityTree.', {\n        visibleActivities,\n        activityTree\n      });\n    }\n\n    return activityTree;\n  }, [activitiesGroupBySender, activitiesGroupByStatus, visibleActivities]);\n\n  // Flatten the tree back into an array with information related to rendering.\n\n  const renderingElements = useMemo(() => {\n    const renderingElements = [];\n    const topSideBotNub = isZeroOrPositive(bubbleNubOffset);\n    const topSideUserNub = isZeroOrPositive(bubbleFromUserNubOffset);\n\n    activityTree.forEach(activitiesWithSameSender => {\n      const [[firstActivity]] = activitiesWithSameSender;\n      const renderAvatar = createAvatarRenderer({ activity: firstActivity });\n\n      activitiesWithSameSender.forEach((activitiesWithSameSenderAndStatus, indexWithinSenderGroup) => {\n        const firstInSenderGroup = !indexWithinSenderGroup;\n        const lastInSenderGroup = indexWithinSenderGroup === activitiesWithSameSender.length - 1;\n\n        activitiesWithSameSenderAndStatus.forEach((activity, indexWithinSenderAndStatusGroup) => {\n          // We only show the timestamp at the end of the sender group. But we always show the \"Send failed, retry\" prompt.\n          const renderActivityStatus = createActivityStatusRenderer({\n            activity\n          });\n\n          const firstInSenderAndStatusGroup = !indexWithinSenderAndStatusGroup;\n          const lastInSenderAndStatusGroup =\n            indexWithinSenderAndStatusGroup === activitiesWithSameSenderAndStatus.length - 1;\n\n          const { renderActivity } = activitiesWithRenderer.find(entry => entry.activity === activity);\n          const key = getActivityUniqueId(activity) || renderingElements.length;\n          const {\n            channelData: { messageBack: { displayText: messageBackDisplayText } = {} } = {},\n            from: { role },\n            text\n          } = activity;\n\n          const topSideNub = role === 'user' ? topSideUserNub : topSideBotNub;\n\n          let showCallout;\n\n          // Depending on the \"showAvatarInGroup\" setting, the avatar will render in different positions.\n          if (showAvatarInGroup === 'sender') {\n            if (topSideNub) {\n              showCallout = firstInSenderGroup && firstInSenderAndStatusGroup;\n            } else {\n              showCallout = lastInSenderGroup && lastInSenderAndStatusGroup;\n            }\n          } else if (showAvatarInGroup === 'status') {\n            if (topSideNub) {\n              showCallout = firstInSenderAndStatusGroup;\n            } else {\n              showCallout = lastInSenderAndStatusGroup;\n            }\n          } else {\n            showCallout = true;\n          }\n\n          const focusActivity = () => {\n            setFocusedActivityKey(getActivityUniqueId(activity));\n\n            // IE11 need to manually focus on the transcript.\n            const { current: rootElement } = rootElementRef;\n\n            rootElement && rootElement.focus();\n          };\n\n          renderingElements.push({\n            activity,\n\n            // After the element is mounted, set it to activityElementsRef.\n            callbackRef: activityElement => {\n              const entry = activityElementsRef.current.find(({ activityID }) => activityID === activity.id);\n\n              if (entry) {\n                entry.element = activityElement;\n              }\n            },\n\n            // Calling this function will put the focus on the transcript and the activity.\n            focusActivity,\n\n            // When a child of the activity receives focus, notify the transcript to set the aria-activedescendant to this activity.\n            handleFocus: () => {\n              setFocusedActivityKey(getActivityUniqueId(activity));\n            },\n\n            handleKeyDown: event => {\n              if (event.key === 'Escape') {\n                event.preventDefault();\n                event.stopPropagation();\n\n                setFocusedActivityKey(getActivityUniqueId(activity));\n\n                const { current } = rootElementRef;\n\n                current && current.focus();\n              }\n            },\n\n            // For accessibility: when the user press up/down arrow keys, we put a visual focus indicator around the focused activity.\n            // We should do the same for mouse, that is why we have the click handler here.\n            // We are doing it in event capture phase to prevent other components from stopping event propagation to us.\n            handleMouseDownCapture: ({ target }) => {\n              const tabIndex = getTabIndex(target);\n\n              if (typeof tabIndex !== 'number' || tabIndex < 0 || target.getAttribute('aria-disabled') === 'true') {\n                focusActivity();\n              }\n            },\n\n            // \"hideTimestamp\" is a render-time parameter for renderActivityStatus().\n            // If true, it will hide the timestamp, but it will continue to show the\n            // retry prompt. And show the screen reader version of the timestamp.\n            hideTimestamp:\n              hideAllTimestamps || indexWithinSenderAndStatusGroup !== activitiesWithSameSenderAndStatus.length - 1,\n            key,\n\n            // When \"liveRegionKey\" changes, it will show up in the live region momentarily.\n            liveRegionKey: key + '|' + (messageBackDisplayText || text),\n            renderActivity,\n            renderActivityStatus,\n            renderAvatar,\n            role,\n\n            // TODO: [P2] #2858 We should use core/definitions/speakingActivity for this predicate instead\n            shouldSpeak: activity.channelData && activity.channelData.speak,\n            showCallout\n          });\n        });\n      });\n    });\n\n    const { current: activityElements } = activityElementsRef;\n\n    // Update activityElementRef with new sets of activity, while retaining the existing referencing element if exists.\n    activityElementsRef.current = renderingElements.map(({ activity, activity: { id }, elementId, key }) => {\n      const existingEntry = activityElements.find(entry => entry.key === key);\n\n      return {\n        activity,\n        activityID: id,\n        ariaLabelID: existingEntry\n          ? existingEntry.ariaLabelID\n          : `webchat__basic-transcript__activity-label-${random().toString(36).substr(2, 5)}`,\n        element: existingEntry && existingEntry.element,\n        elementId,\n        key\n      };\n    });\n\n    // There must be one focused (a.k.a. aria-activedescendant) designated. We default it to the last one.\n    if (!renderingElements.find(({ focused }) => focused)) {\n      const lastElement = renderingElements[renderingElements.length - 1];\n\n      if (lastElement) {\n        lastElement.focused = true;\n      }\n    }\n\n    return renderingElements;\n  }, [\n    activitiesWithRenderer,\n    activityElementsRef,\n    activityTree,\n    bubbleFromUserNubOffset,\n    bubbleNubOffset,\n    createActivityStatusRenderer,\n    createAvatarRenderer,\n    hideAllTimestamps,\n    rootElementRef,\n    showAvatarInGroup\n  ]);\n\n  const renderingActivities = useMemo(() => renderingElements.map(({ activity }) => activity), [renderingElements]);\n\n  const scrollToBottomScrollTo = useScrollTo();\n  const scrollToBottomScrollToEnd = useScrollToEnd();\n\n  const scrollTo = useCallback(\n    (position, { behavior = 'auto' } = {}) => {\n      if (!position) {\n        throw new Error(\n          'botframework-webchat: First argument passed to \"useScrollTo\" must be a ScrollPosition object.'\n        );\n      }\n\n      const { activityID, scrollTop } = position;\n\n      if (typeof scrollTop !== 'undefined') {\n        scrollToBottomScrollTo(scrollTop, { behavior });\n      } else if (typeof activityID !== 'undefined') {\n        const { current: rootElement } = rootElementRef;\n        const { element: activityElement } =\n          activityElementsRef.current.find(entry => entry.activityID === activityID) || {};\n\n        const scrollableElement = rootElement.querySelector('.webchat__basic-transcript__scrollable');\n\n        if (scrollableElement && activityElement) {\n          const [{ height: activityElementHeight, y: activityElementY }] = activityElement.getClientRects();\n          const [{ height: scrollableHeight }] = scrollableElement.getClientRects();\n\n          const activityElementOffsetTop = activityElementY + scrollableElement.scrollTop;\n\n          const scrollTop = Math.min(\n            activityElementOffsetTop,\n            activityElementOffsetTop - scrollableHeight + activityElementHeight\n          );\n\n          scrollToBottomScrollTo(scrollTop, { behavior });\n        }\n      }\n    },\n    [activityElementsRef, rootElementRef, scrollToBottomScrollTo]\n  );\n\n  const scrollRelative = useCallback(\n    (direction, { displacement } = {}) => {\n      const { current: rootElement } = rootElementRef;\n\n      if (!rootElement) {\n        return;\n      }\n\n      const scrollable = rootElement.querySelector('.webchat__basic-transcript__scrollable');\n      let nextScrollTop;\n\n      if (typeof displacement === 'number') {\n        nextScrollTop = scrollable.scrollTop + (direction === 'down' ? 1 : -1) * displacement;\n      } else {\n        nextScrollTop = scrollable.scrollTop + (direction === 'down' ? 1 : -1) * scrollable.offsetHeight;\n      }\n\n      scrollTo(\n        {\n          scrollTop: Math.max(0, Math.min(scrollable.scrollHeight - scrollable.offsetHeight, nextScrollTop))\n        },\n        { behavior: 'smooth' }\n      );\n    },\n    [rootElementRef, scrollTo]\n  );\n\n  // Since there could be multiple instances of <BasicTranscript> inside the <Composer>, when the developer calls `scrollXXX`, we need to call it on all instances.\n  // We call `useRegisterScrollXXX` to register a callback function, the `useScrollXXX` will multiplex the call into each instance of <BasicTranscript>.\n  useRegisterScrollTo(scrollTo);\n  useRegisterScrollToEnd(scrollToBottomScrollToEnd);\n  useRegisterScrollRelative(scrollRelative);\n\n  const dispatchScrollPosition = useDispatchScrollPosition();\n  const patchedDispatchScrollPosition = useMemo(() => {\n    if (!dispatchScrollPosition) {\n      return;\n    }\n\n    return ({ scrollTop }) => {\n      const { current: rootElement } = rootElementRef;\n\n      if (!rootElement) {\n        return;\n      }\n\n      const scrollableElement = rootElement.querySelector('.webchat__basic-transcript__scrollable');\n\n      const [{ height: offsetHeight } = {}] = scrollableElement.getClientRects();\n\n      // Find the activity just above scroll view bottom.\n      // If the scroll view is already on top, get the first activity.\n      const entry = scrollableElement.scrollTop\n        ? [...activityElementsRef.current].reverse().find(({ element }) => {\n            if (!element) {\n              return false;\n            }\n\n            const [{ y } = {}] = element.getClientRects();\n\n            return y < offsetHeight;\n          })\n        : activityElementsRef.current[0];\n\n      const { activityID } = entry || {};\n\n      dispatchScrollPosition({ ...(activityID ? { activityID } : {}), scrollTop });\n    };\n  }, [activityElementsRef, dispatchScrollPosition, rootElementRef]);\n\n  useObserveScrollPosition(patchedDispatchScrollPosition);\n\n  const [lastInteractedActivity] = useAcknowledgedActivity();\n\n  const indexOfLastInteractedActivity = activities.indexOf(lastInteractedActivity);\n\n  // Create a new ID for aria-activedescendant every time the active descendant change.\n  // In our design, the transcript will only have 1 focused activity and it has an ID. Other blurred activities will not have ID assigned.\n  // This help with performance.\n  // But browser usually do noop if the value of aria-activedescendant doesn't change.\n  // That means, if we assign the same ID to another element, browser will do noop.\n  // We need to generate a new ID so the browser see there is a change in aria-activedescendant value and perform accordingly.\n  const activeDescendantElementId = useMemo(\n    () => focusedActivityKey && `webchat__basic-transcript__active-descendant-${random().toString(36).substr(2, 5)}`,\n    [focusedActivityKey]\n  );\n\n  const scrollActiveDescendantIntoView = useCallback(() => {\n    const activeDescendant = activeDescendantElementId && document.getElementById(activeDescendantElementId);\n\n    // Don't scroll active descendant into view if the focus is already inside it.\n    // Otherwise, given the focus is on the send box, clicking on any <input> inside the Adaptive Cards may cause the view to move.\n    // This UX is not desirable because click should not cause scroll.\n    if (activeDescendant && !activeDescendant.contains(document.activeElement)) {\n      // Checks if scrollIntoView support options or not.\n      // - https://github.com/Modernizr/Modernizr/issues/1568#issuecomment-419457972\n      // - https://stackoverflow.com/questions/46919627/is-it-possible-to-test-for-scrollintoview-browser-compatibility\n      if ('scrollBehavior' in document.documentElement.style) {\n        activeDescendant.scrollIntoView({ block: 'nearest' });\n      } else {\n        // This is for browser that does not support options passed to scrollIntoView(), possibly IE11.\n        const scrollableElement = rootElementRef.current.querySelector('.webchat__basic-transcript__scrollable');\n        const scrollTopAtTopSide = activeDescendant.offsetTop;\n        const scrollTopAtBottomSide = activeDescendant.offsetTop + activeDescendant.offsetHeight;\n\n        if (scrollTopAtTopSide < scrollableElement.scrollTop) {\n          scrollableElement.scrollTop = scrollTopAtTopSide;\n        } else if (scrollTopAtBottomSide > scrollableElement.scrollTop + scrollableElement.offsetHeight) {\n          scrollableElement.scrollTop = scrollTopAtBottomSide - scrollableElement.offsetHeight;\n        }\n      }\n    }\n  }, [activeDescendantElementId, rootElementRef]);\n\n  const handleTranscriptFocus = useCallback(\n    event => {\n      const { currentTarget, target } = event;\n\n      // When focus is placed on the transcript, scroll active descendant into the view.\n      currentTarget === target && scrollActiveDescendantIntoView();\n    },\n    [scrollActiveDescendantIntoView]\n  );\n\n  // After new aria-activedescendant is assigned, we will need to scroll it into view.\n  // User agent will scroll automatically for focusing element, but not for aria-activedescendant.\n  // We need to do the scrolling manually.\n  useEffect(() => scrollActiveDescendantIntoView(), [scrollActiveDescendantIntoView]);\n\n  // If any activities has changed, reset the active descendant.\n  useEffect(() => setFocusedActivityKey(undefined), [activities, setFocusedActivityKey]);\n\n  const focusRelativeActivity = useCallback(\n    delta => {\n      if (isNaN(delta) || !renderingElements.length) {\n        return setFocusedActivityKey(undefined);\n      }\n\n      const index = renderingElements.findIndex(({ key }) => key === focusedActivityKey);\n      const nextIndex = ~index\n        ? Math.max(0, Math.min(renderingElements.length - 1, index + delta))\n        : renderingElements.length - 1;\n      const nextFocusedActivity = renderingElements[nextIndex];\n\n      setFocusedActivityKey(nextFocusedActivity.key);\n      rootElementRef.current && rootElementRef.current.focus();\n    },\n    [focusedActivityKey, renderingElements, rootElementRef, setFocusedActivityKey]\n  );\n\n  const handleTranscriptKeyDown = useCallback(\n    event => {\n      const { target } = event;\n\n      const fromEndOfTranscriptIndicator = target === terminatorRef.current;\n      const fromTranscript = target === event.currentTarget;\n\n      if (!fromEndOfTranscriptIndicator && !fromTranscript) {\n        return;\n      }\n\n      let handled = true;\n\n      switch (event.key) {\n        case 'ArrowDown':\n          focusRelativeActivity(fromEndOfTranscriptIndicator ? 0 : 1);\n          break;\n\n        case 'ArrowUp':\n          focusRelativeActivity(fromEndOfTranscriptIndicator ? 0 : -1);\n          break;\n\n        case 'End':\n          focusRelativeActivity(Infinity);\n          break;\n\n        case 'Enter':\n          if (!fromEndOfTranscriptIndicator) {\n            const focusedActivityEntry = renderingElements.find(({ key }) => key === focusedActivityKey);\n\n            if (focusedActivityEntry) {\n              const { element: focusedActivityElement } =\n                activityElementsRef.current.find(({ activity }) => activity === focusedActivityEntry.activity) || {};\n\n              if (focusedActivityElement) {\n                const [firstTabbableElement] = tabbableElements(focusedActivityElement).filter(\n                  ({ className }) => className !== 'webchat__basic-transcript__activity-sentinel'\n                );\n\n                firstTabbableElement && firstTabbableElement.focus();\n              }\n            }\n          }\n\n          break;\n\n        case 'Escape':\n          focus('sendBoxWithoutKeyboard');\n          break;\n\n        case 'Home':\n          focusRelativeActivity(-Infinity);\n          break;\n\n        default:\n          handled = false;\n          break;\n      }\n\n      if (handled) {\n        event.preventDefault();\n\n        // If a custom HTML control wants to handle up/down arrow, we will prevent them from listening to this event to prevent bugs due to handling arrow keys twice.\n        event.stopPropagation();\n      }\n    },\n    [focusedActivityKey, activityElementsRef, focusRelativeActivity, focus, terminatorRef, renderingElements]\n  );\n\n  const labelId = useUniqueId('webchat__basic-transcript__label');\n\n  // If SHIFT-TAB from \"End of transcript\" indicator, if focusedActivityKey is not set (or no longer exists), set it the the bottommost activity.\n  const setBottommostFocusedActivityKeyIfNeeded = useCallback(() => {\n    if (!~renderingElements.findIndex(({ key }) => key === focusedActivityKey)) {\n      const { key: lastActivityKey } = renderingElements[renderingElements.length - 1] || {};\n\n      setFocusedActivityKey(lastActivityKey);\n    }\n  }, [focusedActivityKey, renderingElements, setFocusedActivityKey]);\n\n  const handleTranscriptKeyDownCapture = useCallback(\n    event => {\n      const { altKey, ctrlKey, key, metaKey, target } = event;\n\n      if (altKey || (ctrlKey && key !== 'v') || metaKey || (!inputtableKey(key) && key !== 'Backspace')) {\n        // Ignore if one of the utility key (except SHIFT) is pressed\n        // E.g. CTRL-C on a link in one of the message should not jump to chat box\n        // E.g. \"A\" or \"Backspace\" should jump to chat box\n        return;\n      }\n\n      // Send keystrokes to send box if we are focusing on the transcript or terminator.\n      if (target === event.currentTarget || target === terminatorRef.current) {\n        event.stopPropagation();\n\n        focus('sendBox');\n      }\n    },\n    [focus]\n  );\n\n  const focusTranscriptCallback = useCallback(() => rootElementRef.current && rootElementRef.current.focus(), [\n    rootElementRef\n  ]);\n\n  useRegisterFocusTranscript(focusTranscriptCallback);\n\n  const handleFocusActivity = useCallback(\n    key => {\n      setFocusedActivityKey(key);\n      rootElementRef.current && rootElementRef.current.focus();\n    },\n    [setFocusedActivityKey]\n  );\n\n  // When the focusing activity has changed, dispatch an event to observers of \"useObserveTranscriptFocus\".\n  const dispatchTranscriptFocus = useDispatchTranscriptFocus();\n  const focusedActivity = useMemo(() => {\n    const { activity } = renderingElements.find(({ key }) => key === focusedActivityKey) || {};\n\n    return activity;\n  }, [focusedActivityKey, renderingElements]);\n\n  useMemo(() => dispatchTranscriptFocus && dispatchTranscriptFocus({ activity: focusedActivity }), [\n    dispatchTranscriptFocus,\n    focusedActivity\n  ]);\n\n  // This is required by IE11.\n  // When the user clicks on and empty space (a.k.a. filler) in an empty transcript, IE11 says the focus is on the <div className=\"filler\">,\n  // despite the fact there are no \"tabIndex\" attributes set on the filler.\n  // We need to artificially send the focus back to the transcript.\n  const handleFocusFiller = useCallback(() => {\n    const { current } = rootElementRef;\n\n    current && current.focus();\n  }, [rootElementRef]);\n\n  return (\n    <div\n      aria-activedescendant={focusedActivityKey ? activeDescendantElementId : undefined}\n      aria-labelledby={labelId}\n      className={classNames(\n        'webchat__basic-transcript',\n        basicTranscriptStyleSet + '',\n        rootClassName,\n        (className || '') + ''\n      )}\n      dir={direction}\n      onFocus={handleTranscriptFocus}\n      onKeyDown={handleTranscriptKeyDown}\n      onKeyDownCapture={handleTranscriptKeyDownCapture}\n      ref={rootElementRef}\n      // \"aria-activedescendant\" will only works with a number of roles and it must be explicitly set.\n      // https://www.w3.org/TR/wai-aria/#aria-activedescendant\n      role=\"group\"\n      // For up/down arrow key navigation across activities, this component must be included in the tab sequence.\n      // Otherwise, \"aria-activedescendant\" will not be narrated when the user press up/down arrow keys.\n      // https://www.w3.org/TR/wai-aria-practices-1.1/#kbd_focus_activedescendant\n      tabIndex={0}\n    >\n      <ScreenReaderText id={labelId} text={transcriptAriaLabel} />\n      {/* This <section> is for live region only. Content is made invisible through CSS. */}\n      <section\n        aria-atomic={false}\n        aria-live=\"polite\"\n        aria-relevant=\"additions\"\n        aria-roledescription={transcriptRoleDescription}\n        role=\"log\"\n      >\n        {renderingElements.map(({ activity, liveRegionKey }) => (\n          <Fade fadeAfter={internalLiveRegionFadeAfter} key={liveRegionKey}>\n            {() => <ScreenReaderActivity activity={activity} />}\n          </Fade>\n        ))}\n      </section>\n      {/* TODO: [P2] Fix ESLint error `no-use-before-define` */}\n      {/* eslint-disable-next-line @typescript-eslint/no-use-before-define */}\n      <InternalTranscriptScrollable\n        activities={renderingActivities}\n        onFocusActivity={handleFocusActivity}\n        onFocusFiller={handleFocusFiller}\n        terminatorRef={terminatorRef}\n      >\n        {renderingElements.map(\n          (\n            {\n              activity,\n              callbackRef,\n              focusActivity,\n              handleFocus,\n              handleKeyDown,\n              handleMouseDownCapture,\n              hideTimestamp,\n              key,\n              renderActivity,\n              renderActivityStatus,\n              renderAvatar,\n              role,\n              shouldSpeak,\n              showCallout\n            },\n            index\n          ) => {\n            const { ariaLabelID, element } =\n              activityElementsRef.current.find(entry => entry.activity === activity) || {};\n            const activeDescendant = focusedActivityKey === key;\n            const isContentInteractive = !!(element\n              ? tabbableElements(element.querySelector('.webchat__basic-transcript__activity-box')).length\n              : 0);\n\n            return (\n              <li\n                aria-labelledby={ariaLabelID}\n                className={classNames('webchat__basic-transcript__activity', {\n                  'webchat__basic-transcript__activity--acknowledged': index <= indexOfLastInteractedActivity,\n                  'webchat__basic-transcript__activity--from-bot': role !== 'user',\n                  'webchat__basic-transcript__activity--from-user': role === 'user'\n                })}\n                // Set \"id\" for valid for accessibility.\n                /* eslint-disable-next-line react/forbid-dom-props */\n                id={activeDescendant ? activeDescendantElementId : undefined}\n                key={key}\n                onFocus={handleFocus}\n                onKeyDown={handleKeyDown}\n                onMouseDownCapture={handleMouseDownCapture}\n                ref={callbackRef}\n              >\n                <ScreenReaderActivity activity={activity} id={ariaLabelID} renderAttachments={false}>\n                  {!!isContentInteractive && <p>{activityInteractiveAlt}</p>}\n                </ScreenReaderActivity>\n                <FocusRedirector\n                  className=\"webchat__basic-transcript__activity-sentinel\"\n                  onFocus={focusActivity}\n                  redirectRef={rootElementRef}\n                />\n                <div className=\"webchat__basic-transcript__activity-box\">\n                  {renderActivity({\n                    hideTimestamp,\n                    renderActivityStatus,\n                    renderAvatar,\n                    showCallout\n                  })}\n                </div>\n                {shouldSpeak && <SpeakActivity activity={activity} />}\n                <FocusRedirector\n                  className=\"webchat__basic-transcript__activity-sentinel\"\n                  onFocus={focusActivity}\n                  redirectRef={rootElementRef}\n                />\n                <div\n                  className={classNames('webchat__basic-transcript__activity-indicator', {\n                    'webchat__basic-transcript__activity-indicator--first': !index,\n                    'webchat__basic-transcript__activity-indicator--focus': activeDescendant\n                  })}\n                />\n              </li>\n            );\n          }\n        )}\n      </InternalTranscriptScrollable>\n      {!!renderingElements.length && (\n        <React.Fragment>\n          <FocusRedirector\n            className=\"webchat__basic-transcript__sentinel\"\n            onFocus={setBottommostFocusedActivityKeyIfNeeded}\n            redirectRef={rootElementRef}\n          />\n          <div className=\"webchat__basic-transcript__terminator\" ref={terminatorRef} tabIndex={0}>\n            <div className=\"webchat__basic-transcript__terminator-body\">\n              <div className=\"webchat__basic-transcript__terminator-text\">{terminatorText}</div>\n            </div>\n          </div>\n        </React.Fragment>\n      )}\n      <div className=\"webchat__basic-transcript__focus-indicator\" />\n    </div>\n  );\n};\n\nInternalTranscript.defaultProps = {\n  className: ''\n};\n\nInternalTranscript.propTypes = {\n  activityElementsRef: PropTypes.shape({\n    current: PropTypes.array.isRequired\n  }).isRequired,\n  className: PropTypes.string\n};\n\nconst InternalScreenReaderTranscript = ({ renderingElements }) => {\n  const localize = useLocalizer();\n  const [internalLiveRegionFadeAfter] = useStyleOptions();\n\n  const transcriptRoleDescription = localize('TRANSCRIPT_ARIA_ROLE_ALT');\n\n  return (\n    <section\n      aria-atomic={false}\n      aria-live=\"polite\"\n      aria-relevant=\"additions\"\n      aria-roledescription={transcriptRoleDescription}\n      role=\"log\"\n    >\n      {renderingElements.map(({ activity, liveRegionKey }) => (\n        <Fade fadeAfter={internalLiveRegionFadeAfter} key={liveRegionKey}>\n          {() => <ScreenReaderActivity activity={activity} />}\n        </Fade>\n      ))}\n    </section>\n  );\n};\n\nInternalScreenReaderTranscript.propTypes = {\n  renderingElements: PropTypes.arrayOf(\n    PropTypes.shape({\n      activity: PropTypes.any,\n      liveRegionKey: PropTypes.string\n    })\n  ).isRequired\n};\n\n// Separating high-frequency hooks to improve performance.\nconst InternalTranscriptScrollable = ({ activities, children, onFocusActivity, onFocusFiller, terminatorRef }) => {\n  const [{ activities: activitiesStyleSet }] = useStyleSet();\n  const [{ hideScrollToEndButton }] = useStyleOptions();\n  const [animatingToEnd] = useAnimatingToEnd();\n  const [sticky] = useSticky();\n  const lastVisibleActivityId = getActivityUniqueId(activities[activities.length - 1] || {}); // Activity ID of the last visible activity in the list.\n  const localize = useLocalizer();\n  const scrollToEndButtonRef = useRef();\n\n  const lastReadActivityIdRef = useRef(lastVisibleActivityId);\n  const transcriptRoleDescription = localize('TRANSCRIPT_ARIA_ROLE_ALT');\n\n  const allActivitiesRead = lastVisibleActivityId === lastReadActivityIdRef.current;\n\n  const handleScrollToEndButtonClick = useCallback(() => {\n    // After the \"New message\" button is clicked, focus on the first unread activity.\n    const index = activities.findIndex(({ id }) => id === lastReadActivityIdRef.current);\n\n    if (~index) {\n      const firstUnreadActivity = activities[index + 1];\n\n      if (firstUnreadActivity) {\n        return onFocusActivity(getActivityUniqueId(firstUnreadActivity));\n      }\n    }\n\n    const { current } = terminatorRef;\n\n    current && current.focus();\n  }, [activities, lastReadActivityIdRef, onFocusActivity, terminatorRef]);\n\n  if (sticky) {\n    // If it is sticky, the user is at the bottom of the transcript, everything is read.\n    // So mark the activity ID as read.\n    lastReadActivityIdRef.current = lastVisibleActivityId;\n  }\n\n  // Finds where we should render the \"New messages\" button, in index. Returns -1 to hide the button.\n  const renderSeparatorAfterIndex = useMemo(() => {\n    // Don't show the button if:\n    // - All activities have been read\n    // - Currently animating towards bottom\n    //   - \"New messages\" button must not flash when: 1. Type \"help\", 2. Scroll to top, 3. Type \"help\" again, 4. Expect the \"New messages\" button not flashy\n    // - Hidden by style options\n    // - It is already at the bottom (sticky)\n\n    // Any changes to this logic, verify:\n    // - \"New messages\" button should persist while programmatically scrolling to mid-point of the transcript:\n    //   1. Type \"help\"\n    //   2. Type \"proactive\", then immediately scroll to top\n    //      Expect: the \"New messages\" button should appear\n    //   3. Run hook \"useScrollTo({ scrollTop: 500 })\"\n    //      Expect: when the scroll is animating to 500px, the \"New messages\" button should kept on the screen\n    // - \"New messages\" button must not flashy:\n    //   1. Type \"help\"\n    //   2. Scroll to top\n    //      Expect: no \"New messages\" button is shown\n    //   3. Type \"help\" again\n    //      Expect: \"New messages\" button must not flash-appear\n\n    if (allActivitiesRead || animatingToEnd || hideScrollToEndButton || sticky) {\n      return -1;\n    }\n\n    return activities.findIndex(activity => getActivityUniqueId(activity) === lastReadActivityIdRef.current);\n  }, [activities, allActivitiesRead, animatingToEnd, hideScrollToEndButton, lastReadActivityIdRef, sticky]);\n\n  return (\n    <React.Fragment>\n      {renderSeparatorAfterIndex !== -1 && (\n        <ScrollToEndButton onClick={handleScrollToEndButtonClick} ref={scrollToEndButtonRef} />\n      )}\n      {!!React.Children.count(children) && (\n        <FocusRedirector className=\"webchat__basic-transcript__sentinel\" redirectRef={terminatorRef} />\n      )}\n      <ReactScrollToBottomPanel className=\"webchat__basic-transcript__scrollable\">\n        <div aria-hidden={true} className=\"webchat__basic-transcript__filler\" onFocus={onFocusFiller} />\n        <ul\n          aria-roledescription={transcriptRoleDescription}\n          className={classNames(activitiesStyleSet + '', 'webchat__basic-transcript__transcript')}\n          role=\"list\"\n        >\n          {children}\n        </ul>\n        <BasicTypingIndicator />\n      </ReactScrollToBottomPanel>\n    </React.Fragment>\n  );\n};\n\nInternalTranscriptScrollable.propTypes = {\n  activities: PropTypes.array.isRequired,\n  children: PropTypes.any.isRequired,\n  onFocusActivity: PropTypes.func.isRequired,\n  onFocusFiller: PropTypes.func.isRequired,\n  terminatorRef: PropTypes.any.isRequired\n};\n\nconst SetScroller = ({ activityElementsRef, scrollerRef }) => {\n  const [\n    { autoScrollSnapOnActivity, autoScrollSnapOnActivityOffset, autoScrollSnapOnPage, autoScrollSnapOnPageOffset }\n  ] = useStyleOptions();\n  const [lastAcknowledgedActivity] = useAcknowledgedActivity();\n\n  const lastAcknowledgedActivityRef = useRef(lastAcknowledgedActivity);\n\n  lastAcknowledgedActivityRef.current = lastAcknowledgedActivity;\n\n  scrollerRef.current = useCallback(\n    ({ offsetHeight, scrollTop }) => {\n      const patchedAutoScrollSnapOnActivity =\n        typeof autoScrollSnapOnActivity === 'number'\n          ? Math.max(0, autoScrollSnapOnActivity)\n          : autoScrollSnapOnActivity\n          ? 1\n          : 0;\n      const patchedAutoScrollSnapOnPage =\n        typeof autoScrollSnapOnPage === 'number'\n          ? Math.max(0, Math.min(1, autoScrollSnapOnPage))\n          : autoScrollSnapOnPage\n          ? 1\n          : 0;\n      const patchedAutoScrollSnapOnActivityOffset =\n        typeof autoScrollSnapOnActivityOffset === 'number' ? autoScrollSnapOnActivityOffset : 0;\n      const patchedAutoScrollSnapOnPageOffset =\n        typeof autoScrollSnapOnPageOffset === 'number' ? autoScrollSnapOnPageOffset : 0;\n\n      if (patchedAutoScrollSnapOnActivity || patchedAutoScrollSnapOnPage) {\n        const { current: lastAcknowledgedActivity } = lastAcknowledgedActivityRef;\n\n        const values = [];\n\n        if (patchedAutoScrollSnapOnActivity) {\n          const { element: nthUnacknowledgedActivityElement } =\n            activityElementsRef.current[\n              activityElementsRef.current.findIndex(({ activity }) => activity === lastAcknowledgedActivity) +\n                patchedAutoScrollSnapOnActivity\n            ] || {};\n\n          if (nthUnacknowledgedActivityElement) {\n            values.push(\n              nthUnacknowledgedActivityElement.offsetTop +\n                nthUnacknowledgedActivityElement.offsetHeight -\n                offsetHeight -\n                scrollTop +\n                patchedAutoScrollSnapOnActivityOffset\n            );\n          }\n        }\n\n        if (patchedAutoScrollSnapOnPage) {\n          const { element: firstUnacknowledgedActivityElement } =\n            activityElementsRef.current[\n              activityElementsRef.current.findIndex(({ activity }) => activity === lastAcknowledgedActivity) + 1\n            ] || {};\n\n          if (firstUnacknowledgedActivityElement) {\n            values.push(\n              firstUnacknowledgedActivityElement.offsetTop -\n                scrollTop -\n                offsetHeight * (1 - patchedAutoScrollSnapOnPage) +\n                patchedAutoScrollSnapOnPageOffset\n            );\n          }\n        }\n\n        return values.reduce((minValue, value) => Math.min(minValue, value), Infinity);\n      }\n\n      return Infinity;\n    },\n    [\n      activityElementsRef,\n      autoScrollSnapOnActivity,\n      autoScrollSnapOnActivityOffset,\n      autoScrollSnapOnPage,\n      autoScrollSnapOnPageOffset,\n      lastAcknowledgedActivityRef\n    ]\n  );\n\n  return false;\n};\n\nconst BasicTranscript = ({ className }) => {\n  const activityElementsRef = useRef([]);\n  const scrollerRef = useRef(() => Infinity);\n\n  const scroller = useCallback((...args) => scrollerRef.current(...args), [scrollerRef]);\n\n  return (\n    <ReactScrollToBottomComposer scroller={scroller}>\n      <SetScroller activityElementsRef={activityElementsRef} scrollerRef={scrollerRef} />\n      <InternalTranscript activityElementsRef={activityElementsRef} className={className} />\n    </ReactScrollToBottomComposer>\n  );\n};\n\nBasicTranscript.defaultProps = {\n  className: ''\n};\n\nBasicTranscript.propTypes = {\n  className: PropTypes.string\n};\n\nexport default BasicTranscript;\n"]}
1196
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/BasicTranscript.js"],"names":["useActivities","hooks","useCreateActivityRenderer","useCreateActivityStatusRenderer","useCreateAvatarRenderer","useCreateScrollToEndButtonRenderer","useDirection","useGroupActivities","useLocalizer","useStyleOptions","ROOT_STYLE","display","flexDirection","overflow","position","flex","overflowX","WebkitOverflowScrolling","listStyleType","validateAllActivitiesTagged","activities","bins","every","activity","some","bin","includes","InternalTranscript","activityElementsRef","className","basicTranscriptStyleSet","basicTranscript","bubbleFromUserNubOffset","bubbleNubOffset","groupTimestamp","internalLiveRegionFadeAfter","showAvatarInGroup","focusedActivityKey","setFocusedActivityKey","direction","createActivityRenderer","createActivityStatusRenderer","createAvatarRenderer","focus","groupActivities","localize","rootClassName","rootElementRef","terminatorRef","activityInteractiveAlt","terminatorText","transcriptAriaLabel","transcriptRoleDescription","hideAllTimestamps","createActivityRendererWithLiteralArgs","nextVisibleActivity","activitiesWithRenderer","createActivityRendererWithLiteralArgsMemoized","index","length","renderActivity","splice","visibleActivities","map","activitiesGroupBySender","sender","activitiesGroupByStatus","status","console","warn","activityTree","visibleActivitiesPendingGrouping","senderTree","activitiesWithSameSender","find","push","forEach","activitiesWithSameStatus","activitiesWithSameSenderAndStatus","removeInline","renderingElements","topSideBotNub","topSideUserNub","firstActivity","renderAvatar","indexWithinSenderGroup","firstInSenderGroup","lastInSenderGroup","indexWithinSenderAndStatusGroup","renderActivityStatus","firstInSenderAndStatusGroup","lastInSenderAndStatusGroup","entry","key","baseAltText","channelData","messageBack","displayText","text","supportScreenReader","role","from","topSideNub","showCallout","focusActivity","rootElement","current","callbackRef","activityElement","activityID","id","element","handleFocus","handleKeyDown","event","preventDefault","stopPropagation","handleMouseDownCapture","target","tabIndex","getAttribute","hideTimestamp","liveRegionKey","shouldSpeak","speak","activityElements","elementId","existingEntry","ariaLabelID","toString","substr","focused","lastElement","renderingActivities","scrollToBottomScrollTo","scrollToBottomScrollToEnd","scrollTo","behavior","Error","scrollTop","scrollableElement","querySelector","getClientRects","activityElementHeight","height","activityElementY","y","scrollableHeight","activityElementOffsetTop","Math","min","scrollToEnd","scrollRelative","displacement","scrollable","nextScrollTop","offsetHeight","max","scrollHeight","dispatchScrollPosition","patchedDispatchScrollPosition","reverse","lastInteractedActivity","indexOfLastInteractedActivity","indexOf","activeDescendantElementId","scrollActiveDescendantIntoView","activeDescendant","document","getElementById","contains","activeElement","documentElement","style","scrollIntoView","block","scrollTopAtTopSide","offsetTop","scrollTopAtBottomSide","handleTranscriptFocus","currentTarget","undefined","focusRelativeActivity","delta","isNaN","findIndex","nextIndex","nextFocusedActivity","handleTranscriptKeyDown","fromEndOfTranscriptIndicator","fromTranscript","handled","Infinity","focusedActivityEntry","focusedActivityElement","filter","firstTabbableElement","labelId","setBottommostFocusedActivityKeyIfNeeded","lastActivityKey","handleTranscriptKeyDownCapture","altKey","ctrlKey","metaKey","focusTranscriptCallback","handleFocusActivity","dispatchTranscriptFocus","focusedActivity","handleFocusFiller","isContentInteractive","defaultProps","propTypes","PropTypes","shape","array","isRequired","string","InternalScreenReaderTranscript","arrayOf","any","InternalTranscriptScrollable","children","onFocusActivity","onFocusFiller","activitiesStyleSet","animatingToEnd","atEnd","sticky","styleOptions","lastVisibleActivityId","lastReadActivityIdRef","handleScrollToEndButtonClick","firstUnreadActivity","ScrollToEndButton","unread","React","Children","count","func","SetScroller","scrollerRef","autoScrollSnapOnActivity","autoScrollSnapOnActivityOffset","autoScrollSnapOnPage","autoScrollSnapOnPageOffset","lastAcknowledgedActivity","activitiesRef","lastAcknowledgedActivityRef","patchedAutoScrollSnapOnActivity","patchedAutoScrollSnapOnPage","patchedAutoScrollSnapOnActivityOffset","patchedAutoScrollSnapOnPageOffset","values","lastAcknowledgedActivityIndex","firstUnacknowledgedActivityElementIndex","activityElementIndex","nthUnacknowledgedActivityElement","firstUnacknowledgedActivityElement","reduce","minValue","value","BasicTranscript","scroller"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["/* eslint no-magic-numbers: [\"error\", { \"ignore\": [-1, 0, 1, 2, 5, 36] }] */\n\nimport { hooks } from 'botframework-webchat-api';\nimport {\n  Composer as ReactScrollToBottomComposer,\n  Panel as ReactScrollToBottomPanel,\n  useAnimatingToEnd,\n  useAtEnd,\n  useObserveScrollPosition,\n  useScrollTo,\n  useScrollToEnd,\n  useSticky\n} from 'react-scroll-to-bottom';\nimport classNames from 'classnames';\nimport PropTypes from 'prop-types';\nimport random from 'math-random';\nimport React, { useCallback, useEffect, useMemo, useRef, useState } from 'react';\n\nimport BasicTypingIndicator from './BasicTypingIndicator';\nimport Fade from './Utils/Fade';\nimport FocusRedirector from './Utils/FocusRedirector';\nimport getActivityUniqueId from './Utils/getActivityUniqueId';\nimport getTabIndex from './Utils/TypeFocusSink/getTabIndex';\nimport inputtableKey from './Utils/TypeFocusSink/inputtableKey';\nimport intersectionOf from './Utils/intersectionOf';\nimport isZeroOrPositive from './Utils/isZeroOrPositive';\nimport removeInline from './Utils/removeInline';\nimport ScreenReaderActivity from './ScreenReaderActivity';\nimport ScreenReaderText from './ScreenReaderText';\nimport SpeakActivity from './Activity/Speak';\nimport tabbableElements from './Utils/tabbableElements';\nimport useAcknowledgedActivity from './hooks/internal/useAcknowledgedActivity';\nimport useDispatchScrollPosition from './hooks/internal/useDispatchScrollPosition';\nimport useDispatchTranscriptFocus from './hooks/internal/useDispatchTranscriptFocus';\nimport useFocus from './hooks/useFocus';\nimport useMemoize from './hooks/internal/useMemoize';\nimport useRegisterFocusTranscript from './hooks/internal/useRegisterFocusTranscript';\nimport useRegisterScrollRelative from './hooks/internal/useRegisterScrollRelative';\nimport useRegisterScrollTo from './hooks/internal/useRegisterScrollTo';\nimport useRegisterScrollToEnd from './hooks/internal/useRegisterScrollToEnd';\nimport useStyleSet from './hooks/useStyleSet';\nimport useStyleToEmotionObject from './hooks/internal/useStyleToEmotionObject';\nimport useUniqueId from './hooks/internal/useUniqueId';\n\nconst {\n  useActivities,\n  useCreateActivityRenderer,\n  useCreateActivityStatusRenderer,\n  useCreateAvatarRenderer,\n  useCreateScrollToEndButtonRenderer,\n  useDirection,\n  useGroupActivities,\n  useLocalizer,\n  useStyleOptions\n} = hooks;\n\nconst ROOT_STYLE = {\n  '&.webchat__basic-transcript': {\n    display: 'flex',\n    flexDirection: 'column',\n    overflow: 'hidden',\n    // Make sure to set \"position: relative\" here to form another stacking context for the scroll-to-end button.\n    // Stacking context help isolating elements that use \"z-index\" from global pollution.\n    // https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Positioning/Understanding_z_index/The_stacking_context\n    position: 'relative',\n\n    '& .webchat__basic-transcript__filler': {\n      flex: 1\n    },\n\n    '& .webchat__basic-transcript__scrollable': {\n      display: 'flex',\n      flexDirection: 'column',\n      overflowX: 'hidden',\n      WebkitOverflowScrolling: 'touch'\n    },\n\n    '& .webchat__basic-transcript__transcript': {\n      listStyleType: 'none'\n    }\n  }\n};\n\nfunction validateAllActivitiesTagged(activities, bins) {\n  return activities.every(activity => bins.some(bin => bin.includes(activity)));\n}\n\nconst InternalTranscript = ({ activityElementsRef, className }) => {\n  const [{ basicTranscript: basicTranscriptStyleSet }] = useStyleSet();\n  const [{ bubbleFromUserNubOffset, bubbleNubOffset, groupTimestamp, internalLiveRegionFadeAfter, showAvatarInGroup }] =\n    useStyleOptions();\n  const [focusedActivityKey, setFocusedActivityKey] = useState();\n  const [activities] = useActivities();\n  const [direction] = useDirection();\n  const createActivityRenderer = useCreateActivityRenderer();\n  const createActivityStatusRenderer = useCreateActivityStatusRenderer();\n  const createAvatarRenderer = useCreateAvatarRenderer();\n  const focus = useFocus();\n  const groupActivities = useGroupActivities();\n  const localize = useLocalizer();\n  const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n  const rootElementRef = useRef();\n  const terminatorRef = useRef();\n\n  const activityInteractiveAlt = localize('ACTIVITY_INTERACTIVE_LABEL_ALT');\n  const terminatorText = localize('TRANSCRIPT_TERMINATOR_TEXT');\n  const transcriptAriaLabel = localize('TRANSCRIPT_ARIA_LABEL_ALT');\n  const transcriptRoleDescription = localize('TRANSCRIPT_ARIA_ROLE_ALT');\n\n  const hideAllTimestamps = groupTimestamp === false;\n\n  // Gets renderer for every activity.\n  // Activities that are not visible will return a falsy renderer.\n\n  // Converted from createActivityRenderer({ activity, nextVisibleActivity }) to createActivityRenderer(activity, nextVisibleActivity).\n  // This is for the memoization function to cache the arguments. Memoizer can only cache literal arguments.\n  const createActivityRendererWithLiteralArgs = useCallback(\n    (activity, nextVisibleActivity) => createActivityRenderer({ activity, nextVisibleActivity }),\n    [createActivityRenderer]\n  );\n\n  // Create a memoized context of the createActivityRenderer function.\n  const activitiesWithRenderer = useMemoize(\n    createActivityRendererWithLiteralArgs,\n    createActivityRendererWithLiteralArgsMemoized => {\n      // All calls to createActivityRendererWithLiteralArgsMemoized() in this function will be memoized (LRU = 1).\n      // In the next render cycle, calls to createActivityRendererWithLiteralArgsMemoized() might return the memoized result instead.\n      // This is an improvement to React useMemo(), because it only allows 1 memoization.\n      // useMemoize() allows any number of memoization.\n\n      const activitiesWithRenderer = [];\n      let nextVisibleActivity;\n\n      for (let index = activities.length - 1; index >= 0; index--) {\n        const activity = activities[index];\n        const renderActivity = createActivityRendererWithLiteralArgsMemoized(activity, nextVisibleActivity);\n\n        if (renderActivity) {\n          activitiesWithRenderer.splice(0, 0, {\n            activity,\n            renderActivity\n          });\n\n          nextVisibleActivity = activity;\n        }\n      }\n\n      return activitiesWithRenderer;\n    },\n    [activities]\n  );\n\n  const visibleActivities = useMemo(\n    () => activitiesWithRenderer.map(({ activity }) => activity),\n    [activitiesWithRenderer]\n  );\n\n  // Tag activities based on types.\n  // The default implementation tag into 2 types: sender and status.\n\n  const { activitiesGroupBySender, activitiesGroupByStatus } = useMemo(() => {\n    const { sender: activitiesGroupBySender, status: activitiesGroupByStatus } = groupActivities({\n      activities: visibleActivities\n    });\n\n    if (!validateAllActivitiesTagged(visibleActivities, activitiesGroupBySender)) {\n      console.warn(\n        'botframework-webchat: Not every activities are grouped in the \"sender\" property. Please fix \"groupActivitiesMiddleware\" and group every activities.'\n      );\n    }\n\n    if (!validateAllActivitiesTagged(visibleActivities, activitiesGroupByStatus)) {\n      console.warn(\n        'botframework-webchat: Not every activities are grouped in the \"status\" property. Please fix \"groupActivitiesMiddleware\" and group every activities.'\n      );\n    }\n\n    return {\n      activitiesGroupBySender,\n      activitiesGroupByStatus\n    };\n  }, [groupActivities, visibleActivities]);\n\n  // Create a tree of activities with 2 dimensions: sender, followed by status.\n\n  const activityTree = useMemo(() => {\n    const visibleActivitiesPendingGrouping = [...visibleActivities];\n    const activityTree = [];\n\n    while (visibleActivitiesPendingGrouping.length) {\n      const [activity] = visibleActivitiesPendingGrouping;\n      const senderTree = [];\n      const activitiesWithSameSender = activitiesGroupBySender.find(activities => activities.includes(activity));\n\n      activityTree.push(senderTree);\n\n      activitiesWithSameSender.forEach(activity => {\n        const activitiesWithSameStatus = activitiesGroupByStatus.find(activities => activities.includes(activity));\n\n        const activitiesWithSameSenderAndStatus = intersectionOf(\n          visibleActivitiesPendingGrouping,\n          activitiesWithSameSender,\n          activitiesWithSameStatus\n        );\n\n        if (activitiesWithSameSenderAndStatus.length) {\n          senderTree.push(activitiesWithSameSenderAndStatus);\n          removeInline(visibleActivitiesPendingGrouping, ...activitiesWithSameSenderAndStatus);\n        }\n      });\n    }\n\n    // Assertion: All activities in visibleActivities, must be assigned to the activityTree\n    if (\n      !visibleActivities.every(activity =>\n        activityTree.some(activitiesWithSameSender =>\n          activitiesWithSameSender.some(activitiesWithSameSenderAndStatus =>\n            activitiesWithSameSenderAndStatus.includes(activity)\n          )\n        )\n      )\n    ) {\n      console.warn('botframework-webchat internal: Not all visible activities are grouped in the activityTree.', {\n        visibleActivities,\n        activityTree\n      });\n    }\n\n    return activityTree;\n  }, [activitiesGroupBySender, activitiesGroupByStatus, visibleActivities]);\n\n  // Flatten the tree back into an array with information related to rendering.\n\n  const renderingElements = useMemo(() => {\n    const renderingElements = [];\n    const topSideBotNub = isZeroOrPositive(bubbleNubOffset);\n    const topSideUserNub = isZeroOrPositive(bubbleFromUserNubOffset);\n\n    activityTree.forEach(activitiesWithSameSender => {\n      const [[firstActivity]] = activitiesWithSameSender;\n      const renderAvatar = createAvatarRenderer({ activity: firstActivity });\n\n      activitiesWithSameSender.forEach((activitiesWithSameSenderAndStatus, indexWithinSenderGroup) => {\n        const firstInSenderGroup = !indexWithinSenderGroup;\n        const lastInSenderGroup = indexWithinSenderGroup === activitiesWithSameSender.length - 1;\n\n        activitiesWithSameSenderAndStatus.forEach((activity, indexWithinSenderAndStatusGroup) => {\n          // We only show the timestamp at the end of the sender group. But we always show the \"Send failed, retry\" prompt.\n          const renderActivityStatus = createActivityStatusRenderer({\n            activity\n          });\n\n          const firstInSenderAndStatusGroup = !indexWithinSenderAndStatusGroup;\n          const lastInSenderAndStatusGroup =\n            indexWithinSenderAndStatusGroup === activitiesWithSameSenderAndStatus.length - 1;\n\n          const { renderActivity } = activitiesWithRenderer.find(entry => entry.activity === activity);\n          const key = getActivityUniqueId(activity) || renderingElements.length;\n          const baseAltText =\n            typeof activity?.channelData?.['webchat:fallback-text'] === 'string'\n              ? activity?.channelData?.['webchat:fallback-text']\n              : activity?.channelData?.messageBack?.displayText || activity.text;\n\n          // If \"webchat:fallback-text\" field is set to empty string, the activity must not be narrated.\n          const supportScreenReader = activity?.channelData?.['webchat:fallback-text'] !== '';\n\n          const {\n            from: { role }\n          } = activity;\n\n          const topSideNub = role === 'user' ? topSideUserNub : topSideBotNub;\n\n          let showCallout;\n\n          // Depending on the \"showAvatarInGroup\" setting, the avatar will render in different positions.\n          if (showAvatarInGroup === 'sender') {\n            if (topSideNub) {\n              showCallout = firstInSenderGroup && firstInSenderAndStatusGroup;\n            } else {\n              showCallout = lastInSenderGroup && lastInSenderAndStatusGroup;\n            }\n          } else if (showAvatarInGroup === 'status') {\n            if (topSideNub) {\n              showCallout = firstInSenderAndStatusGroup;\n            } else {\n              showCallout = lastInSenderAndStatusGroup;\n            }\n          } else {\n            showCallout = true;\n          }\n\n          const focusActivity = () => {\n            setFocusedActivityKey(getActivityUniqueId(activity));\n\n            // IE11 need to manually focus on the transcript.\n            const { current: rootElement } = rootElementRef;\n\n            rootElement && rootElement.focus();\n          };\n\n          renderingElements.push({\n            activity,\n\n            // After the element is mounted, set it to activityElementsRef.\n            callbackRef: activityElement => {\n              const entry = activityElementsRef.current.find(({ activityID }) => activityID === activity.id);\n\n              if (entry) {\n                entry.element = activityElement;\n              }\n            },\n\n            // Calling this function will put the focus on the transcript and the activity.\n            focusActivity,\n\n            // When a child of the activity receives focus, notify the transcript to set the aria-activedescendant to this activity.\n            handleFocus: () => {\n              setFocusedActivityKey(getActivityUniqueId(activity));\n            },\n\n            handleKeyDown: event => {\n              if (event.key === 'Escape') {\n                event.preventDefault();\n                event.stopPropagation();\n\n                setFocusedActivityKey(getActivityUniqueId(activity));\n\n                const { current } = rootElementRef;\n\n                current && current.focus();\n              }\n            },\n\n            // For accessibility: when the user press up/down arrow keys, we put a visual focus indicator around the focused activity.\n            // We should do the same for mouse, that is why we have the click handler here.\n            // We are doing it in event capture phase to prevent other components from stopping event propagation to us.\n            handleMouseDownCapture: ({ target }) => {\n              const tabIndex = getTabIndex(target);\n\n              if (typeof tabIndex !== 'number' || tabIndex < 0 || target.getAttribute('aria-disabled') === 'true') {\n                focusActivity();\n              }\n            },\n\n            // \"hideTimestamp\" is a render-time parameter for renderActivityStatus().\n            // If true, it will hide the timestamp, but it will continue to show the\n            // retry prompt. And show the screen reader version of the timestamp.\n            hideTimestamp:\n              hideAllTimestamps || indexWithinSenderAndStatusGroup !== activitiesWithSameSenderAndStatus.length - 1,\n            key,\n\n            // When \"liveRegionKey\" changes or contents that made up the alt text changed, it will show up in the live region momentarily.\n            liveRegionKey: key + '|' + baseAltText,\n            renderActivity,\n            renderActivityStatus,\n            renderAvatar,\n            role,\n\n            // TODO: [P2] #2858 We should use core/definitions/speakingActivity for this predicate instead\n            shouldSpeak: activity.channelData && activity.channelData.speak,\n            showCallout,\n            supportScreenReader\n          });\n        });\n      });\n    });\n\n    const { current: activityElements } = activityElementsRef;\n\n    // Update activityElementRef with new sets of activity, while retaining the existing referencing element if exists.\n    activityElementsRef.current = renderingElements.map(({ activity, activity: { id }, elementId, key }) => {\n      const existingEntry = activityElements.find(entry => entry.key === key);\n\n      return {\n        activity,\n        activityID: id,\n        ariaLabelID: existingEntry\n          ? existingEntry.ariaLabelID\n          : `webchat__basic-transcript__activity-label-${random().toString(36).substr(2, 5)}`,\n        element: existingEntry && existingEntry.element,\n        elementId,\n        key\n      };\n    });\n\n    // There must be one focused (a.k.a. aria-activedescendant) designated. We default it to the last one.\n    if (!renderingElements.find(({ focused }) => focused)) {\n      const lastElement = renderingElements[renderingElements.length - 1];\n\n      if (lastElement) {\n        lastElement.focused = true;\n      }\n    }\n\n    return renderingElements;\n  }, [\n    activitiesWithRenderer,\n    activityElementsRef,\n    activityTree,\n    bubbleFromUserNubOffset,\n    bubbleNubOffset,\n    createActivityStatusRenderer,\n    createAvatarRenderer,\n    hideAllTimestamps,\n    rootElementRef,\n    showAvatarInGroup\n  ]);\n\n  const renderingActivities = useMemo(() => renderingElements.map(({ activity }) => activity), [renderingElements]);\n\n  const scrollToBottomScrollTo = useScrollTo();\n  const scrollToBottomScrollToEnd = useScrollToEnd();\n\n  const scrollTo = useCallback(\n    (position, { behavior = 'auto' } = {}) => {\n      if (!position) {\n        throw new Error(\n          'botframework-webchat: First argument passed to \"useScrollTo\" must be a ScrollPosition object.'\n        );\n      }\n\n      const { activityID, scrollTop } = position;\n\n      if (typeof scrollTop !== 'undefined') {\n        scrollToBottomScrollTo(scrollTop, { behavior });\n      } else if (typeof activityID !== 'undefined') {\n        const { current: rootElement } = rootElementRef;\n        const { element: activityElement } =\n          activityElementsRef.current.find(entry => entry.activityID === activityID) || {};\n\n        const scrollableElement = rootElement.querySelector('.webchat__basic-transcript__scrollable');\n\n        if (scrollableElement && activityElement) {\n          const [{ height: activityElementHeight, y: activityElementY }] = activityElement.getClientRects();\n          const [{ height: scrollableHeight }] = scrollableElement.getClientRects();\n\n          const activityElementOffsetTop = activityElementY + scrollableElement.scrollTop;\n\n          const scrollTop = Math.min(\n            activityElementOffsetTop,\n            activityElementOffsetTop - scrollableHeight + activityElementHeight\n          );\n\n          scrollToBottomScrollTo(scrollTop, { behavior });\n        }\n      }\n    },\n    [activityElementsRef, rootElementRef, scrollToBottomScrollTo]\n  );\n\n  const scrollToEnd = useCallback(() => scrollToBottomScrollToEnd({ behavior: 'smooth' }), [scrollToBottomScrollToEnd]);\n\n  const scrollRelative = useCallback(\n    (direction, { displacement } = {}) => {\n      const { current: rootElement } = rootElementRef;\n\n      if (!rootElement) {\n        return;\n      }\n\n      const scrollable = rootElement.querySelector('.webchat__basic-transcript__scrollable');\n      let nextScrollTop;\n\n      if (typeof displacement === 'number') {\n        nextScrollTop = scrollable.scrollTop + (direction === 'down' ? 1 : -1) * displacement;\n      } else {\n        nextScrollTop = scrollable.scrollTop + (direction === 'down' ? 1 : -1) * scrollable.offsetHeight;\n      }\n\n      scrollTo(\n        {\n          scrollTop: Math.max(0, Math.min(scrollable.scrollHeight - scrollable.offsetHeight, nextScrollTop))\n        },\n        { behavior: 'smooth' }\n      );\n    },\n    [rootElementRef, scrollTo]\n  );\n\n  // Since there could be multiple instances of <BasicTranscript> inside the <Composer>, when the developer calls `scrollXXX`, we need to call it on all instances.\n  // We call `useRegisterScrollXXX` to register a callback function, the `useScrollXXX` will multiplex the call into each instance of <BasicTranscript>.\n  useRegisterScrollTo(scrollTo);\n  useRegisterScrollToEnd(scrollToEnd);\n  useRegisterScrollRelative(scrollRelative);\n\n  const dispatchScrollPosition = useDispatchScrollPosition();\n  const patchedDispatchScrollPosition = useMemo(() => {\n    if (!dispatchScrollPosition) {\n      return;\n    }\n\n    return ({ scrollTop }) => {\n      const { current: rootElement } = rootElementRef;\n\n      if (!rootElement) {\n        return;\n      }\n\n      const scrollableElement = rootElement.querySelector('.webchat__basic-transcript__scrollable');\n\n      const [{ height: offsetHeight } = {}] = scrollableElement.getClientRects();\n\n      // Find the activity just above scroll view bottom.\n      // If the scroll view is already on top, get the first activity.\n      const entry = scrollableElement.scrollTop\n        ? [...activityElementsRef.current].reverse().find(({ element }) => {\n            if (!element) {\n              return false;\n            }\n\n            const [{ y } = {}] = element.getClientRects();\n\n            return y < offsetHeight;\n          })\n        : activityElementsRef.current[0];\n\n      const { activityID } = entry || {};\n\n      dispatchScrollPosition({ ...(activityID ? { activityID } : {}), scrollTop });\n    };\n  }, [activityElementsRef, dispatchScrollPosition, rootElementRef]);\n\n  useObserveScrollPosition(patchedDispatchScrollPosition);\n\n  const [lastInteractedActivity] = useAcknowledgedActivity();\n\n  const indexOfLastInteractedActivity = activities.indexOf(lastInteractedActivity);\n\n  // Create a new ID for aria-activedescendant every time the active descendant change.\n  // In our design, the transcript will only have 1 focused activity and it has an ID. Other blurred activities will not have ID assigned.\n  // This help with performance.\n  // But browser usually do noop if the value of aria-activedescendant doesn't change.\n  // That means, if we assign the same ID to another element, browser will do noop.\n  // We need to generate a new ID so the browser see there is a change in aria-activedescendant value and perform accordingly.\n  const activeDescendantElementId = useMemo(\n    () => focusedActivityKey && `webchat__basic-transcript__active-descendant-${random().toString(36).substr(2, 5)}`,\n    [focusedActivityKey]\n  );\n\n  const scrollActiveDescendantIntoView = useCallback(() => {\n    const activeDescendant = activeDescendantElementId && document.getElementById(activeDescendantElementId);\n\n    // Don't scroll active descendant into view if the focus is already inside it.\n    // Otherwise, given the focus is on the send box, clicking on any <input> inside the Adaptive Cards may cause the view to move.\n    // This UX is not desirable because click should not cause scroll.\n    if (activeDescendant && !activeDescendant.contains(document.activeElement)) {\n      // Checks if scrollIntoView support options or not.\n      // - https://github.com/Modernizr/Modernizr/issues/1568#issuecomment-419457972\n      // - https://stackoverflow.com/questions/46919627/is-it-possible-to-test-for-scrollintoview-browser-compatibility\n      if ('scrollBehavior' in document.documentElement.style) {\n        activeDescendant.scrollIntoView({ block: 'nearest' });\n      } else {\n        // This is for browser that does not support options passed to scrollIntoView(), possibly IE11.\n        const scrollableElement = rootElementRef.current.querySelector('.webchat__basic-transcript__scrollable');\n        const scrollTopAtTopSide = activeDescendant.offsetTop;\n        const scrollTopAtBottomSide = activeDescendant.offsetTop + activeDescendant.offsetHeight;\n\n        if (scrollTopAtTopSide < scrollableElement.scrollTop) {\n          scrollableElement.scrollTop = scrollTopAtTopSide;\n        } else if (scrollTopAtBottomSide > scrollableElement.scrollTop + scrollableElement.offsetHeight) {\n          scrollableElement.scrollTop = scrollTopAtBottomSide - scrollableElement.offsetHeight;\n        }\n      }\n    }\n  }, [activeDescendantElementId, rootElementRef]);\n\n  const handleTranscriptFocus = useCallback(\n    event => {\n      const { currentTarget, target } = event;\n\n      // When focus is placed on the transcript, scroll active descendant into the view.\n      currentTarget === target && scrollActiveDescendantIntoView();\n    },\n    [scrollActiveDescendantIntoView]\n  );\n\n  // After new aria-activedescendant is assigned, we will need to scroll it into view.\n  // User agent will scroll automatically for focusing element, but not for aria-activedescendant.\n  // We need to do the scrolling manually.\n  useEffect(() => scrollActiveDescendantIntoView(), [scrollActiveDescendantIntoView]);\n\n  // If any activities has changed, reset the active descendant.\n  useEffect(() => setFocusedActivityKey(undefined), [activities, setFocusedActivityKey]);\n\n  const focusRelativeActivity = useCallback(\n    delta => {\n      if (isNaN(delta) || !renderingElements.length) {\n        return setFocusedActivityKey(undefined);\n      }\n\n      const index = renderingElements.findIndex(({ key }) => key === focusedActivityKey);\n      const nextIndex = ~index\n        ? Math.max(0, Math.min(renderingElements.length - 1, index + delta))\n        : renderingElements.length - 1;\n      const nextFocusedActivity = renderingElements[nextIndex];\n\n      setFocusedActivityKey(nextFocusedActivity.key);\n      rootElementRef.current && rootElementRef.current.focus();\n    },\n    [focusedActivityKey, renderingElements, rootElementRef, setFocusedActivityKey]\n  );\n\n  const handleTranscriptKeyDown = useCallback(\n    event => {\n      const { target } = event;\n\n      const fromEndOfTranscriptIndicator = target === terminatorRef.current;\n      const fromTranscript = target === event.currentTarget;\n\n      if (!fromEndOfTranscriptIndicator && !fromTranscript) {\n        return;\n      }\n\n      let handled = true;\n\n      switch (event.key) {\n        case 'ArrowDown':\n          focusRelativeActivity(fromEndOfTranscriptIndicator ? 0 : 1);\n          break;\n\n        case 'ArrowUp':\n          focusRelativeActivity(fromEndOfTranscriptIndicator ? 0 : -1);\n          break;\n\n        case 'End':\n          focusRelativeActivity(Infinity);\n          break;\n\n        case 'Enter':\n          if (!fromEndOfTranscriptIndicator) {\n            const focusedActivityEntry = renderingElements.find(({ key }) => key === focusedActivityKey);\n\n            if (focusedActivityEntry) {\n              const { element: focusedActivityElement } =\n                activityElementsRef.current.find(({ activity }) => activity === focusedActivityEntry.activity) || {};\n\n              if (focusedActivityElement) {\n                const [firstTabbableElement] = tabbableElements(focusedActivityElement).filter(\n                  ({ className }) => className !== 'webchat__basic-transcript__activity-sentinel'\n                );\n\n                firstTabbableElement && firstTabbableElement.focus();\n              }\n            }\n          }\n\n          break;\n\n        case 'Escape':\n          focus('sendBoxWithoutKeyboard');\n          break;\n\n        case 'Home':\n          focusRelativeActivity(-Infinity);\n          break;\n\n        default:\n          handled = false;\n          break;\n      }\n\n      if (handled) {\n        event.preventDefault();\n\n        // If a custom HTML control wants to handle up/down arrow, we will prevent them from listening to this event to prevent bugs due to handling arrow keys twice.\n        event.stopPropagation();\n      }\n    },\n    [focusedActivityKey, activityElementsRef, focusRelativeActivity, focus, terminatorRef, renderingElements]\n  );\n\n  const labelId = useUniqueId('webchat__basic-transcript__label');\n\n  // If SHIFT-TAB from \"End of transcript\" indicator, if focusedActivityKey is not set (or no longer exists), set it the the bottommost activity.\n  const setBottommostFocusedActivityKeyIfNeeded = useCallback(() => {\n    if (!~renderingElements.findIndex(({ key }) => key === focusedActivityKey)) {\n      const { key: lastActivityKey } = renderingElements[renderingElements.length - 1] || {};\n\n      setFocusedActivityKey(lastActivityKey);\n    }\n  }, [focusedActivityKey, renderingElements, setFocusedActivityKey]);\n\n  const handleTranscriptKeyDownCapture = useCallback(\n    event => {\n      const { altKey, ctrlKey, key, metaKey, target } = event;\n\n      if (altKey || (ctrlKey && key !== 'v') || metaKey || (!inputtableKey(key) && key !== 'Backspace')) {\n        // Ignore if one of the utility key (except SHIFT) is pressed\n        // E.g. CTRL-C on a link in one of the message should not jump to chat box\n        // E.g. \"A\" or \"Backspace\" should jump to chat box\n        return;\n      }\n\n      // Send keystrokes to send box if we are focusing on the transcript or terminator.\n      if (target === event.currentTarget || target === terminatorRef.current) {\n        event.stopPropagation();\n\n        focus('sendBox');\n      }\n    },\n    [focus]\n  );\n\n  const focusTranscriptCallback = useCallback(\n    () => rootElementRef.current && rootElementRef.current.focus(),\n    [rootElementRef]\n  );\n\n  useRegisterFocusTranscript(focusTranscriptCallback);\n\n  const handleFocusActivity = useCallback(\n    key => {\n      setFocusedActivityKey(key);\n      rootElementRef.current && rootElementRef.current.focus();\n    },\n    [setFocusedActivityKey]\n  );\n\n  // When the focusing activity has changed, dispatch an event to observers of \"useObserveTranscriptFocus\".\n  const dispatchTranscriptFocus = useDispatchTranscriptFocus();\n  const focusedActivity = useMemo(() => {\n    const { activity } = renderingElements.find(({ key }) => key === focusedActivityKey) || {};\n\n    return activity;\n  }, [focusedActivityKey, renderingElements]);\n\n  useMemo(\n    () => dispatchTranscriptFocus && dispatchTranscriptFocus({ activity: focusedActivity }),\n    [dispatchTranscriptFocus, focusedActivity]\n  );\n\n  // This is required by IE11.\n  // When the user clicks on and empty space (a.k.a. filler) in an empty transcript, IE11 says the focus is on the <div className=\"filler\">,\n  // despite the fact there are no \"tabIndex\" attributes set on the filler.\n  // We need to artificially send the focus back to the transcript.\n  const handleFocusFiller = useCallback(() => {\n    const { current } = rootElementRef;\n\n    current && current.focus();\n  }, [rootElementRef]);\n\n  return (\n    <div\n      aria-activedescendant={focusedActivityKey ? activeDescendantElementId : undefined}\n      aria-labelledby={labelId}\n      className={classNames(\n        'webchat__basic-transcript',\n        basicTranscriptStyleSet + '',\n        rootClassName,\n        (className || '') + ''\n      )}\n      dir={direction}\n      onFocus={handleTranscriptFocus}\n      onKeyDown={handleTranscriptKeyDown}\n      onKeyDownCapture={handleTranscriptKeyDownCapture}\n      ref={rootElementRef}\n      // \"aria-activedescendant\" will only works with a number of roles and it must be explicitly set.\n      // https://www.w3.org/TR/wai-aria/#aria-activedescendant\n      role=\"group\"\n      // For up/down arrow key navigation across activities, this component must be included in the tab sequence.\n      // Otherwise, \"aria-activedescendant\" will not be narrated when the user press up/down arrow keys.\n      // https://www.w3.org/TR/wai-aria-practices-1.1/#kbd_focus_activedescendant\n      tabIndex={0}\n    >\n      <ScreenReaderText id={labelId} text={transcriptAriaLabel} />\n      {/* This <section> is for live region only. Content is made invisible through CSS. */}\n      <section\n        aria-atomic={false}\n        aria-live=\"polite\"\n        aria-relevant=\"additions\"\n        aria-roledescription={transcriptRoleDescription}\n        role=\"log\"\n      >\n        {renderingElements\n          .filter(({ supportScreenReader }) => supportScreenReader)\n          .map(({ activity, liveRegionKey }) => (\n            <Fade fadeAfter={internalLiveRegionFadeAfter} key={liveRegionKey}>\n              {() => <ScreenReaderActivity activity={activity} />}\n            </Fade>\n          ))}\n      </section>\n      {/* TODO: [P2] Fix ESLint error `no-use-before-define` */}\n      {/* eslint-disable-next-line @typescript-eslint/no-use-before-define */}\n      <InternalTranscriptScrollable\n        activities={renderingActivities}\n        onFocusActivity={handleFocusActivity}\n        onFocusFiller={handleFocusFiller}\n        terminatorRef={terminatorRef}\n      >\n        {renderingElements.map(\n          (\n            {\n              activity,\n              callbackRef,\n              focusActivity,\n              handleFocus,\n              handleKeyDown,\n              handleMouseDownCapture,\n              hideTimestamp,\n              key,\n              renderActivity,\n              renderActivityStatus,\n              renderAvatar,\n              role,\n              shouldSpeak,\n              showCallout,\n              supportScreenReader\n            },\n            index\n          ) => {\n            const { ariaLabelID, element } =\n              activityElementsRef.current.find(entry => entry.activity === activity) || {};\n            const activeDescendant = focusedActivityKey === key;\n            const isContentInteractive = !!(element\n              ? tabbableElements(element.querySelector('.webchat__basic-transcript__activity-box')).length\n              : 0);\n\n            return (\n              <li\n                aria-labelledby={ariaLabelID}\n                className={classNames('webchat__basic-transcript__activity', {\n                  'webchat__basic-transcript__activity--acknowledged': index <= indexOfLastInteractedActivity,\n                  'webchat__basic-transcript__activity--from-bot': role !== 'user',\n                  'webchat__basic-transcript__activity--from-user': role === 'user'\n                })}\n                // Set \"id\" for valid for accessibility.\n                /* eslint-disable-next-line react/forbid-dom-props */\n                id={activeDescendant ? activeDescendantElementId : undefined}\n                key={key}\n                onFocus={handleFocus}\n                onKeyDown={handleKeyDown}\n                onMouseDownCapture={handleMouseDownCapture}\n                ref={callbackRef}\n              >\n                {supportScreenReader && (\n                  <ScreenReaderActivity activity={activity} id={ariaLabelID} renderAttachments={false}>\n                    {!!isContentInteractive && <p>{activityInteractiveAlt}</p>}\n                  </ScreenReaderActivity>\n                )}\n                <FocusRedirector\n                  className=\"webchat__basic-transcript__activity-sentinel\"\n                  onFocus={focusActivity}\n                  redirectRef={rootElementRef}\n                />\n                <div className=\"webchat__basic-transcript__activity-box\">\n                  {renderActivity({\n                    hideTimestamp,\n                    renderActivityStatus,\n                    renderAvatar,\n                    showCallout\n                  })}\n                </div>\n                {shouldSpeak && <SpeakActivity activity={activity} />}\n                <FocusRedirector\n                  className=\"webchat__basic-transcript__activity-sentinel\"\n                  onFocus={focusActivity}\n                  redirectRef={rootElementRef}\n                />\n                <div\n                  className={classNames('webchat__basic-transcript__activity-indicator', {\n                    'webchat__basic-transcript__activity-indicator--first': !index,\n                    'webchat__basic-transcript__activity-indicator--focus': activeDescendant\n                  })}\n                />\n              </li>\n            );\n          }\n        )}\n      </InternalTranscriptScrollable>\n      {!!renderingElements.length && (\n        <React.Fragment>\n          <FocusRedirector\n            className=\"webchat__basic-transcript__sentinel\"\n            onFocus={setBottommostFocusedActivityKeyIfNeeded}\n            redirectRef={rootElementRef}\n          />\n          <div className=\"webchat__basic-transcript__terminator\" ref={terminatorRef} tabIndex={0}>\n            <div className=\"webchat__basic-transcript__terminator-body\">\n              <div className=\"webchat__basic-transcript__terminator-text\">{terminatorText}</div>\n            </div>\n          </div>\n        </React.Fragment>\n      )}\n      <div className=\"webchat__basic-transcript__focus-indicator\" />\n    </div>\n  );\n};\n\nInternalTranscript.defaultProps = {\n  className: ''\n};\n\nInternalTranscript.propTypes = {\n  activityElementsRef: PropTypes.shape({\n    current: PropTypes.array.isRequired\n  }).isRequired,\n  className: PropTypes.string\n};\n\nconst InternalScreenReaderTranscript = ({ renderingElements }) => {\n  const localize = useLocalizer();\n  const [internalLiveRegionFadeAfter] = useStyleOptions();\n\n  const transcriptRoleDescription = localize('TRANSCRIPT_ARIA_ROLE_ALT');\n\n  return (\n    <section\n      aria-atomic={false}\n      aria-live=\"polite\"\n      aria-relevant=\"additions\"\n      aria-roledescription={transcriptRoleDescription}\n      role=\"log\"\n    >\n      {renderingElements.map(({ activity, liveRegionKey }) => (\n        <Fade fadeAfter={internalLiveRegionFadeAfter} key={liveRegionKey}>\n          {() => <ScreenReaderActivity activity={activity} />}\n        </Fade>\n      ))}\n    </section>\n  );\n};\n\nInternalScreenReaderTranscript.propTypes = {\n  renderingElements: PropTypes.arrayOf(\n    PropTypes.shape({\n      activity: PropTypes.any,\n      liveRegionKey: PropTypes.string\n    })\n  ).isRequired\n};\n\n// Separating high-frequency hooks to improve performance.\nconst InternalTranscriptScrollable = ({ activities, children, onFocusActivity, onFocusFiller, terminatorRef }) => {\n  const [{ activities: activitiesStyleSet }] = useStyleSet();\n  const [animatingToEnd] = useAnimatingToEnd();\n  const [atEnd] = useAtEnd();\n  const [sticky] = useSticky();\n  const [styleOptions] = useStyleOptions();\n  const lastVisibleActivityId = getActivityUniqueId(activities[activities.length - 1] || {}); // Activity ID of the last visible activity in the list.\n  const localize = useLocalizer();\n  const scrollToEnd = useScrollToEnd();\n\n  const lastReadActivityIdRef = useRef(lastVisibleActivityId);\n  const transcriptRoleDescription = localize('TRANSCRIPT_ARIA_ROLE_ALT');\n\n  const handleScrollToEndButtonClick = useCallback(() => {\n    scrollToEnd({ behavior: 'smooth' });\n\n    // After the \"New message\" button is clicked, focus on the first unread activity.\n    const index = activities.findIndex(({ id }) => id === lastReadActivityIdRef.current);\n\n    if (~index) {\n      const firstUnreadActivity = activities[index + 1];\n\n      if (firstUnreadActivity) {\n        return onFocusActivity(getActivityUniqueId(firstUnreadActivity));\n      }\n    }\n\n    const { current } = terminatorRef;\n\n    current && current.focus();\n  }, [activities, lastReadActivityIdRef, onFocusActivity, scrollToEnd, terminatorRef]);\n\n  if (atEnd || sticky) {\n    // If it is sticky or at the end, the user is at the bottom of the transcript, everything is read.\n    // So mark the activity ID as read.\n    lastReadActivityIdRef.current = lastVisibleActivityId;\n  }\n\n  const ScrollToEndButton = useCreateScrollToEndButtonRenderer()({\n    atEnd: animatingToEnd || atEnd || sticky,\n    styleOptions,\n\n    // Unread means:\n    // 1. Last read is not the last one in the transcript, and;\n    // 2. Last read is still in the transcript.\n    unread:\n      lastVisibleActivityId !== lastReadActivityIdRef.current &&\n      !!~activities.findIndex(activity => getActivityUniqueId(activity) === lastReadActivityIdRef.current)\n  });\n\n  return (\n    <React.Fragment>\n      {ScrollToEndButton && <ScrollToEndButton onClick={handleScrollToEndButtonClick} />}\n      {!!React.Children.count(children) && (\n        <FocusRedirector className=\"webchat__basic-transcript__sentinel\" redirectRef={terminatorRef} />\n      )}\n      <ReactScrollToBottomPanel className=\"webchat__basic-transcript__scrollable\">\n        <div aria-hidden={true} className=\"webchat__basic-transcript__filler\" onFocus={onFocusFiller} />\n        <ul\n          aria-roledescription={transcriptRoleDescription}\n          className={classNames(activitiesStyleSet + '', 'webchat__basic-transcript__transcript')}\n          role=\"list\"\n        >\n          {children}\n        </ul>\n        <BasicTypingIndicator />\n      </ReactScrollToBottomPanel>\n    </React.Fragment>\n  );\n};\n\nInternalTranscriptScrollable.propTypes = {\n  activities: PropTypes.array.isRequired,\n  children: PropTypes.any.isRequired,\n  onFocusActivity: PropTypes.func.isRequired,\n  onFocusFiller: PropTypes.func.isRequired,\n  terminatorRef: PropTypes.any.isRequired\n};\n\nconst SetScroller = ({ activityElementsRef, scrollerRef }) => {\n  const [\n    { autoScrollSnapOnActivity, autoScrollSnapOnActivityOffset, autoScrollSnapOnPage, autoScrollSnapOnPageOffset }\n  ] = useStyleOptions();\n  const [activities] = useActivities();\n  const [lastAcknowledgedActivity] = useAcknowledgedActivity();\n\n  const activitiesRef = useRef(activities);\n  const lastAcknowledgedActivityRef = useRef(lastAcknowledgedActivity);\n\n  activitiesRef.current = activities;\n  lastAcknowledgedActivityRef.current = lastAcknowledgedActivity;\n\n  scrollerRef.current = useCallback(\n    ({ offsetHeight, scrollTop }) => {\n      const patchedAutoScrollSnapOnActivity =\n        typeof autoScrollSnapOnActivity === 'number'\n          ? Math.max(0, autoScrollSnapOnActivity)\n          : autoScrollSnapOnActivity\n          ? 1\n          : 0;\n      const patchedAutoScrollSnapOnPage =\n        typeof autoScrollSnapOnPage === 'number'\n          ? Math.max(0, Math.min(1, autoScrollSnapOnPage))\n          : autoScrollSnapOnPage\n          ? 1\n          : 0;\n      const patchedAutoScrollSnapOnActivityOffset =\n        typeof autoScrollSnapOnActivityOffset === 'number' ? autoScrollSnapOnActivityOffset : 0;\n      const patchedAutoScrollSnapOnPageOffset =\n        typeof autoScrollSnapOnPageOffset === 'number' ? autoScrollSnapOnPageOffset : 0;\n\n      if (patchedAutoScrollSnapOnActivity || patchedAutoScrollSnapOnPage) {\n        const { current: activities } = activitiesRef;\n        const { current: activityElements } = activityElementsRef;\n        const { current: lastAcknowledgedActivity } = lastAcknowledgedActivityRef;\n        const values = [];\n\n        const lastAcknowledgedActivityIndex = activities.indexOf(lastAcknowledgedActivity);\n\n        if (~lastAcknowledgedActivityIndex) {\n          // The activity that we acknowledged could be not rendered, such as post back activity.\n          // When calculating scroll snap, we can only base on the first unacknowledged-and-rendering activity.\n          let firstUnacknowledgedActivityElementIndex = -1;\n\n          for (let index = lastAcknowledgedActivityIndex + 1, { length } = activities; index < length; index++) {\n            const activity = activities[index];\n            const activityElementIndex = activityElements.findIndex(entry => entry.activity === activity);\n\n            if (~activityElementIndex) {\n              firstUnacknowledgedActivityElementIndex = activityElementIndex;\n              break;\n            }\n          }\n\n          if (~firstUnacknowledgedActivityElementIndex) {\n            if (patchedAutoScrollSnapOnActivity) {\n              // Gets the activity element which we should snap to.\n              const { element: nthUnacknowledgedActivityElement } =\n                activityElements[firstUnacknowledgedActivityElementIndex + patchedAutoScrollSnapOnActivity - 1];\n\n              if (nthUnacknowledgedActivityElement) {\n                values.push(\n                  nthUnacknowledgedActivityElement.offsetTop +\n                    nthUnacknowledgedActivityElement.offsetHeight -\n                    offsetHeight -\n                    scrollTop +\n                    patchedAutoScrollSnapOnActivityOffset\n                );\n              }\n            }\n\n            if (patchedAutoScrollSnapOnPage) {\n              const { element: firstUnacknowledgedActivityElement } =\n                activityElements[firstUnacknowledgedActivityElementIndex];\n\n              values.push(\n                firstUnacknowledgedActivityElement.offsetTop -\n                  scrollTop -\n                  offsetHeight * (1 - patchedAutoScrollSnapOnPage) +\n                  patchedAutoScrollSnapOnPageOffset\n              );\n            }\n          }\n        }\n\n        return values.reduce((minValue, value) => Math.min(minValue, value), Infinity);\n      }\n\n      return Infinity;\n    },\n    [\n      activitiesRef,\n      activityElementsRef,\n      autoScrollSnapOnActivity,\n      autoScrollSnapOnActivityOffset,\n      autoScrollSnapOnPage,\n      autoScrollSnapOnPageOffset,\n      lastAcknowledgedActivityRef\n    ]\n  );\n\n  return false;\n};\n\nconst BasicTranscript = ({ className }) => {\n  const activityElementsRef = useRef([]);\n  const scrollerRef = useRef(() => Infinity);\n\n  const scroller = useCallback((...args) => scrollerRef.current(...args), [scrollerRef]);\n\n  return (\n    <ReactScrollToBottomComposer scroller={scroller}>\n      <SetScroller activityElementsRef={activityElementsRef} scrollerRef={scrollerRef} />\n      <InternalTranscript activityElementsRef={activityElementsRef} className={className} />\n    </ReactScrollToBottomComposer>\n  );\n};\n\nBasicTranscript.defaultProps = {\n  className: ''\n};\n\nBasicTranscript.propTypes = {\n  className: PropTypes.string\n};\n\nexport default BasicTranscript;\n"]}