botframework-webchat-api 4.13.0 → 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 (689) hide show
  1. package/.eslintrc.yml +4 -100
  2. package/.prettierrc.yml +1 -1
  3. package/lib/StyleOptions.d.ts +270 -15
  4. package/lib/StyleOptions.d.ts.map +1 -1
  5. package/lib/defaultStyleOptions.d.ts +4 -0
  6. package/lib/defaultStyleOptions.d.ts.map +1 -0
  7. package/lib/defaultStyleOptions.js +73 -16
  8. package/lib/hooks/Composer.d.ts +71 -0
  9. package/lib/hooks/Composer.d.ts.map +1 -0
  10. package/lib/hooks/Composer.js +122 -90
  11. package/lib/hooks/index.d.ts +74 -0
  12. package/lib/hooks/index.d.ts.map +1 -0
  13. package/lib/hooks/index.js +89 -1
  14. package/lib/hooks/internal/ErrorBox.js +2 -2
  15. package/lib/hooks/internal/Tracker.d.ts +4 -0
  16. package/lib/hooks/internal/Tracker.d.ts.map +1 -0
  17. package/lib/hooks/internal/WebChatAPIContext.d.ts +81 -0
  18. package/lib/hooks/internal/WebChatAPIContext.d.ts.map +1 -0
  19. package/lib/hooks/internal/WebChatAPIContext.js +2 -4
  20. package/lib/hooks/internal/useCreateActivityRendererInternal.d.ts +4 -0
  21. package/lib/hooks/internal/useCreateActivityRendererInternal.d.ts.map +1 -0
  22. package/lib/hooks/internal/useCreateActivityRendererInternal.js +1 -1
  23. package/lib/hooks/internal/useDebugDeps.js +11 -5
  24. package/lib/hooks/internal/useDownscaleImageToDataURL.js +1 -1
  25. package/lib/hooks/internal/useErrorBoxClass.js +1 -1
  26. package/lib/hooks/internal/useForceRender.js +2 -2
  27. package/lib/hooks/internal/useLocalizedStrings.js +1 -1
  28. package/lib/hooks/internal/usePrevious.d.ts +2 -0
  29. package/lib/hooks/internal/usePrevious.d.ts.map +1 -0
  30. package/lib/hooks/internal/usePrevious.js +17 -0
  31. package/lib/hooks/internal/useReadTelemetryDimensions.js +2 -2
  32. package/lib/hooks/internal/useTimePassed.js +2 -2
  33. package/lib/hooks/internal/useTracker.js +2 -2
  34. package/lib/hooks/internal/useValueRef.d.ts +3 -0
  35. package/lib/hooks/internal/useValueRef.d.ts.map +1 -0
  36. package/lib/hooks/internal/useValueRef.js +24 -0
  37. package/lib/hooks/middleware/UserlandBoundary.js +4 -4
  38. package/lib/hooks/middleware/applyMiddleware.js +6 -6
  39. package/lib/hooks/middleware/concatMiddleware.d.ts +6 -0
  40. package/lib/hooks/middleware/concatMiddleware.d.ts.map +1 -0
  41. package/lib/hooks/middleware/concatMiddleware.js +3 -3
  42. package/lib/hooks/middleware/createDefaultCardActionMiddleware.d.ts +3 -0
  43. package/lib/hooks/middleware/createDefaultCardActionMiddleware.d.ts.map +1 -0
  44. package/lib/hooks/middleware/createDefaultCardActionMiddleware.js +6 -8
  45. package/lib/hooks/middleware/createDefaultGroupActivitiesMiddleware.d.ts +5 -0
  46. package/lib/hooks/middleware/createDefaultGroupActivitiesMiddleware.d.ts.map +1 -0
  47. package/lib/hooks/middleware/createDefaultGroupActivitiesMiddleware.js +1 -1
  48. package/lib/hooks/useActiveTyping.d.ts +6 -0
  49. package/lib/hooks/useActiveTyping.d.ts.map +1 -0
  50. package/lib/hooks/useActiveTyping.js +4 -4
  51. package/lib/hooks/useActivities.d.ts +3 -0
  52. package/lib/hooks/useActivities.d.ts.map +1 -0
  53. package/lib/hooks/useActivities.js +1 -1
  54. package/lib/hooks/useActivityKeys.d.ts +3 -0
  55. package/lib/hooks/useActivityKeys.d.ts.map +1 -0
  56. package/lib/hooks/useActivityKeys.js +14 -0
  57. package/lib/hooks/useActivityKeysByRead.d.ts +3 -0
  58. package/lib/hooks/useActivityKeysByRead.d.ts.map +1 -0
  59. package/lib/hooks/useActivityKeysByRead.js +14 -0
  60. package/lib/hooks/useAvatarForBot.d.ts +5 -0
  61. package/lib/hooks/useAvatarForBot.d.ts.map +1 -0
  62. package/lib/hooks/useAvatarForBot.js +2 -2
  63. package/lib/hooks/useAvatarForUser.d.ts +5 -0
  64. package/lib/hooks/useAvatarForUser.d.ts.map +1 -0
  65. package/lib/hooks/useAvatarForUser.js +2 -2
  66. package/lib/hooks/useByteFormatter.d.ts +2 -0
  67. package/lib/hooks/useByteFormatter.d.ts.map +1 -0
  68. package/lib/hooks/useByteFormatter.js +2 -2
  69. package/lib/hooks/useConnectivityStatus.d.ts +2 -0
  70. package/lib/hooks/useConnectivityStatus.d.ts.map +1 -0
  71. package/lib/hooks/useConnectivityStatus.js +1 -1
  72. package/lib/hooks/useCreateActivityRenderer.d.ts +3 -0
  73. package/lib/hooks/useCreateActivityRenderer.d.ts.map +1 -0
  74. package/lib/hooks/useCreateActivityRenderer.js +1 -2
  75. package/lib/hooks/useCreateActivityStatusRenderer.d.ts +9 -0
  76. package/lib/hooks/useCreateActivityStatusRenderer.d.ts.map +1 -0
  77. package/lib/hooks/useCreateActivityStatusRenderer.js +6 -4
  78. package/lib/hooks/useCreateAvatarRenderer.d.ts +6 -0
  79. package/lib/hooks/useCreateAvatarRenderer.d.ts.map +1 -0
  80. package/lib/hooks/useCreateAvatarRenderer.js +2 -2
  81. package/lib/hooks/useCreateScrollToEndButtonRenderer.d.ts +3 -0
  82. package/lib/hooks/useCreateScrollToEndButtonRenderer.d.ts.map +1 -0
  83. package/lib/hooks/useCreateScrollToEndButtonRenderer.js +15 -0
  84. package/lib/hooks/useDateFormatter.d.ts +2 -0
  85. package/lib/hooks/useDateFormatter.d.ts.map +1 -0
  86. package/lib/hooks/useDateFormatter.js +2 -2
  87. package/lib/hooks/useDebouncedNotifications.d.ts +13 -0
  88. package/lib/hooks/useDebouncedNotifications.d.ts.map +1 -0
  89. package/lib/hooks/useDebouncedNotifications.js +7 -7
  90. package/lib/hooks/useDictateInterims.d.ts +2 -0
  91. package/lib/hooks/useDictateInterims.d.ts.map +1 -0
  92. package/lib/hooks/useDictateInterims.js +1 -1
  93. package/lib/hooks/useDictateState.d.ts +2 -0
  94. package/lib/hooks/useDictateState.d.ts.map +1 -0
  95. package/lib/hooks/useDictateState.js +1 -1
  96. package/lib/hooks/useDirection.d.ts +2 -0
  97. package/lib/hooks/useDirection.d.ts.map +1 -0
  98. package/lib/hooks/useDirection.js +2 -2
  99. package/lib/hooks/useDisabled.d.ts +2 -0
  100. package/lib/hooks/useDisabled.d.ts.map +1 -0
  101. package/lib/hooks/useDisabled.js +1 -1
  102. package/lib/hooks/useDismissNotification.d.ts +2 -0
  103. package/lib/hooks/useDismissNotification.d.ts.map +1 -0
  104. package/lib/hooks/useDismissNotification.js +1 -1
  105. package/lib/hooks/useEmitTypingIndicator.d.ts +2 -0
  106. package/lib/hooks/useEmitTypingIndicator.d.ts.map +1 -0
  107. package/lib/hooks/useEmitTypingIndicator.js +1 -1
  108. package/lib/hooks/useGetActivityByKey.d.ts +3 -0
  109. package/lib/hooks/useGetActivityByKey.d.ts.map +1 -0
  110. package/lib/hooks/useGetActivityByKey.js +14 -0
  111. package/lib/hooks/useGetHasAcknowledgedByActivityKey.d.ts +3 -0
  112. package/lib/hooks/useGetHasAcknowledgedByActivityKey.d.ts.map +1 -0
  113. package/lib/hooks/useGetHasAcknowledgedByActivityKey.js +14 -0
  114. package/lib/hooks/useGetKeyByActivity.d.ts +3 -0
  115. package/lib/hooks/useGetKeyByActivity.d.ts.map +1 -0
  116. package/lib/hooks/useGetKeyByActivity.js +14 -0
  117. package/lib/hooks/useGetKeyByActivityId.d.ts +3 -0
  118. package/lib/hooks/useGetKeyByActivityId.d.ts.map +1 -0
  119. package/lib/hooks/useGetKeyByActivityId.js +14 -0
  120. package/lib/hooks/useGetSendTimeoutForActivity.d.ts +5 -0
  121. package/lib/hooks/useGetSendTimeoutForActivity.d.ts.map +1 -0
  122. package/lib/hooks/useGetSendTimeoutForActivity.js +2 -2
  123. package/lib/hooks/useGrammars.d.ts +2 -0
  124. package/lib/hooks/useGrammars.d.ts.map +1 -0
  125. package/lib/hooks/useGrammars.js +1 -1
  126. package/lib/hooks/useGroupActivities.d.ts +8 -0
  127. package/lib/hooks/useGroupActivities.d.ts.map +1 -0
  128. package/lib/hooks/useGroupActivities.js +1 -1
  129. package/lib/hooks/useGroupTimestamp.d.ts +2 -0
  130. package/lib/hooks/useGroupTimestamp.d.ts.map +1 -0
  131. package/lib/hooks/useGroupTimestamp.js +2 -2
  132. package/lib/hooks/useLanguage.d.ts +2 -0
  133. package/lib/hooks/useLanguage.d.ts.map +1 -0
  134. package/lib/hooks/useLanguage.js +1 -1
  135. package/lib/hooks/useLastAcknowledgedActivityKey.d.ts +3 -0
  136. package/lib/hooks/useLastAcknowledgedActivityKey.d.ts.map +1 -0
  137. package/lib/hooks/useLastAcknowledgedActivityKey.js +14 -0
  138. package/lib/hooks/useLastReadActivityKey.d.ts +3 -0
  139. package/lib/hooks/useLastReadActivityKey.d.ts.map +1 -0
  140. package/lib/hooks/useLastReadActivityKey.js +14 -0
  141. package/lib/hooks/useLastTypingAt.d.ts +5 -0
  142. package/lib/hooks/useLastTypingAt.d.ts.map +1 -0
  143. package/lib/hooks/useLastTypingAt.js +2 -1
  144. package/lib/hooks/useLocalize.d.ts +3 -0
  145. package/lib/hooks/useLocalize.d.ts.map +1 -0
  146. package/lib/hooks/useLocalize.js +5 -2
  147. package/lib/hooks/useLocalizeDate.d.ts +3 -0
  148. package/lib/hooks/useLocalizeDate.d.ts.map +1 -0
  149. package/lib/hooks/useLocalizeDate.js +3 -2
  150. package/lib/hooks/useLocalizer.d.ts +13 -0
  151. package/lib/hooks/useLocalizer.d.ts.map +1 -0
  152. package/lib/hooks/useLocalizer.js +16 -6
  153. package/lib/hooks/useMarkActivityAsSpoken.d.ts +3 -0
  154. package/lib/hooks/useMarkActivityAsSpoken.d.ts.map +1 -0
  155. package/lib/hooks/useMarkActivityAsSpoken.js +1 -1
  156. package/lib/hooks/useMarkActivityKeyAsRead.d.ts +3 -0
  157. package/lib/hooks/useMarkActivityKeyAsRead.d.ts.map +1 -0
  158. package/lib/hooks/useMarkActivityKeyAsRead.js +14 -0
  159. package/lib/hooks/useMarkAllAsAcknowledged.d.ts +3 -0
  160. package/lib/hooks/useMarkAllAsAcknowledged.d.ts.map +1 -0
  161. package/lib/hooks/useMarkAllAsAcknowledged.js +14 -0
  162. package/lib/hooks/useNotifications.d.ts +3 -0
  163. package/lib/hooks/useNotifications.d.ts.map +1 -0
  164. package/lib/hooks/useNotifications.js +1 -1
  165. package/lib/hooks/usePerformCardAction.d.ts +3 -0
  166. package/lib/hooks/usePerformCardAction.d.ts.map +1 -0
  167. package/lib/hooks/usePerformCardAction.js +1 -1
  168. package/lib/hooks/usePostActivity.d.ts +4 -0
  169. package/lib/hooks/usePostActivity.d.ts.map +1 -0
  170. package/lib/hooks/usePostActivity.js +1 -1
  171. package/lib/hooks/useReferenceGrammarID.d.ts +2 -0
  172. package/lib/hooks/useReferenceGrammarID.d.ts.map +1 -0
  173. package/lib/hooks/useReferenceGrammarID.js +1 -1
  174. package/lib/hooks/useRelativeTimeFormatter.d.ts +2 -0
  175. package/lib/hooks/useRelativeTimeFormatter.d.ts.map +1 -0
  176. package/lib/hooks/useRelativeTimeFormatter.js +2 -2
  177. package/lib/hooks/useRenderActivity.js +2 -1
  178. package/lib/hooks/useRenderActivityStatus.js +2 -1
  179. package/lib/hooks/useRenderAttachment.js +1 -1
  180. package/lib/hooks/useRenderAvatar.js +2 -1
  181. package/lib/hooks/useRenderToast.d.ts +3 -0
  182. package/lib/hooks/useRenderToast.d.ts.map +1 -0
  183. package/lib/hooks/useRenderToast.js +1 -1
  184. package/lib/hooks/useRenderTypingIndicator.d.ts +3 -0
  185. package/lib/hooks/useRenderTypingIndicator.d.ts.map +1 -0
  186. package/lib/hooks/useRenderTypingIndicator.js +1 -1
  187. package/lib/hooks/useSendBoxValue.d.ts +2 -0
  188. package/lib/hooks/useSendBoxValue.d.ts.map +1 -0
  189. package/lib/hooks/useSendBoxValue.js +1 -1
  190. package/lib/hooks/useSendEvent.d.ts +2 -0
  191. package/lib/hooks/useSendEvent.d.ts.map +1 -0
  192. package/lib/hooks/useSendEvent.js +1 -1
  193. package/lib/hooks/useSendFiles.d.ts +2 -0
  194. package/lib/hooks/useSendFiles.d.ts.map +1 -0
  195. package/lib/hooks/useSendFiles.js +1 -1
  196. package/lib/hooks/useSendMessage.d.ts +4 -0
  197. package/lib/hooks/useSendMessage.d.ts.map +1 -0
  198. package/lib/hooks/useSendMessage.js +1 -1
  199. package/lib/hooks/useSendMessageBack.d.ts +2 -0
  200. package/lib/hooks/useSendMessageBack.d.ts.map +1 -0
  201. package/lib/hooks/useSendMessageBack.js +1 -1
  202. package/lib/hooks/useSendPostBack.d.ts +2 -0
  203. package/lib/hooks/useSendPostBack.d.ts.map +1 -0
  204. package/lib/hooks/useSendPostBack.js +1 -1
  205. package/lib/hooks/useSendTimeoutForActivity.d.ts +4 -0
  206. package/lib/hooks/useSendTimeoutForActivity.d.ts.map +1 -0
  207. package/lib/hooks/useSendTimeoutForActivity.js +2 -1
  208. package/lib/hooks/useSendTypingIndicator.d.ts +2 -0
  209. package/lib/hooks/useSendTypingIndicator.d.ts.map +1 -0
  210. package/lib/hooks/useSendTypingIndicator.js +1 -1
  211. package/lib/hooks/useSetNotification.d.ts +3 -0
  212. package/lib/hooks/useSetNotification.d.ts.map +1 -0
  213. package/lib/hooks/useSetNotification.js +1 -1
  214. package/lib/hooks/useShouldSpeakIncomingActivity.d.ts +2 -0
  215. package/lib/hooks/useShouldSpeakIncomingActivity.d.ts.map +1 -0
  216. package/lib/hooks/useShouldSpeakIncomingActivity.js +1 -1
  217. package/lib/hooks/useStartDictate.d.ts +2 -0
  218. package/lib/hooks/useStartDictate.d.ts.map +1 -0
  219. package/lib/hooks/useStartDictate.js +1 -1
  220. package/lib/hooks/useStopDictate.d.ts +2 -0
  221. package/lib/hooks/useStopDictate.d.ts.map +1 -0
  222. package/lib/hooks/useStopDictate.js +1 -1
  223. package/lib/hooks/useStyleOptions.d.ts +3 -0
  224. package/lib/hooks/useStyleOptions.d.ts.map +1 -0
  225. package/lib/hooks/useStyleOptions.js +1 -1
  226. package/lib/hooks/useSubmitSendBox.d.ts +4 -0
  227. package/lib/hooks/useSubmitSendBox.d.ts.map +1 -0
  228. package/lib/hooks/useSubmitSendBox.js +8 -5
  229. package/lib/hooks/useSuggestedActions.d.ts +6 -0
  230. package/lib/hooks/useSuggestedActions.d.ts.map +1 -0
  231. package/lib/hooks/useSuggestedActions.js +1 -1
  232. package/lib/hooks/useTimeoutForSend.d.ts +3 -0
  233. package/lib/hooks/useTimeoutForSend.d.ts.map +1 -0
  234. package/lib/hooks/useTimeoutForSend.js +2 -2
  235. package/lib/hooks/useTrackDimension.d.ts +2 -0
  236. package/lib/hooks/useTrackDimension.d.ts.map +1 -0
  237. package/lib/hooks/useTrackDimension.js +1 -1
  238. package/lib/hooks/useTrackEvent.d.ts +10 -0
  239. package/lib/hooks/useTrackEvent.d.ts.map +1 -0
  240. package/lib/hooks/useTrackEvent.js +1 -1
  241. package/lib/hooks/useTrackException.d.ts +2 -0
  242. package/lib/hooks/useTrackException.d.ts.map +1 -0
  243. package/lib/hooks/useTrackException.js +2 -2
  244. package/lib/hooks/useTrackTiming.d.ts +2 -0
  245. package/lib/hooks/useTrackTiming.d.ts.map +1 -0
  246. package/lib/hooks/useTrackTiming.js +1 -1
  247. package/lib/hooks/useUserID.d.ts +2 -0
  248. package/lib/hooks/useUserID.d.ts.map +1 -0
  249. package/lib/hooks/useUserID.js +1 -1
  250. package/lib/hooks/useUsername.d.ts +2 -0
  251. package/lib/hooks/useUsername.d.ts.map +1 -0
  252. package/lib/hooks/useUsername.js +1 -1
  253. package/lib/hooks/useVoiceSelector.d.ts +2 -0
  254. package/lib/hooks/useVoiceSelector.d.ts.map +1 -0
  255. package/lib/hooks/useVoiceSelector.js +1 -1
  256. package/lib/hooks/utils/ErrorBoundary.js +4 -4
  257. package/lib/hooks/utils/observableToPromise.d.ts +3 -0
  258. package/lib/hooks/utils/observableToPromise.d.ts.map +1 -0
  259. package/lib/hooks/utils/observableToPromise.js +1 -1
  260. package/lib/index.d.ts +20 -4
  261. package/lib/index.d.ts.map +1 -1
  262. package/lib/index.js +10 -10
  263. package/lib/localization/Localize.d.ts +10 -0
  264. package/lib/localization/Localize.d.ts.map +1 -0
  265. package/lib/localization/Localize.js +18 -12
  266. package/lib/localization/ar-SA.json +24 -4
  267. package/lib/localization/bg-BG.json +24 -4
  268. package/lib/localization/ca-ES.json +24 -4
  269. package/lib/localization/cs-CZ.json +24 -4
  270. package/lib/localization/da-DK.json +24 -4
  271. package/lib/localization/de-DE.json +24 -4
  272. package/lib/localization/el-GR.json +24 -4
  273. package/lib/localization/en-US.json +30 -7
  274. package/lib/localization/es-ES.json +24 -4
  275. package/lib/localization/et-EE.json +24 -4
  276. package/lib/localization/eu-ES.json +24 -4
  277. package/lib/localization/fi-FI.json +24 -4
  278. package/lib/localization/fr-FR.json +24 -4
  279. package/lib/localization/getAllLocalizedStrings.d.ts +6 -0
  280. package/lib/localization/getAllLocalizedStrings.d.ts.map +1 -0
  281. package/lib/localization/getAllLocalizedStrings.js +1 -1
  282. package/lib/localization/getLocaleString.d.ts +2 -0
  283. package/lib/localization/getLocaleString.d.ts.map +1 -0
  284. package/lib/localization/getLocaleString.js +3 -3
  285. package/lib/localization/getRTLList.d.ts +2 -0
  286. package/lib/localization/getRTLList.d.ts.map +1 -0
  287. package/lib/localization/getRTLList.js +1 -1
  288. package/lib/localization/gl-ES.json +24 -4
  289. package/lib/localization/he-IL.json +24 -4
  290. package/lib/localization/hi-IN.json +24 -4
  291. package/lib/localization/hr-HR.json +24 -4
  292. package/lib/localization/hu-HU.json +24 -4
  293. package/lib/localization/id-ID.json +24 -4
  294. package/lib/localization/it-IT.json +24 -4
  295. package/lib/localization/ja-JP.json +24 -4
  296. package/lib/localization/kk-KZ.json +24 -4
  297. package/lib/localization/ko-KR.json +24 -4
  298. package/lib/localization/lt-LT.json +24 -4
  299. package/lib/localization/lv-LV.json +24 -4
  300. package/lib/localization/mergeLocalizedStrings.d.ts +7 -0
  301. package/lib/localization/mergeLocalizedStrings.d.ts.map +1 -0
  302. package/lib/localization/mergeLocalizedStrings.js +14 -7
  303. package/lib/localization/ms-MY.json +24 -4
  304. package/lib/localization/nb-NO.json +24 -4
  305. package/lib/localization/nl-NL.json +24 -4
  306. package/lib/localization/pl-PL.json +24 -4
  307. package/lib/localization/pt-BR.json +24 -4
  308. package/lib/localization/pt-PT.json +24 -4
  309. package/lib/localization/ro-RO.json +24 -4
  310. package/lib/localization/ru-RU.json +24 -4
  311. package/lib/localization/sk-SK.json +24 -4
  312. package/lib/localization/sl-SI.json +24 -4
  313. package/lib/localization/sr-Cyrl-CS.json +24 -4
  314. package/lib/localization/sr-Latn-CS.json +24 -4
  315. package/lib/localization/sv-SE.json +24 -4
  316. package/lib/localization/th-TH.json +24 -4
  317. package/lib/localization/tr-TR.json +24 -4
  318. package/lib/localization/uk-UA.json +24 -4
  319. package/lib/localization/vi-VN.json +24 -4
  320. package/lib/localization/yue.json +27 -7
  321. package/lib/localization/zh-CN.json +24 -4
  322. package/lib/localization/zh-HK.json +24 -4
  323. package/lib/localization/zh-TW.json +24 -4
  324. package/lib/normalizeStyleOptions.d.ts +3 -0
  325. package/lib/normalizeStyleOptions.d.ts.map +1 -0
  326. package/lib/normalizeStyleOptions.js +85 -5
  327. package/lib/patchStyleOptionsFromDeprecatedProps.js +1 -2
  328. package/lib/providers/ActivityAcknowledgement/ActivityAcknowledgementComposer.d.ts +5 -0
  329. package/lib/providers/ActivityAcknowledgement/ActivityAcknowledgementComposer.d.ts.map +1 -0
  330. package/lib/providers/ActivityAcknowledgement/ActivityAcknowledgementComposer.js +184 -0
  331. package/lib/providers/ActivityAcknowledgement/private/Context.d.ts +13 -0
  332. package/lib/providers/ActivityAcknowledgement/private/Context.d.ts.map +1 -0
  333. package/lib/providers/ActivityAcknowledgement/private/Context.js +13 -0
  334. package/lib/providers/ActivityAcknowledgement/private/types.d.ts +6 -0
  335. package/lib/providers/ActivityAcknowledgement/private/types.d.ts.map +1 -0
  336. package/lib/providers/ActivityAcknowledgement/private/types.js +2 -0
  337. package/lib/providers/ActivityAcknowledgement/private/useContext.d.ts +3 -0
  338. package/lib/providers/ActivityAcknowledgement/private/useContext.d.ts.map +1 -0
  339. package/lib/providers/ActivityAcknowledgement/private/useContext.js +24 -0
  340. package/lib/providers/ActivityAcknowledgement/useActivityKeysByRead.d.ts +5 -0
  341. package/lib/providers/ActivityAcknowledgement/useActivityKeysByRead.d.ts.map +1 -0
  342. package/lib/providers/ActivityAcknowledgement/useActivityKeysByRead.js +18 -0
  343. package/lib/providers/ActivityAcknowledgement/useGetHasAcknowledgedByActivityKey.d.ts +2 -0
  344. package/lib/providers/ActivityAcknowledgement/useGetHasAcknowledgedByActivityKey.d.ts.map +1 -0
  345. package/lib/providers/ActivityAcknowledgement/useGetHasAcknowledgedByActivityKey.js +15 -0
  346. package/lib/providers/ActivityAcknowledgement/useLastAcknowledgedActivityKey.d.ts +2 -0
  347. package/lib/providers/ActivityAcknowledgement/useLastAcknowledgedActivityKey.d.ts.map +1 -0
  348. package/lib/providers/ActivityAcknowledgement/useLastAcknowledgedActivityKey.js +15 -0
  349. package/lib/providers/ActivityAcknowledgement/useLastReadActivityKey.d.ts +2 -0
  350. package/lib/providers/ActivityAcknowledgement/useLastReadActivityKey.d.ts.map +1 -0
  351. package/lib/providers/ActivityAcknowledgement/useLastReadActivityKey.js +15 -0
  352. package/lib/providers/ActivityAcknowledgement/useMarkActivityKeyAsRead.d.ts +2 -0
  353. package/lib/providers/ActivityAcknowledgement/useMarkActivityKeyAsRead.d.ts.map +1 -0
  354. package/lib/providers/ActivityAcknowledgement/useMarkActivityKeyAsRead.js +15 -0
  355. package/lib/providers/ActivityAcknowledgement/useMarkAllAsAcknowledged.d.ts +2 -0
  356. package/lib/providers/ActivityAcknowledgement/useMarkAllAsAcknowledged.d.ts.map +1 -0
  357. package/lib/providers/ActivityAcknowledgement/useMarkAllAsAcknowledged.js +15 -0
  358. package/lib/providers/ActivityKeyer/ActivityKeyerComposer.d.ts +18 -0
  359. package/lib/providers/ActivityKeyer/ActivityKeyerComposer.d.ts.map +1 -0
  360. package/lib/providers/ActivityKeyer/ActivityKeyerComposer.js +153 -0
  361. package/lib/providers/ActivityKeyer/private/Context.d.ts +12 -0
  362. package/lib/providers/ActivityKeyer/private/Context.d.ts.map +1 -0
  363. package/lib/providers/ActivityKeyer/private/Context.js +13 -0
  364. package/lib/providers/ActivityKeyer/private/getActivityId.d.ts +3 -0
  365. package/lib/providers/ActivityKeyer/private/getActivityId.d.ts.map +1 -0
  366. package/lib/providers/ActivityKeyer/private/getActivityId.js +11 -0
  367. package/lib/providers/ActivityKeyer/private/getClientActivityId.d.ts +3 -0
  368. package/lib/providers/ActivityKeyer/private/getClientActivityId.d.ts.map +1 -0
  369. package/lib/providers/ActivityKeyer/private/getClientActivityId.js +13 -0
  370. package/lib/providers/ActivityKeyer/private/uniqueId.d.ts +2 -0
  371. package/lib/providers/ActivityKeyer/private/uniqueId.d.ts.map +1 -0
  372. package/lib/providers/ActivityKeyer/private/uniqueId.js +18 -0
  373. package/lib/providers/ActivityKeyer/private/useContext.d.ts +3 -0
  374. package/lib/providers/ActivityKeyer/private/useContext.d.ts.map +1 -0
  375. package/lib/providers/ActivityKeyer/private/useContext.js +24 -0
  376. package/lib/providers/ActivityKeyer/useActivityKeys.d.ts +2 -0
  377. package/lib/providers/ActivityKeyer/useActivityKeys.d.ts.map +1 -0
  378. package/lib/providers/ActivityKeyer/useActivityKeys.js +15 -0
  379. package/lib/providers/ActivityKeyer/useGetActivityByKey.d.ts +3 -0
  380. package/lib/providers/ActivityKeyer/useGetActivityByKey.d.ts.map +1 -0
  381. package/lib/providers/ActivityKeyer/useGetActivityByKey.js +15 -0
  382. package/lib/providers/ActivityKeyer/useGetKeyByActivity.d.ts +3 -0
  383. package/lib/providers/ActivityKeyer/useGetKeyByActivity.d.ts.map +1 -0
  384. package/lib/providers/ActivityKeyer/useGetKeyByActivity.js +15 -0
  385. package/lib/providers/ActivityKeyer/useGetKeyByActivityId.d.ts +2 -0
  386. package/lib/providers/ActivityKeyer/useGetKeyByActivityId.d.ts.map +1 -0
  387. package/lib/providers/ActivityKeyer/useGetKeyByActivityId.js +15 -0
  388. package/lib/tsconfig.json +3 -1
  389. package/lib/types/ActivityMiddleware.d.ts +25 -0
  390. package/lib/types/ActivityMiddleware.d.ts.map +1 -0
  391. package/lib/types/ActivityMiddleware.js +2 -0
  392. package/lib/types/ActivityStatusMiddleware.d.ts +18 -0
  393. package/lib/types/ActivityStatusMiddleware.d.ts.map +1 -0
  394. package/lib/types/ActivityStatusMiddleware.js +2 -0
  395. package/lib/types/AttachmentForScreenReaderMiddleware.d.ts +14 -0
  396. package/lib/types/AttachmentForScreenReaderMiddleware.d.ts.map +1 -0
  397. package/lib/types/AttachmentForScreenReaderMiddleware.js +2 -0
  398. package/lib/types/AttachmentMiddleware.d.ts +12 -0
  399. package/lib/types/AttachmentMiddleware.d.ts.map +1 -0
  400. package/lib/types/AttachmentMiddleware.js +2 -0
  401. package/lib/types/AvatarMiddleware.d.ts +15 -0
  402. package/lib/types/AvatarMiddleware.d.ts.map +1 -0
  403. package/lib/types/AvatarMiddleware.js +2 -0
  404. package/lib/types/CardActionMiddleware.d.ts +19 -0
  405. package/lib/types/CardActionMiddleware.d.ts.map +1 -0
  406. package/lib/types/CardActionMiddleware.js +2 -0
  407. package/lib/types/ComponentMiddleware.d.ts +31 -0
  408. package/lib/types/ComponentMiddleware.d.ts.map +1 -0
  409. package/lib/types/ComponentMiddleware.js +2 -0
  410. package/lib/types/FunctionMiddleware.d.ts +6 -0
  411. package/lib/types/FunctionMiddleware.d.ts.map +1 -0
  412. package/lib/types/FunctionMiddleware.js +2 -0
  413. package/lib/types/GroupActivitiesMiddleware.d.ts +22 -0
  414. package/lib/types/GroupActivitiesMiddleware.d.ts.map +1 -0
  415. package/lib/types/GroupActivitiesMiddleware.js +2 -0
  416. package/lib/types/LocalizedStrings.d.ts +5 -0
  417. package/lib/types/LocalizedStrings.d.ts.map +1 -0
  418. package/lib/types/LocalizedStrings.js +2 -0
  419. package/lib/types/Notification.d.ts +10 -0
  420. package/lib/types/Notification.d.ts.map +1 -0
  421. package/lib/types/Notification.js +2 -0
  422. package/lib/types/PrecompiledGlobalize.d.ts +13 -0
  423. package/lib/types/PrecompiledGlobalize.d.ts.map +1 -0
  424. package/lib/types/PrecompiledGlobalize.js +2 -0
  425. package/lib/types/ScrollToEndButtonMiddleware.d.ts +30 -0
  426. package/lib/types/ScrollToEndButtonMiddleware.d.ts.map +1 -0
  427. package/lib/types/ScrollToEndButtonMiddleware.js +2 -0
  428. package/lib/types/SendState.d.ts +3 -0
  429. package/lib/types/SendState.d.ts.map +1 -0
  430. package/lib/types/SendState.js +2 -0
  431. package/lib/types/TelemetryMeasurementEvent.d.ts +31 -0
  432. package/lib/types/TelemetryMeasurementEvent.d.ts.map +1 -0
  433. package/lib/types/TelemetryMeasurementEvent.js +2 -0
  434. package/lib/types/ToastMiddleware.d.ts +11 -0
  435. package/lib/types/ToastMiddleware.d.ts.map +1 -0
  436. package/lib/types/ToastMiddleware.js +2 -0
  437. package/lib/types/Typing.d.ts +8 -0
  438. package/lib/types/Typing.d.ts.map +1 -0
  439. package/lib/types/Typing.js +2 -0
  440. package/lib/types/TypingIndicatorMiddleware.d.ts +17 -0
  441. package/lib/types/TypingIndicatorMiddleware.d.ts.map +1 -0
  442. package/lib/types/TypingIndicatorMiddleware.js +2 -0
  443. package/lib/types/WebSpeechPonyfill.d.ts +18 -0
  444. package/lib/types/WebSpeechPonyfill.d.ts.map +1 -0
  445. package/lib/types/WebSpeechPonyfill.js +2 -0
  446. package/lib/types/WebSpeechPonyfillFactory.d.ts +6 -0
  447. package/lib/types/WebSpeechPonyfillFactory.d.ts.map +1 -0
  448. package/lib/types/WebSpeechPonyfillFactory.js +2 -0
  449. package/lib/utils/createCustomEvent.d.ts +4 -0
  450. package/lib/utils/createCustomEvent.d.ts.map +1 -0
  451. package/lib/utils/createCustomEvent.js +9 -3
  452. package/lib/utils/findLastIndex.d.ts +2 -0
  453. package/lib/utils/findLastIndex.d.ts.map +1 -0
  454. package/lib/utils/findLastIndex.js +32 -0
  455. package/lib/utils/findMin.d.ts +7 -0
  456. package/lib/utils/findMin.d.ts.map +1 -0
  457. package/lib/utils/findMin.js +3 -3
  458. package/lib/utils/isObject.js +1 -1
  459. package/lib/utils/mapMap.d.ts +6 -0
  460. package/lib/utils/mapMap.d.ts.map +1 -0
  461. package/lib/utils/mapMap.js +10 -3
  462. package/lib/utils/normalizeLanguage.d.ts +2 -0
  463. package/lib/utils/normalizeLanguage.d.ts.map +1 -0
  464. package/lib/utils/normalizeLanguage.js +1 -1
  465. package/lib/utils/randomId.d.ts +2 -0
  466. package/lib/utils/randomId.d.ts.map +1 -0
  467. package/lib/utils/randomId.js +1 -1
  468. package/lib/utils/warnOnce.js +17 -0
  469. package/package.json +25 -32
  470. package/scripts/createPrecompiledGlobalize.mjs +44 -0
  471. package/src/StyleOptions.ts +332 -15
  472. package/src/defaultStyleOptions.ts +75 -15
  473. package/src/hooks/Composer.tsx +224 -145
  474. package/src/hooks/{index.js → index.ts} +22 -0
  475. package/src/hooks/internal/WebChatAPIContext.ts +68 -3
  476. package/src/hooks/internal/useCreateActivityRendererInternal.ts +46 -0
  477. package/src/hooks/internal/useDebugDeps.js +9 -2
  478. package/src/hooks/internal/usePrevious.ts +11 -0
  479. package/src/hooks/internal/useValueRef.ts +21 -0
  480. package/src/hooks/middleware/applyMiddleware.js +2 -3
  481. package/src/hooks/middleware/concatMiddleware.spec.js +4 -6
  482. package/src/hooks/middleware/concatMiddleware.ts +27 -0
  483. package/src/hooks/middleware/createDefaultCardActionMiddleware.ts +42 -0
  484. package/src/hooks/middleware/{createDefaultGroupActivitiesMiddleware.js → createDefaultGroupActivitiesMiddleware.ts} +20 -12
  485. package/src/hooks/{useActiveTyping.js → useActiveTyping.ts} +13 -9
  486. package/src/hooks/useActivities.ts +7 -0
  487. package/src/hooks/useActivityKeys.ts +3 -0
  488. package/src/hooks/useActivityKeysByRead.ts +3 -0
  489. package/src/hooks/{useAvatarForBot.js → useAvatarForBot.ts} +1 -1
  490. package/src/hooks/{useAvatarForUser.js → useAvatarForUser.ts} +1 -1
  491. package/src/hooks/{useByteFormatter.js → useByteFormatter.ts} +1 -1
  492. package/src/hooks/{useConnectivityStatus.js → useConnectivityStatus.ts} +1 -1
  493. package/src/hooks/{useCreateActivityRenderer.js → useCreateActivityRenderer.ts} +2 -3
  494. package/src/hooks/{useCreateActivityStatusRenderer.js → useCreateActivityStatusRenderer.tsx} +27 -11
  495. package/src/hooks/useCreateAvatarRenderer.ts +39 -0
  496. package/src/hooks/useCreateScrollToEndButtonRenderer.ts +6 -0
  497. package/src/hooks/useDateFormatter.ts +14 -0
  498. package/src/hooks/useDebouncedNotifications.spec.js +2 -0
  499. package/src/hooks/{useDebouncedNotifications.js → useDebouncedNotifications.ts} +10 -2
  500. package/src/hooks/{useDictateInterims.js → useDictateInterims.ts} +1 -1
  501. package/src/hooks/{useDictateState.js → useDictateState.ts} +1 -1
  502. package/src/hooks/{useDirection.js → useDirection.ts} +1 -1
  503. package/src/hooks/{useDisabled.js → useDisabled.ts} +1 -1
  504. package/src/hooks/{useDismissNotification.js → useDismissNotification.ts} +1 -1
  505. package/src/hooks/{useEmitTypingIndicator.js → useEmitTypingIndicator.ts} +1 -1
  506. package/src/hooks/useGetActivityByKey.ts +3 -0
  507. package/src/hooks/useGetHasAcknowledgedByActivityKey.ts +3 -0
  508. package/src/hooks/useGetKeyByActivity.ts +3 -0
  509. package/src/hooks/useGetKeyByActivityId.ts +3 -0
  510. package/src/hooks/useGetSendTimeoutForActivity.ts +20 -0
  511. package/src/hooks/{useGrammars.js → useGrammars.ts} +1 -1
  512. package/src/hooks/useGroupActivities.ts +10 -0
  513. package/src/hooks/{useGroupTimestamp.js → useGroupTimestamp.ts} +1 -1
  514. package/src/hooks/{useLanguage.js → useLanguage.ts} +1 -1
  515. package/src/hooks/useLastAcknowledgedActivityKey.ts +3 -0
  516. package/src/hooks/useLastReadActivityKey.ts +3 -0
  517. package/src/hooks/{useLastTypingAt.js → useLastTypingAt.ts} +2 -1
  518. package/src/hooks/{useLocalize.js → useLocalize.ts} +3 -1
  519. package/src/hooks/{useLocalizeDate.js → useLocalizeDate.ts} +2 -1
  520. package/src/hooks/{useLocalizer.js → useLocalizer.ts} +24 -6
  521. package/src/hooks/{useMarkActivityAsSpoken.js → useMarkActivityAsSpoken.ts} +2 -1
  522. package/src/hooks/useMarkActivityKeyAsRead.ts +3 -0
  523. package/src/hooks/useMarkAllAsAcknowledged.ts +3 -0
  524. package/src/hooks/{useNotifications.js → useNotifications.ts} +2 -1
  525. package/src/hooks/usePerformCardAction.ts +6 -0
  526. package/src/hooks/usePostActivity.ts +8 -0
  527. package/src/hooks/{useReferenceGrammarID.js → useReferenceGrammarID.ts} +1 -1
  528. package/src/hooks/{useRelativeTimeFormatter.js → useRelativeTimeFormatter.ts} +1 -1
  529. package/src/hooks/useRenderActivity.js +12 -10
  530. package/src/hooks/useRenderActivityStatus.js +1 -0
  531. package/src/hooks/useRenderAvatar.js +1 -0
  532. package/src/hooks/{useRenderToast.js → useRenderToast.ts} +2 -1
  533. package/src/hooks/useRenderTypingIndicator.ts +6 -0
  534. package/src/hooks/{useSendBoxValue.js → useSendBoxValue.ts} +1 -1
  535. package/src/hooks/{useSendEvent.js → useSendEvent.ts} +1 -1
  536. package/src/hooks/{useSendFiles.js → useSendFiles.ts} +1 -1
  537. package/src/hooks/useSendMessage.ts +9 -0
  538. package/src/hooks/{useSendMessageBack.js → useSendMessageBack.ts} +1 -1
  539. package/src/hooks/{useSendPostBack.js → useSendPostBack.ts} +1 -1
  540. package/src/hooks/{useSendTimeoutForActivity.js → useSendTimeoutForActivity.ts} +4 -1
  541. package/src/hooks/{useSendTypingIndicator.js → useSendTypingIndicator.ts} +1 -1
  542. package/src/hooks/useSetNotification.ts +6 -0
  543. package/src/hooks/{useShouldSpeakIncomingActivity.js → useShouldSpeakIncomingActivity.ts} +1 -1
  544. package/src/hooks/{useStartDictate.js → useStartDictate.ts} +1 -1
  545. package/src/hooks/{useStopDictate.js → useStopDictate.ts} +1 -1
  546. package/src/hooks/useStyleOptions.ts +6 -0
  547. package/src/hooks/{useSubmitSendBox.js → useSubmitSendBox.ts} +3 -6
  548. package/src/hooks/{useSuggestedActions.js → useSuggestedActions.ts} +5 -1
  549. package/src/hooks/useTimeoutForSend.ts +9 -0
  550. package/src/hooks/{useTrackDimension.js → useTrackDimension.ts} +1 -1
  551. package/src/hooks/{useTrackEvent.js → useTrackEvent.ts} +10 -2
  552. package/src/hooks/{useTrackException.js → useTrackException.ts} +1 -1
  553. package/src/hooks/{useTrackTiming.js → useTrackTiming.ts} +4 -1
  554. package/src/hooks/{useUserID.js → useUserID.ts} +1 -1
  555. package/src/hooks/{useUsername.js → useUsername.ts} +1 -1
  556. package/src/hooks/{useVoiceSelector.js → useVoiceSelector.ts} +4 -1
  557. package/src/hooks/utils/{observableToPromise.js → observableToPromise.ts} +5 -3
  558. package/src/index.ts +51 -0
  559. package/src/localization/Localize.spec.js +2 -0
  560. package/src/localization/{Localize.js → Localize.ts} +15 -8
  561. package/src/localization/ar-SA.json +24 -4
  562. package/src/localization/bg-BG.json +24 -4
  563. package/src/localization/ca-ES.json +24 -4
  564. package/src/localization/cs-CZ.json +24 -4
  565. package/src/localization/da-DK.json +24 -4
  566. package/src/localization/de-DE.json +24 -4
  567. package/src/localization/el-GR.json +24 -4
  568. package/src/localization/en-US.json +30 -7
  569. package/src/localization/es-ES.json +24 -4
  570. package/src/localization/et-EE.json +24 -4
  571. package/src/localization/eu-ES.json +24 -4
  572. package/src/localization/fi-FI.json +24 -4
  573. package/src/localization/fr-FR.json +24 -4
  574. package/src/localization/getAllLocalizedStrings.spec.js +3 -1
  575. package/src/localization/{getAllLocalizedStrings.js → getAllLocalizedStrings.ts} +2 -1
  576. package/src/localization/getLocaleString.spec.js +4 -2
  577. package/src/localization/{getLocaleString.js → getLocaleString.ts} +2 -2
  578. package/src/localization/{getRTLList.js → getRTLList.ts} +1 -1
  579. package/src/localization/gl-ES.json +24 -4
  580. package/src/localization/he-IL.json +24 -4
  581. package/src/localization/hi-IN.json +24 -4
  582. package/src/localization/hr-HR.json +24 -4
  583. package/src/localization/hu-HU.json +24 -4
  584. package/src/localization/id-ID.json +24 -4
  585. package/src/localization/it-IT.json +24 -4
  586. package/src/localization/ja-JP.json +24 -4
  587. package/src/localization/kk-KZ.json +24 -4
  588. package/src/localization/ko-KR.json +24 -4
  589. package/src/localization/lt-LT.json +24 -4
  590. package/src/localization/lv-LV.json +24 -4
  591. package/src/localization/mergeLocalizedStrings.ts +20 -0
  592. package/src/localization/ms-MY.json +24 -4
  593. package/src/localization/nb-NO.json +24 -4
  594. package/src/localization/nl-NL.json +24 -4
  595. package/src/localization/pl-PL.json +24 -4
  596. package/src/localization/pt-BR.json +24 -4
  597. package/src/localization/pt-PT.json +24 -4
  598. package/src/localization/ro-RO.json +24 -4
  599. package/src/localization/ru-RU.json +24 -4
  600. package/src/localization/sk-SK.json +24 -4
  601. package/src/localization/sl-SI.json +24 -4
  602. package/src/localization/sr-Cyrl-CS.json +24 -4
  603. package/src/localization/sr-Latn-CS.json +24 -4
  604. package/src/localization/sv-SE.json +24 -4
  605. package/src/localization/th-TH.json +24 -4
  606. package/src/localization/tr-TR.json +24 -4
  607. package/src/localization/uk-UA.json +24 -4
  608. package/src/localization/vi-VN.json +24 -4
  609. package/src/localization/yue.json +27 -7
  610. package/src/localization/zh-CN.json +24 -4
  611. package/src/localization/zh-HK.json +24 -4
  612. package/src/localization/zh-TW.json +24 -4
  613. package/src/normalizeStyleOptions.ts +113 -2
  614. package/src/patchStyleOptionsFromDeprecatedProps.js +0 -2
  615. package/src/providers/ActivityAcknowledgement/ActivityAcknowledgementComposer.tsx +180 -0
  616. package/src/providers/ActivityAcknowledgement/private/Context.ts +18 -0
  617. package/src/providers/ActivityAcknowledgement/private/types.ts +6 -0
  618. package/src/providers/ActivityAcknowledgement/private/useContext.ts +19 -0
  619. package/src/providers/ActivityAcknowledgement/useActivityKeysByRead.tsx +8 -0
  620. package/src/providers/ActivityAcknowledgement/useGetHasAcknowledgedByActivityKey.ts +5 -0
  621. package/src/providers/ActivityAcknowledgement/useLastAcknowledgedActivityKey.ts +5 -0
  622. package/src/providers/ActivityAcknowledgement/useLastReadActivityKey.ts +5 -0
  623. package/src/providers/ActivityAcknowledgement/useMarkActivityKeyAsRead.ts +5 -0
  624. package/src/providers/ActivityAcknowledgement/useMarkAllAsAcknowledged.ts +5 -0
  625. package/src/providers/ActivityKeyer/ActivityKeyerComposer.tsx +151 -0
  626. package/src/providers/ActivityKeyer/private/Context.ts +14 -0
  627. package/src/providers/ActivityKeyer/private/getActivityId.ts +5 -0
  628. package/src/providers/ActivityKeyer/private/getClientActivityId.ts +5 -0
  629. package/src/providers/ActivityKeyer/private/uniqueId.ts +8 -0
  630. package/src/providers/ActivityKeyer/private/useContext.ts +15 -0
  631. package/src/providers/ActivityKeyer/useActivityKeys.ts +5 -0
  632. package/src/providers/ActivityKeyer/useGetActivityByKey.ts +7 -0
  633. package/src/providers/ActivityKeyer/useGetKeyByActivity.ts +7 -0
  634. package/src/providers/ActivityKeyer/useGetKeyByActivityId.ts +5 -0
  635. package/src/tsconfig.json +3 -1
  636. package/src/types/ActivityMiddleware.ts +38 -0
  637. package/src/types/ActivityStatusMiddleware.ts +28 -0
  638. package/src/types/AttachmentForScreenReaderMiddleware.ts +24 -0
  639. package/src/types/AttachmentMiddleware.ts +16 -0
  640. package/src/types/AvatarMiddleware.ts +20 -0
  641. package/src/types/CardActionMiddleware.ts +21 -0
  642. package/src/types/ComponentMiddleware.ts +42 -0
  643. package/src/types/FunctionMiddleware.ts +13 -0
  644. package/src/types/GroupActivitiesMiddleware.ts +24 -0
  645. package/src/types/LocalizedStrings.ts +5 -0
  646. package/src/types/Notification.ts +10 -0
  647. package/src/types/PrecompiledGlobalize.ts +9 -0
  648. package/src/types/ScrollToEndButtonMiddleware.ts +34 -0
  649. package/src/types/SendState.ts +3 -0
  650. package/src/types/TelemetryMeasurementEvent.ts +44 -0
  651. package/src/types/ToastMiddleware.ts +16 -0
  652. package/src/types/Typing.ts +8 -0
  653. package/src/types/TypingIndicatorMiddleware.ts +18 -0
  654. package/src/types/WebSpeechPonyfill.ts +24 -0
  655. package/src/types/WebSpeechPonyfillFactory.ts +5 -0
  656. package/src/utils/createCustomEvent.ts +28 -0
  657. package/src/utils/findLastIndex.spec.js +31 -0
  658. package/src/utils/findLastIndex.ts +11 -0
  659. package/src/utils/findMin.spec.js +2 -0
  660. package/src/utils/{findMin.js → findMin.ts} +3 -3
  661. package/src/utils/mapMap.spec.js +2 -0
  662. package/src/utils/mapMap.ts +16 -0
  663. package/src/utils/{normalizeLanguage.js → normalizeLanguage.ts} +1 -1
  664. package/src/utils/{randomId.js → randomId.ts} +1 -1
  665. package/src/utils/warnOnce.ts +10 -0
  666. package/.eslintignore +0 -9
  667. package/lib/hooks/utils/singleToArray.js +0 -11
  668. package/scripts/createPrecompiledGlobalize.js +0 -41
  669. package/src/hooks/internal/useCreateActivityRendererInternal.js +0 -41
  670. package/src/hooks/middleware/concatMiddleware.js +0 -19
  671. package/src/hooks/middleware/createDefaultCardActionMiddleware.js +0 -36
  672. package/src/hooks/useActivities.js +0 -5
  673. package/src/hooks/useCreateAvatarRenderer.js +0 -32
  674. package/src/hooks/useDateFormatter.js +0 -13
  675. package/src/hooks/useGetSendTimeoutForActivity.js +0 -18
  676. package/src/hooks/useGroupActivities.js +0 -5
  677. package/src/hooks/usePerformCardAction.js +0 -5
  678. package/src/hooks/usePostActivity.js +0 -5
  679. package/src/hooks/useRenderTypingIndicator.js +0 -5
  680. package/src/hooks/useSendMessage.js +0 -5
  681. package/src/hooks/useSetNotification.js +0 -5
  682. package/src/hooks/useStyleOptions.js +0 -5
  683. package/src/hooks/useTimeoutForSend.js +0 -7
  684. package/src/hooks/utils/singleToArray.js +0 -3
  685. package/src/index.js +0 -10
  686. package/src/index.tsx +0 -10
  687. package/src/localization/mergeLocalizedStrings.js +0 -10
  688. package/src/utils/createCustomEvent.js +0 -17
  689. package/src/utils/mapMap.js +0 -7
