stream-chat-react 9.5.0 → 10.0.0-theming-v2.3

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 (526) hide show
  1. package/dist/browser.full-bundle.js +14484 -9186
  2. package/dist/browser.full-bundle.js.map +1 -1
  3. package/dist/browser.full-bundle.min.js +20 -5
  4. package/dist/browser.full-bundle.min.js.map +1 -1
  5. package/dist/components/Attachment/Attachment.d.ts +1 -0
  6. package/dist/components/Attachment/Attachment.d.ts.map +1 -1
  7. package/dist/components/Attachment/Attachment.js +80 -35
  8. package/dist/components/Attachment/AttachmentActions.d.ts.map +1 -1
  9. package/dist/components/Attachment/AttachmentActions.js +2 -6
  10. package/dist/components/Attachment/AttachmentContainer.d.ts +12 -0
  11. package/dist/components/Attachment/AttachmentContainer.d.ts.map +1 -0
  12. package/dist/components/Attachment/AttachmentContainer.js +107 -0
  13. package/dist/components/Attachment/Audio.d.ts +11 -0
  14. package/dist/components/Attachment/Audio.d.ts.map +1 -1
  15. package/dist/components/Attachment/Audio.js +59 -32
  16. package/dist/components/Attachment/Card.d.ts +5 -20
  17. package/dist/components/Attachment/Card.d.ts.map +1 -1
  18. package/dist/components/Attachment/Card.js +93 -15
  19. package/dist/components/Attachment/DownloadButton.d.ts +6 -0
  20. package/dist/components/Attachment/DownloadButton.d.ts.map +1 -0
  21. package/dist/components/Attachment/DownloadButton.js +8 -0
  22. package/dist/components/Attachment/FileAttachment.d.ts +1 -1
  23. package/dist/components/Attachment/FileAttachment.d.ts.map +1 -1
  24. package/dist/components/Attachment/FileAttachment.js +23 -6
  25. package/dist/components/Attachment/FileSizeIndicator.d.ts +6 -0
  26. package/dist/components/Attachment/FileSizeIndicator.d.ts.map +1 -0
  27. package/dist/components/Attachment/FileSizeIndicator.js +8 -0
  28. package/dist/components/Attachment/hooks/useAudioController.d.ts +9 -0
  29. package/dist/components/Attachment/hooks/useAudioController.d.ts.map +1 -0
  30. package/dist/components/Attachment/hooks/useAudioController.js +45 -0
  31. package/dist/components/Attachment/icons.d.ts +5 -0
  32. package/dist/components/Attachment/icons.d.ts.map +1 -0
  33. package/dist/components/Attachment/icons.js +10 -0
  34. package/dist/components/Attachment/index.d.ts +1 -0
  35. package/dist/components/Attachment/index.d.ts.map +1 -1
  36. package/dist/components/Attachment/index.js +1 -0
  37. package/dist/components/Attachment/utils.d.ts +41 -4
  38. package/dist/components/Attachment/utils.d.ts.map +1 -1
  39. package/dist/components/Attachment/utils.js +63 -18
  40. package/dist/components/AutoCompleteTextarea/Item.d.ts.map +1 -1
  41. package/dist/components/AutoCompleteTextarea/Item.js +11 -4
  42. package/dist/components/AutoCompleteTextarea/List.d.ts +17 -1
  43. package/dist/components/AutoCompleteTextarea/List.d.ts.map +1 -1
  44. package/dist/components/AutoCompleteTextarea/List.js +19 -17
  45. package/dist/components/AutoCompleteTextarea/Textarea.d.ts +16 -2
  46. package/dist/components/AutoCompleteTextarea/Textarea.d.ts.map +1 -1
  47. package/dist/components/AutoCompleteTextarea/Textarea.js +19 -16
  48. package/dist/components/AutoCompleteTextarea/utils.js +1 -1
  49. package/dist/components/Avatar/Avatar.js +10 -10
  50. package/dist/components/Channel/Channel.d.ts +7 -2
  51. package/dist/components/Channel/Channel.d.ts.map +1 -1
  52. package/dist/components/Channel/Channel.js +77 -67
  53. package/dist/components/Channel/LoadingChannel.d.ts +2 -0
  54. package/dist/components/Channel/LoadingChannel.d.ts.map +1 -0
  55. package/dist/components/Channel/LoadingChannel.js +20 -0
  56. package/dist/components/Channel/channelState.d.ts +1 -0
  57. package/dist/components/Channel/channelState.d.ts.map +1 -1
  58. package/dist/components/Channel/channelState.js +14 -9
  59. package/dist/components/Channel/hooks/useChannelContainerClasses.d.ts +9 -0
  60. package/dist/components/Channel/hooks/useChannelContainerClasses.d.ts.map +1 -0
  61. package/dist/components/Channel/hooks/useChannelContainerClasses.js +14 -0
  62. package/dist/components/Channel/hooks/useCreateChannelStateContext.js +6 -6
  63. package/dist/components/Channel/utils.d.ts +3 -0
  64. package/dist/components/Channel/utils.d.ts.map +1 -1
  65. package/dist/components/Channel/utils.js +9 -5
  66. package/dist/components/ChannelHeader/ChannelHeader.d.ts.map +1 -1
  67. package/dist/components/ChannelHeader/ChannelHeader.js +14 -9
  68. package/dist/components/ChannelList/ChannelList.d.ts +10 -4
  69. package/dist/components/ChannelList/ChannelList.d.ts.map +1 -1
  70. package/dist/components/ChannelList/ChannelList.js +32 -14
  71. package/dist/components/ChannelList/hooks/useChannelDeletedListener.js +10 -6
  72. package/dist/components/ChannelList/hooks/useChannelHiddenListener.js +10 -6
  73. package/dist/components/ChannelList/hooks/useChannelTruncatedListener.d.ts +1 -1
  74. package/dist/components/ChannelList/hooks/useChannelTruncatedListener.d.ts.map +1 -1
  75. package/dist/components/ChannelList/hooks/useChannelTruncatedListener.js +9 -5
  76. package/dist/components/ChannelList/hooks/useChannelUpdatedListener.d.ts +1 -1
  77. package/dist/components/ChannelList/hooks/useChannelUpdatedListener.d.ts.map +1 -1
  78. package/dist/components/ChannelList/hooks/useChannelUpdatedListener.js +9 -5
  79. package/dist/components/ChannelList/hooks/useChannelVisibleListener.js +9 -5
  80. package/dist/components/ChannelList/hooks/useConnectionRecoveredListener.d.ts +1 -1
  81. package/dist/components/ChannelList/hooks/useConnectionRecoveredListener.d.ts.map +1 -1
  82. package/dist/components/ChannelList/hooks/useMessageNewListener.js +9 -5
  83. package/dist/components/ChannelList/hooks/useMobileNavigation.d.ts +1 -1
  84. package/dist/components/ChannelList/hooks/useMobileNavigation.d.ts.map +1 -1
  85. package/dist/components/ChannelList/hooks/useNotificationAddedToChannelListener.js +9 -5
  86. package/dist/components/ChannelList/hooks/useNotificationMessageNewListener.js +9 -5
  87. package/dist/components/ChannelList/hooks/usePaginatedChannels.js +9 -5
  88. package/dist/components/ChannelList/hooks/useUserPresenceChangedListener.js +9 -5
  89. package/dist/components/ChannelList/utils.js +9 -5
  90. package/dist/components/ChannelPreview/ChannelPreview.d.ts +6 -0
  91. package/dist/components/ChannelPreview/ChannelPreview.d.ts.map +1 -1
  92. package/dist/components/ChannelPreview/ChannelPreview.js +5 -21
  93. package/dist/components/ChannelPreview/ChannelPreviewMessenger.d.ts.map +1 -1
  94. package/dist/components/ChannelPreview/ChannelPreviewMessenger.js +13 -9
  95. package/dist/components/ChannelPreview/hooks/useChannelPreviewInfo.d.ts +14 -0
  96. package/dist/components/ChannelPreview/hooks/useChannelPreviewInfo.d.ts.map +1 -0
  97. package/dist/components/ChannelPreview/hooks/useChannelPreviewInfo.js +29 -0
  98. package/dist/components/ChannelPreview/utils.js +2 -2
  99. package/dist/components/ChannelSearch/ChannelSearch.d.ts +6 -42
  100. package/dist/components/ChannelSearch/ChannelSearch.d.ts.map +1 -1
  101. package/dist/components/ChannelSearch/ChannelSearch.js +4 -160
  102. package/dist/components/ChannelSearch/SearchBar.d.ts +29 -0
  103. package/dist/components/ChannelSearch/SearchBar.d.ts.map +1 -0
  104. package/dist/components/ChannelSearch/SearchBar.js +93 -0
  105. package/dist/components/ChannelSearch/SearchInput.d.ts +9 -17
  106. package/dist/components/ChannelSearch/SearchInput.d.ts.map +1 -1
  107. package/dist/components/ChannelSearch/SearchInput.js +2 -4
  108. package/dist/components/ChannelSearch/SearchResults.d.ts +14 -8
  109. package/dist/components/ChannelSearch/SearchResults.d.ts.map +1 -1
  110. package/dist/components/ChannelSearch/SearchResults.js +44 -27
  111. package/dist/components/ChannelSearch/hooks/useChannelSearch.d.ts +50 -0
  112. package/dist/components/ChannelSearch/hooks/useChannelSearch.d.ts.map +1 -0
  113. package/dist/components/ChannelSearch/hooks/useChannelSearch.js +232 -0
  114. package/dist/components/ChannelSearch/icons.d.ts +6 -0
  115. package/dist/components/ChannelSearch/icons.d.ts.map +1 -0
  116. package/dist/components/ChannelSearch/icons.js +12 -0
  117. package/dist/components/Chat/Chat.d.ts.map +1 -1
  118. package/dist/components/Chat/Chat.js +4 -0
  119. package/dist/components/Chat/hooks/useChat.d.ts +1 -1
  120. package/dist/components/Chat/hooks/useChat.d.ts.map +1 -1
  121. package/dist/components/Chat/hooks/useChat.js +1 -1
  122. package/dist/components/Chat/hooks/useCreateChatContext.d.ts.map +1 -1
  123. package/dist/components/Chat/hooks/useCreateChatContext.js +3 -2
  124. package/dist/components/Chat/hooks/useCustomStyles.d.ts +1 -1
  125. package/dist/components/Chat/hooks/useCustomStyles.d.ts.map +1 -1
  126. package/dist/components/ChatAutoComplete/ChatAutoComplete.js +1 -1
  127. package/dist/components/DateSeparator/DateSeparator.js +1 -1
  128. package/dist/components/EmoticonItem/EmoticonItem.js +1 -1
  129. package/dist/components/EmptyStateIndicator/EmptyStateIndicator.d.ts +1 -1
  130. package/dist/components/EmptyStateIndicator/EmptyStateIndicator.d.ts.map +1 -1
  131. package/dist/components/EmptyStateIndicator/EmptyStateIndicator.js +16 -3
  132. package/dist/components/EmptyStateIndicator/icons.d.ts +2 -0
  133. package/dist/components/EmptyStateIndicator/icons.d.ts.map +1 -0
  134. package/dist/components/EmptyStateIndicator/icons.js +3 -0
  135. package/dist/components/EventComponent/EventComponent.js +1 -1
  136. package/dist/components/Gallery/Gallery.d.ts.map +1 -1
  137. package/dist/components/Gallery/Gallery.js +16 -14
  138. package/dist/components/Gallery/Image.d.ts +7 -3
  139. package/dist/components/Gallery/Image.d.ts.map +1 -1
  140. package/dist/components/Gallery/Image.js +21 -9
  141. package/dist/components/Gallery/ModalGallery.d.ts +10 -0
  142. package/dist/components/Gallery/ModalGallery.d.ts.map +1 -0
  143. package/dist/components/Gallery/ModalGallery.js +16 -0
  144. package/dist/components/Gallery/index.d.ts +1 -1
  145. package/dist/components/Gallery/index.js +1 -1
  146. package/dist/components/InfiniteScrollPaginator/InfiniteScroll.d.ts +2 -0
  147. package/dist/components/InfiniteScrollPaginator/InfiniteScroll.d.ts.map +1 -1
  148. package/dist/components/InfiniteScrollPaginator/InfiniteScroll.js +4 -1
  149. package/dist/components/LoadMore/LoadMoreButton.js +2 -2
  150. package/dist/components/Loading/LoadingChannels.js +2 -2
  151. package/dist/components/Loading/LoadingIndicator.js +1 -1
  152. package/dist/components/MML/MML.js +1 -1
  153. package/dist/components/Message/FixedHeightMessage.js +3 -3
  154. package/dist/components/Message/MessageDeleted.js +2 -2
  155. package/dist/components/Message/MessageOptions.d.ts +1 -0
  156. package/dist/components/Message/MessageOptions.d.ts.map +1 -1
  157. package/dist/components/Message/MessageOptions.js +9 -16
  158. package/dist/components/Message/MessageRepliesCountButton.d.ts.map +1 -1
  159. package/dist/components/Message/MessageRepliesCountButton.js +8 -5
  160. package/dist/components/Message/MessageSimple.d.ts.map +1 -1
  161. package/dist/components/Message/MessageSimple.js +41 -21
  162. package/dist/components/Message/MessageStatus.d.ts.map +1 -1
  163. package/dist/components/Message/MessageStatus.js +34 -23
  164. package/dist/components/Message/MessageText.d.ts +1 -1
  165. package/dist/components/Message/MessageText.d.ts.map +1 -1
  166. package/dist/components/Message/MessageText.js +10 -14
  167. package/dist/components/Message/QuotedMessage.d.ts.map +1 -1
  168. package/dist/components/Message/QuotedMessage.js +8 -3
  169. package/dist/components/Message/hooks/index.d.ts +0 -2
  170. package/dist/components/Message/hooks/index.d.ts.map +1 -1
  171. package/dist/components/Message/hooks/index.js +0 -2
  172. package/dist/components/Message/hooks/useEditHandler.d.ts +1 -1
  173. package/dist/components/Message/hooks/useEditHandler.d.ts.map +1 -1
  174. package/dist/components/Message/hooks/useReactionHandler.d.ts +3 -3
  175. package/dist/components/Message/hooks/useReactionHandler.d.ts.map +1 -1
  176. package/dist/components/Message/hooks/useReactionHandler.js +11 -7
  177. package/dist/components/Message/hooks/useUserRole.d.ts +1 -1
  178. package/dist/components/Message/hooks/useUserRole.d.ts.map +1 -1
  179. package/dist/components/Message/icons.d.ts +6 -4
  180. package/dist/components/Message/icons.d.ts.map +1 -1
  181. package/dist/components/Message/icons.js +25 -10
  182. package/dist/components/Message/index.d.ts +0 -3
  183. package/dist/components/Message/index.d.ts.map +1 -1
  184. package/dist/components/Message/index.js +0 -3
  185. package/dist/components/Message/utils.js +10 -6
  186. package/dist/components/MessageActions/MessageActions.d.ts.map +1 -1
  187. package/dist/components/MessageActions/MessageActions.js +3 -3
  188. package/dist/components/MessageActions/MessageActionsBox.d.ts.map +1 -1
  189. package/dist/components/MessageActions/MessageActionsBox.js +14 -7
  190. package/dist/components/MessageInput/AttachmentPreviewList.d.ts +2 -0
  191. package/dist/components/MessageInput/AttachmentPreviewList.d.ts.map +1 -0
  192. package/dist/components/MessageInput/AttachmentPreviewList.js +60 -0
  193. package/dist/components/MessageInput/EditMessageForm.d.ts.map +1 -1
  194. package/dist/components/MessageInput/EditMessageForm.js +11 -6
  195. package/dist/components/MessageInput/EmojiPicker.d.ts +1 -1
  196. package/dist/components/MessageInput/EmojiPicker.d.ts.map +1 -1
  197. package/dist/components/MessageInput/EmojiPicker.js +14 -17
  198. package/dist/components/MessageInput/MessageInput.d.ts +1 -1
  199. package/dist/components/MessageInput/MessageInput.d.ts.map +1 -1
  200. package/dist/components/MessageInput/MessageInputFlat.d.ts.map +1 -1
  201. package/dist/components/MessageInput/MessageInputFlat.js +87 -10
  202. package/dist/components/MessageInput/MessageInputSmall.d.ts +9 -0
  203. package/dist/components/MessageInput/MessageInputSmall.d.ts.map +1 -1
  204. package/dist/components/MessageInput/MessageInputSmall.js +10 -1
  205. package/dist/components/MessageInput/QuotedMessagePreview.d.ts +2 -1
  206. package/dist/components/MessageInput/QuotedMessagePreview.d.ts.map +1 -1
  207. package/dist/components/MessageInput/QuotedMessagePreview.js +29 -22
  208. package/dist/components/MessageInput/UploadsPreview.d.ts +7 -0
  209. package/dist/components/MessageInput/UploadsPreview.d.ts.map +1 -1
  210. package/dist/components/MessageInput/UploadsPreview.js +17 -6
  211. package/dist/components/MessageInput/hooks/useCommandTrigger.d.ts.map +1 -1
  212. package/dist/components/MessageInput/hooks/useCommandTrigger.js +6 -4
  213. package/dist/components/MessageInput/hooks/useCooldownTimer.d.ts +1 -1
  214. package/dist/components/MessageInput/hooks/useCooldownTimer.d.ts.map +1 -1
  215. package/dist/components/MessageInput/hooks/useCooldownTimer.js +4 -4
  216. package/dist/components/MessageInput/hooks/useEmojiPicker.d.ts +1 -1
  217. package/dist/components/MessageInput/hooks/useEmojiPicker.d.ts.map +1 -1
  218. package/dist/components/MessageInput/hooks/useEmojiTrigger.d.ts +1 -1
  219. package/dist/components/MessageInput/hooks/useEmojiTrigger.d.ts.map +1 -1
  220. package/dist/components/MessageInput/hooks/useEmojiTrigger.js +23 -19
  221. package/dist/components/MessageInput/hooks/useFileState.d.ts +7 -0
  222. package/dist/components/MessageInput/hooks/useFileState.d.ts.map +1 -0
  223. package/dist/components/MessageInput/hooks/useFileState.js +8 -0
  224. package/dist/components/MessageInput/hooks/useMessageInputState.d.ts +2 -6
  225. package/dist/components/MessageInput/hooks/useMessageInputState.d.ts.map +1 -1
  226. package/dist/components/MessageInput/hooks/useSubmitHandler.js +10 -6
  227. package/dist/components/MessageInput/hooks/useUserTrigger.d.ts +1 -1
  228. package/dist/components/MessageInput/hooks/useUserTrigger.d.ts.map +1 -1
  229. package/dist/components/MessageInput/hooks/useUserTrigger.js +13 -9
  230. package/dist/components/MessageInput/hooks/utils.d.ts +1 -1
  231. package/dist/components/MessageInput/hooks/utils.d.ts.map +1 -1
  232. package/dist/components/MessageInput/icons.d.ts +12 -2
  233. package/dist/components/MessageInput/icons.d.ts.map +1 -1
  234. package/dist/components/MessageInput/icons.js +67 -7
  235. package/dist/components/MessageList/CustomNotification.js +1 -1
  236. package/dist/components/MessageList/MessageList.d.ts +3 -0
  237. package/dist/components/MessageList/MessageList.d.ts.map +1 -1
  238. package/dist/components/MessageList/MessageList.js +17 -14
  239. package/dist/components/MessageList/MessageListMainPanel.d.ts +3 -0
  240. package/dist/components/MessageList/MessageListMainPanel.d.ts.map +1 -0
  241. package/dist/components/MessageList/MessageListMainPanel.js +9 -0
  242. package/dist/components/MessageList/MessageListNotifications.d.ts +2 -0
  243. package/dist/components/MessageList/MessageListNotifications.d.ts.map +1 -1
  244. package/dist/components/MessageList/MessageListNotifications.js +2 -2
  245. package/dist/components/MessageList/MessageNotification.d.ts +9 -6
  246. package/dist/components/MessageList/MessageNotification.d.ts.map +1 -1
  247. package/dist/components/MessageList/MessageNotification.js +1 -1
  248. package/dist/components/MessageList/ScrollToBottomButton.d.ts +3 -0
  249. package/dist/components/MessageList/ScrollToBottomButton.d.ts.map +1 -0
  250. package/dist/components/MessageList/ScrollToBottomButton.js +53 -0
  251. package/dist/components/MessageList/VirtualizedMessageList.d.ts +5 -0
  252. package/dist/components/MessageList/VirtualizedMessageList.d.ts.map +1 -1
  253. package/dist/components/MessageList/VirtualizedMessageList.js +41 -14
  254. package/dist/components/MessageList/hooks/useMessageListElements.d.ts +1 -1
  255. package/dist/components/MessageList/hooks/useMessageListElements.d.ts.map +1 -1
  256. package/dist/components/MessageList/hooks/useMessageListElements.js +4 -3
  257. package/dist/components/MessageList/hooks/useMessageListScrollManager.d.ts.map +1 -1
  258. package/dist/components/MessageList/hooks/useMessageListScrollManager.js +3 -1
  259. package/dist/components/MessageList/hooks/useNewMessageNotification.d.ts +2 -0
  260. package/dist/components/MessageList/hooks/useNewMessageNotification.d.ts.map +1 -1
  261. package/dist/components/MessageList/hooks/useNewMessageNotification.js +8 -1
  262. package/dist/components/MessageList/hooks/useScrollLocationLogic.d.ts +1 -2
  263. package/dist/components/MessageList/hooks/useScrollLocationLogic.d.ts.map +1 -1
  264. package/dist/components/MessageList/hooks/useScrollLocationLogic.js +12 -30
  265. package/dist/components/MessageList/icons.d.ts +8 -0
  266. package/dist/components/MessageList/icons.d.ts.map +1 -0
  267. package/dist/components/MessageList/icons.js +11 -0
  268. package/dist/components/MessageList/index.d.ts +1 -0
  269. package/dist/components/MessageList/index.d.ts.map +1 -1
  270. package/dist/components/MessageList/index.js +1 -0
  271. package/dist/components/MessageList/utils.d.ts +4 -2
  272. package/dist/components/MessageList/utils.d.ts.map +1 -1
  273. package/dist/components/MessageList/utils.js +16 -3
  274. package/dist/components/Modal/Modal.d.ts +2 -2
  275. package/dist/components/Modal/Modal.d.ts.map +1 -1
  276. package/dist/components/Modal/Modal.js +18 -15
  277. package/dist/components/Modal/icons.d.ts +2 -0
  278. package/dist/components/Modal/icons.d.ts.map +1 -0
  279. package/dist/components/Modal/icons.js +5 -0
  280. package/dist/components/Reactions/ReactionSelector.d.ts +2 -0
  281. package/dist/components/Reactions/ReactionSelector.d.ts.map +1 -1
  282. package/dist/components/Reactions/ReactionSelector.js +18 -9
  283. package/dist/components/Reactions/ReactionsList.d.ts +3 -1
  284. package/dist/components/Reactions/ReactionsList.d.ts.map +1 -1
  285. package/dist/components/Reactions/ReactionsList.js +48 -47
  286. package/dist/components/Reactions/SimpleReactionsList.d.ts +3 -1
  287. package/dist/components/Reactions/SimpleReactionsList.d.ts.map +1 -1
  288. package/dist/components/Reactions/SimpleReactionsList.js +41 -58
  289. package/dist/components/Reactions/hooks/useProcessReactions.d.ts +22 -0
  290. package/dist/components/Reactions/hooks/useProcessReactions.d.ts.map +1 -0
  291. package/dist/components/Reactions/hooks/useProcessReactions.js +62 -0
  292. package/dist/components/Thread/Thread.d.ts +2 -6
  293. package/dist/components/Thread/Thread.d.ts.map +1 -1
  294. package/dist/components/Thread/Thread.js +21 -89
  295. package/dist/components/Thread/ThreadHead.d.ts +4 -0
  296. package/dist/components/Thread/ThreadHead.d.ts.map +1 -0
  297. package/dist/components/Thread/ThreadHead.js +21 -0
  298. package/dist/components/Thread/ThreadHeader.d.ts +12 -0
  299. package/dist/components/Thread/ThreadHeader.d.ts.map +1 -0
  300. package/dist/components/Thread/ThreadHeader.js +21 -0
  301. package/dist/components/Thread/ThreadStart.d.ts +2 -0
  302. package/dist/components/Thread/ThreadStart.d.ts.map +1 -0
  303. package/dist/components/Thread/ThreadStart.js +10 -0
  304. package/dist/components/Thread/icons.d.ts +4 -0
  305. package/dist/components/Thread/icons.d.ts.map +1 -0
  306. package/dist/components/Thread/icons.js +9 -0
  307. package/dist/components/Thread/index.d.ts +2 -0
  308. package/dist/components/Thread/index.d.ts.map +1 -1
  309. package/dist/components/Thread/index.js +2 -0
  310. package/dist/components/Tooltip/Tooltip.d.ts +14 -2
  311. package/dist/components/Tooltip/Tooltip.d.ts.map +1 -1
  312. package/dist/components/Tooltip/Tooltip.js +22 -3
  313. package/dist/components/Tooltip/hooks/index.d.ts +2 -0
  314. package/dist/components/Tooltip/hooks/index.d.ts.map +1 -0
  315. package/dist/components/Tooltip/hooks/index.js +1 -0
  316. package/dist/components/Tooltip/hooks/useEnterLeaveHandlers.d.ts +7 -0
  317. package/dist/components/Tooltip/hooks/useEnterLeaveHandlers.d.ts.map +1 -0
  318. package/dist/components/Tooltip/hooks/useEnterLeaveHandlers.js +14 -0
  319. package/dist/components/TypingIndicator/TypingIndicator.d.ts.map +1 -1
  320. package/dist/components/TypingIndicator/TypingIndicator.js +52 -9
  321. package/dist/components/UserItem/UserItem.d.ts +1 -1
  322. package/dist/components/UserItem/UserItem.d.ts.map +1 -1
  323. package/dist/components/UserItem/UserItem.js +15 -8
  324. package/dist/components/Window/Window.js +1 -1
  325. package/dist/constants/limits.d.ts +4 -0
  326. package/dist/constants/limits.d.ts.map +1 -0
  327. package/dist/constants/limits.js +3 -0
  328. package/dist/context/ChannelActionContext.d.ts +1 -1
  329. package/dist/context/ChannelActionContext.d.ts.map +1 -1
  330. package/dist/context/ChannelActionContext.js +1 -1
  331. package/dist/context/ChannelStateContext.d.ts +3 -2
  332. package/dist/context/ChannelStateContext.d.ts.map +1 -1
  333. package/dist/context/ChannelStateContext.js +1 -1
  334. package/dist/context/ChatContext.d.ts +5 -4
  335. package/dist/context/ChatContext.d.ts.map +1 -1
  336. package/dist/context/ChatContext.js +2 -2
  337. package/dist/context/ComponentContext.d.ts +6 -2
  338. package/dist/context/ComponentContext.d.ts.map +1 -1
  339. package/dist/context/ComponentContext.js +1 -1
  340. package/dist/context/EmojiContext.d.ts +1 -1
  341. package/dist/context/EmojiContext.d.ts.map +1 -1
  342. package/dist/context/EmojiContext.js +1 -1
  343. package/dist/context/MessageContext.d.ts +1 -1
  344. package/dist/context/MessageContext.d.ts.map +1 -1
  345. package/dist/context/MessageContext.js +1 -1
  346. package/dist/context/MessageInputContext.d.ts +1 -1
  347. package/dist/context/MessageInputContext.d.ts.map +1 -1
  348. package/dist/context/MessageInputContext.js +1 -1
  349. package/dist/context/TranslationContext.d.ts +2 -2
  350. package/dist/context/TranslationContext.d.ts.map +1 -1
  351. package/dist/context/TranslationContext.js +8 -4
  352. package/dist/context/TypingContext.d.ts +1 -1
  353. package/dist/context/TypingContext.d.ts.map +1 -1
  354. package/dist/context/TypingContext.js +1 -1
  355. package/dist/css/index.css +1 -1
  356. package/dist/css/index.css.map +1 -0
  357. package/dist/css/v2/index.css +1 -0
  358. package/dist/css/v2/index.css.map +1 -0
  359. package/dist/css/v2/index.layout.css +1 -0
  360. package/dist/css/v2/index.layout.css.map +1 -0
  361. package/dist/i18n/Streami18n.d.ts +8 -2
  362. package/dist/i18n/Streami18n.d.ts.map +1 -1
  363. package/dist/i18n/Streami18n.js +12 -12
  364. package/dist/i18n/de.json +8 -2
  365. package/dist/i18n/en.json +8 -2
  366. package/dist/i18n/es.json +9 -2
  367. package/dist/i18n/fr.json +9 -2
  368. package/dist/i18n/hi.json +8 -2
  369. package/dist/i18n/it.json +9 -2
  370. package/dist/i18n/ja.json +8 -2
  371. package/dist/i18n/ko.json +8 -2
  372. package/dist/i18n/nl.json +8 -2
  373. package/dist/i18n/pt.json +9 -2
  374. package/dist/i18n/ru.json +10 -2
  375. package/dist/i18n/tr.json +8 -2
  376. package/dist/index.cjs.js +8396 -3951
  377. package/dist/index.cjs.js.map +1 -1
  378. package/dist/scss/Attachment.scss +52 -22
  379. package/dist/scss/Audio.scss +1 -1
  380. package/dist/scss/Avatar.scss +1 -1
  381. package/dist/scss/ChannelList.scss +5 -1
  382. package/dist/scss/ChannelPreview.scss +25 -0
  383. package/dist/scss/ChannelSearch.scss +5 -3
  384. package/dist/scss/Gallery.scss +0 -26
  385. package/dist/scss/ImageCarousel.scss +45 -0
  386. package/dist/scss/LoadingChannels.scss +1 -1
  387. package/dist/scss/Message.scss +21 -51
  388. package/dist/scss/MessageActions.scss +15 -0
  389. package/dist/scss/MessageCommerce.scss +57 -13
  390. package/dist/scss/MessageInput.scss +1 -0
  391. package/dist/scss/MessageInputFlat.scss +21 -9
  392. package/dist/scss/MessageList.scss +35 -3
  393. package/dist/scss/MessageLivestream.scss +23 -10
  394. package/dist/scss/MessageNotification.scss +7 -1
  395. package/dist/scss/MessageTeam.scss +37 -10
  396. package/dist/scss/Modal.scss +2 -0
  397. package/dist/scss/ReactionList.scss +14 -0
  398. package/dist/scss/ReactionSelector.scss +6 -0
  399. package/dist/scss/SendButton.scss +6 -0
  400. package/dist/scss/SmallMessageInput.scss +0 -1
  401. package/dist/scss/Thread.scss +21 -2
  402. package/dist/scss/Tooltip.scss +6 -3
  403. package/dist/scss/TypingIndicator.scss +5 -0
  404. package/dist/scss/_base.scss +26 -0
  405. package/dist/scss/_variables.scss +2 -1
  406. package/dist/scss/index.scss +5 -4
  407. package/dist/scss/v2/AttachmentList/AttachmentList-layout.scss +392 -0
  408. package/dist/scss/v2/AttachmentList/AttachmentList-theme.scss +400 -0
  409. package/dist/scss/v2/AttachmentPreviewList/AttachmentPreviewList-layout.scss +118 -0
  410. package/dist/scss/v2/AttachmentPreviewList/AttachmentPreviewList-theme.scss +150 -0
  411. package/dist/scss/v2/Autocomplete/Autocomplete-layout.scss +62 -0
  412. package/dist/scss/v2/Autocomplete/Autocomplete-theme.scss +207 -0
  413. package/dist/scss/v2/Avatar/Avatar-layout.scss +13 -0
  414. package/dist/scss/v2/Avatar/Avatar-theme.scss +42 -0
  415. package/dist/scss/v2/Channel/Channel-layout.scss +139 -0
  416. package/dist/scss/v2/Channel/Channel-theme.scss +99 -0
  417. package/dist/scss/v2/ChannelHeader/ChannelHeader-layout.scss +23 -0
  418. package/dist/scss/v2/ChannelHeader/ChannelHeader-theme.scss +43 -0
  419. package/dist/scss/v2/ChannelList/ChannelList-layout.scss +41 -0
  420. package/dist/scss/v2/ChannelList/ChannelList-theme.scss +87 -0
  421. package/dist/scss/v2/ChannelPreview/ChannelPreview-layout.scss +82 -0
  422. package/dist/scss/v2/ChannelPreview/ChannelPreview-theme.scss +108 -0
  423. package/dist/scss/v2/ChannelSearch/ChannelSearch-layout.scss +71 -0
  424. package/dist/scss/v2/ChannelSearch/ChannelSearch-theme.scss +190 -0
  425. package/dist/scss/v2/EditMessageForm/EditMessageForm-layout.scss +53 -0
  426. package/dist/scss/v2/EditMessageForm/EditMessageForm-theme.scss +50 -0
  427. package/dist/scss/v2/ImageCarousel/ImageCarousel-layout.scss +41 -0
  428. package/dist/scss/v2/ImageCarousel/ImageCarousel-theme.scss +15 -0
  429. package/dist/scss/v2/LoadingIndicator/LoadingIndicator-layout.scss +39 -0
  430. package/dist/scss/v2/LoadingIndicator/LoadingIndicator-theme.scss +12 -0
  431. package/dist/scss/v2/Message/Message-layout.scss +362 -0
  432. package/dist/scss/v2/Message/Message-theme.scss +353 -0
  433. package/dist/scss/v2/MessageActionsBox/MessageActionsBox-layout.scss +48 -0
  434. package/dist/scss/v2/MessageActionsBox/MessageActionsBox-theme.scss +69 -0
  435. package/dist/scss/v2/MessageInput/MessageInput-layout.scss +186 -0
  436. package/dist/scss/v2/MessageInput/MessageInput-theme.scss +221 -0
  437. package/dist/scss/v2/MessageList/MessageList-layout.scss +61 -0
  438. package/dist/scss/v2/MessageList/MessageList-theme.scss +105 -0
  439. package/dist/scss/v2/MessageList/VirtualizedMessageList-layout.scss +44 -0
  440. package/dist/scss/v2/MessageList/VirtualizedMessageList-theme.scss +32 -0
  441. package/dist/scss/v2/MessageReactions/MessageReactions-layout.scss +55 -0
  442. package/dist/scss/v2/MessageReactions/MessageReactions-theme.scss +75 -0
  443. package/dist/scss/v2/MessageReactions/MessageReactionsSelector-layout.scss +52 -0
  444. package/dist/scss/v2/MessageReactions/MessageReactionsSelector-theme.scss +83 -0
  445. package/dist/scss/v2/Modal/Modal-layout.scss +40 -0
  446. package/dist/scss/v2/Modal/Modal-theme.scss +82 -0
  447. package/dist/scss/v2/Notification/MessageNotification-layout.scss +12 -0
  448. package/dist/scss/v2/Notification/MessageNotification-theme.scss +34 -0
  449. package/dist/scss/v2/Notification/Notification-layout.scss +3 -0
  450. package/dist/scss/v2/Notification/Notification-theme.scss +32 -0
  451. package/dist/scss/v2/Notification/NotificationList-layout.scss +11 -0
  452. package/dist/scss/v2/Notification/NotificationList-theme.scss +31 -0
  453. package/dist/scss/v2/Thread/Thread-layout.scss +47 -0
  454. package/dist/scss/v2/Thread/Thread-theme.scss +82 -0
  455. package/dist/scss/v2/Tooltip/Tooltip-layout.scss +9 -0
  456. package/dist/scss/v2/Tooltip/Tooltip-theme.scss +36 -0
  457. package/dist/scss/v2/TypingIndicator/TypingIndicator-layout.scss +27 -0
  458. package/dist/scss/v2/TypingIndicator/TypingIndicator-theme.scss +68 -0
  459. package/dist/scss/v2/_base.scss +29 -0
  460. package/dist/scss/v2/_global-layout-variables.scss +65 -0
  461. package/dist/scss/v2/_global-theme-variables.scss +166 -0
  462. package/dist/scss/v2/_palette-variables.scss +55 -0
  463. package/dist/scss/v2/_utils.scss +188 -0
  464. package/dist/scss/v2/common/CTAButton/CTAButton-layout.scss +4 -0
  465. package/dist/scss/v2/common/CTAButton/CTAButton-theme.scss +42 -0
  466. package/dist/scss/v2/common/CircleFAButton/CircleFAButton-layout.scss +14 -0
  467. package/dist/scss/v2/common/CircleFAButton/CircleFAButton-theme.scss +35 -0
  468. package/dist/scss/v2/index.layout.scss +31 -0
  469. package/dist/scss/v2/index.scss +36 -0
  470. package/dist/scss/{vendor → v2/vendor}/emoji-mart.scss +27 -8
  471. package/dist/stories/add-message.stories.d.ts +0 -1
  472. package/dist/stories/add-message.stories.d.ts.map +1 -1
  473. package/dist/stories/add-message.stories.js +0 -1
  474. package/dist/stories/edit-message.stories.d.ts +0 -1
  475. package/dist/stories/edit-message.stories.d.ts.map +1 -1
  476. package/dist/stories/edit-message.stories.js +0 -1
  477. package/dist/stories/hello.stories.d.ts +0 -1
  478. package/dist/stories/hello.stories.d.ts.map +1 -1
  479. package/dist/stories/hello.stories.js +0 -1
  480. package/dist/stories/jump-to-message.stories.d.ts +0 -1
  481. package/dist/stories/jump-to-message.stories.d.ts.map +1 -1
  482. package/dist/stories/jump-to-message.stories.js +0 -1
  483. package/dist/stories/mark-read.stories.d.ts +0 -1
  484. package/dist/stories/mark-read.stories.d.ts.map +1 -1
  485. package/dist/stories/mark-read.stories.js +0 -1
  486. package/dist/stories/message-status-readby-tooltip.stories.d.ts +0 -1
  487. package/dist/stories/message-status-readby-tooltip.stories.d.ts.map +1 -1
  488. package/dist/stories/message-status-readby-tooltip.stories.js +0 -1
  489. package/dist/stories/navigate-long-message-lists.stories.d.ts +0 -2
  490. package/dist/stories/navigate-long-message-lists.stories.d.ts.map +1 -1
  491. package/dist/stories/navigate-long-message-lists.stories.js +1 -11
  492. package/dist/stories/toggle-message-actions.stories.d.ts +0 -1
  493. package/dist/stories/toggle-message-actions.stories.d.ts.map +1 -1
  494. package/dist/stories/toggle-message-actions.stories.js +0 -1
  495. package/dist/stories/utils.d.ts.map +1 -1
  496. package/dist/stories/utils.js +2 -1
  497. package/dist/types/types.d.ts +7 -0
  498. package/dist/types/types.d.ts.map +1 -1
  499. package/dist/utils.d.ts +2 -2
  500. package/dist/utils.d.ts.map +1 -1
  501. package/dist/utils.js +4 -4
  502. package/dist/version.d.ts +1 -1
  503. package/dist/version.d.ts.map +1 -1
  504. package/dist/version.js +1 -1
  505. package/package.json +14 -12
  506. package/dist/components/Gallery/ModalWrapper.d.ts +0 -14
  507. package/dist/components/Gallery/ModalWrapper.d.ts.map +0 -1
  508. package/dist/components/Gallery/ModalWrapper.js +0 -8
  509. package/dist/components/Message/MessageCommerce.d.ts +0 -10
  510. package/dist/components/Message/MessageCommerce.d.ts.map +0 -1
  511. package/dist/components/Message/MessageCommerce.js +0 -64
  512. package/dist/components/Message/MessageLivestream.d.ts +0 -16
  513. package/dist/components/Message/MessageLivestream.d.ts.map +0 -1
  514. package/dist/components/Message/MessageLivestream.js +0 -164
  515. package/dist/components/Message/MessageTeam.d.ts +0 -11
  516. package/dist/components/Message/MessageTeam.d.ts.map +0 -1
  517. package/dist/components/Message/MessageTeam.js +0 -110
  518. package/dist/components/Message/hooks/useBreakpoint.d.ts +0 -6
  519. package/dist/components/Message/hooks/useBreakpoint.d.ts.map +0 -1
  520. package/dist/components/Message/hooks/useBreakpoint.js +0 -18
  521. package/dist/components/Message/hooks/useMobilePress.d.ts +0 -5
  522. package/dist/components/Message/hooks/useMobilePress.d.ts.map +0 -1
  523. package/dist/components/Message/hooks/useMobilePress.js +0 -33
  524. package/dist/scss/vendor/mml-react.scss +0 -1749
  525. package/dist/scss/vendor/react-file-utils.scss +0 -378
  526. package/dist/scss/vendor/react-image-gallery.scss +0 -224
