botframework-webchat-component 4.14.1 → 4.15.0

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 (371) hide show
  1. package/.eslintrc.yml +4 -106
  2. package/.prettierrc.yml +1 -1
  3. package/lib/Activity/CarouselFilmStrip.js +1 -1
  4. package/lib/Activity/CarouselFilmStripAttachment.js +1 -1
  5. package/lib/Activity/Speak.js +1 -1
  6. package/lib/Activity/StackedLayout.d.ts.map +1 -1
  7. package/lib/Activity/StackedLayout.js +2 -2
  8. package/lib/Attachment/FileAttachment.js +2 -2
  9. package/lib/Attachment/FileContent.d.ts.map +1 -1
  10. package/lib/Attachment/FileContent.js +11 -1
  11. package/lib/BasicSendBox.js +1 -1
  12. package/lib/BasicToaster.js +5 -2
  13. package/lib/BasicTranscript.d.ts +7 -0
  14. package/lib/BasicTranscript.d.ts.map +1 -0
  15. package/lib/BasicTranscript.js +368 -725
  16. package/lib/BasicTypingIndicator.d.ts +2 -1
  17. package/lib/BasicTypingIndicator.d.ts.map +1 -1
  18. package/lib/BasicTypingIndicator.js +12 -4
  19. package/lib/Composer.d.ts.map +1 -1
  20. package/lib/Composer.js +34 -29
  21. package/lib/Middleware/Activity/createCoreMiddleware.d.ts.map +1 -1
  22. package/lib/Middleware/Activity/createCoreMiddleware.js +1 -1
  23. package/lib/Middleware/ActivityStatus/SendStatus/SendStatus.js +1 -1
  24. package/lib/Middleware/ActivityStatus/createSendStatusMiddleware.js +18 -15
  25. package/lib/Middleware/Attachment/createCoreMiddleware.js +2 -5
  26. package/lib/Middleware/AttachmentForScreenReader/createCoreMiddleware.d.ts.map +1 -1
  27. package/lib/Middleware/AttachmentForScreenReader/createCoreMiddleware.js +1 -1
  28. package/lib/Middleware/Avatar/createCoreMiddleware.d.ts.map +1 -1
  29. package/lib/Middleware/Avatar/createCoreMiddleware.js +2 -3
  30. package/lib/Middleware/CardAction/createCoreMiddleware.js +10 -3
  31. package/lib/Middleware/ScrollToEndButton/createScrollToEndButtonMiddleware.d.ts.map +1 -1
  32. package/lib/Middleware/ScrollToEndButton/createScrollToEndButtonMiddleware.js +1 -1
  33. package/lib/Middleware/Toast/createCoreMiddleware.d.ts.map +1 -1
  34. package/lib/Middleware/Toast/createCoreMiddleware.js +1 -1
  35. package/lib/Middleware/TypingIndicator/createCoreMiddleware.d.ts.map +1 -1
  36. package/lib/Middleware/TypingIndicator/createCoreMiddleware.js +8 -6
  37. package/lib/ScreenReaderActivity.js +14 -5
  38. package/lib/ScreenReaderText.d.ts +9 -0
  39. package/lib/ScreenReaderText.d.ts.map +1 -0
  40. package/lib/ScreenReaderText.js +22 -8
  41. package/lib/SendBox/DictationInterims.js +1 -1
  42. package/lib/SendBox/IconButton.d.ts +11 -0
  43. package/lib/SendBox/IconButton.d.ts.map +1 -0
  44. package/lib/SendBox/IconButton.js +26 -6
  45. package/lib/SendBox/MicrophoneButton.js +1 -1
  46. package/lib/SendBox/SendButton.js +1 -1
  47. package/lib/SendBox/SuggestedAction.d.ts +17 -0
  48. package/lib/SendBox/SuggestedAction.d.ts.map +1 -0
  49. package/lib/SendBox/SuggestedAction.js +25 -16
  50. package/lib/SendBox/SuggestedActions.d.ts.map +1 -1
  51. package/lib/SendBox/SuggestedActions.js +25 -8
  52. package/lib/SendBox/TextBox.js +1 -1
  53. package/lib/SendBox/UploadButton.js +1 -1
  54. package/lib/Styles/StyleSet/BasicTranscript.d.ts +13 -5
  55. package/lib/Styles/StyleSet/BasicTranscript.d.ts.map +1 -1
  56. package/lib/Styles/StyleSet/BasicTranscript.js +21 -9
  57. package/lib/Styles/StyleSet/Bubble.d.ts.map +1 -1
  58. package/lib/Styles/StyleSet/Bubble.js +1 -1
  59. package/lib/Styles/StyleSet/CarouselFilmStrip.d.ts.map +1 -1
  60. package/lib/Styles/StyleSet/CarouselFilmStrip.js +1 -1
  61. package/lib/Styles/StyleSet/CarouselFilmStripAttachment.d.ts.map +1 -1
  62. package/lib/Styles/StyleSet/CarouselFilmStripAttachment.js +1 -1
  63. package/lib/Styles/StyleSet/KeyboardHelp.d.ts +123 -0
  64. package/lib/Styles/StyleSet/KeyboardHelp.d.ts.map +1 -0
  65. package/lib/Styles/StyleSet/KeyboardHelp.js +145 -0
  66. package/lib/Styles/StyleSet/ScrollToEndButton.d.ts +1 -1
  67. package/lib/Styles/StyleSet/ScrollToEndButton.js +2 -2
  68. package/lib/Styles/StyleSet/SendBoxButton.d.ts +56 -10
  69. package/lib/Styles/StyleSet/SendBoxButton.d.ts.map +1 -1
  70. package/lib/Styles/StyleSet/SendBoxButton.js +76 -12
  71. package/lib/Styles/StyleSet/SendBoxTextBox.d.ts +1 -1
  72. package/lib/Styles/StyleSet/SendBoxTextBox.d.ts.map +1 -1
  73. package/lib/Styles/StyleSet/SendBoxTextBox.js +3 -3
  74. package/lib/Styles/StyleSet/StackedLayout.d.ts.map +1 -1
  75. package/lib/Styles/StyleSet/StackedLayout.js +1 -1
  76. package/lib/Styles/StyleSet/SuggestedAction.d.ts +73 -28
  77. package/lib/Styles/StyleSet/SuggestedAction.d.ts.map +1 -1
  78. package/lib/Styles/StyleSet/SuggestedAction.js +116 -41
  79. package/lib/Styles/StyleSet/SuggestedActions.d.ts +13 -6
  80. package/lib/Styles/StyleSet/SuggestedActions.d.ts.map +1 -1
  81. package/lib/Styles/StyleSet/SuggestedActions.js +13 -6
  82. package/lib/Styles/createStyleSet.d.ts +323 -54
  83. package/lib/Styles/createStyleSet.d.ts.map +1 -1
  84. package/lib/Styles/createStyleSet.js +4 -1
  85. package/lib/Styles/mirrorStyle.js +12 -3
  86. package/lib/Toast/NotificationIcon.js +7 -3
  87. package/lib/Toast/createToastMiddleware.d.ts.map +1 -1
  88. package/lib/Toast/createToastMiddleware.js +1 -1
  89. package/lib/Transcript/ActivityRow.d.ts +9 -0
  90. package/lib/Transcript/ActivityRow.d.ts.map +1 -0
  91. package/lib/Transcript/ActivityRow.js +157 -0
  92. package/lib/Transcript/ActivityTextAlt.js +57 -0
  93. package/lib/Transcript/FocusTrap.d.ts +8 -0
  94. package/lib/Transcript/FocusTrap.d.ts.map +1 -0
  95. package/lib/Transcript/FocusTrap.js +74 -0
  96. package/lib/Transcript/KeyboardHelp.d.ts +4 -0
  97. package/lib/Transcript/KeyboardHelp.d.ts.map +1 -0
  98. package/lib/Transcript/KeyboardHelp.js +550 -0
  99. package/lib/Transcript/LiveRegionTranscript.d.ts +8 -0
  100. package/lib/Transcript/LiveRegionTranscript.d.ts.map +1 -0
  101. package/lib/Transcript/LiveRegionTranscript.js +214 -0
  102. package/lib/Transcript/types.d.ts +2 -0
  103. package/lib/Transcript/types.d.ts.map +1 -0
  104. package/lib/Transcript/types.js +2 -0
  105. package/lib/Transcript/useActivityAccessibleName.d.ts +4 -0
  106. package/lib/Transcript/useActivityAccessibleName.d.ts.map +1 -0
  107. package/lib/Transcript/useActivityAccessibleName.js +97 -0
  108. package/lib/Utils/AccessibleButton.d.ts +11 -0
  109. package/lib/Utils/AccessibleButton.d.ts.map +1 -0
  110. package/lib/Utils/AccessibleButton.js +11 -6
  111. package/lib/Utils/FocusRedirector.d.ts +9 -0
  112. package/lib/Utils/FocusRedirector.d.ts.map +1 -0
  113. package/lib/Utils/FocusRedirector.js +16 -13
  114. package/lib/Utils/InlineMarkdown.js +12 -5
  115. package/lib/Utils/TypeFocusSink/inputtableKey.d.ts +2 -0
  116. package/lib/Utils/TypeFocusSink/inputtableKey.d.ts.map +1 -0
  117. package/lib/Utils/TypeFocusSink/inputtableKey.js +5 -2
  118. package/lib/Utils/activityAltText.d.ts +8 -0
  119. package/lib/Utils/activityAltText.d.ts.map +1 -0
  120. package/lib/Utils/createCustomEvent.js +8 -2
  121. package/lib/Utils/detectBrowser.js +4 -2
  122. package/lib/Utils/downscaleImageToDataURL/downscaleImageToDataURLUsingWorker.js +1 -1
  123. package/lib/Utils/findAncestor.js +17 -0
  124. package/lib/Utils/getActivityUniqueId.js +4 -2
  125. package/lib/Utils/intersectionOf.d.ts +5 -0
  126. package/lib/Utils/intersectionOf.d.ts.map +1 -0
  127. package/lib/Utils/intersectionOf.js +17 -2
  128. package/lib/Utils/isZeroOrPositive.d.ts +5 -0
  129. package/lib/Utils/isZeroOrPositive.d.ts.map +1 -0
  130. package/lib/Utils/isZeroOrPositive.js +4 -1
  131. package/lib/Utils/mapMap.js +9 -2
  132. package/lib/Utils/readDataURIToBlob.js +1 -1
  133. package/lib/Utils/scrollIntoViewWithBlockNearest.d.ts +7 -0
  134. package/lib/Utils/scrollIntoViewWithBlockNearest.d.ts.map +1 -0
  135. package/lib/Utils/scrollIntoViewWithBlockNearest.js +48 -0
  136. package/lib/Utils/shallowEquals.js +7 -3
  137. package/lib/Utils/supportPseudoClass.d.ts +2 -0
  138. package/lib/Utils/supportPseudoClass.d.ts.map +1 -0
  139. package/lib/Utils/supportPseudoClass.js +23 -0
  140. package/lib/Utils/tabbableElements.d.ts +2 -0
  141. package/lib/Utils/tabbableElements.d.ts.map +1 -0
  142. package/lib/Utils/tabbableElements.js +2 -2
  143. package/lib/connectToWebChat.js +13 -5
  144. package/lib/hooks/index.js +24 -24
  145. package/lib/hooks/internal/BypassSpeechSynthesisPonyfill.js +5 -4
  146. package/lib/hooks/internal/useChanged.js +8 -1
  147. package/lib/hooks/internal/useDispatchScrollPosition.js +3 -7
  148. package/lib/hooks/internal/useDispatchTranscriptFocusByActivityKey.d.ts +2 -0
  149. package/lib/hooks/internal/useDispatchTranscriptFocusByActivityKey.d.ts.map +1 -0
  150. package/lib/hooks/internal/useDispatchTranscriptFocusByActivityKey.js +15 -0
  151. package/lib/hooks/internal/useFocusVisible.d.ts +3 -0
  152. package/lib/hooks/internal/useFocusVisible.d.ts.map +1 -0
  153. package/lib/hooks/internal/useFocusVisible.js +48 -0
  154. package/lib/hooks/internal/useMemoWithPrevious.d.ts +3 -0
  155. package/lib/hooks/internal/useMemoWithPrevious.d.ts.map +1 -0
  156. package/lib/hooks/internal/useMemoWithPrevious.js +22 -0
  157. package/lib/hooks/internal/useMemoize.d.ts +14 -0
  158. package/lib/hooks/internal/useMemoize.d.ts.map +1 -0
  159. package/lib/hooks/internal/useMemoize.js +11 -2
  160. package/lib/hooks/internal/useObserveFocusVisible.d.ts +3 -0
  161. package/lib/hooks/internal/useObserveFocusVisible.d.ts.map +1 -0
  162. package/lib/hooks/internal/useObserveFocusVisible.js +208 -0
  163. package/lib/hooks/internal/usePrevious.d.ts +2 -0
  164. package/lib/hooks/internal/usePrevious.d.ts.map +1 -0
  165. package/lib/hooks/internal/usePrevious.js +18 -0
  166. package/lib/hooks/internal/useStateRef.d.ts +3 -0
  167. package/lib/hooks/internal/useStateRef.d.ts.map +1 -0
  168. package/lib/hooks/internal/useStateRef.js +40 -0
  169. package/lib/hooks/internal/useValueRef.d.ts +3 -0
  170. package/lib/hooks/internal/useValueRef.d.ts.map +1 -0
  171. package/lib/hooks/internal/useValueRef.js +25 -0
  172. package/lib/hooks/useFocus.d.ts +1 -1
  173. package/lib/hooks/useFocus.d.ts.map +1 -1
  174. package/lib/hooks/useFocus.js +1 -1
  175. package/lib/hooks/useRenderMarkdownAsHTML.d.ts.map +1 -1
  176. package/lib/hooks/useRenderMarkdownAsHTML.js +1 -1
  177. package/lib/hooks/useScrollTo.d.ts.map +1 -1
  178. package/lib/hooks/useScrollTo.js +1 -1
  179. package/lib/hooks/useScrollToEnd.d.ts.map +1 -1
  180. package/lib/hooks/useScrollToEnd.js +1 -1
  181. package/lib/index.d.ts +10 -0
  182. package/lib/index.d.ts.map +1 -1
  183. package/lib/index.js +17 -15
  184. package/lib/providers/ActivityTree/ActivityTreeComposer.d.ts +5 -0
  185. package/lib/providers/ActivityTree/ActivityTreeComposer.d.ts.map +1 -0
  186. package/lib/providers/ActivityTree/ActivityTreeComposer.js +86 -0
  187. package/lib/providers/ActivityTree/private/Context.d.ts +9 -0
  188. package/lib/providers/ActivityTree/private/Context.d.ts.map +1 -0
  189. package/lib/providers/ActivityTree/private/Context.js +13 -0
  190. package/lib/providers/ActivityTree/private/types.d.ts +10 -0
  191. package/lib/providers/ActivityTree/private/types.d.ts.map +1 -0
  192. package/lib/providers/ActivityTree/private/types.js +2 -0
  193. package/lib/providers/ActivityTree/private/useActivitiesWithRenderer.d.ts +4 -0
  194. package/lib/providers/ActivityTree/private/useActivitiesWithRenderer.d.ts.map +1 -0
  195. package/lib/providers/ActivityTree/private/useActivitiesWithRenderer.js +58 -0
  196. package/lib/providers/ActivityTree/private/useActivityTreeWithRenderer.d.ts +5 -0
  197. package/lib/providers/ActivityTree/private/useActivityTreeWithRenderer.d.ts.map +1 -0
  198. package/lib/providers/ActivityTree/private/useActivityTreeWithRenderer.js +166 -0
  199. package/lib/providers/ActivityTree/private/useContext.d.ts +3 -0
  200. package/lib/providers/ActivityTree/private/useContext.d.ts.map +1 -0
  201. package/lib/providers/ActivityTree/private/useContext.js +24 -0
  202. package/lib/providers/ActivityTree/useActivityTreeWithRenderer.d.ts +8 -0
  203. package/lib/providers/ActivityTree/useActivityTreeWithRenderer.d.ts.map +1 -0
  204. package/lib/providers/ActivityTree/useActivityTreeWithRenderer.js +17 -0
  205. package/lib/providers/LiveRegionTwin/LiveRegionTwinComposer.d.ts +35 -0
  206. package/lib/providers/LiveRegionTwin/LiveRegionTwinComposer.d.ts.map +1 -0
  207. package/lib/providers/LiveRegionTwin/LiveRegionTwinComposer.js +156 -0
  208. package/lib/providers/LiveRegionTwin/private/Context.d.ts +10 -0
  209. package/lib/providers/LiveRegionTwin/private/Context.d.ts.map +1 -0
  210. package/lib/providers/LiveRegionTwin/private/Context.js +13 -0
  211. package/lib/providers/LiveRegionTwin/private/LiveRegionTwinContainer.d.ts +11 -0
  212. package/lib/providers/LiveRegionTwin/private/LiveRegionTwinContainer.d.ts.map +1 -0
  213. package/lib/providers/LiveRegionTwin/private/LiveRegionTwinContainer.js +86 -0
  214. package/lib/providers/LiveRegionTwin/private/types.d.ts +8 -0
  215. package/lib/providers/LiveRegionTwin/private/types.d.ts.map +1 -0
  216. package/lib/providers/LiveRegionTwin/private/types.js +2 -0
  217. package/lib/providers/LiveRegionTwin/private/useContext.d.ts +3 -0
  218. package/lib/providers/LiveRegionTwin/private/useContext.d.ts.map +1 -0
  219. package/lib/providers/LiveRegionTwin/private/useContext.js +24 -0
  220. package/lib/providers/LiveRegionTwin/private/useMarkAllAsRenderedEffect.d.ts +2 -0
  221. package/lib/providers/LiveRegionTwin/private/useMarkAllAsRenderedEffect.d.ts.map +1 -0
  222. package/lib/providers/LiveRegionTwin/private/useMarkAllAsRenderedEffect.js +24 -0
  223. package/lib/providers/LiveRegionTwin/private/useStaticElementEntries.d.ts +3 -0
  224. package/lib/providers/LiveRegionTwin/private/useStaticElementEntries.d.ts.map +1 -0
  225. package/lib/providers/LiveRegionTwin/private/useStaticElementEntries.js +15 -0
  226. package/lib/providers/LiveRegionTwin/useQueueStaticElement.d.ts +8 -0
  227. package/lib/providers/LiveRegionTwin/useQueueStaticElement.d.ts.map +1 -0
  228. package/lib/providers/LiveRegionTwin/useQueueStaticElement.js +20 -0
  229. package/lib/providers/TranscriptFocus/TranscriptFocusComposer.d.ts +7 -0
  230. package/lib/providers/TranscriptFocus/TranscriptFocusComposer.d.ts.map +1 -0
  231. package/lib/providers/TranscriptFocus/TranscriptFocusComposer.js +184 -0
  232. package/lib/providers/TranscriptFocus/private/Context.d.ts +12 -0
  233. package/lib/providers/TranscriptFocus/private/Context.d.ts.map +1 -0
  234. package/lib/providers/TranscriptFocus/private/Context.js +13 -0
  235. package/lib/providers/TranscriptFocus/private/useContext.d.ts +2 -0
  236. package/lib/providers/TranscriptFocus/private/useContext.d.ts.map +1 -0
  237. package/lib/providers/TranscriptFocus/private/useContext.js +24 -0
  238. package/lib/providers/TranscriptFocus/useActiveDescendantId.d.ts +2 -0
  239. package/lib/providers/TranscriptFocus/useActiveDescendantId.d.ts.map +1 -0
  240. package/lib/providers/TranscriptFocus/useActiveDescendantId.js +15 -0
  241. package/lib/providers/TranscriptFocus/useFocusByActivityKey.d.ts +8 -0
  242. package/lib/providers/TranscriptFocus/useFocusByActivityKey.d.ts.map +1 -0
  243. package/lib/providers/TranscriptFocus/useFocusByActivityKey.js +21 -0
  244. package/lib/providers/TranscriptFocus/useFocusRelativeActivity.d.ts +2 -0
  245. package/lib/providers/TranscriptFocus/useFocusRelativeActivity.d.ts.map +1 -0
  246. package/lib/providers/TranscriptFocus/useFocusRelativeActivity.js +15 -0
  247. package/lib/providers/TranscriptFocus/useFocusedActivityKey.d.ts +2 -0
  248. package/lib/providers/TranscriptFocus/useFocusedActivityKey.d.ts.map +1 -0
  249. package/lib/providers/TranscriptFocus/useFocusedActivityKey.js +15 -0
  250. package/lib/providers/TranscriptFocus/useFocusedExplicitly.d.ts +2 -0
  251. package/lib/providers/TranscriptFocus/useFocusedExplicitly.d.ts.map +1 -0
  252. package/lib/providers/TranscriptFocus/useFocusedExplicitly.js +15 -0
  253. package/lib/providers/TranscriptFocus/useGetDescendantIdByActivityKey.d.ts +2 -0
  254. package/lib/providers/TranscriptFocus/useGetDescendantIdByActivityKey.d.ts.map +1 -0
  255. package/lib/providers/TranscriptFocus/useGetDescendantIdByActivityKey.js +15 -0
  256. package/package.json +17 -24
  257. package/src/Activity/CarouselFilmStripAttachment.js +0 -1
  258. package/src/Activity/StackedLayout.tsx +10 -9
  259. package/src/Attachment/FileAttachment.js +1 -1
  260. package/src/Attachment/FileContent.tsx +12 -0
  261. package/src/BasicToaster.js +5 -1
  262. package/src/BasicTranscript.tsx +878 -0
  263. package/src/BasicTypingIndicator.tsx +3 -2
  264. package/src/Composer.tsx +41 -29
  265. package/src/Middleware/Activity/createCoreMiddleware.tsx +50 -44
  266. package/src/Middleware/ActivityStatus/createSendStatusMiddleware.js +2 -0
  267. package/src/Middleware/Attachment/createCoreMiddleware.tsx +28 -28
  268. package/src/Middleware/AttachmentForScreenReader/createCoreMiddleware.tsx +25 -23
  269. package/src/Middleware/Avatar/createCoreMiddleware.tsx +9 -8
  270. package/src/Middleware/CardAction/createCoreMiddleware.js +9 -2
  271. package/src/Middleware/ScrollToEndButton/createScrollToEndButtonMiddleware.ts +11 -9
  272. package/src/Middleware/Toast/createCoreMiddleware.tsx +12 -10
  273. package/src/Middleware/TypingIndicator/createCoreMiddleware.tsx +8 -2
  274. package/src/ScreenReaderActivity.js +18 -3
  275. package/src/{ScreenReaderText.js → ScreenReaderText.tsx} +27 -9
  276. package/src/SendBox/{IconButton.js → IconButton.tsx} +19 -3
  277. package/src/SendBox/{SuggestedAction.js → SuggestedAction.tsx} +72 -35
  278. package/src/SendBox/SuggestedActions.tsx +47 -20
  279. package/src/Styles/StyleSet/BasicTranscript.ts +34 -20
  280. package/src/Styles/StyleSet/Bubble.ts +0 -1
  281. package/src/Styles/StyleSet/CarouselFilmStrip.ts +12 -10
  282. package/src/Styles/StyleSet/CarouselFilmStripAttachment.ts +4 -3
  283. package/src/Styles/StyleSet/KeyboardHelp.ts +157 -0
  284. package/src/Styles/StyleSet/ScrollToEndButton.ts +1 -1
  285. package/src/Styles/StyleSet/SendBoxButton.ts +84 -13
  286. package/src/Styles/StyleSet/SendBoxTextBox.ts +1 -2
  287. package/src/Styles/StyleSet/StackedLayout.ts +13 -11
  288. package/src/Styles/StyleSet/SuggestedAction.ts +129 -42
  289. package/src/Styles/StyleSet/SuggestedActions.ts +13 -5
  290. package/src/Styles/createStyleSet.ts +2 -1
  291. package/src/Styles/mirrorStyle.js +10 -2
  292. package/src/Toast/NotificationIcon.js +4 -1
  293. package/src/Toast/createToastMiddleware.tsx +4 -1
  294. package/src/Transcript/ActivityRow.tsx +124 -0
  295. package/src/Transcript/ActivityTextAlt.tsx +32 -0
  296. package/src/Transcript/FocusTrap.tsx +64 -0
  297. package/src/Transcript/KeyboardHelp.tsx +282 -0
  298. package/src/Transcript/LiveRegionTranscript.tsx +181 -0
  299. package/src/Transcript/types.ts +1 -0
  300. package/src/Transcript/useActivityAccessibleName.ts +85 -0
  301. package/src/Utils/{AccessibleButton.js → AccessibleButton.tsx} +19 -4
  302. package/src/Utils/{FocusRedirector.js → FocusRedirector.tsx} +21 -8
  303. package/src/Utils/InlineMarkdown.js +18 -2
  304. package/src/Utils/TypeFocusSink/inputtableKey.ts +5 -1
  305. package/src/Utils/createCustomEvent.js +7 -1
  306. package/src/Utils/detectBrowser.js +2 -1
  307. package/src/Utils/findAncestor.ts +12 -0
  308. package/src/Utils/getActivityUniqueId.ts +5 -0
  309. package/src/Utils/intersectionOf.ts +14 -0
  310. package/src/Utils/isZeroOrPositive.ts +7 -0
  311. package/src/Utils/mapMap.js +7 -1
  312. package/src/Utils/scrollIntoViewWithBlockNearest.ts +20 -0
  313. package/src/Utils/shallowEquals.js +8 -1
  314. package/src/Utils/supportPseudoClass.ts +17 -0
  315. package/src/Utils/{tabbableElements.js → tabbableElements.ts} +6 -5
  316. package/src/connectToWebChat.js +11 -4
  317. package/src/hooks/internal/BypassSpeechSynthesisPonyfill.js +3 -1
  318. package/src/hooks/internal/useChanged.ts +17 -0
  319. package/src/hooks/internal/useDispatchScrollPosition.js +1 -3
  320. package/src/hooks/internal/useDispatchTranscriptFocusByActivityKey.ts +5 -0
  321. package/src/hooks/internal/useFocusVisible.ts +22 -0
  322. package/src/hooks/internal/useMemoWithPrevious.ts +16 -0
  323. package/src/hooks/internal/useMemoize.spec.js +1 -1
  324. package/src/hooks/internal/useMemoize.ts +53 -0
  325. package/src/hooks/internal/useObserveFocusVisible.ts +252 -0
  326. package/src/hooks/internal/usePrevious.ts +12 -0
  327. package/src/hooks/internal/useStateRef.ts +31 -0
  328. package/src/hooks/internal/useValueRef.ts +22 -0
  329. package/src/hooks/useFocus.ts +1 -1
  330. package/src/hooks/useRenderMarkdownAsHTML.ts +4 -5
  331. package/src/hooks/useScrollTo.ts +4 -3
  332. package/src/hooks/useScrollToEnd.ts +4 -3
  333. package/src/index.ts +0 -1
  334. package/src/providers/ActivityTree/ActivityTreeComposer.tsx +74 -0
  335. package/src/providers/ActivityTree/private/Context.ts +12 -0
  336. package/src/providers/ActivityTree/private/types.ts +12 -0
  337. package/src/providers/ActivityTree/private/useActivitiesWithRenderer.ts +66 -0
  338. package/src/providers/ActivityTree/private/useActivityTreeWithRenderer.ts +140 -0
  339. package/src/providers/ActivityTree/private/useContext.ts +15 -0
  340. package/src/providers/ActivityTree/useActivityTreeWithRenderer.ts +16 -0
  341. package/src/providers/LiveRegionTwin/LiveRegionTwinComposer.tsx +154 -0
  342. package/src/providers/LiveRegionTwin/private/Context.ts +15 -0
  343. package/src/providers/LiveRegionTwin/private/LiveRegionTwinContainer.tsx +64 -0
  344. package/src/providers/LiveRegionTwin/private/types.ts +10 -0
  345. package/src/providers/LiveRegionTwin/private/useContext.ts +15 -0
  346. package/src/providers/LiveRegionTwin/private/useMarkAllAsRenderedEffect.ts +13 -0
  347. package/src/providers/LiveRegionTwin/private/useStaticElementEntries.ts +7 -0
  348. package/src/providers/LiveRegionTwin/useQueueStaticElement.ts +12 -0
  349. package/src/providers/TranscriptFocus/TranscriptFocusComposer.tsx +180 -0
  350. package/src/providers/TranscriptFocus/private/Context.ts +16 -0
  351. package/src/providers/TranscriptFocus/private/useContext.ts +13 -0
  352. package/src/providers/TranscriptFocus/useActiveDescendantId.ts +5 -0
  353. package/src/providers/TranscriptFocus/useFocusByActivityKey.ts +14 -0
  354. package/src/providers/TranscriptFocus/useFocusRelativeActivity.ts +5 -0
  355. package/src/providers/TranscriptFocus/useFocusedActivityKey.ts +5 -0
  356. package/src/providers/TranscriptFocus/useFocusedExplicitly.ts +5 -0
  357. package/src/providers/TranscriptFocus/useGetDescendantIdByActivityKey.ts +5 -0
  358. package/.eslintignore +0 -1
  359. package/lib/Utils/findLastIndex.js +0 -32
  360. package/lib/hooks/internal/useAcknowledgedActivity.js +0 -90
  361. package/lib/hooks/internal/useDispatchTranscriptFocus.js +0 -19
  362. package/src/BasicTranscript.js +0 -1139
  363. package/src/Utils/findLastIndex.js +0 -11
  364. package/src/Utils/findLastIndex.spec.js +0 -31
  365. package/src/Utils/getActivityUniqueId.js +0 -3
  366. package/src/Utils/intersectionOf.js +0 -11
  367. package/src/Utils/isZeroOrPositive.js +0 -4
  368. package/src/hooks/internal/useAcknowledgedActivity.js +0 -65
  369. package/src/hooks/internal/useChanged.js +0 -10
  370. package/src/hooks/internal/useDispatchTranscriptFocus.js +0 -7
  371. package/src/hooks/internal/useMemoize.js +0 -37