@@ -1,8 +1,73 @@
1
1
  import { createContext } from 'react';
2
+ import { DirectLineActivity, DirectLineJSBotConnection } from 'botframework-webchat-core';
2
3
 
3
- const context = createContext<any>({
4
- sendFocusRef: null
5
- });
4
+ import { AttachmentForScreenReaderComponentFactory } from '../../types/AttachmentForScreenReaderMiddleware';
5
+ import { AvatarComponentFactory } from '../../types/AvatarMiddleware';
6
+ import { GroupActivities } from '../../types/GroupActivitiesMiddleware';
7
+ import { LegacyActivityRenderer } from '../../types/ActivityMiddleware';
8
+ import { Observable } from 'redux';
9
+ import { PerformCardAction } from '../../types/CardActionMiddleware';
10
+ import { RenderActivityStatus } from '../../types/ActivityStatusMiddleware';
11
+ import { RenderAttachment } from '../../types/AttachmentMiddleware';
12
+ import { RenderToast } from '../../types/ToastMiddleware';
13
+ import { ScrollToEndButtonComponentFactory } from '../../types/ScrollToEndButtonMiddleware';
14
+ import { StrictStyleOptions } from '../../StyleOptions';
15
+ import LocalizedStrings from '../../types/LocalizedStrings';
16
+ import PrecompiledGlobalize from '../../types/PrecompiledGlobalize';
17
+ import TelemetryMeasurementEvent from '../../types/TelemetryMeasurementEvent';
18
+
19
+ type WebChatAPIContext = {
20
+ activityRenderer?: LegacyActivityRenderer;
21
+ activityStatusRenderer?: RenderActivityStatus;
22
+ attachmentForScreenReaderRenderer?: AttachmentForScreenReaderComponentFactory;
23
+ attachmentRenderer?: RenderAttachment;
24
+ avatarRenderer?: AvatarComponentFactory;
25
+ clearSuggestedActions?: () => void;
26
+ dir?: string;
27
+ directLine?: DirectLineJSBotConnection;
28
+ disabled?: boolean;
29
+ dismissNotification?: (id: string) => void;
30
+ downscaleImageToDataURL?: (blob: Blob, maxWidth: number, maxHeight: number, type: string, quality: number) => string;
31
+ emitTypingIndicator?: () => void;
32
+ grammars?: any;
33
+ groupActivities?: GroupActivities;
34
+ internalErrorBoxClass?: React.Component | Function;
35
+ language?: string;
36
+ localizedGlobalizeState?: PrecompiledGlobalize[];
37
+ localizedStrings?: { [language: string]: LocalizedStrings };
38
+ markActivity?: ({ id: string }, name: string, value?: any) => void;
39
+ onCardAction?: PerformCardAction;
40
+ onTelemetry?: (event: TelemetryMeasurementEvent) => void;
41
+ postActivity?: (activity: DirectLineActivity) => Observable<string>;
42
+ renderMarkdown?: (markdown: string, { markdownRespectCRLF: boolean }, { externalLinkAlt: string }) => string;
43
+ scrollToEndButtonRenderer?: ScrollToEndButtonComponentFactory;
44
+ selectVoice?: (voices: typeof window.SpeechSynthesisVoice[], activity: DirectLineActivity) => void;
45
+ sendEvent?: (name: string, value: any) => void;
46
+ sendFiles?: (files: File[]) => void;
47
+ sendMessage?: (text: string, method?: string, { channelData }?: { channelData?: any }) => void;
48
+ sendMessageBack?: (value: any, text?: string, displayText?: string) => void;
49
+ sendPostBack?: (value?: any) => void;
50
+ sendTypingIndicator?: boolean;
51
+ setDictateInterims?: (interims: string[]) => void;
52
+ setDictateState?: (dictateState: number) => void;
53
+ setNotification?: (notification: Notification) => void;
54
+ setSendBox?: (value: string) => void;
55
+ setSendTimeout?: (timeout: number) => void;
56
+ startDictate?: () => void;
57
+ startSpeakingActivity?: () => void;
58
+ stopDictate?: () => void;
59
+ stopSpeakingActivity?: () => void;
60
+ styleOptions?: StrictStyleOptions;
61
+ submitSendBox?: (method?: string, { channelData }?: { channelData: any }) => void;
62
+ telemetryDimensionsRef?: React.Ref<any>;
63
+ toastRenderer?: RenderToast;
64
+ trackDimension?: (name: string, data: any) => void;
65
+ typingIndicatorRenderer?: any; // TODO
66
+ userID?: string;
67
+ username?: string;
68
+ };
69
+
70
+ const context = createContext<WebChatAPIContext>(undefined);
6
71
 