@@ -24,7 +24,9 @@ export function useMessageListScrollManager(params) {
24
24
  // messages added to the top
25
25
  if ((lastPrevMessage === null || lastPrevMessage === void 0 ? void 0 : lastPrevMessage.id) === lastNewMessage.id) {
26
26
  var listHeightDelta = newMeasures.scrollHeight - prevMeasures.scrollHeight;
27
- onScrollBy(listHeightDelta);
27
+ if (scrollTop.current === 0) {
28
+ onScrollBy(listHeightDelta);
29
+ }
28
30
  }
29
31
  // messages added to the bottom
30
32
  else {
@@ -2,7 +2,9 @@ import type { StreamMessage } from '../../../context/ChannelStateContext';
2
2
  import type { DefaultStreamChatGenerics } from '../../../types/types';
3
3
  export declare function useNewMessageNotification<StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics>(messages: StreamMessage<StreamChatGenerics>[], currentUserId: string | undefined, hasMoreNewer?: boolean): {
4
4
  atBottom: import("react").MutableRefObject<boolean>;
5
+ isMessageListScrolledToBottom: boolean;
5
6
  newMessagesNotification: boolean;
7
+ setIsMessageListScrolledToBottom: import("react").Dispatch<import("react").SetStateAction<boolean>>;
6
8
  setNewMessagesNotification: import("react").Dispatch<import("react").SetStateAction<boolean>>;
7
9
  };
8
10
  //# sourceMappingURL=useNewMessageNotification.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"useNewMessageNotification.d.ts","sourceRoot":"","sources":["../../../../src/components/MessageList/hooks/useNewMessageNotification.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AAE1E,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAEtE,wBAAgB,yBAAyB,CACvC,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,EAEhF,QAAQ,EAAE,aAAa,CAAC,kBAAkB,CAAC,EAAE,EAC7C,aAAa,EAAE,MAAM,GAAG,SAAS,EACjC,YAAY,CAAC,EAAE,OAAO;;;;EAsCvB"}
1
+ {"version":3,"file":"useNewMessageNotification.d.ts","sourceRoot":"","sources":["../../../../src/components/MessageList/hooks/useNewMessageNotification.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AAE1E,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAEtE,wBAAgB,yBAAyB,CACvC,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,EAEhF,QAAQ,EAAE,aAAa,CAAC,kBAAkB,CAAC,EAAE,EAC7C,aAAa,EAAE,MAAM,GAAG,SAAS,EACjC,YAAY,CAAC,EAAE,OAAO;;;;;;EA6CvB"}
@@ -1,6 +1,7 @@
1
1
  import { useEffect, useRef, useState } from 'react';
2
2
  export function useNewMessageNotification(messages, currentUserId, hasMoreNewer) {
3
3
  var _a = useState(false), newMessagesNotification = _a[0], setNewMessagesNotification = _a[1];
4
+ var _b = useState(true), isMessageListScrolledToBottom = _b[0], setIsMessageListScrolledToBottom = _b[1];
4
5
  /**
5
6
  * use the flag to avoid the initial "new messages" quick blink
6
7
  */
@@ -32,5 +33,11 @@ export function useNewMessageNotification(messages, currentUserId, hasMoreNewer)
32
33
  }
33
34
  didMount.current = true;
34
35
  }, [currentUserId, messages, hasMoreNewer]);
35
- return { atBottom: atBottom, newMessagesNotification: newMessagesNotification, setNewMessagesNotification: setNewMessagesNotification };
36
+ return {
37
+ atBottom: atBottom,
38
+ isMessageListScrolledToBottom: isMessageListScrolledToBottom,
39
+ newMessagesNotification: newMessagesNotification,
40
+ setIsMessageListScrolledToBottom: setIsMessageListScrolledToBottom,
41
+ setNewMessagesNotification: setNewMessagesNotification,
42
+ };
36
43
  }