@@ -15,45 +15,49 @@ var _classnames = _interopRequireDefault(require("classnames"));
15
15
 
16
16
  var _propTypes = _interopRequireDefault(require("prop-types"));
17
17
 
18
- var _mathRandom = _interopRequireDefault(require("math-random"));
19
-
20
18
  var _react = _interopRequireWildcard(require("react"));
21
19
 
22
- var _BasicTypingIndicator = _interopRequireDefault(require("./BasicTypingIndicator"));
23
-
24
- var _Fade = _interopRequireDefault(require("./Utils/Fade"));
20
+ var _detectBrowser = require("./Utils/detectBrowser");
25
21
 
26
- var _FocusRedirector = _interopRequireDefault(require("./Utils/FocusRedirector"));
22
+ var _ActivityRow = _interopRequireDefault(require("./Transcript/ActivityRow"));
27
23
 
28
- var _getActivityUniqueId = _interopRequireDefault(require("./Utils/getActivityUniqueId"));
24
+ var _BasicTypingIndicator = _interopRequireDefault(require("./BasicTypingIndicator"));
29
25
 
30
- var _getTabIndex = _interopRequireDefault(require("./Utils/TypeFocusSink/getTabIndex"));
26
+ var _FocusRedirector = _interopRequireDefault(require("./Utils/FocusRedirector"));
31
27
 
32
28
  var _inputtableKey = _interopRequireDefault(require("./Utils/TypeFocusSink/inputtableKey"));
33
29
 
34
- var _intersectionOf = _interopRequireDefault(require("./Utils/intersectionOf"));
35
-
36
30
  var _isZeroOrPositive = _interopRequireDefault(require("./Utils/isZeroOrPositive"));
37
31
 
38
- var _removeInline = _interopRequireDefault(require("./Utils/removeInline"));
32
+ var _KeyboardHelp = _interopRequireDefault(require("./Transcript/KeyboardHelp"));
39
33
 
40
- var _ScreenReaderActivity = _interopRequireDefault(require("./ScreenReaderActivity"));
34
+ var _LiveRegionTranscript = _interopRequireDefault(require("./Transcript/LiveRegionTranscript"));
41
35
 
42
- var _ScreenReaderText = _interopRequireDefault(require("./ScreenReaderText"));
36
+ var _tabbableElements = _interopRequireDefault(require("./Utils/tabbableElements"));
43
37
 
44
- var _Speak = _interopRequireDefault(require("./Activity/Speak"));
38
+ var _TranscriptFocusComposer = _interopRequireDefault(require("./providers/TranscriptFocus/TranscriptFocusComposer"));
45
39
 
46
- var _tabbableElements = _interopRequireDefault(require("./Utils/tabbableElements"));
40
+ var _useActiveDescendantId = _interopRequireDefault(require("./providers/TranscriptFocus/useActiveDescendantId"));
47
41
 
48
- var _useAcknowledgedActivity = _interopRequireDefault(require("./hooks/internal/useAcknowledgedActivity"));
42
+ var _useActivityTreeWithRenderer = _interopRequireDefault(require("./providers/ActivityTree/useActivityTreeWithRenderer"));
49
43
 
50
44
  var _useDispatchScrollPosition = _interopRequireDefault(require("./hooks/internal/useDispatchScrollPosition"));
51
45
 
52
- var _useDispatchTranscriptFocus = _interopRequireDefault(require("./hooks/internal/useDispatchTranscriptFocus"));
46
+ var _useDispatchTranscriptFocusByActivityKey = _interopRequireDefault(require("./hooks/internal/useDispatchTranscriptFocusByActivityKey"));
53
47
 
54
48
  var _useFocus = _interopRequireDefault(require("./hooks/useFocus"));
55
49
 
56
- var _useMemoize = _interopRequireDefault(require("./hooks/internal/useMemoize"));
50
+ var _useFocusByActivityKey = _interopRequireDefault(require("./providers/TranscriptFocus/useFocusByActivityKey"));
51
+
52
+ var _useFocusedActivityKey = _interopRequireDefault(require("./providers/TranscriptFocus/useFocusedActivityKey"));
53
+
54
+ var _useFocusedExplicitly3 = _interopRequireDefault(require("./providers/TranscriptFocus/useFocusedExplicitly"));
55
+
56
+ var _useFocusRelativeActivity = _interopRequireDefault(require("./providers/TranscriptFocus/useFocusRelativeActivity"));
57
+
58
+ var _useObserveFocusVisible = _interopRequireDefault(require("./hooks/internal/useObserveFocusVisible"));
59
+
60
+ var _usePrevious = _interopRequireDefault(require("./hooks/internal/usePrevious"));
57
61
 
58
62
  var _useRegisterFocusTranscript = _interopRequireDefault(require("./hooks/internal/useRegisterFocusTranscript"));
59
63
 
@@ -69,26 +73,22 @@ var _useStyleToEmotionObject = _interopRequireDefault(require("./hooks/internal/
69
73
 
70
74
  var _useUniqueId = _interopRequireDefault(require("./hooks/internal/useUniqueId"));
71
75
 
76
+ var _useValueRef = _interopRequireDefault(require("./hooks/internal/useValueRef"));
77
+
72
78
  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); }
73
79
 
74
80
  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; }
75
81
 
76
82
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
77
83
 
84
+ function _createForOfIteratorHelper(o, allowArrayLike) { var it = typeof Symbol !== "undefined" && o[Symbol.iterator] || o["@@iterator"]; if (!it) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = it.call(o); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
85
+
78
86
  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; }
79
87
 
80
88
  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; }
81
89
 
82
90
  function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
83
91
 
84
- function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
85
-
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."); }
87
-
88
- function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter); }
89
-
90
- function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
91
-
92
92
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
93
93
 
94
94
  function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
@@ -101,14 +101,19 @@ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Sy
101
101
 
102
102
  function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
103
103
 
104
- var useActivities = _botframeworkWebchatApi.hooks.useActivities,
105
- useCreateActivityRenderer = _botframeworkWebchatApi.hooks.useCreateActivityRenderer,
104
+ var useActivityKeys = _botframeworkWebchatApi.hooks.useActivityKeys,
105
+ useActivityKeysByRead = _botframeworkWebchatApi.hooks.useActivityKeysByRead,
106
106
  useCreateActivityStatusRenderer = _botframeworkWebchatApi.hooks.useCreateActivityStatusRenderer,
107
107
  useCreateAvatarRenderer = _botframeworkWebchatApi.hooks.useCreateAvatarRenderer,
108
108
  useCreateScrollToEndButtonRenderer = _botframeworkWebchatApi.hooks.useCreateScrollToEndButtonRenderer,
109
109
  useDirection = _botframeworkWebchatApi.hooks.useDirection,
110
- useGroupActivities = _botframeworkWebchatApi.hooks.useGroupActivities,
110
+ useGetActivityByKey = _botframeworkWebchatApi.hooks.useGetActivityByKey,
111
+ useGetKeyByActivity = _botframeworkWebchatApi.hooks.useGetKeyByActivity,
112
+ useGetKeyByActivityId = _botframeworkWebchatApi.hooks.useGetKeyByActivityId,
113
+ useLastAcknowledgedActivityKey = _botframeworkWebchatApi.hooks.useLastAcknowledgedActivityKey,
111
114
  useLocalizer = _botframeworkWebchatApi.hooks.useLocalizer,