7
72
  context.displayName = 'WebChatAPIContext';
8
73
 
@@ -0,0 +1,46 @@
1
+ import { isValidElement, useMemo } from 'react';
2
+
3
+ import { ActivityComponentFactory } from '../../types/ActivityMiddleware';
4
+ import { RenderAttachment } from '../../types/AttachmentMiddleware';
5
+ import useRenderAttachment from '../useRenderAttachment';
6
+ import useWebChatAPIContext from './useWebChatAPIContext';
7
+
8
+ export default function useCreateActivityRendererInternal(
9
+ renderAttachmentOverride?: RenderAttachment
10
+ ): ActivityComponentFactory {
11
+ const { activityRenderer: createActivityRenderer } = useWebChatAPIContext();
12
+ const defaultRenderAttachment = useRenderAttachment();
13
+
14
+ const renderAttachment: RenderAttachment = renderAttachmentOverride || defaultRenderAttachment;
15
+
16
+ return useMemo(
17
+ () =>
18
+ (...createActivityRendererOptions) => {
19
+ const renderActivity = createActivityRenderer(...createActivityRendererOptions);
20
+
21
+ if (!renderActivity) {
22
+ return false;
23
+ }
24
+
25
+ return renderActivityOptions => {
26
+ if (isValidElement(renderActivity)) {
27
+ return renderActivity;
28
+ }
29
+
30
+ const activityElement = renderActivity(
31
+ (...renderAttachmentArgs) => renderAttachment(...renderAttachmentArgs),
32
+ renderActivityOptions
33
+ );
34
+
35
+ // "activityElement" cannot be false. If the middleware want to hide the "activityElement", it should return "false" when we call createActivityRenderer().
36
+ activityElement ||
37
+ console.warn(
38
+ 'botframework-webchat: To hide an activity, the activity renderer should return false. It should not return a function that will return false when called.'
39
+ );
40
+
41
+ return activityElement;
42
+ };
43
+ },
44
+ [createActivityRenderer, renderAttachment]
45
+ );
46
+ }
@@ -1,5 +1,6 @@
1
1
  /* eslint no-console: "off" */