@@ -5,14 +5,13 @@ export declare type UseScrollLocationLogicParams<StreamChatGenerics extends Defa
5
5
  hasMoreNewer: boolean;
6
6
  listElement: HTMLDivElement | null;
7
7
  suppressAutoscroll: boolean;
8
- ulElement: HTMLUListElement | null;
9
8
  currentUserId?: string;
10
9
  messages?: StreamMessage<StreamChatGenerics>[];
11
10
  scrolledUpThreshold?: number;
12
11
  };
13
12
  export declare const useScrollLocationLogic: <StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics>(params: UseScrollLocationLogicParams<StreamChatGenerics>) => {
14
13
  hasNewMessages: boolean;
15
- listElement: HTMLDivElement | null;
14
+ isMessageListScrolledToBottom: boolean;
16
15
  onMessageLoadCaptured: () => void;
17
16
  onScroll: (event: React.UIEvent<HTMLDivElement>) => void;
18
17
  scrollToBottom: () => void;
@@ -1 +1 @@
1
- {"version":3,"file":"useScrollLocationLogic.d.ts","sourceRoot":"","sources":["../../../../src/components/MessageList/hooks/useScrollLocationLogic.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoE,MAAM,OAAO,CAAC;AAKzF,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AAE1E,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAKtE,oBAAY,4BAA4B,CACtC,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,YAAY,EAAE,OAAO,CAAC;IACtB,WAAW,EAAE,cAAc,GAAG,IAAI,CAAC;IACnC,kBAAkB,EAAE,OAAO,CAAC;IAC5B,SAAS,EAAE,gBAAgB,GAAG,IAAI,CAAC;IACnC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,EAAE,aAAa,CAAC,kBAAkB,CAAC,EAAE,CAAC;IAC/C,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,eAAO,MAAM,sBAAsB;;;;sBAoFvB,aAAa,CAAC,cAAc,CAAC;;;CAqCxC,CAAC"}
1
+ {"version":3,"file":"useScrollLocationLogic.d.ts","sourceRoot":"","sources":["../../../../src/components/MessageList/hooks/useScrollLocationLogic.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAyD,MAAM,OAAO,CAAC;AAI9E,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AAE1E,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAEtE,oBAAY,4BAA4B,CACtC,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,YAAY,EAAE,OAAO,CAAC;IACtB,WAAW,EAAE,cAAc,GAAG,IAAI,CAAC;IACnC,kBAAkB,EAAE,OAAO,CAAC;IAC5B,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,QAAQ,CAAC,EAAE,aAAa,CAAC,kBAAkB,CAAC,EAAE,CAAC;IAC/C,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,eAAO,MAAM,sBAAsB;;;;sBAwDvB,aAAa,CAAC,cAAc,CAAC;;;CA2CxC,CAAC"}
@@ -1,12 +1,10 @@
1
- import { useCallback, useEffect, useLayoutEffect, useRef, useState } from 'react';
2
- import { ResizeObserver as Polyfill } from '@juggle/resize-observer';
1
+ import { useCallback, useLayoutEffect, useRef, useState } from 'react';
3
2
  import { useMessageListScrollManager } from './useMessageListScrollManager';
4
- var isBrowser = typeof window !== 'undefined';
5
- var ResizeObserver = (isBrowser && window.ResizeObserver) || Polyfill;
6
3
  export var useScrollLocationLogic = function (params) {
7
- var _a = params.messages, messages = _a === void 0 ? [] : _a, _b = params.scrolledUpThreshold, scrolledUpThreshold = _b === void 0 ? 200 : _b, hasMoreNewer = params.hasMoreNewer, suppressAutoscroll = params.suppressAutoscroll, listElement = params.listElement, ulElement = params.ulElement;
4
+ var _a = params.messages, messages = _a === void 0 ? [] : _a, _b = params.scrolledUpThreshold, scrolledUpThreshold = _b === void 0 ? 200 : _b, hasMoreNewer = params.hasMoreNewer, suppressAutoscroll = params.suppressAutoscroll, listElement = params.listElement;
8
5
  var _c = useState(false), hasNewMessages = _c[0], setHasNewMessages = _c[1];
9
6
  var _d = useState(), wrapperRect = _d[0], setWrapperRect = _d[1];
7
+ var _e = useState(true), isMessageListScrolledToBottom = _e[0], setIsMessageListScrolledToBottom = _e[1];
10
8
  var closeToBottom = useRef(false);
11
9
  var closeToTop = useRef(false);
12
10
  var scrollCounter = useRef({ autoScroll: 0, scroll: 0 });
@@ -20,29 +18,6 @@ export var useScrollLocationLogic = function (params) {
20
18
  });
21
19
  setHasNewMessages(false);
22
20
  }, [listElement, hasMoreNewer, suppressAutoscroll]);
23
- useEffect(function () {
24
- if (!listElement)
25
- return;
26
- var observer = new ResizeObserver(scrollToBottom);
27
- var cancelObserverOnUserScroll = function () {
28
- scrollCounter.current.scroll += 1;
29
- var userScrolled = scrollCounter.current.autoScroll < scrollCounter.current.scroll;
30
- if (ulElement && userScrolled) {
31
- observer.unobserve(ulElement);
32
- listElement === null || listElement === void 0 ? void 0 : listElement.removeEventListener('scroll', cancelObserverOnUserScroll);
33
- }
34
- };
35
- if (ulElement) {
36
- observer.observe(ulElement);
37
- }
38
- listElement.addEventListener('scroll', cancelObserverOnUserScroll);
39
- return function () {
40
- observer.disconnect();
41
- if (listElement) {
42
- listElement.removeEventListener('scroll', cancelObserverOnUserScroll);
43
- }
44
- };
45
- }, [ulElement, scrollToBottom]);
46
21
  useLayoutEffect(function () {
47
22
  if (listElement) {
48
23
  setWrapperRect(listElement.getBoundingClientRect());
@@ -68,24 +43,31 @@ export var useScrollLocationLogic = function (params) {
68
43
  updateScrollTop(scrollTop);
69
44
  var offsetHeight = element.offsetHeight;
70
45
  var scrollHeight = element.scrollHeight;
46
+ var prevCloseToBottom = closeToBottom.current;
71
47
  closeToBottom.current = scrollHeight - (scrollTop + offsetHeight) < scrolledUpThreshold;
72
48
  closeToTop.current = scrollTop < scrolledUpThreshold;
73
49
  if (closeToBottom.current) {
74
50
  setHasNewMessages(false);
75
51
  }
52
+ if (prevCloseToBottom && !closeToBottom.current) {
53
+ setIsMessageListScrolledToBottom(false);
54
+ }
55
+ else if (!prevCloseToBottom && closeToBottom.current) {
56
+ setIsMessageListScrolledToBottom(true);
57
+ }
76
58
  }, [updateScrollTop, closeToTop, closeToBottom, scrolledUpThreshold]);
77
59
  var onMessageLoadCaptured = useCallback(function () {
78
60
  /**
79
61
  * A load event (emitted by e.g. an <img>) was captured on a message.
80
62
  * In some cases, the loaded asset is larger than the placeholder, which means we have to scroll down.
81
63
  */
82
- if (closeToBottom.current && !closeToTop.current) {
64
+ if (closeToBottom.current) {
83
65
  scrollToBottom();
84
66
  }
85
67
  }, [closeToTop, closeToBottom, scrollToBottom]);
86
68
  return {
87
69
  hasNewMessages: hasNewMessages,
88
- listElement: listElement,
70
+ isMessageListScrolledToBottom: isMessageListScrolledToBottom,
89
71
  onMessageLoadCaptured: onMessageLoadCaptured,
90
72
  onScroll: onScroll,
91
73
  scrollToBottom: scrollToBottom,
@@ -0,0 +1,8 @@
1
+ interface ArrowProps {
2
+ className?: string;
3
+ color?: string;
4
+ }
5
+ export declare const ArrowUp: ({ className, color }: ArrowProps) => JSX.Element;
6
+ export declare const ArrowDown: ({ className, color }: ArrowProps) => JSX.Element;
7
+ export {};
8
+ //# sourceMappingURL=icons.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icons.d.ts","sourceRoot":"","sources":["../../../src/components/MessageList/icons.tsx"],"names":[],"mappings":"AAEA,UAAU,UAAU;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,OAAO,yBAA0B,UAAU,gBAevD,CAAC;AAEF,eAAO,MAAM,SAAS,yBAA0B,UAAU,gBAezD,CAAC"}
@@ -0,0 +1,11 @@
1
+ import React from 'react';
2
+ export var ArrowUp = function (_a) {
3
+ var className = _a.className, color = _a.color;
4
+ return (React.createElement("svg", { className: className, "data-testid": 'arrow-up', fill: 'none', height: '24', viewBox: '0 0 24 24', width: '24', xmlns: 'http://www.w3.org/2000/svg' },
5
+ React.createElement("path", { d: 'M16.59 15.7051L12 11.1251L7.41 15.7051L6 14.2951L12 8.29508L18 14.2951L16.59 15.7051Z', fill: color || 'var(--primary-color)' })));
6
+ };
7
+ export var ArrowDown = function (_a) {
8
+ var className = _a.className, color = _a.color;
9
+ return (React.createElement("svg", { className: className, "data-testid": 'arrow-down', fill: 'none', height: '24', viewBox: '0 0 24 24', width: '24', xmlns: 'http://www.w3.org/2000/svg' },
10
+ React.createElement("path", { d: 'M7.41 8.29504L12 12.875L16.59 8.29504L18 9.70504L12 15.705L6 9.70504L7.41 8.29504Z', fill: color || 'var(--primary-color)' })));
11
+ };
@@ -2,6 +2,7 @@ export * from './ConnectionStatus';
2
2
  export * from './GiphyPreviewMessage';
3
3
  export * from './MessageList';
4
4
  export * from './MessageNotification';
5
+ export * from './ScrollToBottomButton';
5
6
  export * from './VirtualizedMessageList';
6
7
  export * from './hooks';
7
8
  export * from './utils';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/MessageList/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,eAAe,CAAC;AAC9B,cAAc,uBAAuB,CAAC;AACtC,cAAc,0BAA0B,CAAC;AACzC,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/MessageList/index.ts"],"names":[],"mappings":"AAAA,cAAc,oBAAoB,CAAC;AACnC,cAAc,uBAAuB,CAAC;AACtC,cAAc,eAAe,CAAC;AAC9B,cAAc,uBAAuB,CAAC;AACtC,cAAc,wBAAwB,CAAC;AACvC,cAAc,0BAA0B,CAAC;AACzC,cAAc,SAAS,CAAC;AACxB,cAAc,SAAS,CAAC"}
@@ -2,6 +2,7 @@ export * from './ConnectionStatus'; // TODO: export this under its own folder
2
2
  export * from './GiphyPreviewMessage';
3
3
  export * from './MessageList';
4
4
  export * from './MessageNotification';
5
+ export * from './ScrollToBottomButton';
5
6
  export * from './VirtualizedMessageList';
6
7
  export * from './hooks';
7
8
  export * from './utils';
@@ -32,14 +32,16 @@ declare type ProcessMessagesParams<StreamChatGenerics extends DefaultStreamChatG
32
32
  * @return {StreamMessage<StreamChatGenerics>[]} Transformed list of messages
33
33
  */
34
34
  export declare const processMessages: <StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics>(params: ProcessMessagesParams<StreamChatGenerics>) => StreamMessage<StreamChatGenerics>[];
35
- export declare const makeDateMessageId: (date?: string | Date | undefined) => string;
35
+ export declare const makeDateMessageId: (date?: string | Date) => string;
36
36
  export declare const getLastReceived: <StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics>(messages: StreamMessage<StreamChatGenerics>[]) => string | null;
37
37
  export declare const getReadStates: <StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics>(messages: StreamMessage<StreamChatGenerics>[], read: Record<string, {
38
38
  last_read: Date;
39
39
  user: UserResponse<StreamChatGenerics>;
40
40
  }> | undefined, returnAllReadData: boolean) => Record<string, UserResponse<StreamChatGenerics>[]>;
41
- export declare const insertIntro: <StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics>(messages: StreamMessage<StreamChatGenerics>[], headerPosition?: number | undefined) => StreamMessage<StreamChatGenerics>[];
41
+ export declare const insertIntro: <StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics>(messages: StreamMessage<StreamChatGenerics>[], headerPosition?: number) => StreamMessage<StreamChatGenerics>[];
42
42
  export declare type GroupStyle = '' | 'middle' | 'top' | 'bottom' | 'single';
43
43
  export declare const getGroupStyles: <StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics>(message: StreamMessage<StreamChatGenerics>, previousMessage: StreamMessage<StreamChatGenerics>, nextMessage: StreamMessage<StreamChatGenerics>, noGroupByUser: boolean) => GroupStyle;
44
+ export declare const hasMoreMessagesProbably: (returnedCountMessages: number, limit: number) => boolean;
45
+ export declare const hasNotMoreMessages: (returnedCountMessages: number, limit: number) => boolean;
44
46
  export {};
45
47
  //# sourceMappingURL=utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/components/MessageList/utils.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAEhD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAEvE,aAAK,qBAAqB,CACxB,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,QAAQ,EAAE,aAAa,CAAC,kBAAkB,CAAC,EAAE,CAAC;IAC9C,MAAM,EAAE,MAAM,CAAC;IACf,4BAA4B;IAC5B,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,2EAA2E;IAC3E,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,kEAAkE;IAClE,uBAAuB,CAAC,EAAE,OAAO,CAAC;IAClC,8DAA8D;IAC9D,QAAQ,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC;IACvB,+FAA+F;IAC/F,sBAAsB,CAAC,EAAE,KAAK,CAAC,QAAQ,CACrC,KAAK,CAAC,cAAc,CAAC,aAAa,CAAC,kBAAkB,CAAC,GAAG,SAAS,CAAC,CACpE,CAAC;CACH,CAAC;AAEF;;;;;;;;;;;;;;;GAeG;AACH,eAAO,MAAM,eAAe,8KAuF3B,CAAC;AAEF,eAAO,MAAM,iBAAiB,8CAQ7B,CAAC;AAGF,eAAO,MAAM,eAAe,oJAY3B,CAAC;AAEF,eAAO,MAAM,aAAa;eAIU,IAAI;;mCACnB,OAAO,uDAqC3B,CAAC;AAEF,eAAO,MAAM,WAAW,+MAoDvB,CAAC;AAEF,oBAAY,UAAU,GAAG,EAAE,GAAG,QAAQ,GAAG,KAAK,GAAG,QAAQ,GAAG,QAAQ,CAAC;AAErE,eAAO,MAAM,cAAc,oPAMV,OAAO,KACrB,UAuCF,CAAC"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/components/MessageList/utils.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAEhD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAEvE,aAAK,qBAAqB,CACxB,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,QAAQ,EAAE,aAAa,CAAC,kBAAkB,CAAC,EAAE,CAAC;IAC9C,MAAM,EAAE,MAAM,CAAC;IACf,4BAA4B;IAC5B,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,2EAA2E;IAC3E,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,kEAAkE;IAClE,uBAAuB,CAAC,EAAE,OAAO,CAAC;IAClC,8DAA8D;IAC9D,QAAQ,CAAC,EAAE,IAAI,GAAG,IAAI,CAAC;IACvB,+FAA+F;IAC/F,sBAAsB,CAAC,EAAE,KAAK,CAAC,QAAQ,CACrC,KAAK,CAAC,cAAc,CAAC,aAAa,CAAC,kBAAkB,CAAC,GAAG,SAAS,CAAC,CACpE,CAAC;CACH,CAAC;AAEF;;;;;;;;;;;;;;;GAeG;AACH,eAAO,MAAM,eAAe,8KAuF3B,CAAC;AAEF,eAAO,MAAM,iBAAiB,UAAW,MAAM,GAAG,IAAI,WAQrD,CAAC;AAGF,eAAO,MAAM,eAAe,oJAY3B,CAAC;AAEF,eAAO,MAAM,aAAa;eAIU,IAAI;;mCACnB,OAAO,uDAqC3B,CAAC;AAEF,eAAO,MAAM,WAAW,qJAIL,MAAM,wCAgDxB,CAAC;AAEF,oBAAY,UAAU,GAAG,EAAE,GAAG,QAAQ,GAAG,KAAK,GAAG,QAAQ,GAAG,QAAQ,CAAC;AAErE,eAAO,MAAM,cAAc,oPAMV,OAAO,KACrB,UAyCF,CAAC;AAOF,eAAO,MAAM,uBAAuB,0BAA2B,MAAM,SAAS,MAAM,YACnD,CAAC;AAElC,eAAO,MAAM,kBAAkB,0BAA2B,MAAM,SAAS,MAAM,YAChD,CAAC"}
@@ -87,7 +87,7 @@ export var makeDateMessageId = function (date) {
87
87
  catch (e) {
88
88
  idSuffix = nanoid();
89
89
  }
90
- return CUSTOM_MESSAGE_TYPE.date + "-" + idSuffix;
90
+ return "".concat(CUSTOM_MESSAGE_TYPE.date, "-").concat(idSuffix);
91
91
  };
92
92
  // fast since it usually iterates just the last few messages
93
93
  export var getLastReceived = function (messages) {
@@ -186,7 +186,8 @@ export var getGroupStyles = function (message, previousMessage, nextMessage, noG
186
186
  ((_b = previousMessage.attachments) === null || _b === void 0 ? void 0 : _b.length) !== 0 ||
187
187
  ((_c = message.user) === null || _c === void 0 ? void 0 : _c.id) !== ((_d = previousMessage.user) === null || _d === void 0 ? void 0 : _d.id) ||
188
188
  previousMessage.type === 'error' ||
189
- previousMessage.deleted_at;
189
+ previousMessage.deleted_at ||
190
+ (message.reaction_counts && Object.keys(message.reaction_counts).length > 0);
190
191
  var isBottomMessage = !nextMessage ||
191
192
  nextMessage.customType === CUSTOM_MESSAGE_TYPE.date ||
192
193
  nextMessage.type === 'system' ||
@@ -194,7 +195,8 @@ export var getGroupStyles = function (message, previousMessage, nextMessage, noG
194
195
  ((_e = nextMessage.attachments) === null || _e === void 0 ? void 0 : _e.length) !== 0 ||
195
196
  ((_f = message.user) === null || _f === void 0 ? void 0 : _f.id) !== ((_g = nextMessage.user) === null || _g === void 0 ? void 0 : _g.id) ||
196
197
  nextMessage.type === 'error' ||
197
- nextMessage.deleted_at;
198
+ nextMessage.deleted_at ||
199
+ (nextMessage.reaction_counts && Object.keys(nextMessage.reaction_counts).length > 0);
198
200
  if (!isTopMessage && !isBottomMessage) {
199
201
  if (message.deleted_at || message.type === 'error')
200
202
  return 'single';
@@ -209,3 +211,14 @@ export var getGroupStyles = function (message, previousMessage, nextMessage, noG
209
211
  return 'top';
210
212
  return '';
211
213
  };
214
+ // "Probably" included, because it may happen that the last page was returned and it has exactly the size of the limit
215
+ // but the back-end cannot provide us with information on whether it has still more messages in the DB
216
+ // FIXME: once the pagination state is moved from Channel to MessageList, these should be moved as well.
217
+ // The MessageList should have configurable the limit for performing the requests.
218
+ // This parameter would then be used within these functions
219
+ export var hasMoreMessagesProbably = function (returnedCountMessages, limit) {
220
+ return returnedCountMessages === limit;
221
+ };
222
+ export var hasNotMoreMessages = function (returnedCountMessages, limit) {
223
+ return returnedCountMessages < limit;
224
+ };
@@ -3,7 +3,7 @@ export declare type ModalProps = {
3
3
  /** If true, modal is opened or visible. */
4
4
  open: boolean;
5
5
  /** Callback handler for closing of modal. */
6
- onClose?: () => void | ((event?: React.BaseSyntheticEvent) => void);
6
+ onClose?: (event: React.KeyboardEvent | React.MouseEvent<HTMLButtonElement | HTMLDivElement>) => void;
7
7
  };
8
- export declare const Modal: (props: PropsWithChildren<ModalProps>) => JSX.Element | null;
8
+ export declare const Modal: ({ children, onClose, open }: PropsWithChildren<ModalProps>) => JSX.Element | null;
9
9
  //# sourceMappingURL=Modal.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Modal.d.ts","sourceRoot":"","sources":["../../../src/components/Modal/Modal.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,iBAAiB,EAAqB,MAAM,OAAO,CAAC;AAIpE,oBAAY,UAAU,GAAG;IACvB,2CAA2C;IAC3C,IAAI,EAAE,OAAO,CAAC;IACd,6CAA6C;IAC7C,OAAO,CAAC,EAAE,MAAM,IAAI,GAAG,CAAC,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC,kBAAkB,KAAK,IAAI,CAAC,CAAC;CACrE,CAAC;AAEF,eAAO,MAAM,KAAK,UAAW,kBAAkB,UAAU,CAAC,uBA8CzD,CAAC"}
1
+ {"version":3,"file":"Modal.d.ts","sourceRoot":"","sources":["../../../src/components/Modal/Modal.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,iBAAiB,EAAqB,MAAM,OAAO,CAAC;AAMpE,oBAAY,UAAU,GAAG;IACvB,2CAA2C;IAC3C,IAAI,EAAE,OAAO,CAAC;IACd,6CAA6C;IAC7C,OAAO,CAAC,EAAE,CACR,KAAK,EAAE,KAAK,CAAC,aAAa,GAAG,KAAK,CAAC,UAAU,CAAC,iBAAiB,GAAG,cAAc,CAAC,KAC9E,IAAI,CAAC;CACX,CAAC;AAEF,eAAO,MAAM,KAAK,gCAAiC,kBAAkB,UAAU,CAAC,uBAiD/E,CAAC"}
@@ -1,8 +1,10 @@
1
1
  import React, { useEffect, useRef } from 'react';
2
- import { useTranslationContext } from '../../context/TranslationContext';
3
- export var Modal = function (props) {
4
- var children = props.children, onClose = props.onClose, open = props.open;
2
+ import { CloseIconRound } from './icons';
3
+ import { useChatContext, useTranslationContext } from '../../context';
4
+ export var Modal = function (_a) {
5
+ var children = _a.children, onClose = _a.onClose, open = _a.open;
5
6
  var t = useTranslationContext('Modal').t;
7
+ var themeVersion = useChatContext('Modal').themeVersion;
6
8
  var innerRef = useRef(null);
7
9
  var closeRef = useRef(null);
8
10
  var handleClick = function (event) {
@@ -10,25 +12,26 @@ export var Modal = function (props) {
10
12
  if (!innerRef.current || !closeRef.current)
11
13
  return;
12
14
  if (!innerRef.current.contains(target) || closeRef.current.contains(target))
13
- onClose === null || onClose === void 0 ? void 0 : onClose();
15
+ onClose === null || onClose === void 0 ? void 0 : onClose(event);
14
16
  };
15
17
  useEffect(function () {
16
18
  if (!open)
17
19
  return;
18
- var handleEscKey = function (event) {
20
+ var handleKeyDown = function (event) {
19
21
  if (event.key === 'Escape')
20
- onClose === null || onClose === void 0 ? void 0 : onClose();
22
+ onClose === null || onClose === void 0 ? void 0 : onClose(event);
21
23
  };
22
- document.addEventListener('keydown', handleEscKey);
23
- return function () { return document.removeEventListener('keydown', handleEscKey); };
24
+ document.addEventListener('keydown', handleKeyDown);
25
+ return function () { return document.removeEventListener('keydown', handleKeyDown); };
24
26
  }, [onClose, open]);
25
- var openClasses = open ? 'str-chat__modal--open' : 'str-chat__modal--closed';
26
27
  if (!open)
27
28
  return null;
28
- return (React.createElement("div", { className: "str-chat__modal " + openClasses, onClick: handleClick },
29
- React.createElement("button", { className: 'str-chat__modal__close-button', ref: closeRef, title: 'Close' },
30
- t('Close'),
31
- React.createElement("svg", { height: '10', width: '10', xmlns: 'http://www.w3.org/2000/svg' },
32
- React.createElement("path", { d: 'M9.916 1.027L8.973.084 5 4.058 1.027.084l-.943.943L4.058 5 .084 8.973l.943.943L5 5.942l3.973 3.974.943-.943L5.942 5z', fillRule: 'evenodd' }))),
33
- React.createElement("div", { className: 'str-chat__modal__inner', ref: innerRef }, children)));
29
+ return (React.createElement("div", { className: 'str-chat__modal str-chat__modal--open', onClick: handleClick },
30
+ React.createElement("button", { className: 'str-chat__modal__close-button', ref: closeRef, title: t('Close') },
31
+ themeVersion === '2' && React.createElement(CloseIconRound, null),
32
+ themeVersion === '1' && (React.createElement(React.Fragment, null,
33
+ t('Close'),
34
+ React.createElement("svg", { height: '10', width: '10', xmlns: 'http://www.w3.org/2000/svg' },
35
+ React.createElement("path", { d: 'M9.916 1.027L8.973.084 5 4.058 1.027.084l-.943.943L4.058 5 .084 8.973l.943.943L5 5.942l3.973 3.974.943-.943L5.942 5z', fillRule: 'evenodd' }))))),
36
+ React.createElement("div", { className: 'str-chat__modal__inner str-chat-react__modal__inner', ref: innerRef }, children)));
34
37
  };
@@ -0,0 +1,2 @@
1
+ export declare const CloseIconRound: () => JSX.Element;
2
+ //# sourceMappingURL=icons.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"icons.d.ts","sourceRoot":"","sources":["../../../src/components/Modal/icons.tsx"],"names":[],"mappings":"AAEA,eAAO,MAAM,cAAc,mBAkB1B,CAAC"}
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ export var CloseIconRound = function () { return (React.createElement("svg", { "data-testid": 'close-icon-round', fill: 'none', height: '28', viewBox: '0 0 28 28', width: '28', xmlns: 'http://www.w3.org/2000/svg' },
3
+ React.createElement("rect", { fill: '#72767E', height: '28', rx: '14', width: '28' }),
4
+ React.createElement("circle", { cx: '14', cy: '14', fill: '#72767E', r: '12' }),
5
+ React.createElement("path", { clipRule: 'evenodd', d: 'M28 14C28 21.732 21.732 28 14 28C6.26801 28 0 21.732 0 14C0 6.26801 6.26801 0 14 0C21.732 0 28 6.26801 28 14ZM26 14C26 20.6274 20.6274 26 14 26C7.37258 26 2 20.6274 2 14C2 7.37258 7.37258 2 14 2C20.6274 2 26 7.37258 26 14ZM19.59 7L21 8.41L15.41 14L21 19.59L19.59 21L14 15.41L8.41 21L7 19.59L12.59 14L7 8.41L8.41 7L14 12.59L19.59 7Z', fill: 'white', fillRule: 'evenodd' }))); };
@@ -15,6 +15,8 @@ export declare type ReactionSelectorProps<StreamChatGenerics extends DefaultStre
15
15
  handleReaction?: (reactionType: string, event: React.BaseSyntheticEvent) => Promise<void>;
16
16
  /** An array of the reaction objects to display in the list */
17
17
  latest_reactions?: ReactionResponse<StreamChatGenerics>[];
18
+ /** An array of the own reaction objects to distinguish own reactions visually */
19
+ own_reactions?: ReactionResponse<StreamChatGenerics>[];
18
20
  /** An object that keeps track of the count of each type of reaction on a message */
19
21
  reaction_counts?: {
20
22
  [key: string]: number;
@@ -1 +1 @@
1
- {"version":3,"file":"ReactionSelector.d.ts","sourceRoot":"","sources":["../../../src/components/Reactions/ReactionSelector.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAsE,MAAM,OAAO,CAAC;AAI3F,OAAO,EAAE,WAAW,EAA2B,MAAM,WAAW,CAAC;AACjE,OAAO,EAAwB,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAM3E,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AACnD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAEpD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,oBAAY,qBAAqB,CAC/B,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,6KAA6K;IAC7K,oBAAoB,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC;IACjD,+LAA+L;IAC/L,MAAM,CAAC,EAAE,KAAK,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;IACxC,yDAAyD;IACzD,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,6GAA6G;IAC7G,cAAc,CAAC,EAAE,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,kBAAkB,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1F,8DAA8D;IAC9D,gBAAgB,CAAC,EAAE,gBAAgB,CAAC,kBAAkB,CAAC,EAAE,CAAC;IAC1D,oFAAoF;IACpF,eAAe,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,CAAC;IAC5C,+DAA+D;IAC/D,eAAe,CAAC,EAAE,aAAa,EAAE,CAAC;IAClC,yFAAyF;IACzF,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,CAAC;AAsLF;;GAEG;AACH,eAAO,MAAM,gBAAgB,gIAES,CAAC"}
1
+ {"version":3,"file":"ReactionSelector.d.ts","sourceRoot":"","sources":["../../../src/components/Reactions/ReactionSelector.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAsE,MAAM,OAAO,CAAC;AAK3F,OAAO,EAAE,WAAW,EAA2B,MAAM,WAAW,CAAC;AACjE,OAAO,EAAwB,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAM3E,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AACnD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAEpD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,oBAAY,qBAAqB,CAC/B,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,6KAA6K;IAC7K,oBAAoB,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC;IACjD,+LAA+L;IAC/L,MAAM,CAAC,EAAE,KAAK,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;IACxC,yDAAyD;IACzD,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,6GAA6G;IAC7G,cAAc,CAAC,EAAE,CAAC,YAAY,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,kBAAkB,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1F,8DAA8D;IAC9D,gBAAgB,CAAC,EAAE,gBAAgB,CAAC,kBAAkB,CAAC,EAAE,CAAC;IAC1D,iFAAiF;IACjF,aAAa,CAAC,EAAE,gBAAgB,CAAC,kBAAkB,CAAC,EAAE,CAAC;IACvD,oFAAoF;IACpF,eAAe,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,CAAC;IAC5C,+DAA+D;IAC/D,eAAe,CAAC,EAAE,aAAa,EAAE,CAAC;IAClC,yFAAyF;IACzF,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,CAAC;AAiMF;;GAEG;AACH,eAAO,MAAM,gBAAgB,gIAES,CAAC"}
@@ -10,6 +10,7 @@ var __assign = (this && this.__assign) || function () {
10
10
  return __assign.apply(this, arguments);
11
11
  };
12
12
  import React, { Suspense, useCallback, useEffect, useMemo, useRef, useState } from 'react';
13
+ import clsx from 'clsx';
13
14
  import { isMutableRef } from './utils/utils';
14
15
  import { Avatar as DefaultAvatar } from '../Avatar';
15
16
  import { getStrippedEmojiData } from '../Channel/emojiData';
@@ -18,7 +19,7 @@ import { useEmojiContext } from '../../context/EmojiContext';
18
19
  import { useMessageContext } from '../../context/MessageContext';
19
20
  var UnMemoizedReactionSelector = React.forwardRef(function (props, ref) {
20
21
  var _a;
21
- var _b = props.additionalEmojiProps, additionalEmojiProps = _b === void 0 ? {} : _b, propAvatar = props.Avatar, _c = props.detailedView, detailedView = _c === void 0 ? true : _c, propHandleReaction = props.handleReaction, propLatestReactions = props.latest_reactions, propReactionCounts = props.reaction_counts, propReactionOptions = props.reactionOptions, _d = props.reverse, reverse = _d === void 0 ? false : _d;
22
+ var _b = props.additionalEmojiProps, additionalEmojiProps = _b === void 0 ? {} : _b, propAvatar = props.Avatar, _c = props.detailedView, detailedView = _c === void 0 ? true : _c, propHandleReaction = props.handleReaction, propLatestReactions = props.latest_reactions, propOwnReactions = props.own_reactions, propReactionCounts = props.reaction_counts, propReactionOptions = props.reactionOptions, _d = props.reverse, reverse = _d === void 0 ? false : _d;
22
23
  var contextAvatar = useComponentContext('ReactionSelector').Avatar;
23
24
  var _e = useEmojiContext('ReactionSelector'), Emoji = _e.Emoji, emojiConfig = _e.emojiConfig;
24
25
  var _f = useMessageContext('ReactionSelector'), contextHandleReaction = _f.handleReaction, message = _f.message;
@@ -26,6 +27,7 @@ var UnMemoizedReactionSelector = React.forwardRef(function (props, ref) {
26
27
  var Avatar = propAvatar || contextAvatar || DefaultAvatar;
27
28
  var handleReaction = propHandleReaction || contextHandleReaction;
28
29
  var latestReactions = propLatestReactions || (message === null || message === void 0 ? void 0 : message.latest_reactions) || [];
30
+ var ownReactions = propOwnReactions || (message === null || message === void 0 ? void 0 : message.own_reactions) || [];
29
31
  var reactionCounts = propReactionCounts || (message === null || message === void 0 ? void 0 : message.reaction_counts) || {};
30
32
  var reactionOptions = propReactionOptions || defaultMinimalEmojis;
31
33
  var reactionsAreCustom = !!(propReactionOptions === null || propReactionOptions === void 0 ? void 0 : propReactionOptions.length);
@@ -71,27 +73,34 @@ var UnMemoizedReactionSelector = React.forwardRef(function (props, ref) {
71
73
  })
72
74
  .filter(Boolean);
73
75
  };
76
+ var iHaveReactedWithReaction = function (reactionType) {
77
+ return ownReactions.find(function (reaction) { return reaction.type === reactionType; });
78
+ };
74
79
  var getLatestUserForReactionType = function (type) {
75
80
  var _a;
76
81
  return ((_a = latestReactions.find(function (reaction) { return reaction.type === type && !!reaction.user; })) === null || _a === void 0 ? void 0 : _a.user) ||
77
82
  undefined;
78
83
  };
79
- return (React.createElement("div", { className: "str-chat__reaction-selector " + (reverse ? 'str-chat__reaction-selector--reverse' : ''), "data-testid": 'reaction-selector', ref: ref },
84
+ return (React.createElement("div", { className: clsx('str-chat__reaction-selector str-chat__message-reaction-selector', {
85
+ 'str-chat__reaction-selector--reverse': reverse,
86
+ }), "data-testid": 'reaction-selector', ref: ref },
80
87
  !!tooltipReactionType && detailedView && (React.createElement("div", { className: 'str-chat__reaction-selector-tooltip', ref: tooltipRef, style: {
81
88
  left: tooltipPositions === null || tooltipPositions === void 0 ? void 0 : tooltipPositions.tooltip,
82
89
  visibility: tooltipPositions ? 'visible' : 'hidden',
83
90
  } },
84
91
  React.createElement("div", { className: 'arrow', style: { left: tooltipPositions === null || tooltipPositions === void 0 ? void 0 : tooltipPositions.arrow } }), (_a = getUsersPerReactionType(tooltipReactionType)) === null || _a === void 0 ? void 0 :
85
- _a.map(function (user, i, users) { return (React.createElement("span", { className: 'latest-user-username', key: "key-" + i + "-" + user }, "" + user + (i < users.length - 1 ? ', ' : ''))); }))),
86
- React.createElement("ul", { className: 'str-chat__message-reactions-list' }, reactionOptions.map(function (reactionOption) {
92
+ _a.map(function (user, i, users) { return (React.createElement("span", { className: 'latest-user-username', key: "key-".concat(i, "-").concat(user) }, "".concat(user).concat(i < users.length - 1 ? ', ' : ''))); }))),
93
+ React.createElement("ul", { className: 'str-chat__message-reactions-list str-chat__message-reactions-options' }, reactionOptions.map(function (reactionOption) {
87
94
  var latestUser = getLatestUserForReactionType(reactionOption.id);
88
95
  var count = reactionCounts && reactionCounts[reactionOption.id];
89
- return (React.createElement("li", { key: "item-" + reactionOption.id },
90
- React.createElement("button", { "aria-label": "Select Reaction: " + reactionOption.name, className: 'str-chat__message-reactions-list-item', "data-text": reactionOption.id, onClick: function (event) { return handleReaction(reactionOption.id, event); } },
91
- !!count && detailedView && (React.createElement(React.Fragment, null,
92
- React.createElement("div", { className: 'latest-user', onClick: hideTooltip, onMouseEnter: function (e) { return showTooltip(e, reactionOption.id); }, onMouseLeave: hideTooltip }, latestUser ? (React.createElement(Avatar, { image: latestUser.image, name: latestUser.name, size: 20, user: latestUser })) : (React.createElement("div", { className: 'latest-user-not-found' }))))),
96
+ return (React.createElement("li", { key: "item-".concat(reactionOption.id) },
97
+ React.createElement("button", { "aria-label": "Select Reaction: ".concat(reactionOption.name), className: clsx('str-chat__message-reactions-list-item str-chat__message-reactions-option', {
98
+ 'str-chat__message-reactions-option-selected': iHaveReactedWithReaction(reactionOption.id),
99
+ }), "data-text": reactionOption.id, onClick: function (event) { return handleReaction(reactionOption.id, event); } },
100
+ !!count && detailedView && (React.createElement("div", { className: 'latest-user str-chat__message-reactions-last-user', onClick: hideTooltip, onMouseEnter: function (e) { return showTooltip(e, reactionOption.id); }, onMouseLeave: hideTooltip }, latestUser ? (React.createElement(Avatar, { image: latestUser.image, name: latestUser.name, size: 20, user: latestUser })) : (React.createElement("div", { className: 'latest-user-not-found' })))),
93
101
  React.createElement(Suspense, { fallback: null },
94
- React.createElement(Emoji, __assign({ data: emojiData, emoji: reactionOption, size: 20 }, (reactionsAreCustom ? additionalEmojiProps : emojiSetDef)))),
102
+ React.createElement("span", { className: 'str-chat__message-reaction-emoji' },
103
+ React.createElement(Emoji, __assign({ data: emojiData, emoji: reactionOption, size: 20 }, (reactionsAreCustom ? additionalEmojiProps : emojiSetDef))))),
95
104
  Boolean(count) && detailedView && (React.createElement("span", { className: 'str-chat__message-reactions-list-item__count' }, count || '')))));
96
105
  }))));
97
106
  });
@@ -1,13 +1,15 @@
1
- import { ReactionEmoji } from '../Channel/emojiData';
2
1
  import type { NimbleEmojiProps } from 'emoji-mart';
3
2
  import type { ReactionResponse } from 'stream-chat';
4
3
  import type { ReactEventHandler } from '../Message/types';
5
4
  import type { DefaultStreamChatGenerics } from '../../types/types';
5
+ import type { ReactionEmoji } from '../Channel/emojiData';
6
6
  export declare type ReactionsListProps<StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics> = {
7
7
  /** Additional props to be passed to the [NimbleEmoji](https://github.com/missive/emoji-mart/blob/master/src/components/emoji/nimble-emoji.js) component from `emoji-mart` */
8
8
  additionalEmojiProps?: Partial<NimbleEmojiProps>;
9
9
  /** Custom on click handler for an individual reaction, defaults to `onReactionListClick` from the `MessageContext` */
10
10
  onClick?: ReactEventHandler;
11
+ /** An array of the own reaction objects to distinguish own reactions visually */
12
+ own_reactions?: ReactionResponse<StreamChatGenerics>[];
11
13
  /** An object that keeps track of the count of each type of reaction on a message */
12
14
  reaction_counts?: {
13
15
  [key: string]: number;
@@ -1 +1 @@
1
- {"version":3,"file":"ReactionsList.d.ts","sourceRoot":"","sources":["../../../src/components/Reactions/ReactionsList.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAwB,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAK3E,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AACnD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAEpD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAE1D,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,oBAAY,kBAAkB,CAC5B,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,6KAA6K;IAC7K,oBAAoB,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC;IACjD,sHAAsH;IACtH,OAAO,CAAC,EAAE,iBAAiB,CAAC;IAC5B,oFAAoF;IACpF,eAAe,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,CAAC;IAC5C,+DAA+D;IAC/D,eAAe,CAAC,EAAE,aAAa,EAAE,CAAC;IAClC,8DAA8D;IAC9D,SAAS,CAAC,EAAE,gBAAgB,CAAC,kBAAkB,CAAC,EAAE,CAAC;IACnD,4EAA4E;IAC5E,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,CAAC;AAyGF;;GAEG;AACH,eAAO,MAAM,aAAa,yJAAwE,CAAC"}
1
+ {"version":3,"file":"ReactionsList.d.ts","sourceRoot":"","sources":["../../../src/components/Reactions/ReactionsList.tsx"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AACnD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAEpD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAE1D,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AACnE,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAK1D,oBAAY,kBAAkB,CAC5B,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,6KAA6K;IAC7K,oBAAoB,CAAC,EAAE,OAAO,CAAC,gBAAgB,CAAC,CAAC;IACjD,sHAAsH;IACtH,OAAO,CAAC,EAAE,iBAAiB,CAAC;IAC5B,iFAAiF;IACjF,aAAa,CAAC,EAAE,gBAAgB,CAAC,kBAAkB,CAAC,EAAE,CAAC;IACvD,oFAAoF;IACpF,eAAe,CAAC,EAAE;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,CAAC;IAC5C,+DAA+D;IAC/D,eAAe,CAAC,EAAE,aAAa,EAAE,CAAC;IAClC,8DAA8D;IAC9D,SAAS,CAAC,EAAE,gBAAgB,CAAC,kBAAkB,CAAC,EAAE,CAAC;IACnD,4EAA4E;IAC5E,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB,CAAC;AAyHF;;GAEG;AACH,eAAO,MAAM,aAAa,yJAAwE,CAAC"}
@@ -9,64 +9,65 @@ var __assign = (this && this.__assign) || function () {
9
9
  };
10
10
  return __assign.apply(this, arguments);
11
11
  };
12
- import React, { Suspense, useMemo } from 'react';
13
- import { getStrippedEmojiData } from '../Channel/emojiData';
12
+ var __rest = (this && this.__rest) || function (s, e) {
13
+ var t = {};
14
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
15
+ t[p] = s[p];
16
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
17
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
18
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
19
+ t[p[i]] = s[p[i]];
20
+ }
21
+ return t;
22
+ };
23
+ import React, { Suspense, useState } from 'react';
24
+ import clsx from 'clsx';
14
25
  import { useEmojiContext } from '../../context/EmojiContext';
15
26
  import { useMessageContext } from '../../context/MessageContext';
27
+ import { useChatContext } from '../../context/ChatContext';
28
+ import { useProcessReactions } from './hooks/useProcessReactions';
29
+ import { PopperTooltip } from '../Tooltip';
30
+ import { useEnterLeaveHandlers } from '../Tooltip/hooks';
31
+ var ButtonWithTooltip = function (_a) {
32
+ var children = _a.children, onMouseEnter = _a.onMouseEnter, onMouseLeave = _a.onMouseLeave, rest = __rest(_a, ["children", "onMouseEnter", "onMouseLeave"]);
33
+ var _b = useState(null), referenceElement = _b[0], setReferenceElement = _b[1];
34
+ var _c = useEnterLeaveHandlers({
35
+ onMouseEnter: onMouseEnter,
36
+ onMouseLeave: onMouseLeave,
37
+ }), handleEnter = _c.handleEnter, handleLeave = _c.handleLeave, tooltipVisible = _c.tooltipVisible;
38
+ var themeVersion = useChatContext('ButtonWithTooltip').themeVersion;
39
+ return (React.createElement(React.Fragment, null,
40
+ themeVersion === '2' && (React.createElement(PopperTooltip, { referenceElement: referenceElement, visible: tooltipVisible }, rest.title)),
41
+ React.createElement("button", __assign({ onMouseEnter: handleEnter, onMouseLeave: handleLeave, ref: setReferenceElement }, rest), children)));
42
+ };
16
43
  var UnMemoizedReactionsList = function (props) {
17
- var additionalEmojiProps = props.additionalEmojiProps, onClick = props.onClick, propReactionCounts = props.reaction_counts, propReactionOptions = props.reactionOptions, propReactions = props.reactions, _a = props.reverse, reverse = _a === void 0 ? false : _a;
44
+ var onClick = props.onClick, _a = props.reverse, reverse = _a === void 0 ? false : _a, rest = __rest(props, ["onClick", "reverse"]);
18
45
  var _b = useEmojiContext('ReactionsList'), Emoji = _b.Emoji, emojiConfig = _b.emojiConfig;
19
- var _c = useMessageContext('ReactionsList'), message = _c.message, onReactionListClick = _c.onReactionListClick;
20
- var _d = emojiConfig || {}, defaultMinimalEmojis = _d.defaultMinimalEmojis, fullEmojiData = _d.emojiData, emojiSetDef = _d.emojiSetDef;
21
- var reactions = propReactions || message.latest_reactions || [];
22
- var reactionCounts = propReactionCounts || message.reaction_counts || {};
23
- var reactionOptions = propReactionOptions || defaultMinimalEmojis;
24
- var reactionsAreCustom = !!(propReactionOptions === null || propReactionOptions === void 0 ? void 0 : propReactionOptions.length);
25
- var emojiData = useMemo(function () { return (reactionsAreCustom ? fullEmojiData : getStrippedEmojiData(fullEmojiData)); }, [fullEmojiData, reactionsAreCustom]);
26
- if (!reactions.length)
46
+ var onReactionListClick = useMessageContext('ReactionsList').onReactionListClick;
47
+ var _c = useProcessReactions(__assign({ emojiConfig: emojiConfig }, rest)), additionalEmojiProps = _c.additionalEmojiProps, aggregatedUserNamesByType = _c.aggregatedUserNamesByType, emojiData = _c.emojiData, getEmojiByReactionType = _c.getEmojiByReactionType, iHaveReactedWithReaction = _c.iHaveReactedWithReaction, latestReactions = _c.latestReactions, latestReactionTypes = _c.latestReactionTypes, reactionCounts = _c.reactionCounts, supportedReactionsArePresent = _c.supportedReactionsArePresent, totalReactionCount = _c.totalReactionCount;
48
+ if (!latestReactions.length)
27
49
  return null;
28
- var getTotalReactionCount = function () {
29
- return Object.values(reactionCounts).reduce(function (total, count) { return total + count; }, 0);
30
- };
31
- var getCurrentMessageReactionTypes = function () {
32
- var reactionTypes = [];
33
- reactions.forEach(function (_a) {
34
- var type = _a.type;
35
- if (reactionTypes.indexOf(type) === -1) {
36
- reactionTypes.push(type);
37
- }
38
- });
39
- return reactionTypes;
40
- };
41
- var getEmojiByReactionType = function (type) {
42
- var reactionEmoji = reactionOptions.find(function (option) { return option.id === type; });
43
- return reactionEmoji;
44
- };
45
- var getSupportedReactionMap = function () {
46
- var reactionMap = {};
47
- reactionOptions.forEach(function (_a) {
48
- var id = _a.id;
49
- return (reactionMap[id] = true);
50
- });
51
- return reactionMap;
52
- };
53
- var messageReactionTypes = getCurrentMessageReactionTypes();
54
- var supportedReactionMap = getSupportedReactionMap();
55
- var supportedReactionsArePresent = messageReactionTypes.some(function (type) { return supportedReactionMap[type]; });
56
50
  if (!supportedReactionsArePresent)
57
51
  return null;
58
- return (React.createElement("div", { "aria-label": 'Reaction list', className: "str-chat__reaction-list " + (reverse ? 'str-chat__reaction-list--reverse' : ''), "data-testid": 'reaction-list', onClick: onClick || onReactionListClick, onKeyPress: onClick || onReactionListClick, role: 'figure' },
59
- React.createElement("ul", null,
60
- messageReactionTypes.map(function (reactionType) {
52
+ return (React.createElement("div", { "aria-label": 'Reaction list', className: clsx('str-chat__reaction-list str-chat__message-reactions-container', {
53
+ 'str-chat__reaction-list--reverse': reverse,
54
+ }), "data-testid": 'reaction-list', onClick: onClick || onReactionListClick, onKeyUp: onClick || onReactionListClick, role: 'figure' },
55
+ React.createElement("ul", { className: 'str-chat__message-reactions' },
56
+ latestReactionTypes.map(function (reactionType) {
61
57
  var emojiObject = getEmojiByReactionType(reactionType);
62
- return emojiObject ? (React.createElement("li", { key: emojiObject.id },
63
- React.createElement("button", { "aria-label": "Reactions: " + reactionType },
58
+ var isOwnReaction = iHaveReactedWithReaction(reactionType);
59
+ return emojiObject ? (React.createElement("li", { className: clsx('str-chat__message-reaction', {
60
+ 'str-chat__message-reaction-own': isOwnReaction,
61
+ }), key: emojiObject.id },
62
+ React.createElement(ButtonWithTooltip, { "aria-label": "Reactions: ".concat(reactionType), title: aggregatedUserNamesByType[reactionType].join(', '), type: 'button' },
64
63
  React.createElement(Suspense, { fallback: null },
65
- React.createElement(Emoji, __assign({ data: emojiData, emoji: emojiObject, size: 16 }, (reactionsAreCustom ? additionalEmojiProps : emojiSetDef)))),
66
- "\u00A0"))) : null;
64
+ React.createElement("span", { className: 'str-chat__message-reaction-emoji' },
65
+ React.createElement(Emoji, __assign({ data: emojiData, emoji: emojiObject, size: 16 }, additionalEmojiProps)))),
66
+ "\u00A0",
67
+ React.createElement("span", { className: 'str-chat__message-reaction-count', "data-testclass": 'reaction-list-reaction-count' }, reactionCounts[reactionType])))) : null;
67
68
  }),
68
69
  React.createElement("li", null,
69
- React.createElement("span", { className: 'str-chat__reaction-list--counter' }, getTotalReactionCount())))));
70
+ React.createElement("span", { className: 'str-chat__reaction-list--counter' }, totalReactionCount)))));
70
71
  };
71
72
  /**
72
73
  * Component that displays a list of reactions on a message.