115
+ useMarkActivityKeyAsRead = _botframeworkWebchatApi.hooks.useMarkActivityKeyAsRead,
116
+ useMarkAllAsAcknowledged = _botframeworkWebchatApi.hooks.useMarkAllAsAcknowledged,
112
117
  useStyleOptions = _botframeworkWebchatApi.hooks.useStyleOptions;
113
118
  var ROOT_STYLE = {
114
119
  '&.webchat__basic-transcript': {
@@ -133,17 +138,9 @@ var ROOT_STYLE = {
133
138
  }
134
139
  }
135
140
  };
136
-
137
- function validateAllActivitiesTagged(activities, bins) {
138
- return activities.every(function (activity) {
139
- return bins.some(function (bin) {
140
- return bin.includes(activity);
141
- });
142
- });
143
- }
144
-
145
- var InternalTranscript = function InternalTranscript(_ref) {
146
- var activityElementsRef = _ref.activityElementsRef,
141
+ // TODO: [P1] #4133 Add telemetry for computing how many re-render done so far.
142
+ var InternalTranscript = /*#__PURE__*/(0, _react.forwardRef)(function (_ref, ref) {
143
+ var activityElementMapRef = _ref.activityElementMapRef,
147
144
  className = _ref.className;
148
145
 
149
146
  var _useStyleSet = (0, _useStyleSet5.default)(),
@@ -156,187 +153,84 @@ var InternalTranscript = function InternalTranscript(_ref) {
156
153
  bubbleFromUserNubOffset = _useStyleOptions2$.bubbleFromUserNubOffset,
157
154
  bubbleNubOffset = _useStyleOptions2$.bubbleNubOffset,
158
155
  groupTimestamp = _useStyleOptions2$.groupTimestamp,
159
- internalLiveRegionFadeAfter = _useStyleOptions2$.internalLiveRegionFadeAfter,
160
156
  showAvatarInGroup = _useStyleOptions2$.showAvatarInGroup;
161
157
 
162
- var _useState = (0, _react.useState)(),
163
- _useState2 = _slicedToArray(_useState, 2),
164
- focusedActivityKey = _useState2[0],
165
- setFocusedActivityKey = _useState2[1];
158
+ var _useActiveDescendantI = (0, _useActiveDescendantId.default)(),
159
+ _useActiveDescendantI2 = _slicedToArray(_useActiveDescendantI, 1),
160
+ activeDescendantId = _useActiveDescendantI2[0];
166
161
 
167
- var _useActivities = useActivities(),
168
- _useActivities2 = _slicedToArray(_useActivities, 1),
169
- activities = _useActivities2[0];
162
+ var _useActivityTreeWithR = (0, _useActivityTreeWithRenderer.default)(),
163
+ _useActivityTreeWithR2 = _slicedToArray(_useActivityTreeWithR, 1),
164
+ activityWithRendererTree = _useActivityTreeWithR2[0];
170
165
 
171
166
  var _useDirection = useDirection(),
172
167
  _useDirection2 = _slicedToArray(_useDirection, 1),
173
168
  direction = _useDirection2[0];
174
169
 
175
- var createActivityRenderer = useCreateActivityRenderer();
170
+ var _useFocusedActivityKe = (0, _useFocusedActivityKey.default)(),
171
+ _useFocusedActivityKe2 = _slicedToArray(_useFocusedActivityKe, 1),
172
+ focusedActivityKey = _useFocusedActivityKe2[0];
173
+
174
+ var _useFocusedExplicitly = (0, _useFocusedExplicitly3.default)(),
175
+ _useFocusedExplicitly2 = _slicedToArray(_useFocusedExplicitly, 1),
176
+ focusedExplicitly = _useFocusedExplicitly2[0];
177
+
176
178
  var createActivityStatusRenderer = useCreateActivityStatusRenderer();
177
179
  var createAvatarRenderer = useCreateAvatarRenderer();
178
180
  var focus = (0, _useFocus.default)();
179
- var groupActivities = useGroupActivities();
181
+ var focusByActivityKey = (0, _useFocusByActivityKey.default)();
182
+ var focusRelativeActivity = (0, _useFocusRelativeActivity.default)();
183
+ var getActivityByKey = useGetActivityByKey();
184
+ var getKeyByActivity = useGetKeyByActivity();
185
+ var getKeyByActivityId = useGetKeyByActivityId();
180
186
  var localize = useLocalizer();
181
187
  var rootClassName = (0, _useStyleToEmotionObject.default)()(ROOT_STYLE) + '';
182
188
  var rootElementRef = (0, _react.useRef)();
189
+ var terminatorLabelId = (0, _useUniqueId.default)('webchat__basic-transcript__terminator-label');
183
190
  var terminatorRef = (0, _react.useRef)();
184
- var activityInteractiveAlt = localize('ACTIVITY_INTERACTIVE_LABEL_ALT');
191
+ var focusedActivityKeyRef = (0, _useValueRef.default)(focusedActivityKey);
192
+ var hideAllTimestamps = groupTimestamp === false;
185
193
  var terminatorText = localize('TRANSCRIPT_TERMINATOR_TEXT');
186
194
  var transcriptAriaLabel = localize('TRANSCRIPT_ARIA_LABEL_ALT');
187
- var transcriptRoleDescription = localize('TRANSCRIPT_ARIA_ROLE_ALT');
188
- var hideAllTimestamps = groupTimestamp === false; // Gets renderer for every activity.
189
- // Activities that are not visible will return a falsy renderer.
190
- // Converted from createActivityRenderer({ activity, nextVisibleActivity }) to createActivityRenderer(activity, nextVisibleActivity).
191
- // This is for the memoization function to cache the arguments. Memoizer can only cache literal arguments.
192
-
193
- var createActivityRendererWithLiteralArgs = (0, _react.useCallback)(function (activity, nextVisibleActivity) {
194
- return createActivityRenderer({
195
- activity: activity,
196
- nextVisibleActivity: nextVisibleActivity
197
- });
198
- }, [createActivityRenderer]); // Create a memoized context of the createActivityRenderer function.
199
-
200
- var activitiesWithRenderer = (0, _useMemoize.default)(createActivityRendererWithLiteralArgs, function (createActivityRendererWithLiteralArgsMemoized) {
201
- // All calls to createActivityRendererWithLiteralArgsMemoized() in this function will be memoized (LRU = 1).
202
- // In the next render cycle, calls to createActivityRendererWithLiteralArgsMemoized() might return the memoized result instead.
203
- // This is an improvement to React useMemo(), because it only allows 1 memoization.
204
- // useMemoize() allows any number of memoization.
205
- var activitiesWithRenderer = [];
206
- var nextVisibleActivity;
207
-
208
- for (var index = activities.length - 1; index >= 0; index--) {
209
- var activity = activities[index];
210
- var renderActivity = createActivityRendererWithLiteralArgsMemoized(activity, nextVisibleActivity);
211
-
212
- if (renderActivity) {
213
- activitiesWithRenderer.splice(0, 0, {
214
- activity: activity,
215
- renderActivity: renderActivity
216
- });
217
- nextVisibleActivity = activity;
218
- }
219
- }
220
-
221
- return activitiesWithRenderer;
222
- }, [activities]);
223
- var visibleActivities = (0, _react.useMemo)(function () {
224
- return activitiesWithRenderer.map(function (_ref2) {
225
- var activity = _ref2.activity;
226
- return activity;
227
- });
228
- }, [activitiesWithRenderer]); // Tag activities based on types.
229
- // The default implementation tag into 2 types: sender and status.
230
-
231
- var _useMemo = (0, _react.useMemo)(function () {
232
- var _groupActivities = groupActivities({
233
- activities: visibleActivities
234
- }),
235
- activitiesGroupBySender = _groupActivities.sender,
236
- activitiesGroupByStatus = _groupActivities.status;
237
-
238
- if (!validateAllActivitiesTagged(visibleActivities, activitiesGroupBySender)) {
239
- console.warn('botframework-webchat: Not every activities are grouped in the "sender" property. Please fix "groupActivitiesMiddleware" and group every activities.');
240
- }
241
-
242
- if (!validateAllActivitiesTagged(visibleActivities, activitiesGroupByStatus)) {
243
- console.warn('botframework-webchat: Not every activities are grouped in the "status" property. Please fix "groupActivitiesMiddleware" and group every activities.');
244
- }
245
-
246
- return {
247
- activitiesGroupBySender: activitiesGroupBySender,
248
- activitiesGroupByStatus: activitiesGroupByStatus
249
- };
250
- }, [groupActivities, visibleActivities]),
251
- activitiesGroupBySender = _useMemo.activitiesGroupBySender,
252
- activitiesGroupByStatus = _useMemo.activitiesGroupByStatus; // Create a tree of activities with 2 dimensions: sender, followed by status.
253
-
254
-
255
- var activityTree = (0, _react.useMemo)(function () {
256
- var visibleActivitiesPendingGrouping = _toConsumableArray(visibleActivities);
257
-
258
- var activityTree = [];
259
-
260
- var _loop = function _loop() {
261
- var _visibleActivitiesPen = _slicedToArray(visibleActivitiesPendingGrouping, 1),
262
- activity = _visibleActivitiesPen[0];
263
-
264
- var senderTree = [];
265
- var activitiesWithSameSender = activitiesGroupBySender.find(function (activities) {
266
- return activities.includes(activity);
267
- });
268
- activityTree.push(senderTree);
269
- activitiesWithSameSender.forEach(function (activity) {
270
- var activitiesWithSameStatus = activitiesGroupByStatus.find(function (activities) {
271
- return activities.includes(activity);
272
- });
273
- var activitiesWithSameSenderAndStatus = (0, _intersectionOf.default)(visibleActivitiesPendingGrouping, activitiesWithSameSender, activitiesWithSameStatus);
274
-
275
- if (activitiesWithSameSenderAndStatus.length) {
276
- senderTree.push(activitiesWithSameSenderAndStatus);
277
-
278
- _removeInline.default.apply(void 0, [visibleActivitiesPendingGrouping].concat(_toConsumableArray(activitiesWithSameSenderAndStatus)));
279
- }
280
- });
281
- };
282
-
283
- while (visibleActivitiesPendingGrouping.length) {
284
- _loop();
285
- } // Assertion: All activities in visibleActivities, must be assigned to the activityTree
286
-
287
-
288
- if (!visibleActivities.every(function (activity) {
289
- return activityTree.some(function (activitiesWithSameSender) {
290
- return activitiesWithSameSender.some(function (activitiesWithSameSenderAndStatus) {
291
- return activitiesWithSameSenderAndStatus.includes(activity);
292
- });
293
- });
294
- })) {
295
- console.warn('botframework-webchat internal: Not all visible activities are grouped in the activityTree.', {
296
- visibleActivities: visibleActivities,
297
- activityTree: activityTree
298
- });
195
+ var callbackRef = (0, _react.useCallback)(function (element) {
196
+ if (typeof ref === 'function') {
197
+ ref(element);
198
+ } else {
199
+ ref.current = element;
299
200
  }
300
201
 
301
- return activityTree;
302
- }, [activitiesGroupBySender, activitiesGroupByStatus, visibleActivities]); // Flatten the tree back into an array with information related to rendering.
202
+ rootElementRef.current = element;
203
+ }, [ref, rootElementRef]); // Flatten the tree back into an array with information related to rendering.
303
204
 
304
205
  var renderingElements = (0, _react.useMemo)(function () {
305
206
  var renderingElements = [];
306
207
  var topSideBotNub = (0, _isZeroOrPositive.default)(bubbleNubOffset);
307
208
  var topSideUserNub = (0, _isZeroOrPositive.default)(bubbleFromUserNubOffset);
308
- activityTree.forEach(function (activitiesWithSameSender) {
309
- var _activitiesWithSameSe = _slicedToArray(activitiesWithSameSender, 1),
310
- _activitiesWithSameSe2 = _slicedToArray(_activitiesWithSameSe[0], 1),
311
- firstActivity = _activitiesWithSameSe2[0];
209
+ activityWithRendererTree.forEach(function (entriesWithSameSender) {
210
+ var _entriesWithSameSende = _slicedToArray(entriesWithSameSender, 1),
211
+ _entriesWithSameSende2 = _slicedToArray(_entriesWithSameSende[0], 1),
212
+ firstActivity = _entriesWithSameSende2[0].activity;
312
213
 
313
214
  var renderAvatar = createAvatarRenderer({
314
215
  activity: firstActivity
315
216
  });
316
- activitiesWithSameSender.forEach(function (activitiesWithSameSenderAndStatus, indexWithinSenderGroup) {
217
+ entriesWithSameSender.forEach(function (entriesWithSameSenderAndStatus, indexWithinSenderGroup) {
317
218
  var firstInSenderGroup = !indexWithinSenderGroup;
318
- var lastInSenderGroup = indexWithinSenderGroup === activitiesWithSameSender.length - 1;
319
- activitiesWithSameSenderAndStatus.forEach(function (activity, indexWithinSenderAndStatusGroup) {
320
- var _activity$channelData, _activity$channelData2, _activity$channelData3, _activity$channelData4, _activity$channelData5;
219
+ var lastInSenderGroup = indexWithinSenderGroup === entriesWithSameSender.length - 1;
220
+ entriesWithSameSenderAndStatus.forEach(function (_ref2, indexWithinSenderAndStatusGroup) {
221
+ var _activity$from;
321
222
 
223
+ var activity = _ref2.activity,
224
+ renderActivity = _ref2.renderActivity;
322
225
  // We only show the timestamp at the end of the sender group. But we always show the "Send failed, retry" prompt.
226
+ var firstInSenderAndStatusGroup = !indexWithinSenderAndStatusGroup;
227
+ var key = getKeyByActivity(activity);
228
+ var lastInSenderAndStatusGroup = indexWithinSenderAndStatusGroup === entriesWithSameSenderAndStatus.length - 1;
323
229
  var renderActivityStatus = createActivityStatusRenderer({
324
- activity: activity
230
+ activity: activity,
231
+ nextVisibleActivity: undefined
325
232
  });
326
- var firstInSenderAndStatusGroup = !indexWithinSenderAndStatusGroup;
327
- var lastInSenderAndStatusGroup = indexWithinSenderAndStatusGroup === activitiesWithSameSenderAndStatus.length - 1;
328
-
329
- var _activitiesWithRender = activitiesWithRenderer.find(function (entry) {
330
- return entry.activity === activity;
331
- }),
332
- renderActivity = _activitiesWithRender.renderActivity;
333
-
334
- var key = (0, _getActivityUniqueId.default)(activity) || renderingElements.length;
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;
339
- var topSideNub = role === 'user' ? topSideUserNub : topSideBotNub;
233
+ var topSideNub = ((_activity$from = activity.from) === null || _activity$from === void 0 ? void 0 : _activity$from.role) === 'user' ? topSideUserNub : topSideBotNub;
340
234
  var showCallout; // Depending on the "showAvatarInGroup" setting, the avatar will render in different positions.
341
235
 
342
236
  if (showAvatarInGroup === 'sender') {
@@ -355,167 +249,78 @@ var InternalTranscript = function InternalTranscript(_ref) {
355
249
  showCallout = true;
356
250
  }
357
251
 
358
- var focusActivity = function focusActivity() {
359
- setFocusedActivityKey((0, _getActivityUniqueId.default)(activity)); // IE11 need to manually focus on the transcript.
360
-
361
- var rootElement = rootElementRef.current;
362
- rootElement && rootElement.focus();
363
- };
364
-
365
252
  renderingElements.push({
366
253
  activity: activity,
367
254
  // After the element is mounted, set it to activityElementsRef.
368
255
  callbackRef: function callbackRef(activityElement) {
369
- var entry = activityElementsRef.current.find(function (_ref3) {
370
- var activityID = _ref3.activityID;
371
- return activityID === activity.id;
372
- });
373
-
374
- if (entry) {
375
- entry.element = activityElement;
376
- }
377
- },
378
- // Calling this function will put the focus on the transcript and the activity.
379
- focusActivity: focusActivity,
380
- // When a child of the activity receives focus, notify the transcript to set the aria-activedescendant to this activity.
381
- handleFocus: function handleFocus() {
382
- setFocusedActivityKey((0, _getActivityUniqueId.default)(activity));
383
- },
384
- handleKeyDown: function handleKeyDown(event) {
385
- if (event.key === 'Escape') {
386
- event.preventDefault();
387
- event.stopPropagation();
388
- setFocusedActivityKey((0, _getActivityUniqueId.default)(activity));
389
- var current = rootElementRef.current;
390
- current && current.focus();
391
- }
392
- },
393
- // For accessibility: when the user press up/down arrow keys, we put a visual focus indicator around the focused activity.
394
- // We should do the same for mouse, that is why we have the click handler here.
395
- // We are doing it in event capture phase to prevent other components from stopping event propagation to us.
396
- handleMouseDownCapture: function handleMouseDownCapture(_ref4) {
397
- var target = _ref4.target;
398
- var tabIndex = (0, _getTabIndex.default)(target);
399
-
400
- if (typeof tabIndex !== 'number' || tabIndex < 0 || target.getAttribute('aria-disabled') === 'true') {
401
- focusActivity();
402
- }
256
+ activityElement ? activityElementMapRef.current.set(key, activityElement) : activityElementMapRef.current.delete(key);
403
257
  },
404
258
  // "hideTimestamp" is a render-time parameter for renderActivityStatus().
405
259
  // If true, it will hide the timestamp, but it will continue to show the
406
260
  // retry prompt. And show the screen reader version of the timestamp.
407
- hideTimestamp: hideAllTimestamps || indexWithinSenderAndStatusGroup !== activitiesWithSameSenderAndStatus.length - 1,
261
+ hideTimestamp: hideAllTimestamps || indexWithinSenderAndStatusGroup !== entriesWithSameSenderAndStatus.length - 1,
408
262
  key: key,
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,
411
263
  renderActivity: renderActivity,
412
264
  renderActivityStatus: renderActivityStatus,
413
265
  renderAvatar: renderAvatar,
414
- role: role,
415
- // TODO: [P2] #2858 We should use core/definitions/speakingActivity for this predicate instead
416
- shouldSpeak: activity.channelData && activity.channelData.speak,
417
- showCallout: showCallout,
418
- supportScreenReader: supportScreenReader
266
+ showCallout: showCallout
419
267
  });
420
268
  });
421
269
  });
422
270
  });
423
- var activityElements = activityElementsRef.current; // Update activityElementRef with new sets of activity, while retaining the existing referencing element if exists.
424
-
425
- activityElementsRef.current = renderingElements.map(function (_ref5) {
426
- var activity = _ref5.activity,
427
- id = _ref5.activity.id,
428
- elementId = _ref5.elementId,
429
- key = _ref5.key;
430
- var existingEntry = activityElements.find(function (entry) {
431
- return entry.key === key;
432
- });
433
- return {
434
- activity: activity,
435
- activityID: id,
436
- ariaLabelID: existingEntry ? existingEntry.ariaLabelID : "webchat__basic-transcript__activity-label-".concat((0, _mathRandom.default)().toString(36).substr(2, 5)),
437
- element: existingEntry && existingEntry.element,
438
- elementId: elementId,
439
- key: key
440
- };
441
- }); // There must be one focused (a.k.a. aria-activedescendant) designated. We default it to the last one.
442
-
443
- if (!renderingElements.find(function (_ref6) {
444
- var focused = _ref6.focused;
445
- return focused;
446
- })) {
447
- var lastElement = renderingElements[renderingElements.length - 1];
448
-
449
- if (lastElement) {
450
- lastElement.focused = true;
451
- }
452
- }
453
-
454
271
  return renderingElements;
455
- }, [activitiesWithRenderer, activityElementsRef, activityTree, bubbleFromUserNubOffset, bubbleNubOffset, createActivityStatusRenderer, createAvatarRenderer, hideAllTimestamps, rootElementRef, showAvatarInGroup]);
456
- var renderingActivities = (0, _react.useMemo)(function () {
457
- return renderingElements.map(function (_ref7) {
458
- var activity = _ref7.activity;
459
- return activity;
460
- });
461
- }, [renderingElements]);
272
+ }, [activityElementMapRef, activityWithRendererTree, bubbleFromUserNubOffset, bubbleNubOffset, createActivityStatusRenderer, createAvatarRenderer, getKeyByActivity, hideAllTimestamps, showAvatarInGroup]);
462
273
  var scrollToBottomScrollTo = (0, _reactScrollToBottom.useScrollTo)();
463
274
  var scrollToBottomScrollToEnd = (0, _reactScrollToBottom.useScrollToEnd)();
464
275
  var scrollTo = (0, _react.useCallback)(function (position) {
465
- var _ref8 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
466
- _ref8$behavior = _ref8.behavior,
467
- behavior = _ref8$behavior === void 0 ? 'auto' : _ref8$behavior;
276
+ var _ref3 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
277
+ _ref3$behavior = _ref3.behavior,
278
+ behavior = _ref3$behavior === void 0 ? 'auto' : _ref3$behavior;
468
279
 
469
280
  if (!position) {
470
281
  throw new Error('botframework-webchat: First argument passed to "useScrollTo" must be a ScrollPosition object.');
471
282
  }
472
283
 
473
- var activityID = position.activityID,
284
+ var activityId = position.activityID,
474
285
  scrollTop = position.scrollTop;
475
286
 
476
287
  if (typeof scrollTop !== 'undefined') {
477
288
  scrollToBottomScrollTo(scrollTop, {
478
289
  behavior: behavior
479
290
  });
480
- } else if (typeof activityID !== 'undefined') {
481
- var rootElement = rootElementRef.current;
291
+ } else if (typeof activityId !== 'undefined') {
292
+ var _activityElementMapRe;
482
293
 
483
- var _ref9 = activityElementsRef.current.find(function (entry) {
484
- return entry.activityID === activityID;
485
- }) || {},
486
- activityElement = _ref9.element;
294
+ var activityBoundingBoxElement = (_activityElementMapRe = activityElementMapRef.current.get(getKeyByActivityId(activityId))) === null || _activityElementMapRe === void 0 ? void 0 : _activityElementMapRe.querySelector('.webchat__basic-transcript__activity-active-descendant');
295
+ var scrollableElement = rootElementRef.current.querySelector('.webchat__basic-transcript__scrollable');
487
296
 
488
- var scrollableElement = rootElement.querySelector('.webchat__basic-transcript__scrollable');
297
+ if (scrollableElement && activityBoundingBoxElement) {
298
+ // ESLint conflict with TypeScript. The result of getClientRects() is not an Array but DOMRectList, and cannot be destructured.
299
+ // eslint-disable-next-line prefer-destructuring
300
+ var _activityBoundingBoxE = activityBoundingBoxElement.getClientRects()[0],
301
+ activityHeight = _activityBoundingBoxE.height,
302
+ activityY = _activityBoundingBoxE.y; // ESLint conflict with TypeScript. The result of getClientRects() is not an Array but DOMRectList, and cannot be destructured.
303
+ // eslint-disable-next-line prefer-destructuring
489
304
 
490
- if (scrollableElement && activityElement) {
491
- var _activityElement$getC = activityElement.getClientRects(),
492
- _activityElement$getC2 = _slicedToArray(_activityElement$getC, 1),
493
- _activityElement$getC3 = _activityElement$getC2[0],
494
- activityElementHeight = _activityElement$getC3.height,
495
- activityElementY = _activityElement$getC3.y;
305
+ var scrollableHeight = scrollableElement.getClientRects()[0].height;
306
+ var activityOffsetTop = activityY + scrollableElement.scrollTop;
496
307
 
497
- var _scrollableElement$ge = scrollableElement.getClientRects(),
498
- _scrollableElement$ge2 = _slicedToArray(_scrollableElement$ge, 1),
499
- scrollableHeight = _scrollableElement$ge2[0].height;
500
-
501
- var activityElementOffsetTop = activityElementY + scrollableElement.scrollTop;
502
-
503
- var _scrollTop = Math.min(activityElementOffsetTop, activityElementOffsetTop - scrollableHeight + activityElementHeight);
308
+ var _scrollTop = Math.min(activityOffsetTop, activityOffsetTop - scrollableHeight + activityHeight);
504
309
 
505
310
  scrollToBottomScrollTo(_scrollTop, {
506
311
  behavior: behavior
507
312
  });
508
313
  }
509
314
  }
510
- }, [activityElementsRef, rootElementRef, scrollToBottomScrollTo]);
315
+ }, [activityElementMapRef, getKeyByActivityId, rootElementRef, scrollToBottomScrollTo]);
511
316
  var scrollToEnd = (0, _react.useCallback)(function () {
512
317
  return scrollToBottomScrollToEnd({
513
318
  behavior: 'smooth'
514
319
  });
515
320
  }, [scrollToBottomScrollToEnd]);
516
321
  var scrollRelative = (0, _react.useCallback)(function (direction) {
517
- var _ref10 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
518
- displacement = _ref10.displacement;
322
+ var _ref4 = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {},
323
+ displacement = _ref4.displacement;
519
324
 
520
325
  var rootElement = rootElementRef.current;
521
326
 
@@ -527,8 +332,10 @@ var InternalTranscript = function InternalTranscript(_ref) {
527
332
  var nextScrollTop;
528
333
 
529
334
  if (typeof displacement === 'number') {
335
+ // eslint-disable-next-line no-magic-numbers
530
336
  nextScrollTop = scrollable.scrollTop + (direction === 'down' ? 1 : -1) * displacement;
531
337
  } else {
338
+ // eslint-disable-next-line no-magic-numbers
532
339
  nextScrollTop = scrollable.scrollTop + (direction === 'down' ? 1 : -1) * scrollable.offsetHeight;
533
340
  }
534
341
 
@@ -543,129 +350,47 @@ var InternalTranscript = function InternalTranscript(_ref) {
543
350
  (0, _useRegisterScrollTo.default)(scrollTo);
544
351
  (0, _useRegisterScrollToEnd.default)(scrollToEnd);
545
352
  (0, _useRegisterScrollRelative.default)(scrollRelative);
546
- var dispatchScrollPosition = (0, _useDispatchScrollPosition.default)();
547
- var patchedDispatchScrollPosition = (0, _react.useMemo)(function () {
548
- if (!dispatchScrollPosition) {
549
- return;
550
- }
353
+ var markActivityKeyAsRead = useMarkActivityKeyAsRead();
354
+ var dispatchScrollPositionWithActivityId = (0, _useDispatchScrollPosition.default)(); // TODO: [P2] We should use IntersectionObserver to track what activity is in the scrollable.
355
+ // However, IntersectionObserver is not available on IE11, we need to make a limited polyfill in React style.
551
356
 
552
- return function (_ref11) {
553
- var scrollTop = _ref11.scrollTop;
554
- var rootElement = rootElementRef.current;
357
+ var handleScrollPosition = (0, _react.useCallback)(function (_ref5) {
358
+ var _ref6;
555
359
 
556
- if (!rootElement) {
557
- return;
558
- }
559
-
560
- var scrollableElement = rootElement.querySelector('.webchat__basic-transcript__scrollable');
360
+ var scrollTop = _ref5.scrollTop;
361
+ var rootElement = rootElementRef.current;
561
362
 
562
- var _scrollableElement$ge3 = scrollableElement.getClientRects(),
563
- _scrollableElement$ge4 = _slicedToArray(_scrollableElement$ge3, 1),
564
- _scrollableElement$ge5 = _scrollableElement$ge4[0];
363
+ if (!rootElement) {
364
+ return;
365
+ }
565
366
 
566
- _scrollableElement$ge5 = _scrollableElement$ge5 === void 0 ? {} : _scrollableElement$ge5;
567
- var offsetHeight = _scrollableElement$ge5.height; // Find the activity just above scroll view bottom.
568
- // If the scroll view is already on top, get the first activity.
367
+ var scrollableElement = rootElement.querySelector('.webchat__basic-transcript__scrollable'); // "getClientRects()" is not returning an array, thus, it is not destructurable.
368
+ // eslint-disable-next-line prefer-destructuring
569
369
 
570
- var entry = scrollableElement.scrollTop ? _toConsumableArray(activityElementsRef.current).reverse().find(function (_ref12) {
571
- var element = _ref12.element;
370
+ var scrollableClientBottom = scrollableElement.getClientRects()[0].bottom; // Find the activity just above scroll view bottom.
371
+ // If the scroll view is already on top, get the first activity.
572
372
 
573
- if (!element) {
574
- return false;
575
- }
373
+ var activityElements = Array.from(activityElementMapRef.current.entries());
374
+ var activityKeyJustAboveScrollBottom = (_ref6 = scrollableElement.scrollTop ? activityElements.reverse() // Add subpixel tolerance
375
+ .find(function (_ref7) {
376
+ var _ref8 = _slicedToArray(_ref7, 2),
377
+ element = _ref8[1];
576
378
 
577
- var _element$getClientRec = element.getClientRects(),
578
- _element$getClientRec2 = _slicedToArray(_element$getClientRec, 1),
579
- _element$getClientRec3 = _element$getClientRec2[0];
379
+ return element.getClientRects()[0].bottom < scrollableClientBottom + 1;
380
+ }) : activityElements[0]) === null || _ref6 === void 0 ? void 0 : _ref6[0]; // When the end-user slowly scrolling the view down, we will mark activity as read when the message fully appear on the screen.
580
381
 
581
- _element$getClientRec3 = _element$getClientRec3 === void 0 ? {} : _element$getClientRec3;
582
- var y = _element$getClientRec3.y;
583
- return y < offsetHeight;
584
- }) : activityElementsRef.current[0];
382
+ activityKeyJustAboveScrollBottom && markActivityKeyAsRead(activityKeyJustAboveScrollBottom);
585
383
 
586
- var _ref13 = entry || {},
587
- activityID = _ref13.activityID;
588
-
589
- dispatchScrollPosition(_objectSpread(_objectSpread({}, activityID ? {
590
- activityID: activityID
384
+ if (dispatchScrollPositionWithActivityId) {
385
+ var activity = getActivityByKey(activityKeyJustAboveScrollBottom);
386
+ dispatchScrollPositionWithActivityId(_objectSpread(_objectSpread({}, activity ? {
387
+ activityID: activity.id
591
388
  } : {}), {}, {
592
389
  scrollTop: scrollTop
593
390
  }));
594
- };
595
- }, [activityElementsRef, dispatchScrollPosition, rootElementRef]);
596
- (0, _reactScrollToBottom.useObserveScrollPosition)(patchedDispatchScrollPosition);
597
-
598
- var _useAcknowledgedActiv = (0, _useAcknowledgedActivity.default)(),
599
- _useAcknowledgedActiv2 = _slicedToArray(_useAcknowledgedActiv, 1),
600
- lastInteractedActivity = _useAcknowledgedActiv2[0];
601
-
602
- var indexOfLastInteractedActivity = activities.indexOf(lastInteractedActivity); // Create a new ID for aria-activedescendant every time the active descendant change.
603
- // In our design, the transcript will only have 1 focused activity and it has an ID. Other blurred activities will not have ID assigned.
604
- // This help with performance.
605
- // But browser usually do noop if the value of aria-activedescendant doesn't change.
606
- // That means, if we assign the same ID to another element, browser will do noop.
607
- // We need to generate a new ID so the browser see there is a change in aria-activedescendant value and perform accordingly.
608
-
609
- var activeDescendantElementId = (0, _react.useMemo)(function () {
610
- return focusedActivityKey && "webchat__basic-transcript__active-descendant-".concat((0, _mathRandom.default)().toString(36).substr(2, 5));
611
- }, [focusedActivityKey]);
612
- var scrollActiveDescendantIntoView = (0, _react.useCallback)(function () {
613
- var activeDescendant = activeDescendantElementId && document.getElementById(activeDescendantElementId); // Don't scroll active descendant into view if the focus is already inside it.
614
- // Otherwise, given the focus is on the send box, clicking on any <input> inside the Adaptive Cards may cause the view to move.
615
- // This UX is not desirable because click should not cause scroll.
616
-
617
- if (activeDescendant && !activeDescendant.contains(document.activeElement)) {
618
- // Checks if scrollIntoView support options or not.
619
- // - https://github.com/Modernizr/Modernizr/issues/1568#issuecomment-419457972
620
- // - https://stackoverflow.com/questions/46919627/is-it-possible-to-test-for-scrollintoview-browser-compatibility
621
- if ('scrollBehavior' in document.documentElement.style) {
622
- activeDescendant.scrollIntoView({
623
- block: 'nearest'
624
- });
625
- } else {
626
- // This is for browser that does not support options passed to scrollIntoView(), possibly IE11.
627
- var scrollableElement = rootElementRef.current.querySelector('.webchat__basic-transcript__scrollable');
628
- var scrollTopAtTopSide = activeDescendant.offsetTop;
629
- var scrollTopAtBottomSide = activeDescendant.offsetTop + activeDescendant.offsetHeight;
630
-
631
- if (scrollTopAtTopSide < scrollableElement.scrollTop) {
632
- scrollableElement.scrollTop = scrollTopAtTopSide;
633
- } else if (scrollTopAtBottomSide > scrollableElement.scrollTop + scrollableElement.offsetHeight) {
634
- scrollableElement.scrollTop = scrollTopAtBottomSide - scrollableElement.offsetHeight;
635
- }
636
- }
637
- }
638
- }, [activeDescendantElementId, rootElementRef]);
639
- var handleTranscriptFocus = (0, _react.useCallback)(function (event) {
640
- var currentTarget = event.currentTarget,
641
- target = event.target; // When focus is placed on the transcript, scroll active descendant into the view.
642
-
643
- currentTarget === target && scrollActiveDescendantIntoView();
644
- }, [scrollActiveDescendantIntoView]); // After new aria-activedescendant is assigned, we will need to scroll it into view.
645
- // User agent will scroll automatically for focusing element, but not for aria-activedescendant.
646
- // We need to do the scrolling manually.
647
-
648
- (0, _react.useEffect)(function () {
649
- return scrollActiveDescendantIntoView();
650
- }, [scrollActiveDescendantIntoView]); // If any activities has changed, reset the active descendant.
651
-
652
- (0, _react.useEffect)(function () {
653
- return setFocusedActivityKey(undefined);
654
- }, [activities, setFocusedActivityKey]);
655
- var focusRelativeActivity = (0, _react.useCallback)(function (delta) {
656
- if (isNaN(delta) || !renderingElements.length) {
657
- return setFocusedActivityKey(undefined);
658
391
  }
659
-
660
- var index = renderingElements.findIndex(function (_ref14) {
661
- var key = _ref14.key;
662
- return key === focusedActivityKey;
663
- });
664
- var nextIndex = ~index ? Math.max(0, Math.min(renderingElements.length - 1, index + delta)) : renderingElements.length - 1;
665
- var nextFocusedActivity = renderingElements[nextIndex];
666
- setFocusedActivityKey(nextFocusedActivity.key);
667
- rootElementRef.current && rootElementRef.current.focus();
668
- }, [focusedActivityKey, renderingElements, rootElementRef, setFocusedActivityKey]);
392
+ }, [activityElementMapRef, dispatchScrollPositionWithActivityId, getActivityByKey, markActivityKeyAsRead, rootElementRef]);
393
+ (0, _reactScrollToBottom.useObserveScrollPosition)(handleScrollPosition);
669
394
  var handleTranscriptKeyDown = (0, _react.useCallback)(function (event) {
670
395
  var target = event.target;
671
396
  var fromEndOfTranscriptIndicator = target === terminatorRef.current;
@@ -683,6 +408,7 @@ var InternalTranscript = function InternalTranscript(_ref) {
683
408
  break;
684
409
 
685
410
  case 'ArrowUp':
411
+ // eslint-disable-next-line no-magic-numbers
686
412
  focusRelativeActivity(fromEndOfTranscriptIndicator ? 0 : -1);
687
413
  break;
688
414
 
@@ -691,30 +417,13 @@ var InternalTranscript = function InternalTranscript(_ref) {
691
417
  break;
692
418
 
693
419
  case 'Enter':
420
+ // This is capturing plain ENTER.
421
+ // When screen reader is not running, or screen reader is running outside of scan mode, the ENTER key will be captured here.
694
422
  if (!fromEndOfTranscriptIndicator) {
695
- var focusedActivityEntry = renderingElements.find(function (_ref15) {
696
- var key = _ref15.key;
697
- return key === focusedActivityKey;
698
- });
423
+ var _activityElementMapRe2, _tabbableElements$;
699
424
 
700
- if (focusedActivityEntry) {
701
- var _ref16 = activityElementsRef.current.find(function (_ref17) {
702
- var activity = _ref17.activity;
703
- return activity === focusedActivityEntry.activity;
704
- }) || {},
705
- focusedActivityElement = _ref16.element;
706
-
707
- if (focusedActivityElement) {
708
- var _tabbableElements$fil = (0, _tabbableElements.default)(focusedActivityElement).filter(function (_ref18) {
709
- var className = _ref18.className;
710
- return className !== 'webchat__basic-transcript__activity-sentinel';
711
- }),
712
- _tabbableElements$fil2 = _slicedToArray(_tabbableElements$fil, 1),
713
- firstTabbableElement = _tabbableElements$fil2[0];
714
-
715
- firstTabbableElement && firstTabbableElement.focus();
716
- }
717
- }
425
+ var body = (_activityElementMapRe2 = activityElementMapRef.current.get(focusedActivityKeyRef.current)) === null || _activityElementMapRe2 === void 0 ? void 0 : _activityElementMapRe2.querySelector('.webchat__basic-transcript__activity-body');
426
+ (_tabbableElements$ = (0, _tabbableElements.default)(body)[0]) === null || _tabbableElements$ === void 0 ? void 0 : _tabbableElements$.focus();
718
427
  }
719
428
 
720
429
  break;
@@ -737,20 +446,7 @@ var InternalTranscript = function InternalTranscript(_ref) {
737
446
 
738
447
  event.stopPropagation();
739
448
  }
740
- }, [focusedActivityKey, activityElementsRef, focusRelativeActivity, focus, terminatorRef, renderingElements]);
741
- var labelId = (0, _useUniqueId.default)('webchat__basic-transcript__label'); // If SHIFT-TAB from "End of transcript" indicator, if focusedActivityKey is not set (or no longer exists), set it the the bottommost activity.
742
-
743
- var setBottommostFocusedActivityKeyIfNeeded = (0, _react.useCallback)(function () {
744
- if (!~renderingElements.findIndex(function (_ref19) {
745
- var key = _ref19.key;
746
- return key === focusedActivityKey;
747
- })) {
748
- var _ref20 = renderingElements[renderingElements.length - 1] || {},
749
- lastActivityKey = _ref20.key;
750
-
751
- setFocusedActivityKey(lastActivityKey);
752
- }
753
- }, [focusedActivityKey, renderingElements, setFocusedActivityKey]);
449
+ }, [activityElementMapRef, focus, focusedActivityKeyRef, focusRelativeActivity, terminatorRef]);
754
450
  var handleTranscriptKeyDownCapture = (0, _react.useCallback)(function (event) {
755
451
  var altKey = event.altKey,
756
452
  ctrlKey = event.ctrlKey,
@@ -771,47 +467,46 @@ var InternalTranscript = function InternalTranscript(_ref) {
771
467
  focus('sendBox');
772
468
  }
773
469
  }, [focus]);
774
- var focusTranscriptCallback = (0, _react.useCallback)(function () {
775
- return rootElementRef.current && rootElementRef.current.focus();
776
- }, [rootElementRef]);
777
- (0, _useRegisterFocusTranscript.default)(focusTranscriptCallback);
778
- var handleFocusActivity = (0, _react.useCallback)(function (key) {
779
- setFocusedActivityKey(key);
780
- rootElementRef.current && rootElementRef.current.focus();
781
- }, [setFocusedActivityKey]); // When the focusing activity has changed, dispatch an event to observers of "useObserveTranscriptFocus".
782
-
783
- var dispatchTranscriptFocus = (0, _useDispatchTranscriptFocus.default)();
784
- var focusedActivity = (0, _react.useMemo)(function () {
785
- var _ref21 = renderingElements.find(function (_ref22) {
786
- var key = _ref22.key;
787
- return key === focusedActivityKey;
788
- }) || {},
789
- activity = _ref21.activity;
790
-
791
- return activity;
792
- }, [focusedActivityKey, renderingElements]);
470
+ (0, _useRegisterFocusTranscript.default)((0, _react.useCallback)(function () {
471
+ return focusByActivityKey(undefined);
472
+ }, [focusByActivityKey])); // When the focusing activity has changed, dispatch an event to observers of "useObserveTranscriptFocus".
473
+
474
+ var dispatchTranscriptFocusByActivityKey = (0, _useDispatchTranscriptFocusByActivityKey.default)(); // Dispatch a "transcript focus" event based on user selection.
475
+ // We should not dispatch "transcript focus" when a new activity come. Although the selection change, it is not initiated from the user.
476
+
793
477
  (0, _react.useMemo)(function () {
794
- return dispatchTranscriptFocus && dispatchTranscriptFocus({
795
- activity: focusedActivity
796
- });
797
- }, [dispatchTranscriptFocus, focusedActivity]); // This is required by IE11.
478
+ return dispatchTranscriptFocusByActivityKey(focusedExplicitly ? focusedActivityKey : undefined);
479
+ }, [dispatchTranscriptFocusByActivityKey, focusedActivityKey, focusedExplicitly]); // When the transcript is being focused on, we should dispatch a "transcriptfocus" event.
480
+
481
+ var handleFocus = (0, _react.useCallback)( // We call "focusByActivityKey" with activity key of "true".
482
+ // It means, tries to focus on anything.
483
+ function (_ref9) {
484
+ var currentTarget = _ref9.currentTarget,
485
+ target = _ref9.target;
486
+ return target === currentTarget && focusByActivityKey(true, false);
487
+ }, [focusByActivityKey]); // This is required by IE11.
798
488
  // 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">,
799
489
  // despite the fact there are no "tabIndex" attributes set on the filler.
800
490
  // We need to artificially send the focus back to the transcript.
801
491
 
802
492
  var handleFocusFiller = (0, _react.useCallback)(function () {
803
- var current = rootElementRef.current;
804
- current && current.focus();
805
- }, [rootElementRef]);
493
+ return focusByActivityKey(undefined);
494
+ }, [focusByActivityKey]); // When focus into the transcript using TAB/SHIFT-TAB, scroll the focused activity into view.
495
+
496
+ (0, _useObserveFocusVisible.default)(rootElementRef, (0, _react.useCallback)(function () {
497
+ return focusByActivityKey(undefined);
498
+ }, [focusByActivityKey]));
806
499
  return /*#__PURE__*/_react.default.createElement("div", {
807
- "aria-activedescendant": focusedActivityKey ? activeDescendantElementId : undefined,
808
- "aria-labelledby": labelId,
500
+ // Although Android TalkBack 12.1 does not support `aria-activedescendant`, when used, it become buggy and will narrate content twice.
501
+ // We are disabling `aria-activedescendant` for Android. See <ActivityRow> for details.
502
+ "aria-activedescendant": _detectBrowser.android ? undefined : activeDescendantId,
503
+ "aria-label": transcriptAriaLabel,
809
504
  className: (0, _classnames.default)('webchat__basic-transcript', basicTranscriptStyleSet + '', rootClassName, (className || '') + ''),
810
505
  dir: direction,
811
- onFocus: handleTranscriptFocus,
506
+ onFocus: handleFocus,
812
507
  onKeyDown: handleTranscriptKeyDown,
813
508
  onKeyDownCapture: handleTranscriptKeyDownCapture,
814
- ref: rootElementRef // "aria-activedescendant" will only works with a number of roles and it must be explicitly set.
509
+ ref: callbackRef // "aria-activedescendant" will only works with a number of roles and it must be explicitly set.
815
510
  // https://www.w3.org/TR/wai-aria/#aria-activedescendant
816
511
  ,
817
512
  role: "group" // For up/down arrow key navigation across activities, this component must be included in the tab sequence.
@@ -819,171 +514,65 @@ var InternalTranscript = function InternalTranscript(_ref) {
819
514
  // https://www.w3.org/TR/wai-aria-practices-1.1/#kbd_focus_activedescendant
820
515
  ,
821
516
  tabIndex: 0
822
- }, /*#__PURE__*/_react.default.createElement(_ScreenReaderText.default, {
823
- id: labelId,
824
- text: transcriptAriaLabel
825
- }), /*#__PURE__*/_react.default.createElement("section", {
826
- "aria-atomic": false,
827
- "aria-live": "polite",
828
- "aria-relevant": "additions",
829
- "aria-roledescription": transcriptRoleDescription,
830
- role: "log"
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;
837
- return /*#__PURE__*/_react.default.createElement(_Fade.default, {
838
- fadeAfter: internalLiveRegionFadeAfter,
839
- key: liveRegionKey
840
- }, function () {
841
- return /*#__PURE__*/_react.default.createElement(_ScreenReaderActivity.default, {
842
- activity: activity
843
- });
844
- });
845
- })), /*#__PURE__*/_react.default.createElement(InternalTranscriptScrollable, {
846
- activities: renderingActivities,
847
- onFocusActivity: handleFocusActivity,
517
+ }, /*#__PURE__*/_react.default.createElement(_LiveRegionTranscript.default, {
518
+ activityElementMapRef: activityElementMapRef
519
+ }), /*#__PURE__*/_react.default.createElement(InternalTranscriptScrollable, {
848
520
  onFocusFiller: handleFocusFiller,
849
521
  terminatorRef: terminatorRef
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) {
868
- return entry.activity === activity;
869
- }) || {},
870
- ariaLabelID = _ref26.ariaLabelID,
871
- element = _ref26.element;
872
-
873
- var activeDescendant = focusedActivityKey === key;
874
- var isContentInteractive = !!(element ? (0, _tabbableElements.default)(element.querySelector('.webchat__basic-transcript__activity-box')).length : 0);
875
- return /*#__PURE__*/_react.default.createElement("li", {
876
- "aria-labelledby": ariaLabelID,
877
- className: (0, _classnames.default)('webchat__basic-transcript__activity', {
878
- 'webchat__basic-transcript__activity--acknowledged': index <= indexOfLastInteractedActivity,
879
- 'webchat__basic-transcript__activity--from-bot': role !== 'user',
880
- 'webchat__basic-transcript__activity--from-user': role === 'user'
881
- }) // Set "id" for valid for accessibility.
882
-
883
- /* eslint-disable-next-line react/forbid-dom-props */
884
- ,
885
- id: activeDescendant ? activeDescendantElementId : undefined,
522
+ }, renderingElements.map(function (_ref10) {
523
+ var activity = _ref10.activity,
524
+ callbackRef = _ref10.callbackRef,
525
+ hideTimestamp = _ref10.hideTimestamp,
526
+ key = _ref10.key,
527
+ renderActivity = _ref10.renderActivity,
528
+ renderActivityStatus = _ref10.renderActivityStatus,
529
+ renderAvatar = _ref10.renderAvatar,
530
+ showCallout = _ref10.showCallout;
531
+ return /*#__PURE__*/_react.default.createElement(_ActivityRow.default, {
532
+ activity: activity,
886
533
  key: key,
887
- onFocus: handleFocus,
888
- onKeyDown: handleKeyDown,
889
- onMouseDownCapture: handleMouseDownCapture,
890
534
  ref: callbackRef
891
- }, supportScreenReader && /*#__PURE__*/_react.default.createElement(_ScreenReaderActivity.default, {
892
- activity: activity,
893
- id: ariaLabelID,
894
- renderAttachments: false
895
- }, !!isContentInteractive && /*#__PURE__*/_react.default.createElement("p", null, activityInteractiveAlt)), /*#__PURE__*/_react.default.createElement(_FocusRedirector.default, {
896
- className: "webchat__basic-transcript__activity-sentinel",
897
- onFocus: focusActivity,
898
- redirectRef: rootElementRef
899
- }), /*#__PURE__*/_react.default.createElement("div", {
900
- className: "webchat__basic-transcript__activity-box"
901
535
  }, renderActivity({
902
536
  hideTimestamp: hideTimestamp,
903
537
  renderActivityStatus: renderActivityStatus,
904
538
  renderAvatar: renderAvatar,
905
539
  showCallout: showCallout
906
- })), shouldSpeak && /*#__PURE__*/_react.default.createElement(_Speak.default, {
907
- activity: activity
908
- }), /*#__PURE__*/_react.default.createElement(_FocusRedirector.default, {
909
- className: "webchat__basic-transcript__activity-sentinel",
910
- onFocus: focusActivity,
911
- redirectRef: rootElementRef
912
- }), /*#__PURE__*/_react.default.createElement("div", {
913
- className: (0, _classnames.default)('webchat__basic-transcript__activity-indicator', {
914
- 'webchat__basic-transcript__activity-indicator--first': !index,
915
- 'webchat__basic-transcript__activity-indicator--focus': activeDescendant
916
- })
917
540
  }));
918
- })), !!renderingElements.length && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_FocusRedirector.default, {
919
- className: "webchat__basic-transcript__sentinel",
920
- onFocus: setBottommostFocusedActivityKeyIfNeeded,
541
+ })), !!renderingElements.length && /*#__PURE__*/_react.default.createElement(_react.Fragment, null, /*#__PURE__*/_react.default.createElement(_FocusRedirector.default, {
921
542
  redirectRef: rootElementRef
922
543
  }), /*#__PURE__*/_react.default.createElement("div", {
544
+ "aria-hidden": true,
545
+ "aria-labelledby": terminatorLabelId,
923
546
  className: "webchat__basic-transcript__terminator",
924
547
  ref: terminatorRef,
548
+ role: "note",
925
549
  tabIndex: 0
926
550
  }, /*#__PURE__*/_react.default.createElement("div", {
927
551
  className: "webchat__basic-transcript__terminator-body"
928
552
  }, /*#__PURE__*/_react.default.createElement("div", {
929
- className: "webchat__basic-transcript__terminator-text"
553
+ className: "webchat__basic-transcript__terminator-text",
554
+ id: terminatorLabelId
930
555
  }, terminatorText)))), /*#__PURE__*/_react.default.createElement("div", {
931
556
  className: "webchat__basic-transcript__focus-indicator"
932
557
  }));
933
- };
934
-
558
+ });
935
559
  InternalTranscript.defaultProps = {
936
560
  className: ''
937
561
  };
938
562
  InternalTranscript.propTypes = {
939
- activityElementsRef: _propTypes.default.shape({
940
- current: _propTypes.default.array.isRequired
563
+ // PropTypes cannot validate precisely with its TypeScript counterpart.
564
+ // @ts-ignore
565
+ activityElementMapRef: _propTypes.default.shape({
566
+ current: _propTypes.default.instanceOf(Map)
941
567
  }).isRequired,
942
568
  className: _propTypes.default.string
943
569
  };
944
570
 
945
- var InternalScreenReaderTranscript = function InternalScreenReaderTranscript(_ref27) {
946
- var renderingElements = _ref27.renderingElements;
947
- var localize = useLocalizer();
948
-
949
- var _useStyleOptions3 = useStyleOptions(),
950
- _useStyleOptions4 = _slicedToArray(_useStyleOptions3, 1),
951
- internalLiveRegionFadeAfter = _useStyleOptions4[0];
952
-
953
- var transcriptRoleDescription = localize('TRANSCRIPT_ARIA_ROLE_ALT');
954
- return /*#__PURE__*/_react.default.createElement("section", {
955
- "aria-atomic": false,
956
- "aria-live": "polite",
957
- "aria-relevant": "additions",
958
- "aria-roledescription": transcriptRoleDescription,
959
- role: "log"
960
- }, renderingElements.map(function (_ref28) {
961
- var activity = _ref28.activity,
962
- liveRegionKey = _ref28.liveRegionKey;
963
- return /*#__PURE__*/_react.default.createElement(_Fade.default, {
964
- fadeAfter: internalLiveRegionFadeAfter,
965
- key: liveRegionKey
966
- }, function () {
967
- return /*#__PURE__*/_react.default.createElement(_ScreenReaderActivity.default, {
968
- activity: activity
969
- });
970
- });
971
- }));
972
- };
973
-
974
- InternalScreenReaderTranscript.propTypes = {
975
- renderingElements: _propTypes.default.arrayOf(_propTypes.default.shape({
976
- activity: _propTypes.default.any,
977
- liveRegionKey: _propTypes.default.string
978
- })).isRequired
979
- }; // Separating high-frequency hooks to improve performance.
980
-
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;
571
+ // Separating high-frequency hooks to improve performance.
572
+ var InternalTranscriptScrollable = function InternalTranscriptScrollable(_ref11) {
573
+ var children = _ref11.children,
574
+ onFocusFiller = _ref11.onFocusFiller,
575
+ terminatorRef = _ref11.terminatorRef;
987
576
 
988
577
  var _useStyleSet3 = (0, _useStyleSet5.default)(),
989
578
  _useStyleSet4 = _slicedToArray(_useStyleSet3, 1),
@@ -997,62 +586,116 @@ var InternalTranscriptScrollable = function InternalTranscriptScrollable(_ref29)
997
586
  _useAtEnd2 = _slicedToArray(_useAtEnd, 1),
998
587
  atEnd = _useAtEnd2[0];
999
588
 
589
+ var _useActivityKeysByRea = useActivityKeysByRead(),
590
+ _useActivityKeysByRea2 = _slicedToArray(_useActivityKeysByRea, 2),
591
+ unreadActivityKeys = _useActivityKeysByRea2[1];
592
+
1000
593
  var _useSticky = (0, _reactScrollToBottom.useSticky)(),
1001
594
  _useSticky2 = _slicedToArray(_useSticky, 1),
1002
595
  sticky = _useSticky2[0];
1003
596
 
1004
- var _useStyleOptions5 = useStyleOptions(),
1005
- _useStyleOptions6 = _slicedToArray(_useStyleOptions5, 1),
1006
- styleOptions = _useStyleOptions6[0];
1007
-
1008
- var lastVisibleActivityId = (0, _getActivityUniqueId.default)(activities[activities.length - 1] || {}); // Activity ID of the last visible activity in the list.
597
+ var _useStyleOptions3 = useStyleOptions(),
598
+ _useStyleOptions4 = _slicedToArray(_useStyleOptions3, 1),
599
+ styleOptions = _useStyleOptions4[0];
1009
600
 
601
+ var focusByActivityKey = (0, _useFocusByActivityKey.default)();
1010
602
  var localize = useLocalizer();
603
+ var markActivityKeyAsRead = useMarkActivityKeyAsRead();
604
+ var markAllAsAcknowledged = useMarkAllAsAcknowledged();
1011
605
  var scrollToEnd = (0, _reactScrollToBottom.useScrollToEnd)();
1012
- var lastReadActivityIdRef = (0, _react.useRef)(lastVisibleActivityId);
606
+ var prevSticky = (0, _usePrevious.default)(sticky);
1013
607
  var transcriptRoleDescription = localize('TRANSCRIPT_ARIA_ROLE_ALT');
608
+ var stickyChangedToTrue = prevSticky !== sticky && sticky; // Acknowledged means either:
609
+ // 1. The user sent a message
610
+ // - We don't need a condition here. When Web Chat sends the user's message, it will scroll to bottom, and it will trigger condition 2 below.
611
+ // 2. The user scroll to the bottom of the transcript, from a non-bottom scroll position
612
+ // - If the transcript is already at the bottom, the user needs to scroll up and then go back down
613
+ // - What happens if we are relaxing "scrolled from a non-bottom scroll position":
614
+ // 1. The condition will become solely "at the bottom of the transcript"
615
+ // 2. Auto-scroll will always scroll the transcript to the bottom
616
+ // 3. Web Chat will always acknowledge all activities as it is at the bottom
617
+ // 4. Acknowledge flag become useless
618
+ // 5. Therefore, even the developer set "pause after 3 activities", if activities are coming in at a slow pace (not batched in a single render)
619
+ // Web Chat will keep scrolling and not snapped/paused
620
+ // Note: When Web Chat is loaded, there are no activities acknowledged. We need to assume all arriving activities are acknowledged until end-user sends their first activity.
621
+ // Activities loaded initially could be from conversation history. Without assuming acknowledgement, Web Chat will not scroll initially (as everything is not acknowledged).
622
+ // It would be better if the chat adapter should let Web Chat know if the activity is loaded from history or not.
623
+ // TODO: [P2] #3670 Move the "conversation history acknowledgement" logic mentioned above to polyfill of chat adapters.
624
+ // 1. Chat adapter should send "acknowledged" as part of "channelData"
625
+ // 2. If "acknowledged" is "undefined", we set it to:
626
+ // a. true, if there are no egress activities yet
627
+ // b. Otherwise, false
628
+
629
+ (0, _react.useMemo)(function () {
630
+ return stickyChangedToTrue && // TODO: [P2] Both `markActivityKeyAsRead` and `markAllAsAcknowledged` hook are setters of useState.
631
+ // This means, in a render loop, we will be calling setter and will cause another re-render.
632
+ // This is not trivial but we should think if there is a way to avoid this.
633
+ markAllAsAcknowledged();
634
+ }, [markAllAsAcknowledged, stickyChangedToTrue]);
635
+
636
+ var _useActivityTreeWithR3 = (0, _useActivityTreeWithRenderer.default)({
637
+ flat: true
638
+ }),
639
+ _useActivityTreeWithR4 = _slicedToArray(_useActivityTreeWithR3, 1),
640
+ flattenedActivityTreeWithRenderer = _useActivityTreeWithR4[0];
641
+
642
+ var getKeyByActivity = useGetKeyByActivity();
643
+ var renderingActivityKeys = (0, _react.useMemo)(function () {
644
+ return flattenedActivityTreeWithRenderer.map(function (_ref12) {
645
+ var activity = _ref12.activity;
646
+ return getKeyByActivity(activity);
647
+ });
648
+ }, [flattenedActivityTreeWithRenderer, getKeyByActivity]);
649
+ var renderingActivityKeysRef = (0, _useValueRef.default)(renderingActivityKeys); // To prevent flashy button, we are not waiting for another render loop to update the `[readActivityKeys, unreadActivityKeys]` state.
650
+ // Instead, we are building the next one in this `useMemo` call.
651
+
652
+ var nextUnreadActivityKeys = (0, _react.useMemo)(function () {
653
+ // This code need to be careful reviewed as it will cause another render. The code should be converging.
654
+ // After we call `markActivityKeyAsRead`, everything will be read and nothing will be unread.
655
+ // That means, in next render, `unreadActivityKeys` will be emptied and the `markActivityKeyAsRead` will not get called again.
656
+ if (sticky && unreadActivityKeys.length) {
657
+ markActivityKeyAsRead(unreadActivityKeys[unreadActivityKeys.length - 1]);
658
+ return [];
659
+ }
660
+
661
+ return unreadActivityKeys;
662
+ }, [markActivityKeyAsRead, sticky, unreadActivityKeys]);
663
+ var nextUnreadActivityKeysRef = (0, _useValueRef.default)(nextUnreadActivityKeys); // If we are rendering anything that is unread, we should show the "New messages" button.
664
+ // Not everything in the `unreadActivityKeys` are rendered, say, bot typing indicator.
665
+ // We should not show the "New messages" button for bot typing indicator as it will confuse the user.
666
+
667
+ var unread = (0, _react.useMemo)(function () {
668
+ return nextUnreadActivityKeys.some(function (key) {
669
+ return renderingActivityKeys.includes(key);
670
+ });
671
+ }, [renderingActivityKeys, nextUnreadActivityKeys]);
1014
672
  var handleScrollToEndButtonClick = (0, _react.useCallback)(function () {
1015
673
  scrollToEnd({
1016
674
  behavior: 'smooth'
1017
- }); // After the "New message" button is clicked, focus on the first unread activity.
675
+ });
676
+ var renderingActivityKeys = renderingActivityKeysRef.current; // After the "New message" button is clicked, focus on the first unread activity which will be rendered.
1018
677
 
1019
- var index = activities.findIndex(function (_ref30) {
1020
- var id = _ref30.id;
1021
- return id === lastReadActivityIdRef.current;
678
+ var firstUnreadRenderingActivityKey = nextUnreadActivityKeysRef.current.find(function (key) {
679
+ return renderingActivityKeys.includes(key);
1022
680
  });
1023
681
 
1024
- if (~index) {
1025
- var firstUnreadActivity = activities[index + 1];
682
+ if (firstUnreadRenderingActivityKey) {
683
+ focusByActivityKey(firstUnreadRenderingActivityKey);
684
+ } else {
685
+ var _terminatorRef$curren;
1026
686
 
1027
- if (firstUnreadActivity) {
1028
- return onFocusActivity((0, _getActivityUniqueId.default)(firstUnreadActivity));
1029
- }
687
+ // If no unread activity, send the focus to the terminator block.
688
+ (_terminatorRef$curren = terminatorRef.current) === null || _terminatorRef$curren === void 0 ? void 0 : _terminatorRef$curren.focus();
1030
689
  }
1031
-
1032
- var current = terminatorRef.current;
1033
- current && current.focus();
1034
- }, [activities, lastReadActivityIdRef, onFocusActivity, scrollToEnd, terminatorRef]);
1035
-
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.
1038
- // So mark the activity ID as read.
1039
- lastReadActivityIdRef.current = lastVisibleActivityId;
1040
- }
1041
-
1042
- var ScrollToEndButton = useCreateScrollToEndButtonRenderer()({
690
+ }, [focusByActivityKey, nextUnreadActivityKeysRef, renderingActivityKeysRef, scrollToEnd, terminatorRef]);
691
+ var renderScrollToEndButton = useCreateScrollToEndButtonRenderer()({
1043
692
  atEnd: animatingToEnd || atEnd || sticky,
1044
693
  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) {
1049
- return (0, _getActivityUniqueId.default)(activity) === lastReadActivityIdRef.current;
1050
- })
694
+ unread: unread
1051
695
  });
1052
- return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, ScrollToEndButton && /*#__PURE__*/_react.default.createElement(ScrollToEndButton, {
696
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, renderScrollToEndButton && renderScrollToEndButton({
1053
697
  onClick: handleScrollToEndButtonClick
1054
698
  }), !!_react.default.Children.count(children) && /*#__PURE__*/_react.default.createElement(_FocusRedirector.default, {
1055
- className: "webchat__basic-transcript__sentinel",
1056
699
  redirectRef: terminatorRef
1057
700
  }), /*#__PURE__*/_react.default.createElement(_reactScrollToBottom.Panel, {
1058
701
  className: "webchat__basic-transcript__scrollable"
@@ -1060,129 +703,129 @@ var InternalTranscriptScrollable = function InternalTranscriptScrollable(_ref29)
1060
703
  "aria-hidden": true,
1061
704
  className: "webchat__basic-transcript__filler",
1062
705
  onFocus: onFocusFiller
1063
- }), /*#__PURE__*/_react.default.createElement("ul", {
706
+ }), /*#__PURE__*/_react.default.createElement("section", {
1064
707
  "aria-roledescription": transcriptRoleDescription,
1065
708
  className: (0, _classnames.default)(activitiesStyleSet + '', 'webchat__basic-transcript__transcript'),
1066
- role: "list"
709
+ role: "feed"
1067
710
  }, children), /*#__PURE__*/_react.default.createElement(_BasicTypingIndicator.default, null)));
1068
711
  };
1069
712
 
1070
713
  InternalTranscriptScrollable.propTypes = {
1071
- activities: _propTypes.default.array.isRequired,
1072
714
  children: _propTypes.default.any.isRequired,
1073
- onFocusActivity: _propTypes.default.func.isRequired,
1074
715
  onFocusFiller: _propTypes.default.func.isRequired,
1075
716
  terminatorRef: _propTypes.default.any.isRequired
1076
717
  };
1077
718
 
1078
- var SetScroller = function SetScroller(_ref31) {
1079
- var activityElementsRef = _ref31.activityElementsRef,
1080
- scrollerRef = _ref31.scrollerRef;
1081
-
1082
- var _useStyleOptions7 = useStyleOptions(),
1083
- _useStyleOptions8 = _slicedToArray(_useStyleOptions7, 1),
1084
- _useStyleOptions8$ = _useStyleOptions8[0],
1085
- autoScrollSnapOnActivity = _useStyleOptions8$.autoScrollSnapOnActivity,
1086
- autoScrollSnapOnActivityOffset = _useStyleOptions8$.autoScrollSnapOnActivityOffset,
1087
- autoScrollSnapOnPage = _useStyleOptions8$.autoScrollSnapOnPage,
1088
- autoScrollSnapOnPageOffset = _useStyleOptions8$.autoScrollSnapOnPageOffset;
1089
-
1090
- var _useActivities3 = useActivities(),
1091
- _useActivities4 = _slicedToArray(_useActivities3, 1),
1092
- activities = _useActivities4[0];
1093
-
1094
- var _useAcknowledgedActiv3 = (0, _useAcknowledgedActivity.default)(),
1095
- _useAcknowledgedActiv4 = _slicedToArray(_useAcknowledgedActiv3, 1),
1096
- lastAcknowledgedActivity = _useAcknowledgedActiv4[0];
1097
-
1098
- var activitiesRef = (0, _react.useRef)(activities);
1099
- var lastAcknowledgedActivityRef = (0, _react.useRef)(lastAcknowledgedActivity);
1100
- activitiesRef.current = activities;
1101
- lastAcknowledgedActivityRef.current = lastAcknowledgedActivity;
1102
- scrollerRef.current = (0, _react.useCallback)(function (_ref32) {
1103
- var offsetHeight = _ref32.offsetHeight,
1104
- scrollTop = _ref32.scrollTop;
719
+ // "scroller" is the auto-scroll limiter, a.k.a. auto scroll snap.
720
+ var useScroller = function useScroller(activityElementMapRef) {
721
+ var _useActivityKeys = useActivityKeys(),
722
+ _useActivityKeys2 = _slicedToArray(_useActivityKeys, 1),
723
+ activityKeys = _useActivityKeys2[0];
724
+
725
+ var _useLastAcknowledgedA = useLastAcknowledgedActivityKey(),
726
+ _useLastAcknowledgedA2 = _slicedToArray(_useLastAcknowledgedA, 1),
727
+ lastAcknowledgedActivityKey = _useLastAcknowledgedA2[0];
728
+
729
+ var _useStyleOptions5 = useStyleOptions(),
730
+ _useStyleOptions6 = _slicedToArray(_useStyleOptions5, 1),
731
+ styleOptions = _useStyleOptions6[0];
732
+
733
+ var activityKeysRef = (0, _useValueRef.default)(activityKeys);
734
+ var lastAcknowledgedActivityKeyRef = (0, _useValueRef.default)(lastAcknowledgedActivityKey);
735
+ var styleOptionsRef = (0, _useValueRef.default)(styleOptions);
736
+ return (0, _react.useCallback)(function (_ref13) {
737
+ var offsetHeight = _ref13.offsetHeight,
738
+ scrollTop = _ref13.scrollTop;
739
+ var _styleOptionsRef$curr = styleOptionsRef.current,
740
+ autoScrollSnapOnActivity = _styleOptionsRef$curr.autoScrollSnapOnActivity,
741
+ autoScrollSnapOnActivityOffset = _styleOptionsRef$curr.autoScrollSnapOnActivityOffset,
742
+ autoScrollSnapOnPage = _styleOptionsRef$curr.autoScrollSnapOnPage,
743
+ autoScrollSnapOnPageOffset = _styleOptionsRef$curr.autoScrollSnapOnPageOffset;
1105
744
  var patchedAutoScrollSnapOnActivity = typeof autoScrollSnapOnActivity === 'number' ? Math.max(0, autoScrollSnapOnActivity) : autoScrollSnapOnActivity ? 1 : 0;
1106
745
  var patchedAutoScrollSnapOnPage = typeof autoScrollSnapOnPage === 'number' ? Math.max(0, Math.min(1, autoScrollSnapOnPage)) : autoScrollSnapOnPage ? 1 : 0;
1107
746
  var patchedAutoScrollSnapOnActivityOffset = typeof autoScrollSnapOnActivityOffset === 'number' ? autoScrollSnapOnActivityOffset : 0;
1108
747
  var patchedAutoScrollSnapOnPageOffset = typeof autoScrollSnapOnPageOffset === 'number' ? autoScrollSnapOnPageOffset : 0;
1109
748
 
1110
749
  if (patchedAutoScrollSnapOnActivity || patchedAutoScrollSnapOnPage) {
1111
- var _activities = activitiesRef.current;
1112
- var activityElements = activityElementsRef.current;
1113
- var _lastAcknowledgedActivity = lastAcknowledgedActivityRef.current;
750
+ var activityElementMap = activityElementMapRef.current;
751
+ var _activityKeys = activityKeysRef.current;
752
+ var _lastAcknowledgedActivityKey = lastAcknowledgedActivityKeyRef.current;
1114
753
  var values = [];
1115
754
 
1116
- var lastAcknowledgedActivityIndex = _activities.indexOf(_lastAcknowledgedActivity);
755
+ var lastAcknowledgedActivityKeyIndex = _activityKeys.indexOf(_lastAcknowledgedActivityKey);
1117
756
 
1118
- if (~lastAcknowledgedActivityIndex) {
757
+ if (~lastAcknowledgedActivityKeyIndex) {
1119
758
  // The activity that we acknowledged could be not rendered, such as post back activity.
1120
759
  // When calculating scroll snap, we can only base on the first unacknowledged-and-rendering activity.
760
+ var renderingActivityKeys = Array.from(activityElementMap.keys());
1121
761
  var firstUnacknowledgedActivityElementIndex = -1;
1122
762
 
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
- });
763
+ var _iterator = _createForOfIteratorHelper(_activityKeys.slice(0, lastAcknowledgedActivityKeyIndex + 1).reverse()),
764
+ _step;
1128
765
 
1129
- if (~activityElementIndex) {
1130
- firstUnacknowledgedActivityElementIndex = activityElementIndex;
1131
- return "break";
1132
- }
1133
- };
766
+ try {
767
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
768
+ var acknowledgedActivityKey = _step.value;
769
+ var index = renderingActivityKeys.indexOf(acknowledgedActivityKey);
1134
770
 
1135
- for (var index = lastAcknowledgedActivityIndex + 1, length = _activities.length; index < length; index++) {
1136
- var _ret = _loop2(index, length);
771
+ if (~index) {
772
+ if (index !== renderingActivityKeys.length - 1) {
773
+ firstUnacknowledgedActivityElementIndex = index + 1;
774
+ }
1137
775
 
1138
- if (_ret === "break") break;
776
+ break;
777
+ }
778
+ }
779
+ } catch (err) {
780
+ _iterator.e(err);
781
+ } finally {
782
+ _iterator.f();
1139
783
  }
1140
784
 
1141
785
  if (~firstUnacknowledgedActivityElementIndex) {
786
+ var activityElements = Array.from(activityElementMap.values());
787
+
1142
788
  if (patchedAutoScrollSnapOnActivity) {
1143
789
  // Gets the activity element which we should snap to.
1144
- var nthUnacknowledgedActivityElement = activityElements[firstUnacknowledgedActivityElementIndex + patchedAutoScrollSnapOnActivity - 1].element;
790
+ var nthUnacknowledgedActivityElement = activityElements[firstUnacknowledgedActivityElementIndex + patchedAutoScrollSnapOnActivity - 1];
1145
791
 
1146
792
  if (nthUnacknowledgedActivityElement) {
1147
- values.push(nthUnacknowledgedActivityElement.offsetTop + nthUnacknowledgedActivityElement.offsetHeight - offsetHeight - scrollTop + patchedAutoScrollSnapOnActivityOffset);
793
+ var nthUnacknowledgedActivityBoundingBoxElement = nthUnacknowledgedActivityElement === null || nthUnacknowledgedActivityElement === void 0 ? void 0 : nthUnacknowledgedActivityElement.querySelector('.webchat__basic-transcript__activity-active-descendant');
794
+ var nthUnacknowledgedActivityOffsetTop = nthUnacknowledgedActivityElement.offsetTop + nthUnacknowledgedActivityBoundingBoxElement.offsetTop;
795
+ values.push(nthUnacknowledgedActivityOffsetTop + nthUnacknowledgedActivityBoundingBoxElement.offsetHeight - offsetHeight - scrollTop + patchedAutoScrollSnapOnActivityOffset);
1148
796
  }
1149
797
  }
1150
798
 
1151
799
  if (patchedAutoScrollSnapOnPage) {
1152
- var firstUnacknowledgedActivityElement = activityElements[firstUnacknowledgedActivityElementIndex].element;
1153
- values.push(firstUnacknowledgedActivityElement.offsetTop - scrollTop - offsetHeight * (1 - patchedAutoScrollSnapOnPage) + patchedAutoScrollSnapOnPageOffset);
800
+ var firstUnacknowledgedActivityElement = activityElements[+firstUnacknowledgedActivityElementIndex];
801
+ var firstUnacknowledgedActivityBoundingBoxElement = firstUnacknowledgedActivityElement.querySelector('.webchat__basic-transcript__activity-active-descendant');
802
+ var firstUnacknowledgedActivityOffsetTop = firstUnacknowledgedActivityElement.offsetTop + firstUnacknowledgedActivityBoundingBoxElement.offsetTop;
803
+ values.push(firstUnacknowledgedActivityOffsetTop - scrollTop - offsetHeight * (1 - patchedAutoScrollSnapOnPage) + patchedAutoScrollSnapOnPageOffset);
1154
804
  }
1155
805
  }
1156
806
  }
1157
807
 
1158
- return values.reduce(function (minValue, value) {
1159
- return Math.min(minValue, value);
1160
- }, Infinity);
808
+ return Math.min.apply(Math, values);
1161
809
  }
1162
810
 
1163
811
  return Infinity;
1164
- }, [activitiesRef, activityElementsRef, autoScrollSnapOnActivity, autoScrollSnapOnActivityOffset, autoScrollSnapOnPage, autoScrollSnapOnPageOffset, lastAcknowledgedActivityRef]);
1165
- return false;
812
+ }, [activityElementMapRef, activityKeysRef, lastAcknowledgedActivityKeyRef, styleOptionsRef]);
1166
813
  };
1167
814
 
1168
- var BasicTranscript = function BasicTranscript(_ref33) {
1169
- var className = _ref33.className;
1170
- var activityElementsRef = (0, _react.useRef)([]);
1171
- var scrollerRef = (0, _react.useRef)(function () {
1172
- return Infinity;
1173
- });
1174
- var scroller = (0, _react.useCallback)(function () {
1175
- return scrollerRef.current.apply(scrollerRef, arguments);
1176
- }, [scrollerRef]);
1177
- return /*#__PURE__*/_react.default.createElement(_reactScrollToBottom.Composer, {
815
+ var BasicTranscript = function BasicTranscript(_ref14) {
816
+ var className = _ref14.className;
817
+ var activityElementMapRef = (0, _react.useRef)(new Map());
818
+ var containerRef = (0, _react.useRef)();
819
+ var scroller = useScroller(activityElementMapRef);
820
+ return /*#__PURE__*/_react.default.createElement(_TranscriptFocusComposer.default, {
821
+ containerRef: containerRef
822
+ }, /*#__PURE__*/_react.default.createElement(_reactScrollToBottom.Composer, {
1178
823
  scroller: scroller
1179
- }, /*#__PURE__*/_react.default.createElement(SetScroller, {
1180
- activityElementsRef: activityElementsRef,
1181
- scrollerRef: scrollerRef
1182
- }), /*#__PURE__*/_react.default.createElement(InternalTranscript, {
1183
- activityElementsRef: activityElementsRef,
1184
- className: className
1185
- }));
824
+ }, /*#__PURE__*/_react.default.createElement(_KeyboardHelp.default, null), /*#__PURE__*/_react.default.createElement(InternalTranscript, {
825
+ activityElementMapRef: activityElementMapRef,
826
+ className: className,
827
+ ref: containerRef
828
+ })));
1186
829
  };
1187
830
 
1188
831
  BasicTranscript.defaultProps = {
@@ -1193,4 +836,4 @@ BasicTranscript.propTypes = {
1193
836
  };
1194
837
  var _default = BasicTranscript;
1195
838
  exports.default = _default;
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"]}
839
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/BasicTranscript.tsx"],"names":["useActivityKeys","hooks","useActivityKeysByRead","useCreateActivityStatusRenderer","useCreateAvatarRenderer","useCreateScrollToEndButtonRenderer","useDirection","useGetActivityByKey","useGetKeyByActivity","useGetKeyByActivityId","useLastAcknowledgedActivityKey","useLocalizer","useMarkActivityKeyAsRead","useMarkAllAsAcknowledged","useStyleOptions","ROOT_STYLE","display","flexDirection","overflow","position","flex","overflowX","WebkitOverflowScrolling","listStyleType","InternalTranscript","ref","activityElementMapRef","className","basicTranscriptStyleSet","basicTranscript","bubbleFromUserNubOffset","bubbleNubOffset","groupTimestamp","showAvatarInGroup","activeDescendantId","activityWithRendererTree","direction","focusedActivityKey","focusedExplicitly","createActivityStatusRenderer","createAvatarRenderer","focus","focusByActivityKey","focusRelativeActivity","getActivityByKey","getKeyByActivity","getKeyByActivityId","localize","rootClassName","rootElementRef","terminatorLabelId","terminatorRef","focusedActivityKeyRef","hideAllTimestamps","terminatorText","transcriptAriaLabel","callbackRef","element","current","renderingElements","topSideBotNub","topSideUserNub","forEach","entriesWithSameSender","firstActivity","activity","renderAvatar","entriesWithSameSenderAndStatus","indexWithinSenderGroup","firstInSenderGroup","lastInSenderGroup","length","indexWithinSenderAndStatusGroup","renderActivity","firstInSenderAndStatusGroup","key","lastInSenderAndStatusGroup","renderActivityStatus","nextVisibleActivity","undefined","topSideNub","from","role","showCallout","push","activityElement","set","delete","hideTimestamp","scrollToBottomScrollTo","scrollToBottomScrollToEnd","scrollTo","behavior","Error","activityId","activityID","scrollTop","activityBoundingBoxElement","get","querySelector","scrollableElement","getClientRects","activityHeight","height","activityY","y","scrollableHeight","activityOffsetTop","Math","min","scrollToEnd","scrollRelative","displacement","rootElement","scrollable","nextScrollTop","offsetHeight","max","scrollHeight","markActivityKeyAsRead","dispatchScrollPositionWithActivityId","handleScrollPosition","scrollableClientBottom","bottom","activityElements","Array","entries","activityKeyJustAboveScrollBottom","reverse","find","id","handleTranscriptKeyDown","event","target","fromEndOfTranscriptIndicator","fromTranscript","currentTarget","handled","Infinity","body","preventDefault","stopPropagation","handleTranscriptKeyDownCapture","altKey","ctrlKey","metaKey","dispatchTranscriptFocusByActivityKey","handleFocus","handleFocusFiller","android","map","defaultProps","propTypes","PropTypes","shape","instanceOf","Map","isRequired","string","InternalTranscriptScrollable","children","onFocusFiller","activitiesStyleSet","activities","animatingToEnd","atEnd","unreadActivityKeys","sticky","styleOptions","markAllAsAcknowledged","prevSticky","transcriptRoleDescription","stickyChangedToTrue","flat","flattenedActivityTreeWithRenderer","renderingActivityKeys","renderingActivityKeysRef","nextUnreadActivityKeys","nextUnreadActivityKeysRef","unread","some","includes","handleScrollToEndButtonClick","firstUnreadRenderingActivityKey","renderScrollToEndButton","onClick","React","Children","count","any","func","useScroller","activityKeys","lastAcknowledgedActivityKey","activityKeysRef","lastAcknowledgedActivityKeyRef","styleOptionsRef","autoScrollSnapOnActivity","autoScrollSnapOnActivityOffset","autoScrollSnapOnPage","autoScrollSnapOnPageOffset","patchedAutoScrollSnapOnActivity","patchedAutoScrollSnapOnPage","patchedAutoScrollSnapOnActivityOffset","patchedAutoScrollSnapOnPageOffset","activityElementMap","values","lastAcknowledgedActivityKeyIndex","indexOf","keys","firstUnacknowledgedActivityElementIndex","slice","acknowledgedActivityKey","index","nthUnacknowledgedActivityElement","nthUnacknowledgedActivityBoundingBoxElement","nthUnacknowledgedActivityOffsetTop","offsetTop","firstUnacknowledgedActivityElement","firstUnacknowledgedActivityBoundingBoxElement","firstUnacknowledgedActivityOffsetTop","BasicTranscript","containerRef","scroller"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["import { 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 React, { forwardRef, Fragment, useCallback, useMemo, useRef } from 'react';\n\nimport type { ActivityComponentFactory, AvatarComponentFactory } from 'botframework-webchat-api';\nimport type { ActivityElementMap } from './Transcript/types';\nimport type { DirectLineActivity } from 'botframework-webchat-core';\nimport type { FC, KeyboardEventHandler, MutableRefObject, ReactNode, VFC } from 'react';\n\nimport { android } from './Utils/detectBrowser';\nimport ActivityRow from './Transcript/ActivityRow';\nimport BasicTypingIndicator from './BasicTypingIndicator';\nimport FocusRedirector from './Utils/FocusRedirector';\nimport inputtableKey from './Utils/TypeFocusSink/inputtableKey';\nimport isZeroOrPositive from './Utils/isZeroOrPositive';\nimport KeyboardHelp from './Transcript/KeyboardHelp';\nimport LiveRegionTranscript from './Transcript/LiveRegionTranscript';\n// TODO: [P2] #4133 Rename to \"getTabbableElements\".\nimport tabbableElements from './Utils/tabbableElements';\nimport TranscriptFocusComposer from './providers/TranscriptFocus/TranscriptFocusComposer';\nimport useActiveDescendantId from './providers/TranscriptFocus/useActiveDescendantId';\nimport useActivityTreeWithRenderer from './providers/ActivityTree/useActivityTreeWithRenderer';\nimport useDispatchScrollPosition from './hooks/internal/useDispatchScrollPosition';\nimport useDispatchTranscriptFocusByActivityKey from './hooks/internal/useDispatchTranscriptFocusByActivityKey';\nimport useFocus from './hooks/useFocus';\nimport useFocusByActivityKey from './providers/TranscriptFocus/useFocusByActivityKey';\nimport useFocusedActivityKey from './providers/TranscriptFocus/useFocusedActivityKey';\nimport useFocusedExplicitly from './providers/TranscriptFocus/useFocusedExplicitly';\nimport useFocusRelativeActivity from './providers/TranscriptFocus/useFocusRelativeActivity';\nimport useObserveFocusVisible from './hooks/internal/useObserveFocusVisible';\nimport usePrevious from './hooks/internal/usePrevious';\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';\nimport useValueRef from './hooks/internal/useValueRef';\n\nconst {\n  useActivityKeys,\n  useActivityKeysByRead,\n  useCreateActivityStatusRenderer,\n  useCreateAvatarRenderer,\n  useCreateScrollToEndButtonRenderer,\n  useDirection,\n  useGetActivityByKey,\n  useGetKeyByActivity,\n  useGetKeyByActivityId,\n  useLastAcknowledgedActivityKey,\n  useLocalizer,\n  useMarkActivityKeyAsRead,\n  useMarkAllAsAcknowledged,\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\ntype RenderingElement = {\n  activity: DirectLineActivity & {\n    channelData?: {\n      ['webchat:fallback-text']: string;\n    };\n  };\n  callbackRef: (element: HTMLElement) => void;\n  hideTimestamp: boolean;\n  key: string;\n  renderActivity: Exclude<ReturnType<ActivityComponentFactory>, false>;\n  renderActivityStatus: (props: { hideTimestamp?: boolean }) => ReactNode;\n  renderAvatar: AvatarComponentFactory;\n  showCallout: boolean;\n};\n\ntype ScrollBehavior = 'auto' | 'smooth';\ntype ScrollToOptions = { behavior?: ScrollBehavior };\ntype ScrollToPosition = { activityID?: string; scrollTop?: number };\n\ntype InternalTranscriptProps = {\n  activityElementMapRef: MutableRefObject<ActivityElementMap>;\n  className?: string;\n};\n\n// TODO: [P1] #4133 Add telemetry for computing how many re-render done so far.\nconst InternalTranscript = forwardRef<HTMLDivElement, InternalTranscriptProps>(\n  ({ activityElementMapRef, className }, ref) => {\n    const [{ basicTranscript: basicTranscriptStyleSet }] = useStyleSet();\n    const [{ bubbleFromUserNubOffset, bubbleNubOffset, groupTimestamp, showAvatarInGroup }] = useStyleOptions();\n    const [activeDescendantId] = useActiveDescendantId();\n    const [activityWithRendererTree] = useActivityTreeWithRenderer();\n    const [direction] = useDirection();\n    const [focusedActivityKey] = useFocusedActivityKey();\n    const [focusedExplicitly] = useFocusedExplicitly();\n    const createActivityStatusRenderer = useCreateActivityStatusRenderer();\n    const createAvatarRenderer = useCreateAvatarRenderer();\n    const focus = useFocus();\n    const focusByActivityKey = useFocusByActivityKey();\n    const focusRelativeActivity = useFocusRelativeActivity();\n    const getActivityByKey = useGetActivityByKey();\n    const getKeyByActivity = useGetKeyByActivity();\n    const getKeyByActivityId = useGetKeyByActivityId();\n    const localize = useLocalizer();\n    const rootClassName = useStyleToEmotionObject()(ROOT_STYLE) + '';\n    const rootElementRef = useRef<HTMLDivElement>();\n    const terminatorLabelId = useUniqueId('webchat__basic-transcript__terminator-label');\n    const terminatorRef = useRef<HTMLDivElement>();\n\n    const focusedActivityKeyRef = useValueRef(focusedActivityKey);\n    const hideAllTimestamps = groupTimestamp === false;\n    const terminatorText = localize('TRANSCRIPT_TERMINATOR_TEXT');\n    const transcriptAriaLabel = localize('TRANSCRIPT_ARIA_LABEL_ALT');\n\n    const callbackRef = useCallback(\n      (element: HTMLDivElement) => {\n        if (typeof ref === 'function') {\n          ref(element);\n        } else {\n          ref.current = element;\n        }\n\n        rootElementRef.current = element;\n      },\n      [ref, rootElementRef]\n    );\n\n    // Flatten the tree back into an array with information related to rendering.\n    const renderingElements = useMemo(() => {\n      const renderingElements: RenderingElement[] = [];\n      const topSideBotNub = isZeroOrPositive(bubbleNubOffset);\n      const topSideUserNub = isZeroOrPositive(bubbleFromUserNubOffset);\n\n      activityWithRendererTree.forEach(entriesWithSameSender => {\n        const [[{ activity: firstActivity }]] = entriesWithSameSender;\n        const renderAvatar = createAvatarRenderer({ activity: firstActivity });\n\n        entriesWithSameSender.forEach((entriesWithSameSenderAndStatus, indexWithinSenderGroup) => {\n          const firstInSenderGroup = !indexWithinSenderGroup;\n          const lastInSenderGroup = indexWithinSenderGroup === entriesWithSameSender.length - 1;\n\n          entriesWithSameSenderAndStatus.forEach(({ activity, renderActivity }, 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 firstInSenderAndStatusGroup = !indexWithinSenderAndStatusGroup;\n            const key: string = getKeyByActivity(activity);\n            const lastInSenderAndStatusGroup =\n              indexWithinSenderAndStatusGroup === entriesWithSameSenderAndStatus.length - 1;\n            const renderActivityStatus = createActivityStatusRenderer({\n              activity,\n              nextVisibleActivity: undefined\n            });\n            const topSideNub = activity.from?.role === 'user' ? topSideUserNub : topSideBotNub;\n\n            let showCallout: boolean;\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            renderingElements.push({\n              activity,\n\n              // After the element is mounted, set it to activityElementsRef.\n              callbackRef: activityElement => {\n                activityElement\n                  ? activityElementMapRef.current.set(key, activityElement)\n                  : activityElementMapRef.current.delete(key);\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 !== entriesWithSameSenderAndStatus.length - 1,\n              key,\n              renderActivity,\n              renderActivityStatus,\n              renderAvatar,\n              showCallout\n            });\n          });\n        });\n      });\n\n      return renderingElements;\n    }, [\n      activityElementMapRef,\n      activityWithRendererTree,\n      bubbleFromUserNubOffset,\n      bubbleNubOffset,\n      createActivityStatusRenderer,\n      createAvatarRenderer,\n      getKeyByActivity,\n      hideAllTimestamps,\n      showAvatarInGroup\n    ]);\n\n    const scrollToBottomScrollTo: (scrollTop: number, options?: ScrollToOptions) => void = useScrollTo();\n    const scrollToBottomScrollToEnd: (options?: ScrollToOptions) => void = useScrollToEnd();\n\n    const scrollTo = useCallback(\n      (position: ScrollToPosition, { behavior = 'auto' }: ScrollToOptions = {}) => {\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: activityId, scrollTop } = position;\n\n        if (typeof scrollTop !== 'undefined') {\n          scrollToBottomScrollTo(scrollTop, { behavior });\n        } else if (typeof activityId !== 'undefined') {\n          const activityBoundingBoxElement = activityElementMapRef.current\n            .get(getKeyByActivityId(activityId))\n            ?.querySelector('.webchat__basic-transcript__activity-active-descendant');\n\n          const scrollableElement = rootElementRef.current.querySelector('.webchat__basic-transcript__scrollable');\n\n          if (scrollableElement && activityBoundingBoxElement) {\n            // ESLint conflict with TypeScript. The result of getClientRects() is not an Array but DOMRectList, and cannot be destructured.\n            // eslint-disable-next-line prefer-destructuring\n            const { height: activityHeight, y: activityY } = activityBoundingBoxElement.getClientRects()[0];\n\n            // ESLint conflict with TypeScript. The result of getClientRects() is not an Array but DOMRectList, and cannot be destructured.\n            // eslint-disable-next-line prefer-destructuring\n            const { height: scrollableHeight } = scrollableElement.getClientRects()[0];\n            const activityOffsetTop = activityY + scrollableElement.scrollTop;\n\n            const scrollTop = Math.min(activityOffsetTop, activityOffsetTop - scrollableHeight + activityHeight);\n\n            scrollToBottomScrollTo(scrollTop, { behavior });\n          }\n        }\n      },\n      [activityElementMapRef, getKeyByActivityId, rootElementRef, scrollToBottomScrollTo]\n    );\n\n    const scrollToEnd = useCallback(\n      () => scrollToBottomScrollToEnd({ behavior: 'smooth' }),\n      [scrollToBottomScrollToEnd]\n    );\n\n    const scrollRelative = useCallback(\n      (direction: 'down' | 'up', { displacement }: { displacement?: number } = {}) => {\n        const { current: rootElement } = rootElementRef;\n\n        if (!rootElement) {\n          return;\n        }\n\n        const scrollable: HTMLElement = rootElement.querySelector('.webchat__basic-transcript__scrollable');\n        let nextScrollTop: number;\n\n        if (typeof displacement === 'number') {\n          // eslint-disable-next-line no-magic-numbers\n          nextScrollTop = scrollable.scrollTop + (direction === 'down' ? 1 : -1) * displacement;\n        } else {\n          // eslint-disable-next-line no-magic-numbers\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 markActivityKeyAsRead = useMarkActivityKeyAsRead();\n\n    const dispatchScrollPositionWithActivityId: (scrollPosition: ScrollToPosition) => void =\n      useDispatchScrollPosition();\n\n    // TODO: [P2] We should use IntersectionObserver to track what activity is in the scrollable.\n    //            However, IntersectionObserver is not available on IE11, we need to make a limited polyfill in React style.\n    const handleScrollPosition = useCallback(\n      ({ scrollTop }: { scrollTop: number }) => {\n        const { current: rootElement } = rootElementRef;\n\n        if (!rootElement) {\n          return;\n        }\n\n        const scrollableElement = rootElement.querySelector('.webchat__basic-transcript__scrollable');\n\n        // \"getClientRects()\" is not returning an array, thus, it is not destructurable.\n        // eslint-disable-next-line prefer-destructuring\n        const { bottom: scrollableClientBottom } = scrollableElement.getClientRects()[0];\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 activityElements = Array.from(activityElementMapRef.current.entries());\n        const activityKeyJustAboveScrollBottom: string | undefined = (\n          scrollableElement.scrollTop\n            ? activityElements\n                .reverse()\n                // Add subpixel tolerance\n                .find(([, element]) => element.getClientRects()[0].bottom < scrollableClientBottom + 1)\n            : activityElements[0]\n        )?.[0];\n\n        // When the end-user slowly scrolling the view down, we will mark activity as read when the message fully appear on the screen.\n        activityKeyJustAboveScrollBottom && markActivityKeyAsRead(activityKeyJustAboveScrollBottom);\n\n        if (dispatchScrollPositionWithActivityId) {\n          const activity = getActivityByKey(activityKeyJustAboveScrollBottom);\n\n          dispatchScrollPositionWithActivityId({ ...(activity ? { activityID: activity.id } : {}), scrollTop });\n        }\n      },\n      [\n        activityElementMapRef,\n        dispatchScrollPositionWithActivityId,\n        getActivityByKey,\n        markActivityKeyAsRead,\n        rootElementRef\n      ]\n    );\n\n    useObserveScrollPosition(handleScrollPosition);\n\n    const handleTranscriptKeyDown = useCallback<KeyboardEventHandler<HTMLDivElement>>(\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            // eslint-disable-next-line no-magic-numbers\n            focusRelativeActivity(fromEndOfTranscriptIndicator ? 0 : -1);\n            break;\n\n          case 'End':\n            focusRelativeActivity(Infinity);\n            break;\n\n          case 'Enter':\n            // This is capturing plain ENTER.\n            // When screen reader is not running, or screen reader is running outside of scan mode, the ENTER key will be captured here.\n            if (!fromEndOfTranscriptIndicator) {\n              const body: HTMLElement = activityElementMapRef.current\n                .get(focusedActivityKeyRef.current)\n                ?.querySelector('.webchat__basic-transcript__activity-body');\n\n              tabbableElements(body)[0]?.focus();\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      [activityElementMapRef, focus, focusedActivityKeyRef, focusRelativeActivity, terminatorRef]\n    );\n\n    const handleTranscriptKeyDownCapture = useCallback<KeyboardEventHandler<HTMLDivElement>>(\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    useRegisterFocusTranscript(useCallback(() => focusByActivityKey(undefined), [focusByActivityKey]));\n\n    // When the focusing activity has changed, dispatch an event to observers of \"useObserveTranscriptFocus\".\n    const dispatchTranscriptFocusByActivityKey = useDispatchTranscriptFocusByActivityKey();\n\n    // Dispatch a \"transcript focus\" event based on user selection.\n    // We should not dispatch \"transcript focus\" when a new activity come. Although the selection change, it is not initiated from the user.\n    useMemo(\n      () => dispatchTranscriptFocusByActivityKey(focusedExplicitly ? focusedActivityKey : undefined),\n      [dispatchTranscriptFocusByActivityKey, focusedActivityKey, focusedExplicitly]\n    );\n\n    // When the transcript is being focused on, we should dispatch a \"transcriptfocus\" event.\n    const handleFocus = useCallback(\n      // We call \"focusByActivityKey\" with activity key of \"true\".\n      // It means, tries to focus on anything.\n      ({ currentTarget, target }) => target === currentTarget && focusByActivityKey(true, false),\n      [focusByActivityKey]\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(() => focusByActivityKey(undefined), [focusByActivityKey]);\n\n    // When focus into the transcript using TAB/SHIFT-TAB, scroll the focused activity into view.\n    useObserveFocusVisible(\n      rootElementRef,\n      useCallback(() => focusByActivityKey(undefined), [focusByActivityKey])\n    );\n\n    return (\n      <div\n        // Although Android TalkBack 12.1 does not support `aria-activedescendant`, when used, it become buggy and will narrate content twice.\n        // We are disabling `aria-activedescendant` for Android. See <ActivityRow> for details.\n        aria-activedescendant={android ? undefined : activeDescendantId}\n        aria-label={transcriptAriaLabel}\n        className={classNames(\n          'webchat__basic-transcript',\n          basicTranscriptStyleSet + '',\n          rootClassName,\n          (className || '') + ''\n        )}\n        dir={direction}\n        onFocus={handleFocus}\n        onKeyDown={handleTranscriptKeyDown}\n        onKeyDownCapture={handleTranscriptKeyDownCapture}\n        ref={callbackRef}\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        <LiveRegionTranscript activityElementMapRef={activityElementMapRef} />\n        {/* TODO: [P2] Fix ESLint error `no-use-before-define` */}\n        {/* eslint-disable-next-line @typescript-eslint/no-use-before-define */}\n        <InternalTranscriptScrollable onFocusFiller={handleFocusFiller} terminatorRef={terminatorRef}>\n          {renderingElements.map(\n            ({\n              activity,\n              callbackRef,\n              hideTimestamp,\n              key,\n              renderActivity,\n              renderActivityStatus,\n              renderAvatar,\n              showCallout\n            }) => (\n              <ActivityRow activity={activity} key={key} ref={callbackRef}>\n                {renderActivity({\n                  hideTimestamp,\n                  renderActivityStatus,\n                  renderAvatar,\n                  showCallout\n                })}\n              </ActivityRow>\n            )\n          )}\n        </InternalTranscriptScrollable>\n        {!!renderingElements.length && (\n          <Fragment>\n            <FocusRedirector redirectRef={rootElementRef} />\n            <div\n              aria-hidden={true}\n              aria-labelledby={terminatorLabelId}\n              className=\"webchat__basic-transcript__terminator\"\n              ref={terminatorRef}\n              role=\"note\"\n              tabIndex={0}\n            >\n              <div className=\"webchat__basic-transcript__terminator-body\">\n                {/* `id` is required for `aria-labelledby` */}\n                {/* eslint-disable-next-line react/forbid-dom-props */}\n                <div className=\"webchat__basic-transcript__terminator-text\" id={terminatorLabelId}>\n                  {terminatorText}\n                </div>\n              </div>\n            </div>\n          </Fragment>\n        )}\n        <div className=\"webchat__basic-transcript__focus-indicator\" />\n      </div>\n    );\n  }\n);\n\nInternalTranscript.defaultProps = {\n  className: ''\n};\n\nInternalTranscript.propTypes = {\n  // PropTypes cannot validate precisely with its TypeScript counterpart.\n  // @ts-ignore\n  activityElementMapRef: PropTypes.shape({\n    current: PropTypes.instanceOf(Map)\n  }).isRequired,\n  className: PropTypes.string\n};\n\ntype InternalTranscriptScrollableProps = {\n  children?: ReactNode;\n  onFocusFiller: () => void;\n  terminatorRef: MutableRefObject<HTMLDivElement>;\n};\n\n// Separating high-frequency hooks to improve performance.\nconst InternalTranscriptScrollable: FC<InternalTranscriptScrollableProps> = ({\n  children,\n  onFocusFiller,\n  terminatorRef\n}) => {\n  const [{ activities: activitiesStyleSet }] = useStyleSet();\n  const [animatingToEnd]: [boolean] = useAnimatingToEnd();\n  const [atEnd]: [boolean] = useAtEnd();\n  const [, unreadActivityKeys] = useActivityKeysByRead();\n  const [sticky]: [boolean] = useSticky();\n  const [styleOptions] = useStyleOptions();\n  const focusByActivityKey = useFocusByActivityKey();\n  const localize = useLocalizer();\n  const markActivityKeyAsRead = useMarkActivityKeyAsRead();\n  const markAllAsAcknowledged = useMarkAllAsAcknowledged();\n  const scrollToEnd: (options?: ScrollToOptions) => void = useScrollToEnd();\n\n  const prevSticky = usePrevious(sticky);\n  const transcriptRoleDescription = localize('TRANSCRIPT_ARIA_ROLE_ALT');\n\n  const stickyChangedToTrue = prevSticky !== sticky && sticky;\n\n  // Acknowledged means either:\n  // 1. The user sent a message\n  //    - We don't need a condition here. When Web Chat sends the user's message, it will scroll to bottom, and it will trigger condition 2 below.\n  // 2. The user scroll to the bottom of the transcript, from a non-bottom scroll position\n  //    - If the transcript is already at the bottom, the user needs to scroll up and then go back down\n  //    - What happens if we are relaxing \"scrolled from a non-bottom scroll position\":\n  //      1. The condition will become solely \"at the bottom of the transcript\"\n  //      2. Auto-scroll will always scroll the transcript to the bottom\n  //      3. Web Chat will always acknowledge all activities as it is at the bottom\n  //      4. Acknowledge flag become useless\n  //      5. Therefore, even the developer set \"pause after 3 activities\", if activities are coming in at a slow pace (not batched in a single render)\n  //         Web Chat will keep scrolling and not snapped/paused\n\n  // Note: When Web Chat is loaded, there are no activities acknowledged. We need to assume all arriving activities are acknowledged until end-user sends their first activity.\n  //       Activities loaded initially could be from conversation history. Without assuming acknowledgement, Web Chat will not scroll initially (as everything is not acknowledged).\n  //       It would be better if the chat adapter should let Web Chat know if the activity is loaded from history or not.\n\n  // TODO: [P2] #3670 Move the \"conversation history acknowledgement\" logic mentioned above to polyfill of chat adapters.\n  //       1. Chat adapter should send \"acknowledged\" as part of \"channelData\"\n  //       2. If \"acknowledged\" is \"undefined\", we set it to:\n  //          a. true, if there are no egress activities yet\n  //          b. Otherwise, false\n\n  useMemo(\n    () =>\n      stickyChangedToTrue &&\n      // TODO: [P2] Both `markActivityKeyAsRead` and `markAllAsAcknowledged` hook are setters of useState.\n      //       This means, in a render loop, we will be calling setter and will cause another re-render.\n      //       This is not trivial but we should think if there is a way to avoid this.\n      markAllAsAcknowledged(),\n    [markAllAsAcknowledged, stickyChangedToTrue]\n  );\n\n  const [flattenedActivityTreeWithRenderer] = useActivityTreeWithRenderer({ flat: true });\n  const getKeyByActivity = useGetKeyByActivity();\n\n  const renderingActivityKeys: string[] = useMemo<string[]>(\n    () => flattenedActivityTreeWithRenderer.map(({ activity }) => getKeyByActivity(activity)),\n    [flattenedActivityTreeWithRenderer, getKeyByActivity]\n  );\n\n  const renderingActivityKeysRef = useValueRef(renderingActivityKeys);\n\n  // To prevent flashy button, we are not waiting for another render loop to update the `[readActivityKeys, unreadActivityKeys]` state.\n  // Instead, we are building the next one in this `useMemo` call.\n  const nextUnreadActivityKeys = useMemo(() => {\n    // This code need to be careful reviewed as it will cause another render. The code should be converging.\n    // After we call `markActivityKeyAsRead`, everything will be read and nothing will be unread.\n    // That means, in next render, `unreadActivityKeys` will be emptied and the `markActivityKeyAsRead` will not get called again.\n    if (sticky && unreadActivityKeys.length) {\n      markActivityKeyAsRead(unreadActivityKeys[unreadActivityKeys.length - 1]);\n\n      return [];\n    }\n\n    return unreadActivityKeys;\n  }, [markActivityKeyAsRead, sticky, unreadActivityKeys]);\n\n  const nextUnreadActivityKeysRef = useValueRef(nextUnreadActivityKeys);\n\n  // If we are rendering anything that is unread, we should show the \"New messages\" button.\n  // Not everything in the `unreadActivityKeys` are rendered, say, bot typing indicator.\n  // We should not show the \"New messages\" button for bot typing indicator as it will confuse the user.\n  const unread = useMemo(\n    () => nextUnreadActivityKeys.some(key => renderingActivityKeys.includes(key)),\n    [renderingActivityKeys, nextUnreadActivityKeys]\n  );\n\n  const handleScrollToEndButtonClick = useCallback(() => {\n    scrollToEnd({ behavior: 'smooth' });\n\n    const { current: renderingActivityKeys } = renderingActivityKeysRef;\n\n    // After the \"New message\" button is clicked, focus on the first unread activity which will be rendered.\n    const firstUnreadRenderingActivityKey = nextUnreadActivityKeysRef.current.find(key =>\n      renderingActivityKeys.includes(key)\n    );\n\n    if (firstUnreadRenderingActivityKey) {\n      focusByActivityKey(firstUnreadRenderingActivityKey);\n    } else {\n      // If no unread activity, send the focus to the terminator block.\n      terminatorRef.current?.focus();\n    }\n  }, [focusByActivityKey, nextUnreadActivityKeysRef, renderingActivityKeysRef, scrollToEnd, terminatorRef]);\n\n  const renderScrollToEndButton = useCreateScrollToEndButtonRenderer()({\n    atEnd: animatingToEnd || atEnd || sticky,\n    styleOptions,\n    unread\n  });\n\n  return (\n    <React.Fragment>\n      {renderScrollToEndButton && renderScrollToEndButton({ onClick: handleScrollToEndButtonClick })}\n      {!!React.Children.count(children) && <FocusRedirector redirectRef={terminatorRef} />}\n      <ReactScrollToBottomPanel className=\"webchat__basic-transcript__scrollable\">\n        <div aria-hidden={true} className=\"webchat__basic-transcript__filler\" onFocus={onFocusFiller} />\n        <section\n          aria-roledescription={transcriptRoleDescription}\n          className={classNames(activitiesStyleSet + '', 'webchat__basic-transcript__transcript')}\n          role=\"feed\"\n        >\n          {children}\n        </section>\n        <BasicTypingIndicator />\n      </ReactScrollToBottomPanel>\n    </React.Fragment>\n  );\n};\n\nInternalTranscriptScrollable.propTypes = {\n  children: PropTypes.any.isRequired,\n  onFocusFiller: PropTypes.func.isRequired,\n  terminatorRef: PropTypes.any.isRequired\n};\n\ntype Scroller = ({ offsetHeight, scrollTop }: { offsetHeight: number; scrollTop: number }) => number;\n\n// \"scroller\" is the auto-scroll limiter, a.k.a. auto scroll snap.\nconst useScroller = (activityElementMapRef: MutableRefObject<ActivityElementMap>): Scroller => {\n  const [activityKeys] = useActivityKeys();\n  const [lastAcknowledgedActivityKey] = useLastAcknowledgedActivityKey();\n  const [styleOptions] = useStyleOptions();\n\n  const activityKeysRef = useValueRef(activityKeys);\n  const lastAcknowledgedActivityKeyRef = useValueRef(lastAcknowledgedActivityKey);\n  const styleOptionsRef = useValueRef(styleOptions);\n\n  return useCallback(\n    ({ offsetHeight, scrollTop }) => {\n      const {\n        current: {\n          autoScrollSnapOnActivity,\n          autoScrollSnapOnActivityOffset,\n          autoScrollSnapOnPage,\n          autoScrollSnapOnPageOffset\n        }\n      } = styleOptionsRef;\n\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: activityElementMap } = activityElementMapRef;\n        const { current: activityKeys } = activityKeysRef;\n        const { current: lastAcknowledgedActivityKey } = lastAcknowledgedActivityKeyRef;\n        const values: number[] = [];\n\n        const lastAcknowledgedActivityKeyIndex = activityKeys.indexOf(lastAcknowledgedActivityKey);\n\n        if (~lastAcknowledgedActivityKeyIndex) {\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          const renderingActivityKeys = Array.from(activityElementMap.keys());\n          let firstUnacknowledgedActivityElementIndex = -1;\n\n          for (const acknowledgedActivityKey of activityKeys.slice(0, lastAcknowledgedActivityKeyIndex + 1).reverse()) {\n            const index = renderingActivityKeys.indexOf(acknowledgedActivityKey);\n\n            if (~index) {\n              if (index !== renderingActivityKeys.length - 1) {\n                firstUnacknowledgedActivityElementIndex = index + 1;\n              }\n\n              break;\n            }\n          }\n\n          if (~firstUnacknowledgedActivityElementIndex) {\n            const activityElements = Array.from(activityElementMap.values());\n\n            if (patchedAutoScrollSnapOnActivity) {\n              // Gets the activity element which we should snap to.\n              const nthUnacknowledgedActivityElement =\n                activityElements[firstUnacknowledgedActivityElementIndex + patchedAutoScrollSnapOnActivity - 1];\n\n              if (nthUnacknowledgedActivityElement) {\n                const nthUnacknowledgedActivityBoundingBoxElement = nthUnacknowledgedActivityElement?.querySelector(\n                  '.webchat__basic-transcript__activity-active-descendant'\n                ) as HTMLElement;\n                const nthUnacknowledgedActivityOffsetTop =\n                  nthUnacknowledgedActivityElement.offsetTop + nthUnacknowledgedActivityBoundingBoxElement.offsetTop;\n\n                values.push(\n                  nthUnacknowledgedActivityOffsetTop +\n                    nthUnacknowledgedActivityBoundingBoxElement.offsetHeight -\n                    offsetHeight -\n                    scrollTop +\n                    patchedAutoScrollSnapOnActivityOffset\n                );\n              }\n            }\n\n            if (patchedAutoScrollSnapOnPage) {\n              const firstUnacknowledgedActivityElement = activityElements[+firstUnacknowledgedActivityElementIndex];\n              const firstUnacknowledgedActivityBoundingBoxElement = firstUnacknowledgedActivityElement.querySelector(\n                '.webchat__basic-transcript__activity-active-descendant'\n              ) as HTMLElement;\n              const firstUnacknowledgedActivityOffsetTop =\n                firstUnacknowledgedActivityElement.offsetTop + firstUnacknowledgedActivityBoundingBoxElement.offsetTop;\n\n              values.push(\n                firstUnacknowledgedActivityOffsetTop -\n                  scrollTop -\n                  offsetHeight * (1 - patchedAutoScrollSnapOnPage) +\n                  patchedAutoScrollSnapOnPageOffset\n              );\n            }\n          }\n        }\n\n        return Math.min(...values);\n      }\n\n      return Infinity;\n    },\n    [activityElementMapRef, activityKeysRef, lastAcknowledgedActivityKeyRef, styleOptionsRef]\n  );\n};\n\ntype BasicTranscriptProps = {\n  className?: string;\n};\n\nconst BasicTranscript: VFC<BasicTranscriptProps> = ({ className }) => {\n  const activityElementMapRef = useRef<ActivityElementMap>(new Map());\n  const containerRef = useRef<HTMLDivElement>();\n\n  const scroller = useScroller(activityElementMapRef);\n\n  return (\n    <TranscriptFocusComposer containerRef={containerRef}>\n      <ReactScrollToBottomComposer scroller={scroller}>\n        <KeyboardHelp />\n        <InternalTranscript activityElementMapRef={activityElementMapRef} className={className} ref={containerRef} />\n      </ReactScrollToBottomComposer>\n    </TranscriptFocusComposer>\n  );\n};\n\nBasicTranscript.defaultProps = {\n  className: ''\n};\n\nBasicTranscript.propTypes = {\n  className: PropTypes.string\n};\n\nexport default BasicTranscript;\n"]}