2
2
 
3
+ import { isForbiddenPropertyNames } from 'botframework-webchat-core';
3
4
  import { useRef } from 'react';
4
5
 
5
6
  export default function useDebugDeps(depsMap, name) {
@@ -7,13 +8,19 @@ export default function useDebugDeps(depsMap, name) {
7
8
 
8
9
  const { current: lastDepsMap } = lastDepsMapRef;
9
10
  const keys = new Set([...Object.keys(depsMap), ...Object.keys(lastDepsMap)]);
10
- const keysChanged = Array.from(keys).filter(key => !Object.is(depsMap[key], lastDepsMap[key]));
11
+ const keysChanged = Array.from(keys).filter(
12
+ // Mitigation through denylisting.
13
+ // eslint-disable-next-line security/detect-object-injection
14
+ key => !isForbiddenPropertyNames(key) && !Object.is(depsMap[key], lastDepsMap[key])
15
+ );
11
16
 
12
17
  if (keysChanged.length) {
13
18
  console.groupCollapsed(`Changes found in ${name}`);
14
19
 
15
20
  keysChanged.forEach(key => {
16
- console.log(key, { from: lastDepsMap[key], to: depsMap[key] });
21
+ // Mitigation through denylisting.
22
+ // eslint-disable-next-line security/detect-object-injection
23
+ isForbiddenPropertyNames(key) || console.log(key, { from: lastDepsMap[key], to: depsMap[key] });
17
24
  });
18
25
 
19
26
  console.groupEnd();
@@ -0,0 +1,11 @@
1
+ import { useEffect, useRef } from 'react';
2
+
3
+ export default function usePrevious<T>(value: T): T {
4
+ const ref = useRef<T>();
5
+
6
+ useEffect(() => {
7
+ ref.current = value;
8
+ });
9
+
10
+ return ref.current;
11
+ }
@@ -0,0 +1,21 @@
1
+ import { RefObject, useMemo, useRef } from 'react';
2
+
3
+ export default function useValueRef<T>(value: T): RefObject<T> {
4
+ const ref = useRef<T>();
5
+ const readOnlyRef = useMemo(
6
+ () =>
7
+ Object.create(
8
+ {},
9
+ {
10
+ current: {
11
+ get: () => ref.current
12
+ }
13
+ }
14
+ ),
15
+ []
16
+ );
17
+
18
+ ref.current = value;
19
+
20
+ return readOnlyRef;
21
+ }
@@ -1,7 +1,6 @@
1
1
  import React, { isValidElement } from 'react';
2
-
3
- import concatMiddleware from './concatMiddleware';
4
2
  import ErrorBox from '../internal/ErrorBox';
3
+ import concatMiddleware from './concatMiddleware';
5
4
  import UserlandBoundary from './UserlandBoundary';
6
5
 
7
6
  export default function applyMiddleware(type, ...middleware) {
@@ -35,7 +34,7 @@ export function forLegacyRenderer(type, ...middleware) {
35
34
  *
36
35
  * @param {string} type Required. String equivalent of type of container to be rendered.
37
36
  * @param { strict = false } - Used to enforce new middleware format which cooperates with new activity grouping.
38
- * @see See {@link https://github.com/microsoft/BotFramework-WebChat/blob/master/CHANGELOG.md#4100---2020-08-18} and {@link https://github.com/microsoft/BotFramework-WebChat/pull/3365} for middleware breaking changes.
37
+ * @see See {@link https://github.com/microsoft/BotFramework-WebChat/blob/main/CHANGELOG.md#4100---2020-08-18} and {@link https://github.com/microsoft/BotFramework-WebChat/pull/3365} for middleware breaking changes.
39
38
  * @param {middleware[]} middleware list of middleware to be applied.
40
39
  * 'createRendererArgs' is "what to render"; for example, an activity.
41
40
  * @returns Returns a function if there is a renderer *committed* to render OR returns false if nothing should be rendered.
@@ -1,3 +1,5 @@
1
+ /* eslint no-magic-numbers: "off" */
2
+
1
3
  import concatMiddleware from './concatMiddleware';
2
4
 
3
5
  describe('two middleware concatenated and ran', () => {
@@ -26,9 +28,7 @@ describe('two middleware concatenated and ran', () => {
26
28
  });
27
29
 
28
30
  test('by a single upstream middleware', () => {
29
- const combine = () => next => value => {
30
- return next(value) + next(value + 1);
31
- };
31
+ const combine = () => next => value => next(value) + next(value + 1);
32
32
 
33
33
  const middleware = concatMiddleware(combine, oddMultiplyByTen, evenMultiplyByHundred);
34
34
  const work = middleware()(value => value);
@@ -38,9 +38,7 @@ describe('two middleware concatenated and ran', () => {
38
38
  });
39
39
 
40
40
  test('one middleware ran twice by a single upstream middleware', () => {
41
- const combine = () => next => value => {
42
- return next(value) + next(value + 1);
43
- };
41
+ const combine = () => next => value => next(value) + next(value + 1);
44
42
 
45
43
  const oddMultiplyByTenAndEvenMultiplyByHundred = () => () => value => {
46
44
  if (value % 2) {
@@ -0,0 +1,27 @@
1
+ type Work<T> = (...args: any[]) => T;
2
+ type Enhancer<T> = (next: Work<T>) => Work<T>;
3
+ type Middleware<Setup, Result> = (setup: Setup) => Enhancer<Result>;
4
+
5
+ export default function concatMiddleware<Setup, Result>(
6
+ ...middleware: Middleware<Setup, Result>[]
7
+ ): Middleware<Setup, Result> {
8
+ return setupArgs => {
9
+ const setup = middleware.reduce(
10
+ (setup, middleware) => (middleware ? [...setup, middleware(setupArgs)] : setup),
11
+ []
12
+ );
13
+
14
+ return last => {
15
+ const stack = setup.slice();
16
+ const work =
17
+ (index: number) =>
18
+ (...runArgs) => {
19
+ const next = stack[+index];
20
+
21
+ return (next ? next(work(index + 1)) : last)(...runArgs);
22
+ };
23
+
24
+ return work(0);
25
+ };
26
+ };
27
+ }
@@ -0,0 +1,42 @@
1
+ import { sendMessage, sendMessageBack, sendPostBack } from 'botframework-webchat-core';
2
+
3
+ import CardActionMiddleware from '../../types/CardActionMiddleware';
4
+
5
+ export default function createDefaultCardActionMiddleware(): CardActionMiddleware {
6
+ return ({ dispatch }) =>
7
+ next =>
8
+ (...args) => {
9
+ const [
10
+ {
11
+ cardAction,
12
+ cardAction: { value }
13
+ }
14
+ ] = args;
15
+
16
+ // We cannot use destructured "type" here because TypeScript don't recognize "messageBack" is "MessageBackCardAction".
17
+ switch (cardAction.type) {
18
+ case 'imBack':
19
+ if (typeof value === 'string') {
20
+ // TODO: [P4] Instead of calling dispatch, we should move to dispatchers instead for completeness
21
+ dispatch(sendMessage(value, 'imBack'));
22
+ } else {
23
+ throw new Error('cannot send "imBack" with a non-string value');
24
+ }
25
+
26
+ break;
27
+
28
+ case 'messageBack':
29
+ dispatch(sendMessageBack(value, cardAction.text, cardAction.displayText));
30
+
31
+ break;
32
+
33
+ case 'postBack':
34
+ dispatch(sendPostBack(value));
35
+
36
+ break;
37
+
38
+ default:
39
+ return next(...args);
40
+ }
41
+ };
42
+ }
@@ -1,13 +1,15 @@
1
- import { Constants } from 'botframework-webchat-core';
1
+ import { Constants, DirectLineActivity } from 'botframework-webchat-core';
2
+
3
+ import GroupActivitiesMiddleware from '../../types/GroupActivitiesMiddleware';
2
4
 
3
5
  const {
4
6
  ActivityClientState: { SENT }
5
7
  } = Constants;
6
8
 
7
- function bin(items, grouping) {
8
- let lastBin;
9
- const bins = [];
10
- let lastItem;
9
+ function bin<T>(items: T[], grouping: (last: T, current: T) => boolean): T[][] {
10
+ let lastBin: T[];
11
+ const bins: T[][] = [];
12
+ let lastItem: T;
11
13
 
12
14
  items.forEach(item => {
13
15
  if (lastItem && grouping(lastItem, item)) {
@@ -23,11 +25,15 @@ function bin(items, grouping) {
23
25
  return bins;
24
26
  }
25
27
 
26
- function sending(activity) {
28
+ function sending(activity: DirectLineActivity): boolean {
27
29
  return activity.from.role === 'user' && activity.channelData && activity.channelData.state !== SENT;
28
30
  }
29
31
 
30
- function shouldGroupTimestamp(activityX, activityY, groupTimestamp) {
32
+ function shouldGroupTimestamp(
33
+ activityX: DirectLineActivity,
34
+ activityY: DirectLineActivity,
35
+ groupTimestamp: boolean | number
36
+ ): boolean {
31
37
  if (groupTimestamp === false) {
32
38
  // Hide timestamp for all activities.
33
39
  return true;
@@ -47,9 +53,11 @@ function shouldGroupTimestamp(activityX, activityY, groupTimestamp) {
47
53
  return false;
48
54
  }
49
55
 
50
- export default function createDefaultGroupActivityMiddleware({ groupTimestamp }) {
51
- return () => () => ({ activities }) => ({
52
- sender: bin(activities, (x, y) => x.from.role === y.from.role),
53
- status: bin(activities, (x, y) => shouldGroupTimestamp(x, y, groupTimestamp))
54
- });
56
+ export default function createDefaultGroupActivityMiddleware({ groupTimestamp }): GroupActivitiesMiddleware {
57
+ return () =>
58
+ () =>
59
+ ({ activities }) => ({
60
+ sender: bin(activities, (x, y) => x.from.role === y.from.role),
61
+ status: bin(activities, (x, y) => shouldGroupTimestamp(x, y, groupTimestamp))
62
+ });
55
63
  }
@@ -1,29 +1,33 @@
1
1
  import { useEffect } from 'react';
2
2
 
3
3
  import { useSelector } from './internal/WebChatReduxContext';
4
+ import Typing from '../types/Typing';
4
5
  import useForceRender from './internal/useForceRender';
5
6
  import useStyleOptions from './useStyleOptions';
6
7
 
7
- function useActiveTyping(expireAfter) {
8
+ function useActiveTyping(expireAfter?: number): [{ [userId: string]: Typing }] {
8
9
  const now = Date.now();
9
10
 
10
11
  const [{ typingAnimationDuration }] = useStyleOptions();
11
12
  const forceRender = useForceRender();
12
- const typing = useSelector(({ typing }) => typing);
13
+ const typing: { [userId: string]: { at: number; name: string; role: string } } = useSelector(({ typing }) => typing);
13
14
 
14
15
  if (typeof expireAfter !== 'number') {
15
16
  expireAfter = typingAnimationDuration;
16
17
  }
17
18
 
18
- const activeTyping = Object.entries(typing).reduce((activeTyping, [id, { at, name, role }]) => {
19
- const until = at + expireAfter;
19
+ const activeTyping: { [userId: string]: Typing } = Object.entries(typing).reduce(
20
+ (activeTyping, [id, { at, name, role }]) => {
21
+ const until = at + expireAfter;
20
22
 
21
- if (until > now) {
22
- return { ...activeTyping, [id]: { at, expireAt: until, name, role } };
23
- }
23
+ if (until > now) {
24
+ return { ...activeTyping, [id]: { at, expireAt: until, name, role } };
25
+ }
24
26
 
25
- return activeTyping;
26
- }, {});
27
+ return activeTyping;
28
+ },
29
+ {}
30
+ );
27
31
 
28
32
  const earliestExpireAt = Math.min(...Object.values(activeTyping).map(({ expireAt }) => expireAt));
29
33
  const timeToRender = earliestExpireAt && earliestExpireAt - now;
@@ -0,0 +1,7 @@
1
+ import { DirectLineActivity } from 'botframework-webchat-core';
2
+
3
+ import { useSelector } from './internal/WebChatReduxContext';
4
+
5
+ export default function useActivities(): [DirectLineActivity[]] {
6
+ return [useSelector(({ activities }) => activities)];
7
+ }
@@ -0,0 +1,3 @@
1
+ import useActivityKeys from '../providers/ActivityKeyer/useActivityKeys';
2
+
3
+ export default useActivityKeys;
@@ -0,0 +1,3 @@
1
+ import useActivityKeysByRead from '../providers/ActivityAcknowledgement/useActivityKeysByRead';
2
+
3
+ export default useActivityKeysByRead;
@@ -1,6 +1,6 @@
1
1
  import useStyleOptions from './useStyleOptions';
2
2
 
3
- export default function useAvatarForBot() {
3
+ export default function useAvatarForBot(): [{ image: string; initials: string }] {
4
4
  const [{ botAvatarImage: image, botAvatarInitials: initials }] = useStyleOptions();
5
5
 
6
6
  return [
@@ -1,6 +1,6 @@
1
1
  import useStyleOptions from './useStyleOptions';
2
2
 
3
- export default function useAvatarForUser() {
3
+ export default function useAvatarForUser(): [{ image: string; initials: string }] {
4
4
  const [{ userAvatarImage: image, userAvatarInitials: initials }] = useStyleOptions();
5
5
 
6
6
  return [
@@ -15,7 +15,7 @@ const SHORT_FORM = {
15
15
  form: 'short'
16
16
  };
17
17
 
18
- export default function useByteFormatter() {
18
+ export default function useByteFormatter(): (bytes: number) => string {
19
19
  const [globalize] = useLocalizedGlobalize();
20
20
 
21
21
  return useMemo(() => {
@@ -1,5 +1,5 @@
1
1
  import { useSelector } from './internal/WebChatReduxContext';
2
2
 
3
- export default function useConnectivityStatus() {
3
+ export default function useConnectivityStatus(): [string] {
4
4
  return [useSelector(({ connectivityStatus }) => connectivityStatus)];
5
5
  }
@@ -1,9 +1,8 @@
1
- /* eslint react/prop-types: "off"*/
2
-
1
+ import { ActivityComponentFactory } from '../types/ActivityMiddleware';
3
2
  import useCreateActivityRendererInternal from './internal/useCreateActivityRendererInternal';
4
3
 
5
4
  // The newer useCreateActivityRenderer() hook does not support override renderAttachment().
6
5
  // Only the deprecated useRenderActivity() hook support overriding renderAttachment().
7
- export default function useCreateActivityRenderer() {
6
+ export default function useCreateActivityRenderer(): ActivityComponentFactory {
8
7
  return useCreateActivityRendererInternal();
9
8
  }
@@ -1,8 +1,10 @@
1
- /* eslint react/prop-types: "off"*/
1
+ /* eslint react/prop-types: "off" */
2
+ /* eslint react/require-default-props: "off" */
2
3
 
3
- import { Constants } from 'botframework-webchat-core';
4
- import React, { useMemo } from 'react';
4
+ import { Constants, DirectLineActivity } from 'botframework-webchat-core';
5
+ import React, { ReactNode, useMemo } from 'react';
5
6
 
7
+ import SendState from '../types/SendState';
6
8
  import useGetSendTimeoutForActivity from './useGetSendTimeoutForActivity';
7
9
  import useTimePassed from './internal/useTimePassed';
8
10
  import useWebChatAPIContext from './internal/useWebChatAPIContext';
@@ -20,6 +22,14 @@ const ActivityStatusContainer = ({ activity, hideTimestamp, nextVisibleActivity
20
22
  const {
21
23
  channelData: { clientTimestamp = 0, state } = {},
22
24
  from: { role }
25
+ }: {
26
+ channelData: {
27
+ clientTimestamp?: number;
28
+ state?: SendState;
29
+ };
30
+ from: {
31
+ role: string;
32
+ };
23
33
  } = activity;
24
34
 
25
35
  const activitySent = state !== SENDING && state !== SEND_FAILED;
@@ -43,15 +53,21 @@ const ActivityStatusContainer = ({ activity, hideTimestamp, nextVisibleActivity
43
53
  );
44
54
  };
45
55
 
46
- export default function useCreateActivityStatusRenderer() {
56
+ export default function useCreateActivityStatusRenderer(): (renderOptions: {
57
+ activity: DirectLineActivity;
58
+ nextVisibleActivity: DirectLineActivity;
59
+ }) => (props: { hideTimestamp?: boolean }) => ReactNode {
47
60
  return useMemo(
48
- () => ({ activity, nextVisibleActivity }) => ({ hideTimestamp } = {}) => (
49
- <ActivityStatusContainer
50
- activity={activity}
51
- hideTimestamp={hideTimestamp}
52
- nextVisibleActivity={nextVisibleActivity}
53
- />
54
- ),
61
+ () =>
62
+ ({ activity, nextVisibleActivity }: { activity: DirectLineActivity; nextVisibleActivity: DirectLineActivity }) =>
63
+ ({ hideTimestamp }: { hideTimestamp?: boolean } = {}) =>
64
+ (
65
+ <ActivityStatusContainer
66
+ activity={activity}
67
+ hideTimestamp={hideTimestamp}
68
+ nextVisibleActivity={nextVisibleActivity}
69
+ />
70
+ ),
55
71
  []
56
72
  );
57
73
  }
@@ -0,0 +1,39 @@
1
+ import { DirectLineActivity } from 'botframework-webchat-core';
2
+ import { useMemo } from 'react';
3
+
4
+ import { AvatarComponentFactory } from '../types/AvatarMiddleware';
5
+ import useStyleOptions from './useStyleOptions';
6
+ import useWebChatAPIContext from './internal/useWebChatAPIContext';
7
+
8
+ export default function useCreateAvatarRenderer(): ({
9
+ activity
10
+ }: {
11
+ activity: DirectLineActivity;
12
+ }) => AvatarComponentFactory {
13
+ const [styleOptions] = useStyleOptions();
14
+ const { avatarRenderer } = useWebChatAPIContext();
15
+
16
+ return useMemo(
17
+ () =>
18
+ ({ activity }) => {
19
+ const { from: { role } = {} }: { from?: { role?: string } } = activity;
20
+
21
+ const result = avatarRenderer({
22
+ activity,
23
+ fromUser: role === 'user',
24
+ styleOptions
25
+ });
26
+
27
+ if (result !== false && typeof result !== 'function') {
28
+ console.warn(
29
+ 'botframework-webchat: avatarMiddleware should return a function to render the avatar, or return false if avatar should be hidden. Please refer to HOOKS.md for details.'
30
+ );
31
+
32
+ return () => result;
33
+ }
34
+
35
+ return result;
36
+ },
37
+ [avatarRenderer, styleOptions]
38
+ );
39
+ }
@@ -0,0 +1,6 @@
1
+ import { ScrollToEndButtonComponentFactory } from '../types/ScrollToEndButtonMiddleware';
2
+ import useWebChatAPIContext from './internal/useWebChatAPIContext';
3
+
4
+ export default function useCreateScrollToEndButtonRenderer(): ScrollToEndButtonComponentFactory {
5
+ return useWebChatAPIContext().scrollToEndButtonRenderer;
6
+ }
@@ -0,0 +1,14 @@
1
+ import { useMemo } from 'react';
2
+
3
+ import useLocalizedGlobalize from './internal/useLocalizedGlobalize';
4
+
5
+ export default function useDateFormatter(): (date: number | Date) => string {
6
+ const [globalize] = useLocalizedGlobalize();
7
+
8
+ const formatDate = useMemo(
9
+ () => date => globalize.dateFormatter({ skeleton: 'MMMMdhm' })(new Date(date)),
10
+ [globalize]
11
+ );
12
+
13
+ return formatDate;
14
+ }
@@ -1,3 +1,5 @@
1
+ /* eslint no-magic-numbers: "off" */
2
+
1
3
  import { getEarliestUpdateNotBefore } from './useDebouncedNotifications';
2
4
 
3
5
  describe('getEarliestUpdateNotBefore', () => {
@@ -2,12 +2,20 @@ import { useRef } from 'react';
2
2
  import updateIn from 'simple-update-in';
3
3
 
4
4
  import findMin from '../utils/findMin';
5
+ import Notification from '../types/Notification';
5
6
  import useForceRender from './internal/useForceRender';
6
7
  import useNotifications from './useNotifications';
7
8
  import useStyleOptions from './useStyleOptions';
8
9
  import useTimer from './internal/useTimer';
9
10
 
10
- function getEarliestUpdateNotBefore(notificationMap) {
11
+ type DebouncedNotification = Notification & {
12
+ outOfDate: boolean;
13
+ updateNotBefore: number;
14
+ };
15
+
16
+ type DebouncedNotifications = { [id: string]: DebouncedNotification };
17
+
18
+ function getEarliestUpdateNotBefore(notificationMap: DebouncedNotifications) {
11
19
  return findMin(
12
20
  Object.values(notificationMap)
13
21
  .filter(({ outOfDate }) => outOfDate)
@@ -15,7 +23,7 @@ function getEarliestUpdateNotBefore(notificationMap) {
15
23
  );
16
24
  }
17
25
 
18
- function useDebouncedNotifications() {
26
+ function useDebouncedNotifications(): [DebouncedNotifications] {
19
27
  const now = Date.now();
20
28
 
21
29
  const [{ notificationDebounceTimeout }] = useStyleOptions();
@@ -1,6 +1,6 @@
1
1
  import { useSelector } from './internal/WebChatReduxContext';
2
2
  import useWebChatAPIContext from './internal/useWebChatAPIContext';
3
3
 
4
- export default function useDictateInterims() {
4
+ export default function useDictateInterims(): [string[], (interims: string[]) => void] {
5
5
  return [useSelector(({ dictateInterims }) => dictateInterims) || [], useWebChatAPIContext().setDictateInterims];
6
6
  }
@@ -1,6 +1,6 @@
1
1
  import { useSelector } from './internal/WebChatReduxContext';
2
2
 
3
3
  // TODO: [P3] We should update this code to use core/src/selectors/dictateState.js
4
- export default function useDictateState() {
4
+ export default function useDictateState(): [number] {
5
5
  return [useSelector(({ dictateState }) => dictateState)];
6
6
  }