stream-chat-react 8.0.0 → 8.1.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 (245) hide show
  1. package/dist/browser.full-bundle.js +1820 -609
  2. package/dist/browser.full-bundle.js.map +1 -1
  3. package/dist/browser.full-bundle.min.js +4 -4
  4. package/dist/browser.full-bundle.min.js.map +1 -1
  5. package/dist/components/Attachment/AttachmentActions.d.ts +0 -1
  6. package/dist/components/Attachment/AttachmentActions.d.ts.map +1 -1
  7. package/dist/components/Attachment/Audio.d.ts +0 -1
  8. package/dist/components/Attachment/Audio.d.ts.map +1 -1
  9. package/dist/components/Attachment/FileAttachment.d.ts +0 -1
  10. package/dist/components/Attachment/FileAttachment.d.ts.map +1 -1
  11. package/dist/components/AutoCompleteTextarea/Item.d.ts.map +1 -1
  12. package/dist/components/AutoCompleteTextarea/Item.js +2 -1
  13. package/dist/components/AutoCompleteTextarea/Textarea.d.ts.map +1 -1
  14. package/dist/components/AutoCompleteTextarea/Textarea.js +1 -1
  15. package/dist/components/Channel/Channel.d.ts.map +1 -1
  16. package/dist/components/Channel/Channel.js +102 -24
  17. package/dist/components/Channel/channelState.d.ts +17 -0
  18. package/dist/components/Channel/channelState.d.ts.map +1 -1
  19. package/dist/components/Channel/channelState.js +24 -2
  20. package/dist/components/Channel/hooks/useCreateChannelStateContext.d.ts.map +1 -1
  21. package/dist/components/Channel/hooks/useCreateChannelStateContext.js +7 -1
  22. package/dist/components/Channel/hooks/useIsMounted.d.ts +0 -1
  23. package/dist/components/Channel/hooks/useIsMounted.d.ts.map +1 -1
  24. package/dist/components/Channel/utils.d.ts +5 -0
  25. package/dist/components/Channel/utils.d.ts.map +1 -0
  26. package/dist/components/Channel/utils.js +19 -0
  27. package/dist/components/ChannelHeader/icons.d.ts +0 -1
  28. package/dist/components/ChannelHeader/icons.d.ts.map +1 -1
  29. package/dist/components/ChannelHeader/icons.js +1 -1
  30. package/dist/components/ChannelList/ChannelList.d.ts +2 -3
  31. package/dist/components/ChannelList/ChannelList.d.ts.map +1 -1
  32. package/dist/components/ChannelList/ChannelList.js +1 -0
  33. package/dist/components/ChannelList/hooks/useChannelDeletedListener.d.ts +0 -1
  34. package/dist/components/ChannelList/hooks/useChannelDeletedListener.d.ts.map +1 -1
  35. package/dist/components/ChannelList/hooks/useChannelHiddenListener.d.ts +0 -1
  36. package/dist/components/ChannelList/hooks/useChannelHiddenListener.d.ts.map +1 -1
  37. package/dist/components/ChannelList/hooks/useChannelTruncatedListener.d.ts +0 -1
  38. package/dist/components/ChannelList/hooks/useChannelTruncatedListener.d.ts.map +1 -1
  39. package/dist/components/ChannelList/hooks/useChannelUpdatedListener.d.ts +0 -1
  40. package/dist/components/ChannelList/hooks/useChannelUpdatedListener.d.ts.map +1 -1
  41. package/dist/components/ChannelList/hooks/useChannelVisibleListener.d.ts +0 -1
  42. package/dist/components/ChannelList/hooks/useChannelVisibleListener.d.ts.map +1 -1
  43. package/dist/components/ChannelList/hooks/useMessageNewListener.d.ts +0 -1
  44. package/dist/components/ChannelList/hooks/useMessageNewListener.d.ts.map +1 -1
  45. package/dist/components/ChannelList/hooks/useNotificationAddedToChannelListener.d.ts +0 -1
  46. package/dist/components/ChannelList/hooks/useNotificationAddedToChannelListener.d.ts.map +1 -1
  47. package/dist/components/ChannelList/hooks/useNotificationMessageNewListener.d.ts +0 -1
  48. package/dist/components/ChannelList/hooks/useNotificationMessageNewListener.d.ts.map +1 -1
  49. package/dist/components/ChannelList/hooks/useNotificationRemovedFromChannelListener.d.ts +0 -1
  50. package/dist/components/ChannelList/hooks/useNotificationRemovedFromChannelListener.d.ts.map +1 -1
  51. package/dist/components/ChannelList/hooks/usePaginatedChannels.d.ts +0 -1
  52. package/dist/components/ChannelList/hooks/usePaginatedChannels.d.ts.map +1 -1
  53. package/dist/components/ChannelList/hooks/useUserPresenceChangedListener.d.ts +0 -1
  54. package/dist/components/ChannelList/hooks/useUserPresenceChangedListener.d.ts.map +1 -1
  55. package/dist/components/ChannelPreview/ChannelPreview.d.ts.map +1 -1
  56. package/dist/components/ChannelPreview/ChannelPreview.js +6 -10
  57. package/dist/components/ChannelPreview/ChannelPreviewMessenger.d.ts +0 -1
  58. package/dist/components/ChannelPreview/ChannelPreviewMessenger.d.ts.map +1 -1
  59. package/dist/components/ChannelPreview/utils.d.ts +0 -1
  60. package/dist/components/ChannelPreview/utils.d.ts.map +1 -1
  61. package/dist/components/Chat/Chat.d.ts.map +1 -1
  62. package/dist/components/Chat/Chat.js +2 -1
  63. package/dist/components/Chat/hooks/useChat.d.ts +1 -1
  64. package/dist/components/Chat/hooks/useChat.d.ts.map +1 -1
  65. package/dist/components/Chat/hooks/useChat.js +12 -7
  66. package/dist/components/Chat/hooks/useCreateChatContext.d.ts.map +1 -1
  67. package/dist/components/Chat/hooks/useCreateChatContext.js +2 -1
  68. package/dist/components/DateSeparator/DateSeparator.d.ts +0 -1
  69. package/dist/components/DateSeparator/DateSeparator.d.ts.map +1 -1
  70. package/dist/components/Gallery/Gallery.d.ts +0 -1
  71. package/dist/components/Gallery/Gallery.d.ts.map +1 -1
  72. package/dist/components/InfiniteScrollPaginator/InfiniteScroll.d.ts +2 -2
  73. package/dist/components/InfiniteScrollPaginator/InfiniteScroll.d.ts.map +1 -1
  74. package/dist/components/InfiniteScrollPaginator/InfiniteScroll.js +16 -45
  75. package/dist/components/InfiniteScrollPaginator/index.d.ts +0 -2
  76. package/dist/components/InfiniteScrollPaginator/index.d.ts.map +1 -1
  77. package/dist/components/InfiniteScrollPaginator/index.js +0 -2
  78. package/dist/components/Message/FixedHeightMessage.d.ts +0 -1
  79. package/dist/components/Message/FixedHeightMessage.d.ts.map +1 -1
  80. package/dist/components/Message/Message.d.ts +0 -1
  81. package/dist/components/Message/Message.d.ts.map +1 -1
  82. package/dist/components/Message/Message.js +8 -7
  83. package/dist/components/Message/MessageCommerce.d.ts +0 -1
  84. package/dist/components/Message/MessageCommerce.d.ts.map +1 -1
  85. package/dist/components/Message/MessageDeleted.d.ts +0 -1
  86. package/dist/components/Message/MessageDeleted.d.ts.map +1 -1
  87. package/dist/components/Message/MessageRepliesCountButton.d.ts.map +1 -1
  88. package/dist/components/Message/MessageRepliesCountButton.js +10 -24
  89. package/dist/components/Message/MessageSimple.d.ts +0 -1
  90. package/dist/components/Message/MessageSimple.d.ts.map +1 -1
  91. package/dist/components/Message/MessageSimple.js +2 -2
  92. package/dist/components/Message/MessageTeam.d.ts +0 -1
  93. package/dist/components/Message/MessageTeam.d.ts.map +1 -1
  94. package/dist/components/Message/MessageText.d.ts +0 -1
  95. package/dist/components/Message/MessageText.d.ts.map +1 -1
  96. package/dist/components/Message/MessageTimestamp.d.ts +0 -1
  97. package/dist/components/Message/MessageTimestamp.d.ts.map +1 -1
  98. package/dist/components/Message/QuotedMessage.d.ts +0 -1
  99. package/dist/components/Message/QuotedMessage.d.ts.map +1 -1
  100. package/dist/components/Message/QuotedMessage.js +3 -1
  101. package/dist/components/Message/hooks/useEditHandler.d.ts +0 -1
  102. package/dist/components/Message/hooks/useEditHandler.d.ts.map +1 -1
  103. package/dist/components/Message/hooks/useUserHandler.d.ts +0 -1
  104. package/dist/components/Message/hooks/useUserHandler.d.ts.map +1 -1
  105. package/dist/components/Message/icons.d.ts +0 -1
  106. package/dist/components/Message/icons.d.ts.map +1 -1
  107. package/dist/components/Message/types.d.ts +2 -1
  108. package/dist/components/Message/types.d.ts.map +1 -1
  109. package/dist/components/Message/utils.d.ts.map +1 -1
  110. package/dist/components/Message/utils.js +3 -0
  111. package/dist/components/MessageActions/MessageActionsBox.d.ts +0 -1
  112. package/dist/components/MessageActions/MessageActionsBox.d.ts.map +1 -1
  113. package/dist/components/MessageInput/EditMessageForm.d.ts +0 -1
  114. package/dist/components/MessageInput/EditMessageForm.d.ts.map +1 -1
  115. package/dist/components/MessageInput/EmojiPicker.d.ts +0 -1
  116. package/dist/components/MessageInput/EmojiPicker.d.ts.map +1 -1
  117. package/dist/components/MessageInput/MessageInputFlat.d.ts +0 -1
  118. package/dist/components/MessageInput/MessageInputFlat.d.ts.map +1 -1
  119. package/dist/components/MessageInput/MessageInputFlat.js +25 -3
  120. package/dist/components/MessageInput/MessageInputSmall.d.ts +0 -1
  121. package/dist/components/MessageInput/MessageInputSmall.d.ts.map +1 -1
  122. package/dist/components/MessageInput/MessageInputSmall.js +26 -4
  123. package/dist/components/MessageInput/QuotedMessagePreview.d.ts +0 -1
  124. package/dist/components/MessageInput/QuotedMessagePreview.d.ts.map +1 -1
  125. package/dist/components/MessageInput/UploadsPreview.d.ts +0 -1
  126. package/dist/components/MessageInput/UploadsPreview.d.ts.map +1 -1
  127. package/dist/components/MessageInput/hooks/useAttachments.d.ts +0 -1
  128. package/dist/components/MessageInput/hooks/useAttachments.d.ts.map +1 -1
  129. package/dist/components/MessageInput/hooks/useCooldownTimer.d.ts.map +1 -1
  130. package/dist/components/MessageInput/hooks/useCooldownTimer.js +19 -29
  131. package/dist/components/MessageInput/hooks/useEmojiPicker.d.ts +0 -1
  132. package/dist/components/MessageInput/hooks/useEmojiPicker.d.ts.map +1 -1
  133. package/dist/components/MessageInput/hooks/useFileUploads.d.ts +0 -1
  134. package/dist/components/MessageInput/hooks/useFileUploads.d.ts.map +1 -1
  135. package/dist/components/MessageInput/hooks/useMessageInputText.d.ts +0 -1
  136. package/dist/components/MessageInput/hooks/useMessageInputText.d.ts.map +1 -1
  137. package/dist/components/MessageInput/hooks/useSubmitHandler.d.ts +0 -1
  138. package/dist/components/MessageInput/hooks/useSubmitHandler.d.ts.map +1 -1
  139. package/dist/components/MessageList/GiphyPreviewMessage.d.ts +0 -1
  140. package/dist/components/MessageList/GiphyPreviewMessage.d.ts.map +1 -1
  141. package/dist/components/MessageList/MessageList.d.ts +8 -3
  142. package/dist/components/MessageList/MessageList.d.ts.map +1 -1
  143. package/dist/components/MessageList/MessageList.js +90 -24
  144. package/dist/components/MessageList/MessageListNotifications.d.ts +1 -0
  145. package/dist/components/MessageList/MessageListNotifications.d.ts.map +1 -1
  146. package/dist/components/MessageList/MessageListNotifications.js +2 -2
  147. package/dist/components/MessageList/VirtualizedMessageList.d.ts +11 -1
  148. package/dist/components/MessageList/VirtualizedMessageList.d.ts.map +1 -1
  149. package/dist/components/MessageList/VirtualizedMessageList.js +116 -19
  150. package/dist/components/MessageList/hooks/index.d.ts +0 -1
  151. package/dist/components/MessageList/hooks/index.d.ts.map +1 -1
  152. package/dist/components/MessageList/hooks/index.js +0 -1
  153. package/dist/components/MessageList/hooks/useEnrichedMessages.d.ts +0 -1
  154. package/dist/components/MessageList/hooks/useEnrichedMessages.d.ts.map +1 -1
  155. package/dist/components/MessageList/hooks/useEnrichedMessages.js +4 -4
  156. package/dist/components/MessageList/hooks/useGiphyPreview.d.ts +0 -1
  157. package/dist/components/MessageList/hooks/useGiphyPreview.d.ts.map +1 -1
  158. package/dist/components/MessageList/hooks/useMessageListElements.d.ts.map +1 -1
  159. package/dist/components/MessageList/hooks/useMessageListElements.js +1 -1
  160. package/dist/components/MessageList/hooks/useNewMessageNotification.d.ts +1 -2
  161. package/dist/components/MessageList/hooks/useNewMessageNotification.d.ts.map +1 -1
  162. package/dist/components/MessageList/hooks/useNewMessageNotification.js +6 -2
  163. package/dist/components/MessageList/hooks/usePrependMessagesCount.d.ts.map +1 -1
  164. package/dist/components/MessageList/hooks/usePrependMessagesCount.js +2 -0
  165. package/dist/components/MessageList/hooks/useScrollLocationLogic.d.ts +2 -0
  166. package/dist/components/MessageList/hooks/useScrollLocationLogic.d.ts.map +1 -1
  167. package/dist/components/MessageList/hooks/useScrollLocationLogic.js +9 -5
  168. package/dist/components/MessageList/utils.d.ts +24 -6
  169. package/dist/components/MessageList/utils.d.ts.map +1 -1
  170. package/dist/components/MessageList/utils.js +31 -23
  171. package/dist/components/Reactions/ReactionsList.d.ts +0 -1
  172. package/dist/components/Reactions/ReactionsList.d.ts.map +1 -1
  173. package/dist/components/Reactions/utils/utils.d.ts +0 -1
  174. package/dist/components/Reactions/utils/utils.d.ts.map +1 -1
  175. package/dist/components/Thread/Thread.d.ts +2 -0
  176. package/dist/components/Thread/Thread.d.ts.map +1 -1
  177. package/dist/components/Thread/Thread.js +6 -10
  178. package/dist/context/ChannelActionContext.d.ts +3 -0
  179. package/dist/context/ChannelActionContext.d.ts.map +1 -1
  180. package/dist/context/ChannelStateContext.d.ts +5 -1
  181. package/dist/context/ChannelStateContext.d.ts.map +1 -1
  182. package/dist/context/ChatContext.d.ts +3 -0
  183. package/dist/context/ChatContext.d.ts.map +1 -1
  184. package/dist/context/MessageContext.d.ts +2 -0
  185. package/dist/context/MessageContext.d.ts.map +1 -1
  186. package/dist/context/utils/getDisplayName.d.ts +0 -1
  187. package/dist/context/utils/getDisplayName.d.ts.map +1 -1
  188. package/dist/css/index.css +1 -1
  189. package/dist/i18n/Streami18n.d.ts +5 -4
  190. package/dist/i18n/Streami18n.d.ts.map +1 -1
  191. package/dist/i18n/Streami18n.js +5 -5
  192. package/dist/i18n/de.json +29 -28
  193. package/dist/i18n/en.json +3 -2
  194. package/dist/i18n/es.json +4 -2
  195. package/dist/i18n/fr.json +4 -2
  196. package/dist/i18n/hi.json +3 -2
  197. package/dist/i18n/it.json +4 -2
  198. package/dist/i18n/ja.json +3 -2
  199. package/dist/i18n/ko.json +3 -2
  200. package/dist/i18n/nl.json +3 -2
  201. package/dist/i18n/pt.json +22 -20
  202. package/dist/i18n/ru.json +5 -2
  203. package/dist/i18n/tr.json +3 -2
  204. package/dist/index.cjs.js +489 -278
  205. package/dist/index.cjs.js.map +1 -1
  206. package/dist/scss/Attachment.scss +6 -1
  207. package/dist/scss/Avatar.scss +1 -1
  208. package/dist/scss/ChannelHeader.scss +8 -13
  209. package/dist/scss/Gallery.scss +19 -0
  210. package/dist/scss/Message.scss +24 -13
  211. package/dist/scss/MessageInputFlat.scss +20 -0
  212. package/dist/scss/MessageList.scss +7 -0
  213. package/dist/scss/ReactionList.scss +2 -1
  214. package/dist/scss/ReactionSelector.scss +2 -1
  215. package/dist/scss/SimpleReactionsList.scss +2 -1
  216. package/dist/scss/SmallMessageInput.scss +34 -0
  217. package/dist/scss/Thread.scss +5 -1
  218. package/dist/scss/VirtualMessage.scss +6 -0
  219. package/dist/scss/_variables.scss +4 -5
  220. package/dist/stories/connected-user.stories.d.ts +4 -0
  221. package/dist/stories/connected-user.stories.d.ts.map +1 -0
  222. package/dist/stories/connected-user.stories.js +81 -0
  223. package/dist/stories/hello.stories.d.ts +3 -0
  224. package/dist/stories/hello.stories.d.ts.map +1 -0
  225. package/dist/stories/hello.stories.js +47 -0
  226. package/dist/stories/jump-to-message.stories.d.ts +4 -0
  227. package/dist/stories/jump-to-message.stories.d.ts.map +1 -0
  228. package/dist/stories/jump-to-message.stories.js +111 -0
  229. package/dist/stories/utils.d.ts +19 -0
  230. package/dist/stories/utils.d.ts.map +1 -0
  231. package/dist/stories/utils.js +5 -0
  232. package/dist/types/types.d.ts +15 -0
  233. package/dist/types/types.d.ts.map +1 -1
  234. package/dist/version.d.ts +1 -1
  235. package/dist/version.js +1 -1
  236. package/package.json +20 -12
  237. package/dist/components/InfiniteScrollPaginator/InfiniteScrollPaginator.d.ts +0 -18
  238. package/dist/components/InfiniteScrollPaginator/InfiniteScrollPaginator.d.ts.map +0 -1
  239. package/dist/components/InfiniteScrollPaginator/InfiniteScrollPaginator.js +0 -8
  240. package/dist/components/InfiniteScrollPaginator/ReverseInfiniteScroll.d.ts +0 -4
  241. package/dist/components/InfiniteScrollPaginator/ReverseInfiniteScroll.d.ts.map +0 -1
  242. package/dist/components/InfiniteScrollPaginator/ReverseInfiniteScroll.js +0 -14
  243. package/dist/components/MessageList/hooks/useCallLoadMore.d.ts +0 -3
  244. package/dist/components/MessageList/hooks/useCallLoadMore.d.ts.map +0 -1
  245. package/dist/components/MessageList/hooks/useCallLoadMore.js +0 -8
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { StreamMessage } from '../../context/ChannelStateContext';
3
2
  import type { DefaultStreamChatGenerics } from '../../types/types';
