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
@@ -64,7 +64,10 @@ export default function createStyleSet(styleOptions: StyleOptions): {
64
64
  boxSizing: string;
65
65
  height: string;
66
66
  left: number;
67
- margin: number;
67
+ marginBottom: number;
68
+ marginLeft: number;
69
+ marginRight: number;
70
+ marginTop: number;
68
71
  pointerEvents: string;
69
72
  position: string;
70
73
  top: number;
@@ -85,21 +88,26 @@ export default function createStyleSet(styleOptions: StyleOptions): {
85
88
  '& .webchat__basic-transcript__activity': {
86
89
  paddingTop: number;
87
90
  position: string;
91
+ '&:first-child': {
92
+ marginTop: number;
93
+ };
88
94
  '&:not(:first-child)': {
89
95
  marginTop: number;
90
96
  };
91
97
  };
92
- '& .webchat__basic-transcript__activity-box:not(:empty)': {
93
- paddingBottom: number;
94
- };
95
- '& .webchat__basic-transcript__activity-sentinel': {
98
+ '& .webchat__basic-transcript__activity-active-descendant': {
96
99
  height: string;
97
100
  left: number;
101
+ marginTop: number;
102
+ paddingBottom: number;
98
103
  pointerEvents: string;
99
104
  position: string;
100
105
  top: number;
101
106
  width: string;
102
107
  };
108
+ '& .webchat__basic-transcript__activity-body:not(:empty)': {
109
+ paddingBottom: number;
110
+ };
103
111
  '& .webchat__basic-transcript__terminator': {
104
112
  bottom: number;
105
113
  height: number;
@@ -286,6 +294,127 @@ export default function createStyleSet(styleOptions: StyleOptions): {
286
294
  };
287
295
  };
288
296
  };
297
+ keyboardHelp: {
298
+ '&.webchat__keyboard-help': {
299
+ fontFamily: string;
300
+ fontSize: number;
301
+ height: string;
302
+ margin: number;
303
+ outline: number;
304
+ '&:not(.webchat__keyboard-help--shown)': {
305
+ height: number;
306
+ margin: number;
307
+ overflow: string;
308
+ pointerEvents: string;
309
+ width: number;
310
+ };
311
+ '& .webchat__keyboard-help__box': {
312
+ borderRadius: number;
313
+ boxShadow: string;
314
+ boxSizing: string;
315
+ height: string;
316
+ padding: number;
317
+ position: string;
318
+ '@media (forced-colors: active)': {
319
+ boxShadow: string;
320
+ outlineColor: string;
321
+ outlineStyle: string;
322
+ outlineWidth: number;
323
+ };
324
+ '@media (forced-colors: none) and (prefers-color-scheme: dark)': {
325
+ boxShadow: string;
326
+ };
327
+ };
328
+ '& .webchat__keyboard-help__close-button': {
329
+ appearance: string;
330
+ backgroundColor: string;
331
+ borderColor: string;
332
+ borderRadius: number;
333
+ borderStyle: string;
334
+ borderWidth: number;
335
+ color: string;
336
+ height: number;
337
+ padding: number;
338
+ position: string;
339
+ right: number;
340
+ top: number;
341
+ width: number;
342
+ '@media (forced-colors: none) and (prefers-color-scheme: light)': {
343
+ '&:active': {
344
+ backgroundColor: string;
345
+ };
346
+ '&:not(:active):hover': {
347
+ backgroundColor: string;
348
+ };
349
+ };
350
+ '@media (forced-colors: none) and (prefers-color-scheme: dark)': {
351
+ borderColor: string;
352
+ '&:active': {
353
+ backgroundColor: string;
354
+ };
355
+ '&:not(:active):hover': {
356
+ backgroundColor: string;
357
+ };
358
+ };
359
+ };
360
+ '& .webchat__keyboard-help__close-button_image': {
361
+ fill: string;
362
+ height: number;
363
+ width: number;
364
+ '@media (forced-colors: active)': {
365
+ fill: string;
366
+ };
367
+ '@media (forced-colors: none) and (prefers-color-scheme: dark)': {
368
+ fill: string;
369
+ };
370
+ };
371
+ '& .webchat__keyboard-help__header, & .webchat__keyboard-help__sub-header': {
372
+ marginBottom: number;
373
+ marginTop: number;
374
+ };
375
+ '& .webchat__keyboard-help__section': {
376
+ marginBottom: number;
377
+ };
378
+ '& .webchat__keyboard-help__two-panes': {
379
+ alignItems: string;
380
+ display: string;
381
+ };
382
+ '& .webchat__keyboard-help__image': {
383
+ flexShrink: number;
384
+ paddingRight: number;
385
+ };
386
+ '& .webchat__keyboard-help__image--dark, & .webchat__keyboard-help__image--high-contrast': {
387
+ display: string;
388
+ };
389
+ '@media (forced-colors: active)': {
390
+ '& .webchat__keyboard-help__image--dark, & .webchat__keyboard-help__image--light': {
391
+ display: string;
392
+ };
393
+ '& .webchat__keyboard-help__image--high-contrast': {
394
+ display: string;
395
+ };
396
+ };
397
+ '@media (forced-colors: none) and (prefers-color-scheme: dark)': {
398
+ backgroundColor: string;
399
+ color: string;
400
+ '& .webchat__keyboard-help__image--light': {
401
+ display: string;
402
+ };
403
+ '& .webchat__keyboard-help__image--dark': {
404
+ display: string;
405
+ };
406
+ };
407
+ '& .webchat__keyboard-help__notes': {
408
+ marginBottom: number;
409
+ };
410
+ '& .webchat__keyboard-help__notes-header': {
411
+ margin: number;
412
+ };
413
+ '& .webchat__keyboard-help__notes-text': {
414
+ margin: number;
415
+ };
416
+ };
417
+ };
289
418
  microphoneButton: {
290
419
  '&.webchat__microphone-button': {
291
420
  '&.webchat__microphone-button--dictating .webchat__microphone-button__button': {
@@ -355,15 +484,28 @@ export default function createStyleSet(styleOptions: StyleOptions): {
355
484
  autoScrollSnapOnActivity: number | boolean;
356
485
  autoScrollSnapOnActivityOffset: number;
357
486
  autoScrollSnapOnPage: number | boolean;
358
- autoScrollSnapOnPageoffset: number;
487
+ autoScrollSnapOnPageOffset: number;
359
488
  hideSendBox: boolean;
360
489
  hideUploadButton: boolean;
361
490
  microphoneButtonColorOnDictate: string;
362
491
  sendBoxBackground: string;
363
492
  sendBoxButtonColor: string;
493
+ sendBoxButtonShadeBorderRadius: number;
494
+ sendBoxButtonShadeColor: string;
495
+ sendBoxButtonShadeInset: number;
496
+ sendBoxButtonColorOnActive: string;
497
+ sendBoxButtonShadeColorOnActive: string;
364
498
  sendBoxButtonColorOnDisabled: string;
499
+ sendBoxButtonShadeColorOnDisabled: string;
365
500
  sendBoxButtonColorOnFocus: string;
501
+ sendBoxButtonShadeColorOnFocus: string;
366
502
  sendBoxButtonColorOnHover: string;
503
+ sendBoxButtonShadeColorOnHover: string;
504
+ sendBoxButtonKeyboardFocusIndicatorBorderColor: string;
505
+ sendBoxButtonKeyboardFocusIndicatorBorderRadius: string | number;
506
+ sendBoxButtonKeyboardFocusIndicatorBorderStyle: string;
507
+ sendBoxButtonKeyboardFocusIndicatorBorderWidth: number;
508
+ sendBoxButtonKeyboardFocusIndicatorInset: number;
367
509
  sendBoxDisabledTextColor: string;
368
510
  sendBoxHeight: string | number;
369
511
  sendBoxMaxHeight: string | number;
@@ -380,26 +522,55 @@ export default function createStyleSet(styleOptions: StyleOptions): {
380
522
  spinnerAnimationHeight: string | number;
381
523
  spinnerAnimationWidth: string | number;
382
524
  spinnerAnimationPadding: string | number;
525
+ suggestedActionBorderRadius: string | number;
383
526
  suggestedActionBackground: string;
527
+ suggestedActionBackgroundColor: string;
384
528
  suggestedActionBorderColor: string;
385
- suggestedActionBorderRadius: string | number;
386
529
  suggestedActionBorderStyle: string;
387
- suggestedActionBorderWidth: string | number;
530
+ suggestedActionBorderWidth: number;
531
+ suggestedActionTextColor: string;
532
+ suggestedActionBackgroundColorOnDisabled: string;
533
+ suggestedActionBorderColorOnDisabled: string;
534
+ suggestedActionBorderStyleOnDisabled: string;
535
+ suggestedActionBorderWidthOnDisabled: number;
536
+ suggestedActionTextColorOnDisabled: string;
537
+ suggestedActionBackgroundColorOnActive: string;
538
+ suggestedActionBorderColorOnActive: string;
539
+ suggestedActionBorderStyleOnActive: string;
540
+ suggestedActionBorderWidthOnActive: number;
541
+ suggestedActionTextColorOnActive: string;
542
+ suggestedActionBackgroundColorOnFocus: string;
543
+ suggestedActionBorderColorOnFocus: string;
544
+ suggestedActionBorderStyleOnFocus: string;
545
+ suggestedActionBorderWidthOnFocus: number;
546
+ suggestedActionTextColorOnFocus: string;
547
+ suggestedActionBackgroundColorOnHover: string;
548
+ suggestedActionBorderColorOnHover: string;
549
+ suggestedActionBorderStyleOnHover: string;
550
+ suggestedActionBorderWidthOnHover: number;
551
+ suggestedActionTextColorOnHover: string;
388
552
  suggestedActionDisabledBackground: string;
389
553
  suggestedActionDisabledBorderColor: string;
390
554
  suggestedActionDisabledBorderStyle: string;
391
- suggestedActionDisabledBorderWidth: string | number;
555
+ suggestedActionDisabledBorderWidth: number;
392
556
  suggestedActionDisabledTextColor: string;
393
557
  suggestedActionHeight: string | number;
394
558
  suggestedActionImageHeight: string | number;
395
559
  suggestedActionLayout: "carousel" | "flow" | "stacked";
396
- suggestedActionTextColor: string;
560
+ suggestedActionKeyboardFocusIndicatorBorderColor: string;
561
+ suggestedActionKeyboardFocusIndicatorBorderRadius: string | number;
562
+ suggestedActionKeyboardFocusIndicatorBorderStyle: string;
563
+ suggestedActionKeyboardFocusIndicatorBorderWidth: number;
564
+ suggestedActionKeyboardFocusIndicatorInset: number;
565
+ suggestedActionActiveBackground: string;
566
+ suggestedActionFocusBackground: string;
567
+ suggestedActionHoverBackground: string;
397
568
  suggestedActionsCarouselFlipperCursor: string;
398
569
  suggestedActionsCarouselFlipperBoxWidth: number;
399
570
  suggestedActionsCarouselFlipperSize: number;
400
571
  suggestedActionsFlowMaxHeight: undefined;
401
572
  suggestedActionsStackedHeight: number | "auto";
402
- suggestedActionsStackedOverflow: "string";
573
+ suggestedActionsStackedOverflow: "hidden" | "scroll" | "visible" | "auto";
403
574
  suggestedActionsStackedLayoutButtonMaxHeight: string | number;
404
575
  suggestedActionsStackedLayoutButtonTextWrap: boolean;
405
576
  groupTimestamp: number | boolean;
@@ -463,7 +634,7 @@ export default function createStyleSet(styleOptions: StyleOptions): {
463
634
  };
464
635
  scrollToEndButton: {
465
636
  '&.webchat__scroll-to-end-button': {
466
- '@media screen and (-ms-high-contrast: active)': {
637
+ '@media screen and (forced-colors: active)': {
467
638
  borderWidth: string;
468
639
  outline: string;
469
640
  };
@@ -520,31 +691,77 @@ export default function createStyleSet(styleOptions: StyleOptions): {
520
691
  sendBoxButton: {
521
692
  '&.webchat__icon-button': {
522
693
  alignItems: string;
694
+ appearance: string;
523
695
  backgroundColor: string;
524
696
  border: number;
525
697
  display: string;
698
+ fill: string;
526
699
  justifyContent: string;
527
700
  outline: number;
528
701
  padding: number;
702
+ position: string;
529
703
  width: string | number;
530
704
  '&:not(.webchat__icon-button--stretch)': {
531
705
  height: string | number;
532
706
  };
707
+ '&:disabled, &[aria-disabled="true"]': {
708
+ fill: string;
709
+ '& .webchat__icon-button__shade': {
710
+ backgroundColor: string;
711
+ };
712
+ };
533
713
  '&:not(:disabled):not([aria-disabled="true"])': {
534
- '&:focus svg': {
714
+ '&:active': {
535
715
  fill: string;
716
+ '& .webchat__icon-button__shade': {
717
+ backgroundColor: string;
718
+ };
536
719
  };
537
- '&:hover svg': {
538
- fill: string;
720
+ '&:not(:active)': {
721
+ '&:hover': {
722
+ fill: string;
723
+ '& .webchat__icon-button__shade': {
724
+ backgroundColor: string;
725
+ };
726
+ };
727
+ '&:not(:hover)': {
728
+ '&:focus': {
729
+ fill: string;
730
+ '& .webchat__icon-button__shade': {
731
+ backgroundColor: string;
732
+ };
733
+ };
734
+ };
539
735
  };
540
736
  };
541
- '& svg': {
542
- fill: string;
737
+ '&:not(:focus-visible) .webchat__icon-button__keyboard-focus-indicator': {
738
+ display: string;
543
739
  };
544
- '&:disabled, &[aria-disabled="true"]': {
545
- '& svg': {
546
- fill: string;
547
- };
740
+ '&:not(.webchat__icon-button--focus-visible) .webchat__icon-button__keyboard-focus-indicator': {
741
+ display: string;
742
+ };
743
+ '& > *': {
744
+ position: string;
745
+ };
746
+ '& .webchat__icon-button__shade': {
747
+ backgroundColor: string;
748
+ borderRadius: number;
749
+ bottom: number;
750
+ left: number;
751
+ position: string;
752
+ right: number;
753
+ top: number;
754
+ };
755
+ '& .webchat__icon-button__keyboard-focus-indicator': {
756
+ borderColor: string;
757
+ borderRadius: string | number;
758
+ borderStyle: string;
759
+ borderWidth: number;
760
+ bottom: number;
761
+ left: number;
762
+ position: string;
763
+ right: number;
764
+ top: number;
548
765
  };
549
766
  };
550
767
  };
@@ -678,42 +895,68 @@ export default function createStyleSet(styleOptions: StyleOptions): {
678
895
  };
679
896
  suggestedAction: {
680
897
  '&.webchat__suggested-action': {
681
- display: string;
898
+ alignItems: string;
899
+ background: string;
900
+ backgroundColor: string;
901
+ borderColor: string;
902
+ borderRadius: string | number;
903
+ borderStyle: string;
904
+ borderWidth: number;
905
+ color: string;
906
+ fontFamily: string;
907
+ fontSize: string;
908
+ height: string | number;
909
+ justifyContent: string;
682
910
  maxWidth: string;
683
- '& .webchat__suggested-action__button': {
684
- alignItems: string;
685
- borderRadius: string | number;
686
- fontFamily: string;
687
- fontSize: string;
688
- height: string | number;
689
- justifyContent: string;
690
- maxWidth: string;
691
- paddingLeft: number;
692
- paddingRight: number;
693
- whiteSpace: string;
694
- width: string;
695
- '&:disabled, &[aria-disabled="true"]': {
911
+ outline: number;
912
+ paddingLeft: number;
913
+ paddingRight: number;
914
+ position: string;
915
+ whiteSpace: string;
916
+ width: string;
917
+ '&:disabled, &[aria-disabled="true"]': {
918
+ background: string;
919
+ backgroundColor: string;
920
+ borderColor: string;
921
+ borderStyle: string;
922
+ borderWidth: number;
923
+ color: string;
924
+ };
925
+ '&:not(:disabled):not([aria-disabled="true"])': {
926
+ '&:active': {
696
927
  background: string;
928
+ backgroundColor: string;
697
929
  borderColor: string;
698
930
  borderStyle: string;
699
- borderWidth: string | number;
931
+ borderWidth: number;
700
932
  color: string;
701
933
  };
702
- '&:not(:disabled):not([aria-disabled="true"])': {
703
- background: string;
704
- borderColor: string;
705
- borderStyle: string;
706
- borderWidth: string | number;
707
- color: string;
934
+ '&:not(:active)': {
935
+ '&:hover': {
936
+ background: string;
937
+ backgroundColor: string;
938
+ borderColor: string;
939
+ borderStyle: string;
940
+ borderWidth: number;
941
+ color: string;
942
+ };
943
+ '&:not(:hover)': {
944
+ '&:focus': {
945
+ background: string;
946
+ backgroundColor: string;
947
+ borderColor: string;
948
+ borderStyle: string;
949
+ borderWidth: number;
950
+ color: string;
951
+ };
952
+ };
708
953
  };
709
954
  };
710
- '& .webchat__suggested-action__image': {
711
- height: string | number;
955
+ '&:not(:focus-visible) .webchat__suggested-action__keyboard-focus-indicator': {
956
+ display: string;
712
957
  };
713
- '& .webchat__suggested-action--wrapping': {
714
- height: string;
715
- maxHeight: string | number;
716
- minHeight: string | number;
958
+ '&:not(.webchat__suggested-action--focus-visible) .webchat__suggested-action__keyboard-focus-indicator': {
959
+ display: string;
717
960
  };
718
961
  '&:not(.webchat__suggested-action--rtl) .webchat__suggested-action__image + .webchat__suggested-action__text': {
719
962
  paddingLeft: number;
@@ -721,6 +964,25 @@ export default function createStyleSet(styleOptions: StyleOptions): {
721
964
  '&.webchat__suggested-action--rtl .webchat__suggested-action__image + .webchat__suggested-action__text': {
722
965
  paddingRight: number;
723
966
  };
967
+ '&.webchat__suggested-action--wrapping': {
968
+ height: string;
969
+ maxHeight: string | number;
970
+ minHeight: string | number;
971
+ };
972
+ '& .webchat__suggested-action__image': {
973
+ height: string | number;
974
+ };
975
+ '& .webchat__suggested-action__keyboard-focus-indicator': {
976
+ borderColor: string;
977
+ borderRadius: string | number;
978
+ borderStyle: string;
979
+ borderWidth: number;
980
+ bottom: number;
981
+ left: number;
982
+ position: string;
983
+ right: number;
984
+ top: number;
985
+ };
724
986
  };
725
987
  };
726
988
  suggestedActions: {
@@ -729,7 +991,7 @@ export default function createStyleSet(styleOptions: StyleOptions): {
729
991
  '& .webchat__suggested-actions__carousel': {
730
992
  paddingBottom: number;
731
993
  paddingTop: number;
732
- '& .webchat__suggested-actions__button': {
994
+ '& .webchat__suggested-actions__item-box': {
733
995
  paddingBottom: number;
734
996
  paddingLeft: number;
735
997
  paddingRight: number;
@@ -802,24 +1064,27 @@ export default function createStyleSet(styleOptions: StyleOptions): {
802
1064
  paddingRight: number;
803
1065
  paddingTop: number;
804
1066
  };
805
- '& .webchat__suggested-actions__item': {
1067
+ '& .webchat__suggested-actions__flow-item-box': {
806
1068
  maxWidth: string;
807
1069
  overflow: string;
808
1070
  };
809
- '& .webchat__suggested-actions__button': {
810
- padding: number;
1071
+ '& .webchat__suggested-actions__item-box': {
1072
+ paddingBottom: number;
1073
+ paddingLeft: number;
1074
+ paddingRight: number;
1075
+ paddingTop: number;
811
1076
  };
812
1077
  };
813
1078
  '&.webchat__suggested-actions--stacked-layout': {
814
1079
  '& .webchat__suggested-actions__stack': {
815
1080
  maxHeight: number | "auto";
816
- overflowY: string;
1081
+ overflowY: "hidden" | "scroll" | "visible" | "auto";
817
1082
  paddingBottom: number;
818
1083
  paddingLeft: number;
819
1084
  paddingRight: number;
820
1085
  paddingTop: number;
821
1086
  };
822
- '& .webchat__suggested-actions__button': {
1087
+ '& .webchat__suggested-actions__item-box': {
823
1088
  paddingBottom: number;
824
1089
  paddingLeft: number;
825
1090
  paddingRight: number;
@@ -837,6 +1102,10 @@ export default function createStyleSet(styleOptions: StyleOptions): {
837
1102
  whiteSpace: string;
838
1103
  };
839
1104
  };
1105
+ '& .webchat__suggested-actions__item-box': {
1106
+ display: string;
1107
+ maxWidth: string;
1108
+ };
840
1109
  };
841
1110
  };
842
1111
  textContent: {
@@ -1 +1 @@
1
- {"version":3,"file":"createStyleSet.d.ts","sourceRoot":"","sources":["../../src/Styles/createStyleSet.ts"],"names":[],"mappings":"AACA,OAAO,EAAyB,YAAY,EAAE,MAAM,0BAA0B,CAAC;AA+C/E,MAAM,CAAC,OAAO,UAAU,cAAc,CAAC,YAAY,EAAE,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA8ChE"}
1
+ {"version":3,"file":"createStyleSet.d.ts","sourceRoot":"","sources":["../../src/Styles/createStyleSet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAyB,YAAY,EAAE,MAAM,0BAA0B,CAAC;AAgD/E,MAAM,CAAC,OAAO,UAAU,cAAc,CAAC,YAAY,EAAE,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA+ChE"}
@@ -41,6 +41,8 @@ var _ImageAvatar = _interopRequireDefault(require("./StyleSet/ImageAvatar"));
41
41
 
42
42
  var _InitialsAvatar = _interopRequireDefault(require("./StyleSet/InitialsAvatar"));
43
43
 
44
+ var _KeyboardHelp = _interopRequireDefault(require("./StyleSet/KeyboardHelp"));
45
+
44
46
  var _MicrophoneButton = _interopRequireDefault(require("./StyleSet/MicrophoneButton"));
45
47
 
46
48
  var _Root = _interopRequireDefault(require("./StyleSet/Root"));
@@ -118,6 +120,7 @@ function createStyleSet(styleOptions) {
118
120
  fileContent: (0, _FileContent.default)(strictStyleOptions),
119
121
  imageAvatar: (0, _ImageAvatar.default)(strictStyleOptions),
120
122
  initialsAvatar: (0, _InitialsAvatar.default)(strictStyleOptions),
123
+ keyboardHelp: (0, _KeyboardHelp.default)(strictStyleOptions),
121
124
  microphoneButton: (0, _MicrophoneButton.default)(strictStyleOptions),
122
125
  options: _objectSpread({}, strictStyleOptions),
123
126
  // Cloned to make sure no additional modifications will propagate up.
@@ -145,4 +148,4 @@ function createStyleSet(styleOptions) {
145
148
  youTubeContent: (0, _YouTubeContent.default)(strictStyleOptions)
146
149
  };
147
150
  }
148
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Styles/createStyleSet.ts"],"names":["createStyleSet","styleOptions","strictStyleOptions","activities","audioAttachment","audioContent","autoResizeTextArea","avatar","basicTranscript","bubble","carouselFilmStrip","carouselFilmStripAttachment","carouselFlipper","connectivityNotification","dictationInterims","errorBox","errorNotification","fileContent","imageAvatar","initialsAvatar","microphoneButton","options","root","scrollToEndButton","sendBox","sendBoxButton","sendBoxTextBox","sendStatus","singleAttachmentActivity","spinnerAnimation","stackedLayout","suggestedAction","suggestedActions","textContent","toast","toaster","typingAnimation","typingIndicator","uploadButton","videoAttachment","videoContent","vimeoContent","warningNotification","youTubeContent"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["/* eslint-disable complexity */\nimport { normalizeStyleOptions, StyleOptions } from 'botframework-webchat-api';\n\nimport createActivitiesStyle from './StyleSet/Activities';\nimport createAudioAttachmentStyle from './StyleSet/AudioAttachment';\nimport createAudioContentStyle from './StyleSet/AudioContent';\nimport createAutoResizeTextAreaStyle from './StyleSet/AutoResizeTextArea';\nimport createAvatarStyle from './StyleSet/Avatar';\nimport createBasicTranscriptStyle from './StyleSet/BasicTranscript';\nimport createBubbleStyle from './StyleSet/Bubble';\nimport createCarouselFilmStrip from './StyleSet/CarouselFilmStrip';\nimport createCarouselFilmStripAttachment from './StyleSet/CarouselFilmStripAttachment';\nimport createCarouselFlipper from './StyleSet/CarouselFlipper';\nimport createConnectivityNotification from './StyleSet/ConnectivityNotification';\nimport createDictationInterimsStyle from './StyleSet/DictationInterims';\nimport createErrorBoxStyle from './StyleSet/ErrorBox';\nimport createErrorNotificationStyle from './StyleSet/ErrorNotification';\nimport createFileContentStyle from './StyleSet/FileContent';\nimport createImageAvatarStyle from './StyleSet/ImageAvatar';\nimport createInitialsAvatarStyle from './StyleSet/InitialsAvatar';\nimport createMicrophoneButtonStyle from './StyleSet/MicrophoneButton';\nimport createRootStyle from './StyleSet/Root';\nimport createScrollToEndButtonStyle from './StyleSet/ScrollToEndButton';\nimport createSendBoxButtonStyle from './StyleSet/SendBoxButton';\nimport createSendBoxStyle from './StyleSet/SendBox';\nimport createSendBoxTextBoxStyle from './StyleSet/SendBoxTextBox';\nimport createSendStatusStyle from './StyleSet/SendStatus';\nimport createSingleAttachmentActivityStyle from './StyleSet/SingleAttachmentActivity';\nimport createSpinnerAnimationStyle from './StyleSet/SpinnerAnimation';\nimport createStackedLayoutStyle from './StyleSet/StackedLayout';\nimport createSuggestedActionsStyle from './StyleSet/SuggestedActions';\nimport createSuggestedActionStyle from './StyleSet/SuggestedAction';\nimport createTextContentStyle from './StyleSet/TextContent';\nimport createToasterStyle from './StyleSet/Toaster';\nimport createToastStyle from './StyleSet/Toast';\nimport createTypingAnimationStyle from './StyleSet/TypingAnimation';\nimport createTypingIndicatorStyle from './StyleSet/TypingIndicator';\nimport createUploadButtonStyle from './StyleSet/UploadButton';\nimport createVideoAttachmentStyle from './StyleSet/VideoAttachment';\nimport createVideoContentStyle from './StyleSet/VideoContent';\nimport createVimeoContentStyle from './StyleSet/VimeoContent';\nimport createWarningNotificationStyle from './StyleSet/WarningNotification';\nimport createYouTubeContentStyle from './StyleSet/YouTubeContent';\n\n// TODO: [P4] We should add a notice for people who want to use \"styleSet\" instead of \"styleOptions\".\n//       \"styleSet\" is actually CSS stylesheet and it is based on the DOM tree.\n//       DOM tree may change from time to time, thus, maintaining \"styleSet\" becomes a constant effort.\n\nexport default function createStyleSet(styleOptions: StyleOptions) {\n  const strictStyleOptions = normalizeStyleOptions(styleOptions);\n\n  return {\n    activities: createActivitiesStyle(),\n    audioAttachment: createAudioAttachmentStyle(strictStyleOptions),\n    audioContent: createAudioContentStyle(),\n    autoResizeTextArea: createAutoResizeTextAreaStyle(strictStyleOptions),\n    avatar: createAvatarStyle(strictStyleOptions),\n    basicTranscript: createBasicTranscriptStyle(strictStyleOptions),\n    bubble: createBubbleStyle(strictStyleOptions),\n    carouselFilmStrip: createCarouselFilmStrip(strictStyleOptions),\n    carouselFilmStripAttachment: createCarouselFilmStripAttachment(strictStyleOptions),\n    carouselFlipper: createCarouselFlipper(strictStyleOptions),\n    connectivityNotification: createConnectivityNotification(strictStyleOptions),\n    dictationInterims: createDictationInterimsStyle(strictStyleOptions),\n    errorBox: createErrorBoxStyle(strictStyleOptions),\n    errorNotification: createErrorNotificationStyle(strictStyleOptions),\n    fileContent: createFileContentStyle(strictStyleOptions),\n    imageAvatar: createImageAvatarStyle(strictStyleOptions),\n    initialsAvatar: createInitialsAvatarStyle(strictStyleOptions),\n    microphoneButton: createMicrophoneButtonStyle(strictStyleOptions),\n    options: { ...strictStyleOptions }, // Cloned to make sure no additional modifications will propagate up.\n    root: createRootStyle(strictStyleOptions),\n    scrollToEndButton: createScrollToEndButtonStyle(strictStyleOptions),\n    sendBox: createSendBoxStyle(strictStyleOptions),\n    sendBoxButton: createSendBoxButtonStyle(strictStyleOptions),\n    sendBoxTextBox: createSendBoxTextBoxStyle(strictStyleOptions),\n    sendStatus: createSendStatusStyle(strictStyleOptions),\n    singleAttachmentActivity: createSingleAttachmentActivityStyle(strictStyleOptions),\n    spinnerAnimation: createSpinnerAnimationStyle(strictStyleOptions),\n    stackedLayout: createStackedLayoutStyle(strictStyleOptions),\n    suggestedAction: createSuggestedActionStyle(strictStyleOptions),\n    suggestedActions: createSuggestedActionsStyle(strictStyleOptions),\n    textContent: createTextContentStyle(strictStyleOptions),\n    toast: createToastStyle(strictStyleOptions),\n    toaster: createToasterStyle(strictStyleOptions),\n    typingAnimation: createTypingAnimationStyle(strictStyleOptions),\n    typingIndicator: createTypingIndicatorStyle(strictStyleOptions),\n    uploadButton: createUploadButtonStyle(strictStyleOptions),\n    videoAttachment: createVideoAttachmentStyle(),\n    videoContent: createVideoContentStyle(strictStyleOptions),\n    vimeoContent: createVimeoContentStyle(strictStyleOptions),\n    warningNotification: createWarningNotificationStyle(strictStyleOptions),\n    youTubeContent: createYouTubeContentStyle(strictStyleOptions)\n  };\n}\n"]}
151
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/Styles/createStyleSet.ts"],"names":["createStyleSet","styleOptions","strictStyleOptions","activities","audioAttachment","audioContent","autoResizeTextArea","avatar","basicTranscript","bubble","carouselFilmStrip","carouselFilmStripAttachment","carouselFlipper","connectivityNotification","dictationInterims","errorBox","errorNotification","fileContent","imageAvatar","initialsAvatar","keyboardHelp","microphoneButton","options","root","scrollToEndButton","sendBox","sendBoxButton","sendBoxTextBox","sendStatus","singleAttachmentActivity","spinnerAnimation","stackedLayout","suggestedAction","suggestedActions","textContent","toast","toaster","typingAnimation","typingIndicator","uploadButton","videoAttachment","videoContent","vimeoContent","warningNotification","youTubeContent"],"mappings":"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","sourceRoot":"component:///","sourcesContent":["import { normalizeStyleOptions, StyleOptions } from 'botframework-webchat-api';\n\nimport createActivitiesStyle from './StyleSet/Activities';\nimport createAudioAttachmentStyle from './StyleSet/AudioAttachment';\nimport createAudioContentStyle from './StyleSet/AudioContent';\nimport createAutoResizeTextAreaStyle from './StyleSet/AutoResizeTextArea';\nimport createAvatarStyle from './StyleSet/Avatar';\nimport createBasicTranscriptStyle from './StyleSet/BasicTranscript';\nimport createBubbleStyle from './StyleSet/Bubble';\nimport createCarouselFilmStrip from './StyleSet/CarouselFilmStrip';\nimport createCarouselFilmStripAttachment from './StyleSet/CarouselFilmStripAttachment';\nimport createCarouselFlipper from './StyleSet/CarouselFlipper';\nimport createConnectivityNotification from './StyleSet/ConnectivityNotification';\nimport createDictationInterimsStyle from './StyleSet/DictationInterims';\nimport createErrorBoxStyle from './StyleSet/ErrorBox';\nimport createErrorNotificationStyle from './StyleSet/ErrorNotification';\nimport createFileContentStyle from './StyleSet/FileContent';\nimport createImageAvatarStyle from './StyleSet/ImageAvatar';\nimport createInitialsAvatarStyle from './StyleSet/InitialsAvatar';\nimport createKeyboardHelpStyle from './StyleSet/KeyboardHelp';\nimport createMicrophoneButtonStyle from './StyleSet/MicrophoneButton';\nimport createRootStyle from './StyleSet/Root';\nimport createScrollToEndButtonStyle from './StyleSet/ScrollToEndButton';\nimport createSendBoxButtonStyle from './StyleSet/SendBoxButton';\nimport createSendBoxStyle from './StyleSet/SendBox';\nimport createSendBoxTextBoxStyle from './StyleSet/SendBoxTextBox';\nimport createSendStatusStyle from './StyleSet/SendStatus';\nimport createSingleAttachmentActivityStyle from './StyleSet/SingleAttachmentActivity';\nimport createSpinnerAnimationStyle from './StyleSet/SpinnerAnimation';\nimport createStackedLayoutStyle from './StyleSet/StackedLayout';\nimport createSuggestedActionsStyle from './StyleSet/SuggestedActions';\nimport createSuggestedActionStyle from './StyleSet/SuggestedAction';\nimport createTextContentStyle from './StyleSet/TextContent';\nimport createToasterStyle from './StyleSet/Toaster';\nimport createToastStyle from './StyleSet/Toast';\nimport createTypingAnimationStyle from './StyleSet/TypingAnimation';\nimport createTypingIndicatorStyle from './StyleSet/TypingIndicator';\nimport createUploadButtonStyle from './StyleSet/UploadButton';\nimport createVideoAttachmentStyle from './StyleSet/VideoAttachment';\nimport createVideoContentStyle from './StyleSet/VideoContent';\nimport createVimeoContentStyle from './StyleSet/VimeoContent';\nimport createWarningNotificationStyle from './StyleSet/WarningNotification';\nimport createYouTubeContentStyle from './StyleSet/YouTubeContent';\n\n// TODO: [P4] We should add a notice for people who want to use \"styleSet\" instead of \"styleOptions\".\n//       \"styleSet\" is actually CSS stylesheet and it is based on the DOM tree.\n//       DOM tree may change from time to time, thus, maintaining \"styleSet\" becomes a constant effort.\n\nexport default function createStyleSet(styleOptions: StyleOptions) {\n  const strictStyleOptions = normalizeStyleOptions(styleOptions);\n\n  return {\n    activities: createActivitiesStyle(),\n    audioAttachment: createAudioAttachmentStyle(strictStyleOptions),\n    audioContent: createAudioContentStyle(),\n    autoResizeTextArea: createAutoResizeTextAreaStyle(strictStyleOptions),\n    avatar: createAvatarStyle(strictStyleOptions),\n    basicTranscript: createBasicTranscriptStyle(strictStyleOptions),\n    bubble: createBubbleStyle(strictStyleOptions),\n    carouselFilmStrip: createCarouselFilmStrip(strictStyleOptions),\n    carouselFilmStripAttachment: createCarouselFilmStripAttachment(strictStyleOptions),\n    carouselFlipper: createCarouselFlipper(strictStyleOptions),\n    connectivityNotification: createConnectivityNotification(strictStyleOptions),\n    dictationInterims: createDictationInterimsStyle(strictStyleOptions),\n    errorBox: createErrorBoxStyle(strictStyleOptions),\n    errorNotification: createErrorNotificationStyle(strictStyleOptions),\n    fileContent: createFileContentStyle(strictStyleOptions),\n    imageAvatar: createImageAvatarStyle(strictStyleOptions),\n    initialsAvatar: createInitialsAvatarStyle(strictStyleOptions),\n    keyboardHelp: createKeyboardHelpStyle(strictStyleOptions),\n    microphoneButton: createMicrophoneButtonStyle(strictStyleOptions),\n    options: { ...strictStyleOptions }, // Cloned to make sure no additional modifications will propagate up.\n    root: createRootStyle(strictStyleOptions),\n    scrollToEndButton: createScrollToEndButtonStyle(strictStyleOptions),\n    sendBox: createSendBoxStyle(strictStyleOptions),\n    sendBoxButton: createSendBoxButtonStyle(strictStyleOptions),\n    sendBoxTextBox: createSendBoxTextBoxStyle(strictStyleOptions),\n    sendStatus: createSendStatusStyle(strictStyleOptions),\n    singleAttachmentActivity: createSingleAttachmentActivityStyle(strictStyleOptions),\n    spinnerAnimation: createSpinnerAnimationStyle(strictStyleOptions),\n    stackedLayout: createStackedLayoutStyle(strictStyleOptions),\n    suggestedAction: createSuggestedActionStyle(strictStyleOptions),\n    suggestedActions: createSuggestedActionsStyle(strictStyleOptions),\n    textContent: createTextContentStyle(strictStyleOptions),\n    toast: createToastStyle(strictStyleOptions),\n    toaster: createToasterStyle(strictStyleOptions),\n    typingAnimation: createTypingAnimationStyle(strictStyleOptions),\n    typingIndicator: createTypingIndicatorStyle(strictStyleOptions),\n    uploadButton: createUploadButtonStyle(strictStyleOptions),\n    videoAttachment: createVideoAttachmentStyle(),\n    videoContent: createVideoContentStyle(strictStyleOptions),\n    vimeoContent: createVimeoContentStyle(strictStyleOptions),\n    warningNotification: createWarningNotificationStyle(strictStyleOptions),\n    youTubeContent: createYouTubeContentStyle(strictStyleOptions)\n  };\n}\n"]}
@@ -5,6 +5,8 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.default = mirrorStyle;
7
7
 
8
+ var _botframeworkWebchatCore = require("botframework-webchat-core");
9
+
8
10
  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; }
9
11
 
10
12
  function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
@@ -33,8 +35,15 @@ function mirrorStyle(mirrorSelector, styles) {
33
35
  var patchedKey = key.replace(/(^left|^right|Left|Right)/, function (match) {
34
36
  return match === 'Left' ? 'Right' : match === 'left' ? 'right' : match === 'Right' ? 'Left' : 'left';
35
37
  });
36
- mirrored[patchedKey] = value;
37
- } else {
38
+
39
+ if (!(0, _botframeworkWebchatCore.isForbiddenPropertyName)(patchedKey)) {
40
+ // Mitigated through denylisting.
41
+ // eslint-disable-next-line security/detect-object-injection
42
+ mirrored[patchedKey] = value;
43
+ }
44
+ } else if (!(0, _botframeworkWebchatCore.isForbiddenPropertyName)(key)) {
45
+ // Mitigated through denylisting.
46
+ // eslint-disable-next-line security/detect-object-injection
38
47
  mirrored[key] = mirrorStyle('', value);
39
48
  }
40
49
  }
@@ -42,4 +51,4 @@ function mirrorStyle(mirrorSelector, styles) {
42
51
  var relative = /^&[\t-\r \xA0\u1680\u2000-\u200A\u2028\u2029\u202F\u205F\u3000\uFEFF]*/g.exec(mirrorSelector) || '';
43
52
  return mirrorSelector ? (_ref = {}, _defineProperty(_ref, "".concat(relative, ":not(").concat(mirrorSelector.substr(relative.length), ")"), styles), _defineProperty(_ref, mirrorSelector, mirrored), _ref) : mirrored;
44
53
  }
45
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9TdHlsZXMvbWlycm9yU3R5bGUuanMiXSwibmFtZXMiOlsibWlycm9yU3R5bGUiLCJtaXJyb3JTZWxlY3RvciIsInN0eWxlcyIsIm1pcnJvcmVkIiwiT2JqZWN0IiwiZW50cmllcyIsImtleSIsInZhbHVlIiwicGF0Y2hlZEtleSIsInJlcGxhY2UiLCJtYXRjaCIsInJlbGF0aXZlIiwiZXhlYyIsInN1YnN0ciIsImxlbmd0aCJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQWUsU0FBU0EsV0FBVCxDQUFxQkMsY0FBckIsRUFBcUNDLE1BQXJDLEVBQTZDO0FBQUE7O0FBQzFELE1BQU1DLFFBQVEsR0FBRyxFQUFqQjs7QUFFQSxxQ0FBMkJDLE1BQU0sQ0FBQ0MsT0FBUCxDQUFlSCxNQUFmLENBQTNCLHFDQUFtRDtBQUE5QztBQUFBLFFBQU9JLEdBQVA7QUFBQSxRQUFZQyxLQUFaOztBQUNILFFBQUksT0FBT0EsS0FBUCxLQUFpQixRQUFqQixJQUE2QixPQUFPQSxLQUFQLEtBQWlCLFFBQWxELEVBQTREO0FBQzFELFVBQU1DLFVBQVUsR0FBR0YsR0FBRyxDQUFDRyxPQUFKLENBQVksMkJBQVosRUFBMEMsVUFBQUMsS0FBSztBQUFBLGVBQ2hFQSxLQUFLLEtBQUssTUFBVixHQUFtQixPQUFuQixHQUE2QkEsS0FBSyxLQUFLLE1BQVYsR0FBbUIsT0FBbkIsR0FBNkJBLEtBQUssS0FBSyxPQUFWLEdBQW9CLE1BQXBCLEdBQTZCLE1BRHZCO0FBQUEsT0FBL0MsQ0FBbkI7QUFJQVAsTUFBQUEsUUFBUSxDQUFDSyxVQUFELENBQVIsR0FBdUJELEtBQXZCO0FBQ0QsS0FORCxNQU1PO0FBQ0xKLE1BQUFBLFFBQVEsQ0FBQ0csR0FBRCxDQUFSLEdBQWdCTixXQUFXLENBQUMsRUFBRCxFQUFLTyxLQUFMLENBQTNCO0FBQ0Q7QUFDRjs7QUFFRCxNQUFNSSxRQUFRLEdBQUcsMEVBQVVDLElBQVYsQ0FBZVgsY0FBZixLQUFrQyxFQUFuRDtBQUVBLFNBQU9BLGNBQWMsK0NBRVhVLFFBRlcsa0JBRUtWLGNBQWMsQ0FBQ1ksTUFBZixDQUFzQkYsUUFBUSxDQUFDRyxNQUEvQixDQUZMLFFBRWlEWixNQUZqRCx5QkFHZEQsY0FIYyxFQUdHRSxRQUhILFdBS2pCQSxRQUxKO0FBTUQiLCJzb3VyY2VSb290IjoiY29tcG9uZW50Oi8vLyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIG1pcnJvclN0eWxlKG1pcnJvclNlbGVjdG9yLCBzdHlsZXMpIHtcbiAgY29uc3QgbWlycm9yZWQgPSB7fTtcblxuICBmb3IgKGNvbnN0IFtrZXksIHZhbHVlXSBvZiBPYmplY3QuZW50cmllcyhzdHlsZXMpKSB7XG4gICAgaWYgKHR5cGVvZiB2YWx1ZSA9PT0gJ251bWJlcicgfHwgdHlwZW9mIHZhbHVlID09PSAnc3RyaW5nJykge1xuICAgICAgY29uc3QgcGF0Y2hlZEtleSA9IGtleS5yZXBsYWNlKC8oXmxlZnR8XnJpZ2h0fExlZnR8UmlnaHQpL3UsIG1hdGNoID0+XG4gICAgICAgIG1hdGNoID09PSAnTGVmdCcgPyAnUmlnaHQnIDogbWF0Y2ggPT09ICdsZWZ0JyA/ICdyaWdodCcgOiBtYXRjaCA9PT0gJ1JpZ2h0JyA/ICdMZWZ0JyA6ICdsZWZ0J1xuICAgICAgKTtcblxuICAgICAgbWlycm9yZWRbcGF0Y2hlZEtleV0gPSB2YWx1ZTtcbiAgICB9IGVsc2Uge1xuICAgICAgbWlycm9yZWRba2V5XSA9IG1pcnJvclN0eWxlKCcnLCB2YWx1ZSk7XG4gICAgfVxuICB9XG5cbiAgY29uc3QgcmVsYXRpdmUgPSAvXiZcXHMqL2d1LmV4ZWMobWlycm9yU2VsZWN0b3IpIHx8ICcnO1xuXG4gIHJldHVybiBtaXJyb3JTZWxlY3RvclxuICAgID8ge1xuICAgICAgICBbYCR7cmVsYXRpdmV9Om5vdCgke21pcnJvclNlbGVjdG9yLnN1YnN0cihyZWxhdGl2ZS5sZW5ndGgpfSlgXTogc3R5bGVzLFxuICAgICAgICBbbWlycm9yU2VsZWN0b3JdOiBtaXJyb3JlZFxuICAgICAgfVxuICAgIDogbWlycm9yZWQ7XG59XG4iXX0=
54
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9TdHlsZXMvbWlycm9yU3R5bGUuanMiXSwibmFtZXMiOlsibWlycm9yU3R5bGUiLCJtaXJyb3JTZWxlY3RvciIsInN0eWxlcyIsIm1pcnJvcmVkIiwiT2JqZWN0IiwiZW50cmllcyIsImtleSIsInZhbHVlIiwicGF0Y2hlZEtleSIsInJlcGxhY2UiLCJtYXRjaCIsInJlbGF0aXZlIiwiZXhlYyIsInN1YnN0ciIsImxlbmd0aCJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOzs7Ozs7Ozs7Ozs7Ozs7O0FBRWUsU0FBU0EsV0FBVCxDQUFxQkMsY0FBckIsRUFBcUNDLE1BQXJDLEVBQTZDO0FBQUE7O0FBQzFELE1BQU1DLFFBQVEsR0FBRyxFQUFqQjs7QUFFQSxxQ0FBMkJDLE1BQU0sQ0FBQ0MsT0FBUCxDQUFlSCxNQUFmLENBQTNCLHFDQUFtRDtBQUE5QztBQUFBLFFBQU9JLEdBQVA7QUFBQSxRQUFZQyxLQUFaOztBQUNILFFBQUksT0FBT0EsS0FBUCxLQUFpQixRQUFqQixJQUE2QixPQUFPQSxLQUFQLEtBQWlCLFFBQWxELEVBQTREO0FBQzFELFVBQU1DLFVBQVUsR0FBR0YsR0FBRyxDQUFDRyxPQUFKLENBQVksMkJBQVosRUFBMEMsVUFBQUMsS0FBSztBQUFBLGVBQ2hFQSxLQUFLLEtBQUssTUFBVixHQUFtQixPQUFuQixHQUE2QkEsS0FBSyxLQUFLLE1BQVYsR0FBbUIsT0FBbkIsR0FBNkJBLEtBQUssS0FBSyxPQUFWLEdBQW9CLE1BQXBCLEdBQTZCLE1BRHZCO0FBQUEsT0FBL0MsQ0FBbkI7O0FBSUEsVUFBSSxDQUFDLHNEQUF3QkYsVUFBeEIsQ0FBTCxFQUEwQztBQUN4QztBQUNBO0FBQ0FMLFFBQUFBLFFBQVEsQ0FBQ0ssVUFBRCxDQUFSLEdBQXVCRCxLQUF2QjtBQUNEO0FBQ0YsS0FWRCxNQVVPLElBQUksQ0FBQyxzREFBd0JELEdBQXhCLENBQUwsRUFBbUM7QUFDeEM7QUFDQTtBQUNBSCxNQUFBQSxRQUFRLENBQUNHLEdBQUQsQ0FBUixHQUFnQk4sV0FBVyxDQUFDLEVBQUQsRUFBS08sS0FBTCxDQUEzQjtBQUNEO0FBQ0Y7O0FBRUQsTUFBTUksUUFBUSxHQUFHLDBFQUFVQyxJQUFWLENBQWVYLGNBQWYsS0FBa0MsRUFBbkQ7QUFFQSxTQUFPQSxjQUFjLCtDQUVYVSxRQUZXLGtCQUVLVixjQUFjLENBQUNZLE1BQWYsQ0FBc0JGLFFBQVEsQ0FBQ0csTUFBL0IsQ0FGTCxRQUVpRFosTUFGakQseUJBR2RELGNBSGMsRUFHR0UsUUFISCxXQUtqQkEsUUFMSjtBQU1EIiwic291cmNlUm9vdCI6ImNvbXBvbmVudDovLy8iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc0ZvcmJpZGRlblByb3BlcnR5TmFtZSB9IGZyb20gJ2JvdGZyYW1ld29yay13ZWJjaGF0LWNvcmUnO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiBtaXJyb3JTdHlsZShtaXJyb3JTZWxlY3Rvciwgc3R5bGVzKSB7XG4gIGNvbnN0IG1pcnJvcmVkID0ge307XG5cbiAgZm9yIChjb25zdCBba2V5LCB2YWx1ZV0gb2YgT2JqZWN0LmVudHJpZXMoc3R5bGVzKSkge1xuICAgIGlmICh0eXBlb2YgdmFsdWUgPT09ICdudW1iZXInIHx8IHR5cGVvZiB2YWx1ZSA9PT0gJ3N0cmluZycpIHtcbiAgICAgIGNvbnN0IHBhdGNoZWRLZXkgPSBrZXkucmVwbGFjZSgvKF5sZWZ0fF5yaWdodHxMZWZ0fFJpZ2h0KS91LCBtYXRjaCA9PlxuICAgICAgICBtYXRjaCA9PT0gJ0xlZnQnID8gJ1JpZ2h0JyA6IG1hdGNoID09PSAnbGVmdCcgPyAncmlnaHQnIDogbWF0Y2ggPT09ICdSaWdodCcgPyAnTGVmdCcgOiAnbGVmdCdcbiAgICAgICk7XG5cbiAgICAgIGlmICghaXNGb3JiaWRkZW5Qcm9wZXJ0eU5hbWUocGF0Y2hlZEtleSkpIHtcbiAgICAgICAgLy8gTWl0aWdhdGVkIHRocm91Z2ggZGVueWxpc3RpbmcuXG4gICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBzZWN1cml0eS9kZXRlY3Qtb2JqZWN0LWluamVjdGlvblxuICAgICAgICBtaXJyb3JlZFtwYXRjaGVkS2V5XSA9IHZhbHVlO1xuICAgICAgfVxuICAgIH0gZWxzZSBpZiAoIWlzRm9yYmlkZGVuUHJvcGVydHlOYW1lKGtleSkpIHtcbiAgICAgIC8vIE1pdGlnYXRlZCB0aHJvdWdoIGRlbnlsaXN0aW5nLlxuICAgICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIHNlY3VyaXR5L2RldGVjdC1vYmplY3QtaW5qZWN0aW9uXG4gICAgICBtaXJyb3JlZFtrZXldID0gbWlycm9yU3R5bGUoJycsIHZhbHVlKTtcbiAgICB9XG4gIH1cblxuICBjb25zdCByZWxhdGl2ZSA9IC9eJlxccyovZ3UuZXhlYyhtaXJyb3JTZWxlY3RvcikgfHwgJyc7XG5cbiAgcmV0dXJuIG1pcnJvclNlbGVjdG9yXG4gICAgPyB7XG4gICAgICAgIFtgJHtyZWxhdGl2ZX06bm90KCR7bWlycm9yU2VsZWN0b3Iuc3Vic3RyKHJlbGF0aXZlLmxlbmd0aCl9KWBdOiBzdHlsZXMsXG4gICAgICAgIFttaXJyb3JTZWxlY3Rvcl06IG1pcnJvcmVkXG4gICAgICB9XG4gICAgOiBtaXJyb3JlZDtcbn1cbiJdfQ==