4
3
  export declare type MessageDeletedProps<StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics> = {
@@ -1 +1 @@
1
- {"version":3,"file":"MessageDeleted.d.ts","sourceRoot":"","sources":["../../../src/components/Message/MessageDeleted.tsx"],"names":[],"mappings":";AAMA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAEvE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,oBAAY,mBAAmB,CAC7B,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,OAAO,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;CAC5C,CAAC;AAEF,eAAO,MAAM,cAAc,mJAwB1B,CAAC"}
1
+ {"version":3,"file":"MessageDeleted.d.ts","sourceRoot":"","sources":["../../../src/components/Message/MessageDeleted.tsx"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAEvE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,oBAAY,mBAAmB,CAC7B,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,OAAO,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;CAC5C,CAAC;AAEF,eAAO,MAAM,cAAc,mJAwB1B,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"MessageRepliesCountButton.d.ts","sourceRoot":"","sources":["../../../src/components/Message/MessageRepliesCountButton.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAM1B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAEjD,oBAAY,8BAA8B,GAAG;IAC3C,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,iBAAiB,CAAC;IAC5B,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB,CAAC;AA4CF,eAAO,MAAM,yBAAyB,0CAES,CAAC"}
1
+ {"version":3,"file":"MessageRepliesCountButton.d.ts","sourceRoot":"","sources":["../../../src/components/Message/MessageRepliesCountButton.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAM1B,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAEjD,oBAAY,8BAA8B,GAAG;IAC3C,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,iBAAiB,CAAC;IAC5B,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB,CAAC;AA6BF,eAAO,MAAM,yBAAyB,0CAES,CAAC"}
@@ -4,31 +4,17 @@ import { useTranslationContext } from '../../context/TranslationContext';
4
4
  var UnMemoizedMessageRepliesCountButton = function (props) {
5
5
  var labelPlural = props.labelPlural, labelSingle = props.labelSingle, onClick = props.onClick, _a = props.reply_count, reply_count = _a === void 0 ? 0 : _a;
6
6
  var t = useTranslationContext('MessageRepliesCountButton').t;
7
- var singleReplyText;
8
- var pluralReplyText;
9
- if (reply_count === 1) {
10
- if (labelSingle) {
11
- singleReplyText = "1 " + labelSingle;
12
- }
13
- else {
14
- singleReplyText = t('1 reply');
15
- }
7
+ if (!reply_count)
8
+ return null;
9
+ var replyCountText = t('replyCount', { count: reply_count });
10
+ if (labelPlural && reply_count > 1) {
11
+ replyCountText = reply_count + " " + labelPlural;
16
12
  }
17
- if (reply_count && reply_count > 1) {
18
- if (labelPlural) {
19
- pluralReplyText = reply_count + " " + labelPlural;
20
- }
21
- else {
22
- pluralReplyText = t('{{ replyCount }} replies', {
23
- replyCount: reply_count,
24
- });
25
- }
13
+ else if (labelSingle) {
14
+ replyCountText = "1 " + labelSingle;
26
15
  }
27
- if (reply_count && reply_count !== 0) {
28
- return (React.createElement("button", { className: 'str-chat__message-replies-count-button', "data-testid": 'replies-count-button', onClick: onClick },
29
- React.createElement(ReplyIcon, null),
30
- reply_count === 1 ? singleReplyText : pluralReplyText));
31
- }
32
- return null;
16
+ return (React.createElement("button", { className: 'str-chat__message-replies-count-button', "data-testid": 'replies-count-button', onClick: onClick },
17
+ React.createElement(ReplyIcon, null),
18
+ replyCountText));
33
19
  };
34
20
  export var MessageRepliesCountButton = React.memo(UnMemoizedMessageRepliesCountButton);
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import { MessageContextValue } from '../../context/MessageContext';
3
2
  import type { MessageUIComponentProps } from './types';
4
3
  import type { DefaultStreamChatGenerics } from '../../types/types';
@@ -1 +1 @@
1
- {"version":3,"file":"MessageSimple.d.ts","sourceRoot":"","sources":["../../../src/components/Message/MessageSimple.tsx"],"names":[],"mappings":";AAoBA,OAAO,EAAE,mBAAmB,EAAqB,MAAM,8BAA8B,CAAC;AAEtF,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,SAAS,CAAC;AAEvD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAiKnE;;GAEG;AACH,eAAO,MAAM,aAAa,4JAQzB,CAAC"}
1
+ {"version":3,"file":"MessageSimple.d.ts","sourceRoot":"","sources":["../../../src/components/Message/MessageSimple.tsx"],"names":[],"mappings":"AAoBA,OAAO,EAAE,mBAAmB,EAAqB,MAAM,8BAA8B,CAAC;AAEtF,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,SAAS,CAAC;AAEvD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAmKnE;;GAEG;AACH,eAAO,MAAM,aAAa,4JAQzB,CAAC"}
@@ -26,7 +26,7 @@ import { useComponentContext } from '../../context/ComponentContext';
26
26
  import { useMessageContext } from '../../context/MessageContext';
27
27
  var MessageSimpleWithContext = function (props) {
28
28
  var _a;
29
- var additionalMessageInputProps = props.additionalMessageInputProps, clearEditingState = props.clearEditingState, editing = props.editing, endOfGroup = props.endOfGroup, firstOfGroup = props.firstOfGroup, groupedByUser = props.groupedByUser, handleAction = props.handleAction, handleOpenThread = props.handleOpenThread, handleRetry = props.handleRetry, isMyMessage = props.isMyMessage, isReactionEnabled = props.isReactionEnabled, message = props.message, onUserClick = props.onUserClick, onUserHover = props.onUserHover, reactionSelectorRef = props.reactionSelectorRef, showDetailedReactions = props.showDetailedReactions, threadList = props.threadList;
29
+ var additionalMessageInputProps = props.additionalMessageInputProps, clearEditingState = props.clearEditingState, editing = props.editing, endOfGroup = props.endOfGroup, firstOfGroup = props.firstOfGroup, groupedByUser = props.groupedByUser, handleAction = props.handleAction, handleOpenThread = props.handleOpenThread, handleRetry = props.handleRetry, highlighted = props.highlighted, isMyMessage = props.isMyMessage, isReactionEnabled = props.isReactionEnabled, message = props.message, onUserClick = props.onUserClick, onUserHover = props.onUserHover, reactionSelectorRef = props.reactionSelectorRef, showDetailedReactions = props.showDetailedReactions, threadList = props.threadList;
30
30
  var _b = useComponentContext('MessageSimple'), Attachment = _b.Attachment, _c = _b.Avatar, Avatar = _c === void 0 ? DefaultAvatar : _c, _d = _b.EditMessageInput, EditMessageInput = _d === void 0 ? DefaultEditMessageForm : _d, _e = _b.MessageDeleted, MessageDeleted = _e === void 0 ? DefaultMessageDeleted : _e, _f = _b.MessageOptions, MessageOptions = _f === void 0 ? DefaultMessageOptions : _f, _g = _b.MessageRepliesCountButton, MessageRepliesCountButton = _g === void 0 ? DefaultMessageRepliesCountButton : _g, _h = _b.MessageStatus, MessageStatus = _h === void 0 ? DefaultMessageStatus : _h, _j = _b.MessageTimestamp, MessageTimestamp = _j === void 0 ? DefaultMessageTimestamp : _j, _k = _b.ReactionSelector, ReactionSelector = _k === void 0 ? DefaultReactionSelector : _k, _l = _b.ReactionsList, ReactionsList = _l === void 0 ? DefaultReactionList : _l;
31
31
  var hasAttachment = messageHasAttachments(message);
32
32
  var hasReactions = messageHasReactions(message);
@@ -42,7 +42,7 @@ var MessageSimpleWithContext = function (props) {
42
42
  return (React.createElement(React.Fragment, null,
43
43
  editing && (React.createElement(Modal, { onClose: clearEditingState, open: editing },
44
44
  React.createElement(MessageInput, __assign({ clearEditingState: clearEditingState, Input: EditMessageInput, message: message }, additionalMessageInputProps)))),
45
- React.createElement("div", { className: ("\n\t\t\t\t\t\t" + messageClasses + "\n\t\t\t\t\t\tstr-chat__message--" + message.type + "\n\t\t\t\t\t\tstr-chat__message--" + message.status + "\n\t\t\t\t\t\t" + (message.text ? 'str-chat__message--has-text' : 'has-no-text') + "\n\t\t\t\t\t\t" + (hasAttachment ? 'str-chat__message--has-attachment' : '') + "\n " + (hasReactions && isReactionEnabled ? 'str-chat__message--with-reactions' : '') + "\n " + (message.pinned ? 'pinned-message' : '') + "\n " + (groupedByUser ? 'str-chat__virtual-message__wrapper--group' : '') + "\n " + (firstOfGroup ? 'str-chat__virtual-message__wrapper--first' : '') + "\n " + (endOfGroup ? 'str-chat__virtual-message__wrapper--end' : '') + "\n\t\t\t\t\t").trim(), key: message.id },
45
+ React.createElement("div", { className: ("\n\t\t\t\t\t\t" + messageClasses + "\n\t\t\t\t\t\tstr-chat__message--" + message.type + "\n\t\t\t\t\t\tstr-chat__message--" + message.status + "\n\t\t\t\t\t\t" + (message.text ? 'str-chat__message--has-text' : 'has-no-text') + "\n\t\t\t\t\t\t" + (hasAttachment ? 'str-chat__message--has-attachment' : '') + "\n " + (hasReactions && isReactionEnabled ? 'str-chat__message--with-reactions' : '') + "\n " + (highlighted ? 'str-chat__message--highlighted' : '') + "\n " + (message.pinned ? 'pinned-message' : '') + "\n " + (groupedByUser ? 'str-chat__virtual-message__wrapper--group' : '') + "\n " + (firstOfGroup ? 'str-chat__virtual-message__wrapper--first' : '') + "\n " + (endOfGroup ? 'str-chat__virtual-message__wrapper--end' : '') + "\n\t\t\t\t\t").trim(), key: message.id },
46
46
  React.createElement(MessageStatus, null),
47
47
  message.user && (React.createElement(Avatar, { image: message.user.image, name: message.user.name || message.user.id, onClick: onUserClick, onMouseOver: onUserHover, user: message.user })),
48
48
  React.createElement("div", { className: 'str-chat__message-inner', "data-testid": 'message-inner', onClick: message.status === 'failed' && message.errorStatusCode !== 403
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import { MessageContextValue } from '../../context/MessageContext';
3
2
  import type { MessageUIComponentProps } from './types';
4
3
  import type { DefaultStreamChatGenerics } from '../../types/types';
@@ -1 +1 @@
1
- {"version":3,"file":"MessageTeam.d.ts","sourceRoot":"","sources":["../../../src/components/Message/MessageTeam.tsx"],"names":[],"mappings":";AAqBA,OAAO,EAAE,mBAAmB,EAAqB,MAAM,8BAA8B,CAAC;AAMtF,OAAO,KAAK,EAAE,uBAAuB,EAAqB,MAAM,SAAS,CAAC;AAE1E,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AA0PnE;;;;;GAKG;AACH,eAAO,MAAM,WAAW,4JA6BvB,CAAC"}
1
+ {"version":3,"file":"MessageTeam.d.ts","sourceRoot":"","sources":["../../../src/components/Message/MessageTeam.tsx"],"names":[],"mappings":"AAqBA,OAAO,EAAE,mBAAmB,EAAqB,MAAM,8BAA8B,CAAC;AAMtF,OAAO,KAAK,EAAE,uBAAuB,EAAqB,MAAM,SAAS,CAAC;AAE1E,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AA0PnE;;;;;GAKG;AACH,eAAO,MAAM,WAAW,4JA6BvB,CAAC"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { StreamMessage } from '../../context/ChannelStateContext';
3
2
  import type { DefaultStreamChatGenerics } from '../../types/types';
4
3
  export declare type MessageTextProps<StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics> = {
@@ -1 +1 @@
1
- {"version":3,"file":"MessageText.d.ts","sourceRoot":"","sources":["../../../src/components/Message/MessageText.tsx"],"names":[],"mappings":";AAaA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,oBAAY,gBAAgB,CAC1B,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,OAAO,CAAC,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;IAC5C,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAqFF,eAAO,MAAM,WAAW,uJAEkB,CAAC"}
1
+ {"version":3,"file":"MessageText.d.ts","sourceRoot":"","sources":["../../../src/components/Message/MessageText.tsx"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,oBAAY,gBAAgB,CAC1B,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,OAAO,CAAC,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;IAC5C,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAqFF,eAAO,MAAM,WAAW,uJAEkB,CAAC"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { StreamMessage } from '../../context/ChannelStateContext';
3
2
  import type { DefaultStreamChatGenerics } from '../../types/types';
4
3
  export declare const defaultTimestampFormat = "h:mmA";
@@ -1 +1 @@
1
- {"version":3,"file":"MessageTimestamp.d.ts","sourceRoot":"","sources":["../../../src/components/Message/MessageTimestamp.tsx"],"names":[],"mappings":";AAYA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAEvE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,eAAO,MAAM,sBAAsB,UAAU,CAAC;AAE9C,eAAO,MAAM,mBAAmB,2FAC0D,CAAC;AAE3F,eAAO,MAAM,wBAAwB,oFAC8C,CAAC;AA4CpF,oBAAY,qBAAqB,CAC/B,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;CAC7C,CAAC;AAqCF,eAAO,MAAM,gBAAgB,4JAES,CAAC"}
1
+ {"version":3,"file":"MessageTimestamp.d.ts","sourceRoot":"","sources":["../../../src/components/Message/MessageTimestamp.tsx"],"names":[],"mappings":"AAYA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAEvE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,eAAO,MAAM,sBAAsB,UAAU,CAAC;AAE9C,eAAO,MAAM,mBAAmB,2FAC0D,CAAC;AAE3F,eAAO,MAAM,wBAAwB,oFAC8C,CAAC;AA4CpF,oBAAY,qBAAqB,CAC/B,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,CAAC,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;CAC7C,CAAC;AAqCF,eAAO,MAAM,gBAAgB,4JAES,CAAC"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { DefaultStreamChatGenerics } from '../../types/types';
3
2
  export declare const QuotedMessage: <StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics>() => JSX.Element | null;
4
3
  //# sourceMappingURL=QuotedMessage.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"QuotedMessage.d.ts","sourceRoot":"","sources":["../../../src/components/Message/QuotedMessage.tsx"],"names":[],"mappings":";AAUA,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,eAAO,MAAM,aAAa,4GA+CzB,CAAC"}
1
+ {"version":3,"file":"QuotedMessage.d.ts","sourceRoot":"","sources":["../../../src/components/Message/QuotedMessage.tsx"],"names":[],"mappings":"AAWA,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,eAAO,MAAM,aAAa,4GAmDzB,CAAC"}
@@ -3,11 +3,13 @@ import { Avatar as DefaultAvatar } from '../Avatar';
3
3
  import { useComponentContext } from '../../context/ComponentContext';
4
4
  import { useMessageContext } from '../../context/MessageContext';
5
5
  import { useTranslationContext } from '../../context/TranslationContext';
6
+ import { useChannelActionContext } from '../../context/ChannelActionContext';
6
7
  export var QuotedMessage = function () {
7
8
  var _a, _b;
8
9
  var _c = useComponentContext('QuotedMessage'), Attachment = _c.Attachment, ContextAvatar = _c.Avatar;
9
10
  var _d = useMessageContext('QuotedMessage'), isMyMessage = _d.isMyMessage, message = _d.message;
10
11
  var userLanguage = useTranslationContext('QuotedMessage').userLanguage;
12
+ var jumpToMessage = useChannelActionContext('QuotedMessage').jumpToMessage;
11
13
  var Avatar = ContextAvatar || DefaultAvatar;
12
14
  var quoted_message = message.quoted_message;
13
15
  if (!quoted_message)
@@ -22,7 +24,7 @@ export var QuotedMessage = function () {
22
24
  if (!quotedMessageText && !quotedMessageAttachment)
23
25
  return null;
24
26
  return (React.createElement(React.Fragment, null,
25
- React.createElement("div", { className: "" + (isMyMessage() ? 'quoted-message mine' : 'quoted-message') },
27
+ React.createElement("div", { className: "" + (isMyMessage() ? 'quoted-message mine' : 'quoted-message'), onClick: function () { return jumpToMessage(quoted_message.id); } },
26
28
  quoted_message.user && (React.createElement(Avatar, { image: quoted_message.user.image, name: quoted_message.user.name || quoted_message.user.id, size: 20, user: quoted_message.user })),
27
29
  React.createElement("div", { className: 'quoted-message-inner' },
28
30
  quotedMessageAttachment && React.createElement(Attachment, { attachments: [quotedMessageAttachment] }),
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { ReactEventHandler } from '../types';
3
2
  export declare type EditHandlerReturnType = {
4
3
  clearEdit: (event?: React.BaseSyntheticEvent) => void;
@@ -1 +1 @@
1
- {"version":3,"file":"useEditHandler.d.ts","sourceRoot":"","sources":["../../../../src/components/Message/hooks/useEditHandler.ts"],"names":[],"mappings":";AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAElD,oBAAY,qBAAqB,GAAG;IAClC,SAAS,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC,kBAAkB,KAAK,IAAI,CAAC;IACtD,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,iBAAiB,CAAC;CAC5B,CAAC;AAEF,eAAO,MAAM,cAAc,mIAEgC,IAAI,0HACK,IAAI,kBACrE,qBAsBF,CAAC"}
1
+ {"version":3,"file":"useEditHandler.d.ts","sourceRoot":"","sources":["../../../../src/components/Message/hooks/useEditHandler.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAElD,oBAAY,qBAAqB,GAAG;IAClC,SAAS,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC,kBAAkB,KAAK,IAAI,CAAC;IACtD,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,iBAAiB,CAAC;CAC5B,CAAC;AAEF,eAAO,MAAM,cAAc,mIAEgC,IAAI,0HACK,IAAI,kBACrE,qBAsBF,CAAC"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { User } from 'stream-chat';
3
2
  import type { ReactEventHandler } from '../types';
4
3
  import type { StreamMessage } from '../../../context/ChannelStateContext';
@@ -1 +1 @@
1
- {"version":3,"file":"useUserHandler.d.ts","sourceRoot":"","sources":["../../../../src/components/Message/hooks/useUserHandler.ts"],"names":[],"mappings":";AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAExC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAElD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AAE1E,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAEtE,oBAAY,gBAAgB,CAC1B,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E,CAAC,KAAK,EAAE,KAAK,CAAC,kBAAkB,EAAE,IAAI,EAAE,IAAI,CAAC,kBAAkB,CAAC,KAAK,IAAI,CAAC;AAE9E,eAAO,MAAM,cAAc;;;kBAQxB;IACD,WAAW,EAAE,iBAAiB,CAAC;IAC/B,WAAW,EAAE,iBAAiB,CAAC;CAe/B,CAAC"}
1
+ {"version":3,"file":"useUserHandler.d.ts","sourceRoot":"","sources":["../../../../src/components/Message/hooks/useUserHandler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,aAAa,CAAC;AAExC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAElD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sCAAsC,CAAC;AAE1E,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAEtE,oBAAY,gBAAgB,CAC1B,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E,CAAC,KAAK,EAAE,KAAK,CAAC,kBAAkB,EAAE,IAAI,EAAE,IAAI,CAAC,kBAAkB,CAAC,KAAK,IAAI,CAAC;AAE9E,eAAO,MAAM,cAAc;;;kBAQxB;IACD,WAAW,EAAE,iBAAiB,CAAC;IAC/B,WAAW,EAAE,iBAAiB,CAAC;CAe/B,CAAC"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { PinIndicatorProps } from './types';
3
2
  import type { DefaultStreamChatGenerics } from '../../types/types';
4
3
  export declare const ActionsIcon: () => JSX.Element;
@@ -1 +1 @@
1
- {"version":3,"file":"icons.d.ts","sourceRoot":"","sources":["../../../src/components/Message/icons.tsx"],"names":[],"mappings":";AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAEjD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,eAAO,MAAM,WAAW,mBAOvB,CAAC;AAEF,eAAO,MAAM,SAAS,mBAOrB,CAAC;AAEF,eAAO,MAAM,kBAAkB,mBAQ9B,CAAC;AAEF,eAAO,MAAM,YAAY,mBAOxB,CAAC;AAEF,eAAO,MAAM,UAAU,mBAOtB,CAAC;AAEF,eAAO,MAAM,SAAS,mBAQrB,CAAC;AAEF,eAAO,MAAM,OAAO,mBAOnB,CAAC;AAEF,eAAO,MAAM,YAAY,kKAyBxB,CAAC"}
1
+ {"version":3,"file":"icons.d.ts","sourceRoot":"","sources":["../../../src/components/Message/icons.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAEjD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,eAAO,MAAM,WAAW,mBAOvB,CAAC;AAEF,eAAO,MAAM,SAAS,mBAOrB,CAAC;AAEF,eAAO,MAAM,kBAAkB,mBAQ9B,CAAC;AAEF,eAAO,MAAM,YAAY,mBAOxB,CAAC;AAEF,eAAO,MAAM,UAAU,mBAOtB,CAAC;AAEF,eAAO,MAAM,SAAS,mBAQrB,CAAC;AAEF,eAAO,MAAM,OAAO,mBAOnB,CAAC;AAEF,eAAO,MAAM,YAAY,kKAyBxB,CAAC"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { TFunction } from 'i18next';
3
2
  import type { UserResponse } from 'stream-chat';
4
3
  import type { PinPermissions, UserEventHandler } from './hooks';
@@ -45,6 +44,8 @@ export declare type MessageProps<StreamChatGenerics extends DefaultStreamChatGen
45
44
  groupedByUser?: boolean;
46
45
  /** A list of styles to apply to this message, ie. top, bottom, single */
47
46
  groupStyles?: GroupStyle[];
47
+ /** Whether to highlight and focus the message on load */
48
+ highlighted?: boolean;
48
49
  /** Whether the threaded message is the first in the thread list */
49
50
  initialMessage?: boolean;
50
51
  /** Latest message id on current channel */
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/components/Message/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/components/Message/types.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/components/Message/utils.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACzC,OAAO,KAAK,EAAE,eAAe,EAAE,IAAI,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAEnF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC9C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAE5C,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AAExE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE;;;GAGG;AACH,eAAO,MAAM,qBAAqB,8CACV,OAAO,2BAiB9B,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,WAAW,2LAUvB,CAAC;AAEF,eAAO,MAAM,eAAe;;;;;;;;;CAS3B,CAAC;AAEF,oBAAY,mBAAmB,CAAC,CAAC,SAAS,MAAM,GAAG,MAAM,IAAI,KAAK,CAChE,QAAQ,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,KAAK,GAAG,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,CAAC,CAC9E,CAAC;AAGF,eAAO,MAAM,qBAAqB,EAAE,cAwDnC,CAAC;AAEF,oBAAY,YAAY,GAAG;IACzB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF,eAAO,MAAM,iBAAiB,YACnB,mBAAmB,GAAG,OAAO,kFAC0C,YAAY,gCA+C7F,CAAC;AAIF,eAAO,MAAM,qBAAqB,oDAErB,OAAO,GAAG,SAAS,YAsB/B,CAAC;AAEF,eAAO,MAAM,oBAAoB;;;;;;aAgDhC,CAAC;AAEF,eAAO,MAAM,sBAAsB;;;;aA6ClC,CAAC;AAEF,eAAO,MAAM,mBAAmB,wJAIqC,CAAC;AAEtE,eAAO,MAAM,qBAAqB,wJAIyB,CAAC;AAE5D,eAAO,MAAM,SAAS,yMASrB,CAAC;AAEF,eAAO,MAAM,sBAAsB,yMASlC,CAAC;AAEF,eAAO,MAAM,oBAAoB,mIAI5B,SAAS,mDA6Cb,CAAC"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/components/Message/utils.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AACzC,OAAO,KAAK,EAAE,eAAe,EAAE,IAAI,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAEnF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAC9C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAE5C,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,8BAA8B,CAAC;AAExE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE;;;GAGG;AACH,eAAO,MAAM,qBAAqB,8CACV,OAAO,2BAiB9B,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,WAAW,2LAUvB,CAAC;AAEF,eAAO,MAAM,eAAe;;;;;;;;;CAS3B,CAAC;AAEF,oBAAY,mBAAmB,CAAC,CAAC,SAAS,MAAM,GAAG,MAAM,IAAI,KAAK,CAChE,QAAQ,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,GAAG,KAAK,GAAG,OAAO,GAAG,OAAO,GAAG,OAAO,GAAG,CAAC,CAC9E,CAAC;AAGF,eAAO,MAAM,qBAAqB,EAAE,cAwDnC,CAAC;AAEF,oBAAY,YAAY,GAAG;IACzB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF,eAAO,MAAM,iBAAiB,YACnB,mBAAmB,GAAG,OAAO,kFAC0C,YAAY,gCA+C7F,CAAC;AAIF,eAAO,MAAM,qBAAqB,oDAErB,OAAO,GAAG,SAAS,YAsB/B,CAAC;AAEF,eAAO,MAAM,oBAAoB;;;;;;aAiDhC,CAAC;AAEF,eAAO,MAAM,sBAAsB;;;;aA8ClC,CAAC;AAEF,eAAO,MAAM,mBAAmB,wJAIqC,CAAC;AAEtE,eAAO,MAAM,qBAAqB,wJAIyB,CAAC;AAE5D,eAAO,MAAM,SAAS,yMASrB,CAAC;AAEF,eAAO,MAAM,sBAAsB,yMASlC,CAAC;AAEF,eAAO,MAAM,oBAAoB,mIAI5B,SAAS,mDA6Cb,CAAC"}
@@ -181,6 +181,7 @@ export var areMessagePropsEqual = function (prevProps, nextProps) {
181
181
  if (!messagesAreEqual)
182
182
  return false;
183
183
  var deepEqualProps = deepequal(nextProps.readBy, prevProps.readBy) &&
184
+ deepequal(nextProps.highlighted, prevProps.highlighted) &&
184
185
  deepequal(nextProps.groupStyles, prevProps.groupStyles) && // last 3 messages can have different group styles
185
186
  deepequal(nextProps.mutes, prevProps.mutes) &&
186
187
  deepequal(nextProps.lastReceivedId, prevProps.lastReceivedId);
@@ -195,6 +196,8 @@ export var areMessageUIPropsEqual = function (prevProps, nextProps) {
195
196
  var nextLastReceivedId = nextProps.lastReceivedId, nextMessage = nextProps.message;
196
197
  if (prevProps.editing !== nextProps.editing)
197
198
  return false;
199
+ if (prevProps.highlighted !== nextProps.highlighted)
200
+ return false;
198
201
  if (prevProps.endOfGroup !== nextProps.endOfGroup)
199
202
  return false;
200
203
  if (((_a = prevProps.mutes) === null || _a === void 0 ? void 0 : _a.length) !== ((_b = nextProps.mutes) === null || _b === void 0 ? void 0 : _b.length))
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import { CustomMessageActions, MessageContextValue } from '../../context/MessageContext';
3
2
  import type { StreamMessage } from '../../context/ChannelStateContext';
4
3
  import type { DefaultStreamChatGenerics } from '../../types/types';
@@ -1 +1 @@
1
- {"version":3,"file":"MessageActionsBox.d.ts","sourceRoot":"","sources":["../../../src/components/MessageActions/MessageActionsBox.tsx"],"names":[],"mappings":";AAKA,OAAO,EACL,oBAAoB,EACpB,mBAAmB,EAEpB,MAAM,8BAA8B,CAAC;AAGtC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAEvE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,oBAAY,wBAAwB,CAClC,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,oBAAoB,EAAE,oBAAoB,CAAC,kBAAkB,CAAC,CAAC;IAC/D,OAAO,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;CAC5C,CAAC;AA+BF,aAAK,+BAA+B,GAChC,mBAAmB,GACnB,cAAc,GACd,YAAY,GACZ,YAAY,GACZ,YAAY,GACZ,WAAW,CAAC;AAEhB,oBAAY,sBAAsB,CAChC,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CAAC,EAAE,+BAA+B,CAAC,GAAG;IACnF,WAAW,EAAE,MAAM,OAAO,CAAC;IAC3B,IAAI,EAAE,OAAO,CAAC;IACd,IAAI,EAAE,OAAO,CAAC;CACf,CAAC;AA8IF;;GAEG;AACH,eAAO,MAAM,iBAAiB,sJAES,CAAC"}
1
+ {"version":3,"file":"MessageActionsBox.d.ts","sourceRoot":"","sources":["../../../src/components/MessageActions/MessageActionsBox.tsx"],"names":[],"mappings":"AAKA,OAAO,EACL,oBAAoB,EACpB,mBAAmB,EAEpB,MAAM,8BAA8B,CAAC;AAGtC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAEvE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,oBAAY,wBAAwB,CAClC,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,oBAAoB,EAAE,oBAAoB,CAAC,kBAAkB,CAAC,CAAC;IAC/D,OAAO,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;CAC5C,CAAC;AA+BF,aAAK,+BAA+B,GAChC,mBAAmB,GACnB,cAAc,GACd,YAAY,GACZ,YAAY,GACZ,YAAY,GACZ,WAAW,CAAC;AAEhB,oBAAY,sBAAsB,CAChC,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E,IAAI,CAAC,mBAAmB,CAAC,kBAAkB,CAAC,EAAE,+BAA+B,CAAC,GAAG;IACnF,WAAW,EAAE,MAAM,OAAO,CAAC;IAC3B,IAAI,EAAE,OAAO,CAAC;IACd,IAAI,EAAE,OAAO,CAAC;CACf,CAAC;AA8IF;;GAEG;AACH,eAAO,MAAM,iBAAiB,sJAES,CAAC"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { CustomTrigger, DefaultStreamChatGenerics } from '../../types/types';
3
2
  export declare const EditMessageForm: <StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics, V extends CustomTrigger = CustomTrigger>() => JSX.Element;
4
3
  //# sourceMappingURL=EditMessageForm.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"EditMessageForm.d.ts","sourceRoot":"","sources":["../../../src/components/MessageInput/EditMessageForm.tsx"],"names":[],"mappings":";AAmBA,OAAO,KAAK,EAAE,aAAa,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAElF,eAAO,MAAM,eAAe,8IA6F3B,CAAC"}
1
+ {"version":3,"file":"EditMessageForm.d.ts","sourceRoot":"","sources":["../../../src/components/MessageInput/EditMessageForm.tsx"],"names":[],"mappings":"AAmBA,OAAO,KAAK,EAAE,aAAa,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAElF,eAAO,MAAM,eAAe,8IA6F3B,CAAC"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { DefaultStreamChatGenerics } from '../../types/types';
3
2
  export declare type MessageInputEmojiPickerProps = {
4
3
  small?: boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"EmojiPicker.d.ts","sourceRoot":"","sources":["../../../src/components/MessageInput/EmojiPicker.tsx"],"names":[],"mappings":";AASA,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AASnE,oBAAY,4BAA4B,GAAG;IACzC,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB,CAAC;AAEF,eAAO,MAAM,WAAW,4FAGf,4BAA4B,uBAqCpC,CAAC"}
1
+ {"version":3,"file":"EmojiPicker.d.ts","sourceRoot":"","sources":["../../../src/components/MessageInput/EmojiPicker.tsx"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AASnE,oBAAY,4BAA4B,GAAG;IACzC,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB,CAAC;AAEF,eAAO,MAAM,WAAW,4FAGf,4BAA4B,uBAqCpC,CAAC"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { DefaultStreamChatGenerics } from '../../types/types';
3
2
  export declare const MessageInputFlat: <StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics>() => JSX.Element;
4
3
  //# sourceMappingURL=MessageInputFlat.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"MessageInputFlat.d.ts","sourceRoot":"","sources":["../../../src/components/MessageInput/MessageInputFlat.tsx"],"names":[],"mappings":";AAqBA,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,eAAO,MAAM,gBAAgB,qGAqG5B,CAAC"}
1
+ {"version":3,"file":"MessageInputFlat.d.ts","sourceRoot":"","sources":["../../../src/components/MessageInput/MessageInputFlat.tsx"],"names":[],"mappings":"AAwBA,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,eAAO,MAAM,gBAAgB,qGAuH5B,CAAC"}
@@ -1,4 +1,4 @@
1
- import React from 'react';
1
+ import React, { useEffect } from 'react';
2
2
  import { FileUploadButton, ImageDropzone } from 'react-file-utils';
3
3
  import { EmojiPicker } from './EmojiPicker';
4
4
  import { CooldownTimer as DefaultCooldownTimer } from './hooks/useCooldownTimer';
@@ -7,15 +7,37 @@ import { QuotedMessagePreview as DefaultQuotedMessagePreview } from './QuotedMes
7
7
  import { UploadsPreview } from './UploadsPreview';
8
8
  import { ChatAutoComplete } from '../ChatAutoComplete/ChatAutoComplete';
9
9
  import { Tooltip } from '../Tooltip/Tooltip';
10
+ import { useChatContext } from '../../context/ChatContext';
11
+ import { useChannelActionContext } from '../../context/ChannelActionContext';
10
12
  import { useChannelStateContext } from '../../context/ChannelStateContext';
11
13
  import { useTranslationContext } from '../../context/TranslationContext';
12
14
  import { useMessageInputContext } from '../../context/MessageInputContext';
13
15
  import { useComponentContext } from '../../context/ComponentContext';
14
16
  export var MessageInputFlat = function () {
15
17
  var _a = useChannelStateContext('MessageInputFlat'), acceptedFiles = _a.acceptedFiles, multipleUploads = _a.multipleUploads, quotedMessage = _a.quotedMessage;
18
+ var setQuotedMessage = useChannelActionContext('MessageInputFlat').setQuotedMessage;
16
19
  var t = useTranslationContext('MessageInputFlat').t;
17
- var _b = useMessageInputContext('MessageInputFlat'), closeEmojiPicker = _b.closeEmojiPicker, cooldownInterval = _b.cooldownInterval, cooldownRemaining = _b.cooldownRemaining, emojiPickerIsOpen = _b.emojiPickerIsOpen, handleSubmit = _b.handleSubmit, isUploadEnabled = _b.isUploadEnabled, maxFilesLeft = _b.maxFilesLeft, numberOfUploads = _b.numberOfUploads, openEmojiPicker = _b.openEmojiPicker, setCooldownRemaining = _b.setCooldownRemaining, uploadNewFiles = _b.uploadNewFiles;
20
+ var channel = useChatContext('MessageInputFlat').channel;
21
+ var _b = useMessageInputContext('MessageInputFlat'), closeEmojiPicker = _b.closeEmojiPicker, cooldownRemaining = _b.cooldownRemaining, emojiPickerIsOpen = _b.emojiPickerIsOpen, handleSubmit = _b.handleSubmit, isUploadEnabled = _b.isUploadEnabled, maxFilesLeft = _b.maxFilesLeft, numberOfUploads = _b.numberOfUploads, openEmojiPicker = _b.openEmojiPicker, setCooldownRemaining = _b.setCooldownRemaining, uploadNewFiles = _b.uploadNewFiles;
18
22
  var _c = useComponentContext('MessageInputFlat'), _d = _c.CooldownTimer, CooldownTimer = _d === void 0 ? DefaultCooldownTimer : _d, _e = _c.EmojiIcon, EmojiIcon = _e === void 0 ? DefaultEmojiIcon : _e, _f = _c.FileUploadIcon, FileUploadIcon = _f === void 0 ? DefaultFileUploadIcon : _f, _g = _c.QuotedMessagePreview, QuotedMessagePreview = _g === void 0 ? DefaultQuotedMessagePreview : _g, _h = _c.SendButton, SendButton = _h === void 0 ? DefaultSendButton : _h;
23
+ useEffect(function () {
24
+ var handleQuotedMessageUpdate = function (e) {
25
+ var _a;
26
+ if (((_a = e.message) === null || _a === void 0 ? void 0 : _a.id) !== (quotedMessage === null || quotedMessage === void 0 ? void 0 : quotedMessage.id))
27
+ return;
28
+ if (e.type === 'message.deleted') {
29
+ setQuotedMessage(undefined);
30
+ return;
31
+ }
32
+ setQuotedMessage(e.message);
33
+ };
34
+ channel === null || channel === void 0 ? void 0 : channel.on('message.deleted', handleQuotedMessageUpdate);
35
+ channel === null || channel === void 0 ? void 0 : channel.on('message.updated', handleQuotedMessageUpdate);
36
+ return function () {
37
+ channel === null || channel === void 0 ? void 0 : channel.off('message.deleted', handleQuotedMessageUpdate);
38
+ channel === null || channel === void 0 ? void 0 : channel.off('message.updated', handleQuotedMessageUpdate);
39
+ };
40
+ }, [channel, quotedMessage]);
19
41
  return (React.createElement("div", { className: "str-chat__input-flat " + (SendButton ? 'str-chat__input-flat--send-button-active' : '') + " " + (quotedMessage && !quotedMessage.parent_id ? 'str-chat__input-flat-quoted' : '') + "\n " + (numberOfUploads ? 'str-chat__input-flat-has-attachments' : '') + "\n " },
20
42
  React.createElement(ImageDropzone, { accept: acceptedFiles, disabled: !isUploadEnabled || maxFilesLeft === 0 || !!cooldownRemaining, handleFiles: uploadNewFiles, maxNumberOfFiles: maxFilesLeft, multiple: multipleUploads },
21
43
  quotedMessage && !quotedMessage.parent_id && (React.createElement(QuotedMessagePreview, { quotedMessage: quotedMessage })),
@@ -25,7 +47,7 @@ export var MessageInputFlat = function () {
25
47
  React.createElement("div", { className: 'str-chat__emojiselect-wrapper' },
26
48
  React.createElement(Tooltip, null, emojiPickerIsOpen ? t('Close emoji picker') : t('Open emoji picker')),
27
49
  React.createElement("button", { "aria-label": 'Emoji picker', className: 'str-chat__input-flat-emojiselect', onClick: emojiPickerIsOpen ? closeEmojiPicker : openEmojiPicker }, cooldownRemaining ? (React.createElement("div", { className: 'str-chat__input-flat-cooldown' },
28
- React.createElement(CooldownTimer, { cooldownInterval: cooldownInterval, setCooldownRemaining: setCooldownRemaining }))) : (React.createElement(EmojiIcon, null)))),
50
+ React.createElement(CooldownTimer, { cooldownInterval: cooldownRemaining, setCooldownRemaining: setCooldownRemaining }))) : (React.createElement(EmojiIcon, null)))),
29
51
  React.createElement(EmojiPicker, null),
30
52
  React.createElement(ChatAutoComplete, null),
31
53
  isUploadEnabled && !cooldownRemaining && (React.createElement("div", { className: 'str-chat__fileupload-wrapper', "data-testid": 'fileinput' },
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { CustomTrigger, DefaultStreamChatGenerics } from '../../types/types';
3
2
  export declare const MessageInputSmall: <StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics, V extends CustomTrigger = CustomTrigger>() => JSX.Element;
4
3
  //# sourceMappingURL=MessageInputSmall.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"MessageInputSmall.d.ts","sourceRoot":"","sources":["../../../src/components/MessageInput/MessageInputSmall.tsx"],"names":[],"mappings":";AAsBA,OAAO,KAAK,EAAE,aAAa,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAElF,eAAO,MAAM,iBAAiB,8IAwG7B,CAAC"}
1
+ {"version":3,"file":"MessageInputSmall.d.ts","sourceRoot":"","sources":["../../../src/components/MessageInput/MessageInputSmall.tsx"],"names":[],"mappings":"AAyBA,OAAO,KAAK,EAAE,aAAa,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAElF,eAAO,MAAM,iBAAiB,8IA0H7B,CAAC"}
@@ -1,4 +1,4 @@
1
- import React from 'react';
1
+ import React, { useEffect } from 'react';
2
2
  import { FileUploadButton, ImageDropzone } from 'react-file-utils';
3
3
  import { EmojiPicker } from './EmojiPicker';
4
4
  import { CooldownTimer as DefaultCooldownTimer } from './hooks/useCooldownTimer';
@@ -6,6 +6,8 @@ import { EmojiIconSmall as DefaultEmojiIcon, FileUploadIconFlat as DefaultFileUp
6
6
  import { UploadsPreview } from './UploadsPreview';
7
7
  import { ChatAutoComplete } from '../ChatAutoComplete/ChatAutoComplete';
8
8
  import { Tooltip } from '../Tooltip/Tooltip';
9
+ import { useChatContext } from '../../context/ChatContext';
10
+ import { useChannelActionContext } from '../../context/ChannelActionContext';
9
11
  import { useChannelStateContext } from '../../context/ChannelStateContext';
10
12
  import { useTranslationContext } from '../../context/TranslationContext';
11
13
  import { useMessageInputContext } from '../../context/MessageInputContext';
@@ -13,18 +15,38 @@ import { useComponentContext } from '../../context/ComponentContext';
13
15
  import { QuotedMessagePreview as DefaultQuotedMessagePreview } from './QuotedMessagePreview';
14
16
  export var MessageInputSmall = function () {
15
17
  var _a = useChannelStateContext('MessageInputSmall'), acceptedFiles = _a.acceptedFiles, multipleUploads = _a.multipleUploads, quotedMessage = _a.quotedMessage;
18
+ var setQuotedMessage = useChannelActionContext('MessageInputSmall').setQuotedMessage;
16
19
  var t = useTranslationContext('MessageInputSmall').t;
17
- var _b = useMessageInputContext('MessageInputSmall'), closeEmojiPicker = _b.closeEmojiPicker, cooldownInterval = _b.cooldownInterval, cooldownRemaining = _b.cooldownRemaining, emojiPickerIsOpen = _b.emojiPickerIsOpen, handleSubmit = _b.handleSubmit, isUploadEnabled = _b.isUploadEnabled, maxFilesLeft = _b.maxFilesLeft, numberOfUploads = _b.numberOfUploads, openEmojiPicker = _b.openEmojiPicker, setCooldownRemaining = _b.setCooldownRemaining, uploadNewFiles = _b.uploadNewFiles;
20
+ var channel = useChatContext('MessageInputSmall').channel;
21
+ var _b = useMessageInputContext('MessageInputSmall'), closeEmojiPicker = _b.closeEmojiPicker, cooldownRemaining = _b.cooldownRemaining, emojiPickerIsOpen = _b.emojiPickerIsOpen, handleSubmit = _b.handleSubmit, isUploadEnabled = _b.isUploadEnabled, maxFilesLeft = _b.maxFilesLeft, numberOfUploads = _b.numberOfUploads, openEmojiPicker = _b.openEmojiPicker, setCooldownRemaining = _b.setCooldownRemaining, uploadNewFiles = _b.uploadNewFiles;
18
22
  var _c = useComponentContext('MessageInputSmall'), _d = _c.CooldownTimer, CooldownTimer = _d === void 0 ? DefaultCooldownTimer : _d, _e = _c.EmojiIcon, EmojiIcon = _e === void 0 ? DefaultEmojiIcon : _e, _f = _c.FileUploadIcon, FileUploadIcon = _f === void 0 ? DefaultFileUploadIcon : _f, _g = _c.SendButton, SendButton = _g === void 0 ? DefaultSendButton : _g, _h = _c.QuotedMessagePreview, QuotedMessagePreview = _h === void 0 ? DefaultQuotedMessagePreview : _h;
23
+ useEffect(function () {
24
+ var handleQuotedMessageUpdate = function (e) {
25
+ var _a;
26
+ if (!(quotedMessage && ((_a = e.message) === null || _a === void 0 ? void 0 : _a.id) === quotedMessage.id))
27
+ return;
28
+ if (e.type === 'message.deleted') {
29
+ setQuotedMessage(undefined);
30
+ return;
31
+ }
32
+ setQuotedMessage(e.message);
33
+ };
34
+ channel === null || channel === void 0 ? void 0 : channel.on('message.deleted', handleQuotedMessageUpdate);
35
+ channel === null || channel === void 0 ? void 0 : channel.on('message.updated', handleQuotedMessageUpdate);
36
+ return function () {
37
+ channel === null || channel === void 0 ? void 0 : channel.off('message.deleted', handleQuotedMessageUpdate);
38
+ channel === null || channel === void 0 ? void 0 : channel.off('message.updated', handleQuotedMessageUpdate);
39
+ };
40
+ }, [channel, quotedMessage]);
19
41
  return (React.createElement("div", { className: 'str-chat__small-message-input__wrapper' },
20
42
  React.createElement(ImageDropzone, { accept: acceptedFiles, disabled: !isUploadEnabled || maxFilesLeft === 0 || !!cooldownRemaining, handleFiles: uploadNewFiles, maxNumberOfFiles: maxFilesLeft, multiple: multipleUploads },
21
43
  React.createElement("div", { className: "str-chat__small-message-input " + (SendButton ? 'str-chat__small-message-input--send-button-active' : '') + " " + (quotedMessage && quotedMessage.parent_id ? 'str-chat__input-flat-quoted' : '') + " " + (numberOfUploads ? 'str-chat__small-message-input-has-attachments' : '') + " " },
22
44
  quotedMessage && quotedMessage.parent_id && (React.createElement(QuotedMessagePreview, { quotedMessage: quotedMessage })),
45
+ isUploadEnabled && React.createElement(UploadsPreview, null),
23
46
  React.createElement("div", { className: 'str-chat__small-message-input--textarea-wrapper' },
24
- isUploadEnabled && React.createElement(UploadsPreview, null),
25
47
  React.createElement(ChatAutoComplete, null),
26
48
  cooldownRemaining ? (React.createElement("div", { className: 'str-chat__input-small-cooldown' },
27
- React.createElement(CooldownTimer, { cooldownInterval: cooldownInterval, setCooldownRemaining: setCooldownRemaining }))) : (React.createElement(React.Fragment, null,
49
+ React.createElement(CooldownTimer, { cooldownInterval: cooldownRemaining, setCooldownRemaining: setCooldownRemaining }))) : (React.createElement(React.Fragment, null,
28
50
  isUploadEnabled && (React.createElement("div", { className: 'str-chat__fileupload-wrapper', "data-testid": 'fileinput' },
29
51
  React.createElement(Tooltip, null, maxFilesLeft
30
52
  ? t('Attach files')
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { StreamMessage } from '../../context/ChannelStateContext';
3
2
  import type { DefaultStreamChatGenerics } from '../../types/types';
4
3
  export declare type QuotedMessagePreviewProps<StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics> = {
@@ -1 +1 @@
1
- {"version":3,"file":"QuotedMessagePreview.d.ts","sourceRoot":"","sources":["../../../src/components/MessageInput/QuotedMessagePreview.tsx"],"names":[],"mappings":";AAUA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAEvE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AA2BnE,oBAAY,yBAAyB,CACnC,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,aAAa,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;CAClD,CAAC;AAEF,eAAO,MAAM,oBAAoB,gKA6ChC,CAAC"}
1
+ {"version":3,"file":"QuotedMessagePreview.d.ts","sourceRoot":"","sources":["../../../src/components/MessageInput/QuotedMessagePreview.tsx"],"names":[],"mappings":"AAUA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAEvE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AA2BnE,oBAAY,yBAAyB,CACnC,kBAAkB,SAAS,yBAAyB,GAAG,yBAAyB,IAC9E;IACF,aAAa,EAAE,aAAa,CAAC,kBAAkB,CAAC,CAAC;CAClD,CAAC;AAEF,eAAO,MAAM,oBAAoB,gKA6ChC,CAAC"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { DefaultStreamChatGenerics } from '../../types/types';
3
2
  export declare const UploadsPreview: <StreamChatGenerics extends DefaultStreamChatGenerics = DefaultStreamChatGenerics>() => JSX.Element;
4
3
  //# sourceMappingURL=UploadsPreview.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"UploadsPreview.d.ts","sourceRoot":"","sources":["../../../src/components/MessageInput/UploadsPreview.tsx"],"names":[],"mappings":";AAMA,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,eAAO,MAAM,cAAc,qGAgD1B,CAAC"}
1
+ {"version":3,"file":"UploadsPreview.d.ts","sourceRoot":"","sources":["../../../src/components/MessageInput/UploadsPreview.tsx"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,mBAAmB,CAAC;AAEnE,eAAO,MAAM,cAAc,qGAgD1B,CAAC"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { FileLike } from 'react-file-utils';
3
2
  import type { MessageInputProps } from '../MessageInput';
4
3
  import type { MessageInputReducerAction, MessageInputState } from './useMessageInputState';
@@ -1 +1 @@
1
- {"version":3,"file":"useAttachments.d.ts","sourceRoot":"","sources":["../../../../src/components/MessageInput/hooks/useAttachments.ts"],"names":[],"mappings":";AAQA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEjD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,KAAK,EAAE,yBAAyB,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAE3F,OAAO,KAAK,EAAE,aAAa,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAIrF,eAAO,MAAM,cAAc,6TAOZ,MAAM,gBAAgB,CAAC,mBAAmB,GAAG,SAAS,CAAC;;;;;;;4BA6B1D,QAAQ,GAAG,IAAI,EAAE,GAAG,QAAQ,EAAE;CA8BzC,CAAC"}
1
+ {"version":3,"file":"useAttachments.d.ts","sourceRoot":"","sources":["../../../../src/components/MessageInput/hooks/useAttachments.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAEjD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACzD,OAAO,KAAK,EAAE,yBAAyB,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAE3F,OAAO,KAAK,EAAE,aAAa,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAIrF,eAAO,MAAM,cAAc,6TAOZ,MAAM,gBAAgB,CAAC,mBAAmB,GAAG,SAAS,CAAC;;;;;;;4BA6B1D,QAAQ,GAAG,IAAI,EAAE,GAAG,QAAQ,EAAE;CA8BzC,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"useCooldownTimer.d.ts","sourceRoot":"","sources":["../../../../src/components/MessageInput/hooks/useCooldownTimer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA8B,MAAM,OAAO,CAAC;AAOnD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAEtE,oBAAY,kBAAkB,GAAG;IAC/B,gBAAgB,EAAE,MAAM,CAAC;IACzB,oBAAoB,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC;CAChF,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CAkBtD,CAAC;AAcF,oBAAY,kBAAkB,GAAG;IAC/B,gBAAgB,EAAE,MAAM,CAAC;IACzB,oBAAoB,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC;IAC/E,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B,CAAC;AAEF,eAAO,MAAM,gBAAgB,0FAExB,kBA0BJ,CAAC"}
1
+ {"version":3,"file":"useCooldownTimer.d.ts","sourceRoot":"","sources":["../../../../src/components/MessageInput/hooks/useCooldownTimer.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA8B,MAAM,OAAO,CAAC;AAOnD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAEtE,oBAAY,kBAAkB,GAAG;IAC/B,gBAAgB,EAAE,MAAM,CAAC;IACzB,oBAAoB,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC;CAChF,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CAkBtD,CAAC;AAEF,oBAAY,kBAAkB,GAAG;IAC/B,gBAAgB,EAAE,MAAM,CAAC;IACzB,oBAAoB,EAAE,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,cAAc,CAAC,MAAM,GAAG,SAAS,CAAC,CAAC,CAAC;IAC/E,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B,CAAC;AAEF,eAAO,MAAM,gBAAgB,0FAExB,kBA6BJ,CAAC"}
@@ -17,36 +17,26 @@ export var CooldownTimer = function (props) {
17
17
  });
18
18
  return React.createElement("div", null, seconds === 0 ? null : seconds);
19
19
  };
20
- var rolesToSkip = {
21
- admin: true,
22
- channel_moderator: true,
23
- moderator: true,
24
- };
25
- var checkUserRoles = function (globalRole, channelRole) {
26
- var skipGlobal = !!rolesToSkip[globalRole];
27
- var skipChannel = !!rolesToSkip[channelRole];
28
- return skipGlobal || skipChannel;
29
- };
30
20
  export var useCooldownTimer = function () {
31
- var _a, _b;
32
- var client = useChatContext('useCooldownTimer').client;
21
+ var latestMessageDatesByChannels = useChatContext('useCooldownTimer').latestMessageDatesByChannels;
33
22
  var channel = useChannelStateContext('useCooldownTimer').channel;
34
- var cooldownInterval = (channel.data ||
35
- {}).cooldown;
36
- var _c = useState(), cooldownRemaining = _c[0], setCooldownRemaining = _c[1];
37
- var globalRole = ((_a = client.user) === null || _a === void 0 ? void 0 : _a.role) || '';
38
- var channelRole = ((_b = channel.state.members[client.userID || '']) === null || _b === void 0 ? void 0 : _b.role) || '';
39
- var skipCooldown = checkUserRoles(globalRole, channelRole);
23
+ var _a = (channel.data ||
24
+ {}), cooldownInterval = _a.cooldown, own_capabilities = _a.own_capabilities;
25
+ var _b = useState(), cooldownRemaining = _b[0], setCooldownRemaining = _b[1];
26
+ var skipCooldown = !(own_capabilities === null || own_capabilities === void 0 ? void 0 : own_capabilities.includes('slow-mode'));
40
27
  useEffect(function () {
41
- var handleEvent = function (event) {
42
- var _a;
43
- if (!skipCooldown && ((_a = event.user) === null || _a === void 0 ? void 0 : _a.id) === client.userID) {
44
- setCooldownRemaining(cooldownInterval);
45
- }
46
- };
47
- if (cooldownInterval)
48
- channel.on('message.new', handleEvent);
49
- return function () { return channel.off('message.new', handleEvent); };
50
- }, [channel.id, cooldownInterval]);
51
- return { cooldownInterval: cooldownInterval || 0, cooldownRemaining: cooldownRemaining, setCooldownRemaining: setCooldownRemaining };
28
+ var latestMessageDate = latestMessageDatesByChannels[channel.cid];
29
+ if (!cooldownInterval || !latestMessageDate) {
30
+ return;
31
+ }
32
+ var remainingCooldown = Math.round(cooldownInterval - (new Date().getTime() - latestMessageDate.getTime()) / 1000);
33
+ if (remainingCooldown > 0 && !skipCooldown) {
34
+ setCooldownRemaining(remainingCooldown);
35
+ }
36
+ }, [channel.id, cooldownInterval, latestMessageDatesByChannels[channel.cid]]);
37
+ return {
38
+ cooldownInterval: cooldownInterval || 0,
39
+ cooldownRemaining: cooldownRemaining,
40
+ setCooldownRemaining: setCooldownRemaining,
41
+ };
52
42
  };
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { MessageInputReducerAction, MessageInputState } from './useMessageInputState';
3
2
  import type { EmojiData } from 'emoji-mart';
4
3
  import type { DefaultStreamChatGenerics } from '../../../types/types';
@@ -1 +1 @@
1
- {"version":3,"file":"useEmojiPicker.d.ts","sourceRoot":"","sources":["../../../../src/components/MessageInput/hooks/useEmojiPicker.ts"],"names":[],"mappings":";AAEA,OAAO,KAAK,EAAE,yBAAyB,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC3F,OAAO,KAAK,EAAa,SAAS,EAAE,MAAM,YAAY,CAAC;AAEvD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAEtE,eAAO,MAAM,cAAc,iPAKE,MAAM,KAAK,IAAI,eAC7B,MAAM,gBAAgB,CAAC,mBAAmB,GAAG,SAAS,CAAC;8BAM1D,UAAU;;;2BAyDV,SAAS;;CAqBpB,CAAC"}
1
+ {"version":3,"file":"useEmojiPicker.d.ts","sourceRoot":"","sources":["../../../../src/components/MessageInput/hooks/useEmojiPicker.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,yBAAyB,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC3F,OAAO,KAAK,EAAa,SAAS,EAAE,MAAM,YAAY,CAAC;AAEvD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAEtE,eAAO,MAAM,cAAc,iPAKE,MAAM,KAAK,IAAI,eAC7B,MAAM,gBAAgB,CAAC,mBAAmB,GAAG,SAAS,CAAC;8BAM1D,UAAU;;;2BAyDV,SAAS;;CAqBpB,CAAC"}
@@ -1,4 +1,3 @@
1
- /// <reference types="react" />
2
1
  import type { MessageInputReducerAction, MessageInputState } from './useMessageInputState';
3
2
  import type { MessageInputProps } from '../MessageInput';
4
3
  import type { CustomTrigger, DefaultStreamChatGenerics } from '../../../types/types';
@@ -1 +1 @@
1
- {"version":3,"file":"useFileUploads.d.ts","sourceRoot":"","sources":["../../../../src/components/MessageInput/hooks/useFileUploads.ts"],"names":[],"mappings":";AAUA,OAAO,KAAK,EAAE,yBAAyB,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC3F,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAEzD,OAAO,KAAK,EAAE,aAAa,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAErF,eAAO,MAAM,cAAc;;;CAiG1B,CAAC"}
1
+ {"version":3,"file":"useFileUploads.d.ts","sourceRoot":"","sources":["../../../../src/components/MessageInput/hooks/useFileUploads.ts"],"names":[],"mappings":"AAUA,OAAO,KAAK,EAAE,yBAAyB,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;AAC3F,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AAEzD,OAAO,KAAK,EAAE,aAAa,EAAE,yBAAyB,EAAE,MAAM,sBAAsB,CAAC;AAErF,eAAO,MAAM,cAAc;;;CAiG1B,CAAC"}