stream-chat-react-native-core 9.0.0-beta.30 → 9.0.0-beta.32

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 (750) hide show
  1. package/lib/commonjs/components/Attachment/Attachment.js +15 -52
  2. package/lib/commonjs/components/Attachment/Attachment.js.map +1 -1
  3. package/lib/commonjs/components/Attachment/FileAttachment.js +4 -6
  4. package/lib/commonjs/components/Attachment/FileAttachment.js.map +1 -1
  5. package/lib/commonjs/components/Attachment/FileAttachmentGroup.js +4 -10
  6. package/lib/commonjs/components/Attachment/FileAttachmentGroup.js.map +1 -1
  7. package/lib/commonjs/components/Attachment/FilePreview.js +3 -6
  8. package/lib/commonjs/components/Attachment/FilePreview.js.map +1 -1
  9. package/lib/commonjs/components/Attachment/Gallery.js +9 -28
  10. package/lib/commonjs/components/Attachment/Gallery.js.map +1 -1
  11. package/lib/commonjs/components/Attachment/GalleryImage.js +3 -3
  12. package/lib/commonjs/components/Attachment/GalleryImage.js.map +1 -1
  13. package/lib/commonjs/components/Attachment/Giphy/GiphyImage.js +7 -13
  14. package/lib/commonjs/components/Attachment/Giphy/GiphyImage.js.map +1 -1
  15. package/lib/commonjs/components/Attachment/UnsupportedAttachment.js +4 -6
  16. package/lib/commonjs/components/Attachment/UnsupportedAttachment.js.map +1 -1
  17. package/lib/commonjs/components/Attachment/UrlPreview/URLPreview.js +3 -3
  18. package/lib/commonjs/components/Attachment/UrlPreview/URLPreview.js.map +1 -1
  19. package/lib/commonjs/components/Attachment/UrlPreview/URLPreviewCompact.js +3 -3
  20. package/lib/commonjs/components/Attachment/UrlPreview/URLPreviewCompact.js.map +1 -1
  21. package/lib/commonjs/components/AttachmentPicker/AttachmentPicker.js +4 -2
  22. package/lib/commonjs/components/AttachmentPicker/AttachmentPicker.js.map +1 -1
  23. package/lib/commonjs/components/AttachmentPicker/components/AttachmentMediaPicker/AttachmentPickerItem.js +7 -4
  24. package/lib/commonjs/components/AttachmentPicker/components/AttachmentMediaPicker/AttachmentPickerItem.js.map +1 -1
  25. package/lib/commonjs/components/AutoCompleteInput/AutoCompleteSuggestionList.js +9 -13
  26. package/lib/commonjs/components/AutoCompleteInput/AutoCompleteSuggestionList.js.map +1 -1
  27. package/lib/commonjs/components/Channel/Channel.js +9 -418
  28. package/lib/commonjs/components/Channel/Channel.js.map +1 -1
  29. package/lib/commonjs/components/Channel/hooks/useCreateChannelContext.js +0 -8
  30. package/lib/commonjs/components/Channel/hooks/useCreateChannelContext.js.map +1 -1
  31. package/lib/commonjs/components/Channel/hooks/useCreateInputMessageInputContext.js +3 -77
  32. package/lib/commonjs/components/Channel/hooks/useCreateInputMessageInputContext.js.map +1 -1
  33. package/lib/commonjs/components/Channel/hooks/useCreateMessagesContext.js +2 -132
  34. package/lib/commonjs/components/Channel/hooks/useCreateMessagesContext.js.map +1 -1
  35. package/lib/commonjs/components/ChannelList/ChannelList.js +1 -57
  36. package/lib/commonjs/components/ChannelList/ChannelList.js.map +1 -1
  37. package/lib/commonjs/components/ChannelList/ChannelListLoadingIndicator.js +4 -2
  38. package/lib/commonjs/components/ChannelList/ChannelListLoadingIndicator.js.map +1 -1
  39. package/lib/commonjs/components/ChannelList/ChannelListView.js +11 -20
  40. package/lib/commonjs/components/ChannelList/ChannelListView.js.map +1 -1
  41. package/lib/commonjs/components/ChannelList/hooks/useCreateChannelsContext.js +1 -39
  42. package/lib/commonjs/components/ChannelList/hooks/useCreateChannelsContext.js.map +1 -1
  43. package/lib/commonjs/components/ChannelPreview/ChannelDetailsBottomSheet.js +3 -2
  44. package/lib/commonjs/components/ChannelPreview/ChannelDetailsBottomSheet.js.map +1 -1
  45. package/lib/commonjs/components/ChannelPreview/ChannelPreview.js +4 -6
  46. package/lib/commonjs/components/ChannelPreview/ChannelPreview.js.map +1 -1
  47. package/lib/commonjs/components/ChannelPreview/ChannelPreviewMessage.js +6 -18
  48. package/lib/commonjs/components/ChannelPreview/ChannelPreviewMessage.js.map +1 -1
  49. package/lib/commonjs/components/ChannelPreview/ChannelPreviewView.js +8 -28
  50. package/lib/commonjs/components/ChannelPreview/ChannelPreviewView.js.map +1 -1
  51. package/lib/commonjs/components/ChannelPreview/ChannelSwipableWrapper.js +3 -3
  52. package/lib/commonjs/components/ChannelPreview/ChannelSwipableWrapper.js.map +1 -1
  53. package/lib/commonjs/components/Chat/Chat.js +4 -6
  54. package/lib/commonjs/components/Chat/Chat.js.map +1 -1
  55. package/lib/commonjs/components/Chat/hooks/useCreateChatContext.js +0 -2
  56. package/lib/commonjs/components/Chat/hooks/useCreateChatContext.js.map +1 -1
  57. package/lib/commonjs/components/ImageGallery/ImageGallery.js +7 -9
  58. package/lib/commonjs/components/ImageGallery/ImageGallery.js.map +1 -1
  59. package/lib/commonjs/components/ImageGallery/components/ImageGalleryFooter.js +4 -2
  60. package/lib/commonjs/components/ImageGallery/components/ImageGalleryFooter.js.map +1 -1
  61. package/lib/commonjs/components/Message/Message.js +9 -13
  62. package/lib/commonjs/components/Message/Message.js.map +1 -1
  63. package/lib/commonjs/components/Message/MessageItemView/MessageBubble.js +4 -2
  64. package/lib/commonjs/components/Message/MessageItemView/MessageBubble.js.map +1 -1
  65. package/lib/commonjs/components/Message/MessageItemView/MessageContent.js +18 -39
  66. package/lib/commonjs/components/Message/MessageItemView/MessageContent.js.map +1 -1
  67. package/lib/commonjs/components/Message/MessageItemView/MessageDeleted.js +5 -7
  68. package/lib/commonjs/components/Message/MessageItemView/MessageDeleted.js.map +1 -1
  69. package/lib/commonjs/components/Message/MessageItemView/MessageFooter.js +4 -8
  70. package/lib/commonjs/components/Message/MessageItemView/MessageFooter.js.map +1 -1
  71. package/lib/commonjs/components/Message/MessageItemView/MessageHeader.js +8 -16
  72. package/lib/commonjs/components/Message/MessageItemView/MessageHeader.js.map +1 -1
  73. package/lib/commonjs/components/Message/MessageItemView/MessageItemView.js +13 -35
  74. package/lib/commonjs/components/Message/MessageItemView/MessageItemView.js.map +1 -1
  75. package/lib/commonjs/components/Message/MessageItemView/MessageReplies.js +3 -5
  76. package/lib/commonjs/components/Message/MessageItemView/MessageReplies.js.map +1 -1
  77. package/lib/commonjs/components/Message/MessageItemView/MessageTextContainer.js +3 -3
  78. package/lib/commonjs/components/Message/MessageItemView/MessageTextContainer.js.map +1 -1
  79. package/lib/commonjs/components/Message/MessageItemView/MessageWrapper.js +6 -4
  80. package/lib/commonjs/components/Message/MessageItemView/MessageWrapper.js.map +1 -1
  81. package/lib/commonjs/components/Message/MessageItemView/ReactionList/ReactionListBottom.js +6 -8
  82. package/lib/commonjs/components/Message/MessageItemView/ReactionList/ReactionListBottom.js.map +1 -1
  83. package/lib/commonjs/components/Message/MessageItemView/ReactionList/ReactionListTop.js +7 -11
  84. package/lib/commonjs/components/Message/MessageItemView/ReactionList/ReactionListTop.js.map +1 -1
  85. package/lib/commonjs/components/Message/MessageItemView/utils/renderText.js +3 -1
  86. package/lib/commonjs/components/Message/MessageItemView/utils/renderText.js.map +1 -1
  87. package/lib/commonjs/components/MessageInput/MessageComposer.js +15 -55
  88. package/lib/commonjs/components/MessageInput/MessageComposer.js.map +1 -1
  89. package/lib/commonjs/components/MessageInput/MessageInputHeaderView.js +5 -5
  90. package/lib/commonjs/components/MessageInput/MessageInputHeaderView.js.map +1 -1
  91. package/lib/commonjs/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.js +9 -17
  92. package/lib/commonjs/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.js.map +1 -1
  93. package/lib/commonjs/components/MessageInput/components/AttachmentPreview/FileAttachmentUploadPreview.js +5 -5
  94. package/lib/commonjs/components/MessageInput/components/AttachmentPreview/FileAttachmentUploadPreview.js.map +1 -1
  95. package/lib/commonjs/components/MessageInput/components/AttachmentPreview/ImageAttachmentUploadPreview.js +5 -5
  96. package/lib/commonjs/components/MessageInput/components/AttachmentPreview/ImageAttachmentUploadPreview.js.map +1 -1
  97. package/lib/commonjs/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.js +5 -5
  98. package/lib/commonjs/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.js.map +1 -1
  99. package/lib/commonjs/components/MessageInput/components/InputButtons/index.js +4 -4
  100. package/lib/commonjs/components/MessageInput/components/InputButtons/index.js.map +1 -1
  101. package/lib/commonjs/components/MessageInput/components/LinkPreviewList.js +3 -2
  102. package/lib/commonjs/components/MessageInput/components/LinkPreviewList.js.map +1 -1
  103. package/lib/commonjs/components/MessageInput/components/OutputButtons/index.js +7 -13
  104. package/lib/commonjs/components/MessageInput/components/OutputButtons/index.js.map +1 -1
  105. package/lib/commonjs/components/MessageList/MessageFlashList.js +14 -40
  106. package/lib/commonjs/components/MessageList/MessageFlashList.js.map +1 -1
  107. package/lib/commonjs/components/MessageList/MessageList.js +12 -38
  108. package/lib/commonjs/components/MessageList/MessageList.js.map +1 -1
  109. package/lib/commonjs/components/MessageList/StickyHeader.js +3 -1
  110. package/lib/commonjs/components/MessageList/StickyHeader.js.map +1 -1
  111. package/lib/commonjs/components/MessageMenu/MessageActionList.js +4 -2
  112. package/lib/commonjs/components/MessageMenu/MessageActionList.js.map +1 -1
  113. package/lib/commonjs/components/MessageMenu/MessageMenu.js.map +1 -1
  114. package/lib/commonjs/components/MessageMenu/MessageUserReactions.js +4 -8
  115. package/lib/commonjs/components/MessageMenu/MessageUserReactions.js.map +1 -1
  116. package/lib/commonjs/components/MessageMenu/MessageUserReactionsItem.js +4 -2
  117. package/lib/commonjs/components/MessageMenu/MessageUserReactionsItem.js.map +1 -1
  118. package/lib/commonjs/components/Poll/CreatePollContent.js +8 -4
  119. package/lib/commonjs/components/Poll/CreatePollContent.js.map +1 -1
  120. package/lib/commonjs/components/Poll/Poll.js +12 -9
  121. package/lib/commonjs/components/Poll/Poll.js.map +1 -1
  122. package/lib/commonjs/components/Poll/components/MultipleAnswersField.js +5 -3
  123. package/lib/commonjs/components/Poll/components/MultipleAnswersField.js.map +1 -1
  124. package/lib/commonjs/components/Poll/components/MultipleVotesSettings.js +5 -3
  125. package/lib/commonjs/components/Poll/components/MultipleVotesSettings.js.map +1 -1
  126. package/lib/commonjs/components/Poll/components/PollAnswersList.js +5 -3
  127. package/lib/commonjs/components/Poll/components/PollAnswersList.js.map +1 -1
  128. package/lib/commonjs/components/Poll/components/PollInputDialog.js +2 -1
  129. package/lib/commonjs/components/Poll/components/PollInputDialog.js.map +1 -1
  130. package/lib/commonjs/components/Poll/components/PollOption.js +5 -3
  131. package/lib/commonjs/components/Poll/components/PollOption.js.map +1 -1
  132. package/lib/commonjs/components/Poll/components/PollResults/PollOptionFullResults.js +5 -5
  133. package/lib/commonjs/components/Poll/components/PollResults/PollOptionFullResults.js.map +1 -1
  134. package/lib/commonjs/components/Poll/components/PollResults/PollResults.js +5 -3
  135. package/lib/commonjs/components/Poll/components/PollResults/PollResults.js.map +1 -1
  136. package/lib/commonjs/components/Reply/Reply.js +11 -4
  137. package/lib/commonjs/components/Reply/Reply.js.map +1 -1
  138. package/lib/commonjs/components/Thread/Thread.js +4 -8
  139. package/lib/commonjs/components/Thread/Thread.js.map +1 -1
  140. package/lib/commonjs/components/Thread/components/ThreadFooterComponent.js +4 -6
  141. package/lib/commonjs/components/Thread/components/ThreadFooterComponent.js.map +1 -1
  142. package/lib/commonjs/components/ThreadList/ThreadList.js +12 -15
  143. package/lib/commonjs/components/ThreadList/ThreadList.js.map +1 -1
  144. package/lib/commonjs/components/ThreadList/ThreadListItem.js +8 -11
  145. package/lib/commonjs/components/ThreadList/ThreadListItem.js.map +1 -1
  146. package/lib/commonjs/components/ui/Avatar/Avatar.js +3 -3
  147. package/lib/commonjs/components/ui/Avatar/Avatar.js.map +1 -1
  148. package/lib/commonjs/contexts/attachmentPickerContext/AttachmentPickerContext.js.map +1 -1
  149. package/lib/commonjs/contexts/channelContext/ChannelContext.js.map +1 -1
  150. package/lib/commonjs/contexts/channelsContext/ChannelsContext.js.map +1 -1
  151. package/lib/commonjs/contexts/chatContext/ChatContext.js.map +1 -1
  152. package/lib/commonjs/contexts/componentsContext/ComponentsContext.js +37 -0
  153. package/lib/commonjs/contexts/componentsContext/ComponentsContext.js.map +1 -0
  154. package/lib/commonjs/contexts/componentsContext/PLAN.md +148 -0
  155. package/lib/commonjs/contexts/componentsContext/defaultComponents.js +286 -0
  156. package/lib/commonjs/contexts/componentsContext/defaultComponents.js.map +1 -0
  157. package/lib/commonjs/contexts/imageGalleryContext/ImageGalleryContext.js +1 -9
  158. package/lib/commonjs/contexts/imageGalleryContext/ImageGalleryContext.js.map +1 -1
  159. package/lib/commonjs/contexts/imageGalleryContext/ImageGalleryContextBase.js.map +1 -1
  160. package/lib/commonjs/contexts/index.js +11 -0
  161. package/lib/commonjs/contexts/index.js.map +1 -1
  162. package/lib/commonjs/contexts/messageInputContext/MessageInputContext.js.map +1 -1
  163. package/lib/commonjs/contexts/messageInputContext/hooks/useCreateMessageInputContext.js +2 -76
  164. package/lib/commonjs/contexts/messageInputContext/hooks/useCreateMessageInputContext.js.map +1 -1
  165. package/lib/commonjs/contexts/messagesContext/MessagesContext.js.map +1 -1
  166. package/lib/commonjs/contexts/overlayContext/MessageOverlayHostLayer.js +7 -5
  167. package/lib/commonjs/contexts/overlayContext/MessageOverlayHostLayer.js.map +1 -1
  168. package/lib/commonjs/contexts/overlayContext/OverlayContext.js.map +1 -1
  169. package/lib/commonjs/contexts/overlayContext/OverlayProvider.js +1 -4
  170. package/lib/commonjs/contexts/overlayContext/OverlayProvider.js.map +1 -1
  171. package/lib/commonjs/contexts/threadsContext/ThreadsContext.js.map +1 -1
  172. package/lib/commonjs/hooks/messagePreview/useMessagePreviewText.js +28 -13
  173. package/lib/commonjs/hooks/messagePreview/useMessagePreviewText.js.map +1 -1
  174. package/lib/commonjs/i18n/en.json +20 -0
  175. package/lib/commonjs/i18n/es.json +20 -0
  176. package/lib/commonjs/i18n/fr.json +20 -0
  177. package/lib/commonjs/i18n/he.json +20 -0
  178. package/lib/commonjs/i18n/hi.json +20 -0
  179. package/lib/commonjs/i18n/it.json +20 -0
  180. package/lib/commonjs/i18n/ja.json +20 -0
  181. package/lib/commonjs/i18n/ko.json +20 -0
  182. package/lib/commonjs/i18n/nl.json +20 -0
  183. package/lib/commonjs/i18n/pt-br.json +20 -0
  184. package/lib/commonjs/i18n/ru.json +20 -0
  185. package/lib/commonjs/i18n/tr.json +20 -0
  186. package/lib/commonjs/icons/arrow-up-right.js +10 -6
  187. package/lib/commonjs/icons/arrow-up-right.js.map +1 -1
  188. package/lib/commonjs/icons/audio.js +10 -6
  189. package/lib/commonjs/icons/audio.js.map +1 -1
  190. package/lib/commonjs/icons/chevron-left.js +10 -6
  191. package/lib/commonjs/icons/chevron-left.js.map +1 -1
  192. package/lib/commonjs/icons/leave.js +10 -6
  193. package/lib/commonjs/icons/leave.js.map +1 -1
  194. package/lib/commonjs/icons/message-bubble.js +10 -6
  195. package/lib/commonjs/icons/message-bubble.js.map +1 -1
  196. package/lib/commonjs/icons/mute.js +11 -7
  197. package/lib/commonjs/icons/mute.js.map +1 -1
  198. package/lib/commonjs/icons/reply.js +10 -6
  199. package/lib/commonjs/icons/reply.js.map +1 -1
  200. package/lib/commonjs/icons/search.js +11 -7
  201. package/lib/commonjs/icons/search.js.map +1 -1
  202. package/lib/commonjs/icons/send.js +11 -7
  203. package/lib/commonjs/icons/send.js.map +1 -1
  204. package/lib/commonjs/icons/thread.js +10 -6
  205. package/lib/commonjs/icons/thread.js.map +1 -1
  206. package/lib/commonjs/icons/video-fill.js +2 -0
  207. package/lib/commonjs/icons/video-fill.js.map +1 -1
  208. package/lib/commonjs/icons/video.js +10 -6
  209. package/lib/commonjs/icons/video.js.map +1 -1
  210. package/lib/commonjs/utils/rtlMirrorSwitchStyle.js +20 -0
  211. package/lib/commonjs/utils/rtlMirrorSwitchStyle.js.map +1 -0
  212. package/lib/commonjs/version.json +1 -1
  213. package/lib/module/components/Attachment/Attachment.js +15 -52
  214. package/lib/module/components/Attachment/Attachment.js.map +1 -1
  215. package/lib/module/components/Attachment/FileAttachment.js +4 -6
  216. package/lib/module/components/Attachment/FileAttachment.js.map +1 -1
  217. package/lib/module/components/Attachment/FileAttachmentGroup.js +4 -10
  218. package/lib/module/components/Attachment/FileAttachmentGroup.js.map +1 -1
  219. package/lib/module/components/Attachment/FilePreview.js +3 -6
  220. package/lib/module/components/Attachment/FilePreview.js.map +1 -1
  221. package/lib/module/components/Attachment/Gallery.js +9 -28
  222. package/lib/module/components/Attachment/Gallery.js.map +1 -1
  223. package/lib/module/components/Attachment/GalleryImage.js +3 -3
  224. package/lib/module/components/Attachment/GalleryImage.js.map +1 -1
  225. package/lib/module/components/Attachment/Giphy/GiphyImage.js +7 -13
  226. package/lib/module/components/Attachment/Giphy/GiphyImage.js.map +1 -1
  227. package/lib/module/components/Attachment/UnsupportedAttachment.js +4 -6
  228. package/lib/module/components/Attachment/UnsupportedAttachment.js.map +1 -1
  229. package/lib/module/components/Attachment/UrlPreview/URLPreview.js +3 -3
  230. package/lib/module/components/Attachment/UrlPreview/URLPreview.js.map +1 -1
  231. package/lib/module/components/Attachment/UrlPreview/URLPreviewCompact.js +3 -3
  232. package/lib/module/components/Attachment/UrlPreview/URLPreviewCompact.js.map +1 -1
  233. package/lib/module/components/AttachmentPicker/AttachmentPicker.js +4 -2
  234. package/lib/module/components/AttachmentPicker/AttachmentPicker.js.map +1 -1
  235. package/lib/module/components/AttachmentPicker/components/AttachmentMediaPicker/AttachmentPickerItem.js +7 -4
  236. package/lib/module/components/AttachmentPicker/components/AttachmentMediaPicker/AttachmentPickerItem.js.map +1 -1
  237. package/lib/module/components/AutoCompleteInput/AutoCompleteSuggestionList.js +9 -13
  238. package/lib/module/components/AutoCompleteInput/AutoCompleteSuggestionList.js.map +1 -1
  239. package/lib/module/components/Channel/Channel.js +9 -418
  240. package/lib/module/components/Channel/Channel.js.map +1 -1
  241. package/lib/module/components/Channel/hooks/useCreateChannelContext.js +0 -8
  242. package/lib/module/components/Channel/hooks/useCreateChannelContext.js.map +1 -1
  243. package/lib/module/components/Channel/hooks/useCreateInputMessageInputContext.js +3 -77
  244. package/lib/module/components/Channel/hooks/useCreateInputMessageInputContext.js.map +1 -1
  245. package/lib/module/components/Channel/hooks/useCreateMessagesContext.js +2 -132
  246. package/lib/module/components/Channel/hooks/useCreateMessagesContext.js.map +1 -1
  247. package/lib/module/components/ChannelList/ChannelList.js +1 -57
  248. package/lib/module/components/ChannelList/ChannelList.js.map +1 -1
  249. package/lib/module/components/ChannelList/ChannelListLoadingIndicator.js +4 -2
  250. package/lib/module/components/ChannelList/ChannelListLoadingIndicator.js.map +1 -1
  251. package/lib/module/components/ChannelList/ChannelListView.js +11 -20
  252. package/lib/module/components/ChannelList/ChannelListView.js.map +1 -1
  253. package/lib/module/components/ChannelList/hooks/useCreateChannelsContext.js +1 -39
  254. package/lib/module/components/ChannelList/hooks/useCreateChannelsContext.js.map +1 -1
  255. package/lib/module/components/ChannelPreview/ChannelDetailsBottomSheet.js +3 -2
  256. package/lib/module/components/ChannelPreview/ChannelDetailsBottomSheet.js.map +1 -1
  257. package/lib/module/components/ChannelPreview/ChannelPreview.js +4 -6
  258. package/lib/module/components/ChannelPreview/ChannelPreview.js.map +1 -1
  259. package/lib/module/components/ChannelPreview/ChannelPreviewMessage.js +6 -18
  260. package/lib/module/components/ChannelPreview/ChannelPreviewMessage.js.map +1 -1
  261. package/lib/module/components/ChannelPreview/ChannelPreviewView.js +8 -28
  262. package/lib/module/components/ChannelPreview/ChannelPreviewView.js.map +1 -1
  263. package/lib/module/components/ChannelPreview/ChannelSwipableWrapper.js +3 -3
  264. package/lib/module/components/ChannelPreview/ChannelSwipableWrapper.js.map +1 -1
  265. package/lib/module/components/Chat/Chat.js +4 -6
  266. package/lib/module/components/Chat/Chat.js.map +1 -1
  267. package/lib/module/components/Chat/hooks/useCreateChatContext.js +0 -2
  268. package/lib/module/components/Chat/hooks/useCreateChatContext.js.map +1 -1
  269. package/lib/module/components/ImageGallery/ImageGallery.js +7 -9
  270. package/lib/module/components/ImageGallery/ImageGallery.js.map +1 -1
  271. package/lib/module/components/ImageGallery/components/ImageGalleryFooter.js +4 -2
  272. package/lib/module/components/ImageGallery/components/ImageGalleryFooter.js.map +1 -1
  273. package/lib/module/components/Message/Message.js +9 -13
  274. package/lib/module/components/Message/Message.js.map +1 -1
  275. package/lib/module/components/Message/MessageItemView/MessageBubble.js +4 -2
  276. package/lib/module/components/Message/MessageItemView/MessageBubble.js.map +1 -1
  277. package/lib/module/components/Message/MessageItemView/MessageContent.js +18 -39
  278. package/lib/module/components/Message/MessageItemView/MessageContent.js.map +1 -1
  279. package/lib/module/components/Message/MessageItemView/MessageDeleted.js +5 -7
  280. package/lib/module/components/Message/MessageItemView/MessageDeleted.js.map +1 -1
  281. package/lib/module/components/Message/MessageItemView/MessageFooter.js +4 -8
  282. package/lib/module/components/Message/MessageItemView/MessageFooter.js.map +1 -1
  283. package/lib/module/components/Message/MessageItemView/MessageHeader.js +8 -16
  284. package/lib/module/components/Message/MessageItemView/MessageHeader.js.map +1 -1
  285. package/lib/module/components/Message/MessageItemView/MessageItemView.js +13 -35
  286. package/lib/module/components/Message/MessageItemView/MessageItemView.js.map +1 -1
  287. package/lib/module/components/Message/MessageItemView/MessageReplies.js +3 -5
  288. package/lib/module/components/Message/MessageItemView/MessageReplies.js.map +1 -1
  289. package/lib/module/components/Message/MessageItemView/MessageTextContainer.js +3 -3
  290. package/lib/module/components/Message/MessageItemView/MessageTextContainer.js.map +1 -1
  291. package/lib/module/components/Message/MessageItemView/MessageWrapper.js +6 -4
  292. package/lib/module/components/Message/MessageItemView/MessageWrapper.js.map +1 -1
  293. package/lib/module/components/Message/MessageItemView/ReactionList/ReactionListBottom.js +6 -8
  294. package/lib/module/components/Message/MessageItemView/ReactionList/ReactionListBottom.js.map +1 -1
  295. package/lib/module/components/Message/MessageItemView/ReactionList/ReactionListTop.js +7 -11
  296. package/lib/module/components/Message/MessageItemView/ReactionList/ReactionListTop.js.map +1 -1
  297. package/lib/module/components/Message/MessageItemView/utils/renderText.js +3 -1
  298. package/lib/module/components/Message/MessageItemView/utils/renderText.js.map +1 -1
  299. package/lib/module/components/MessageInput/MessageComposer.js +15 -55
  300. package/lib/module/components/MessageInput/MessageComposer.js.map +1 -1
  301. package/lib/module/components/MessageInput/MessageInputHeaderView.js +5 -5
  302. package/lib/module/components/MessageInput/MessageInputHeaderView.js.map +1 -1
  303. package/lib/module/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.js +9 -17
  304. package/lib/module/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.js.map +1 -1
  305. package/lib/module/components/MessageInput/components/AttachmentPreview/FileAttachmentUploadPreview.js +5 -5
  306. package/lib/module/components/MessageInput/components/AttachmentPreview/FileAttachmentUploadPreview.js.map +1 -1
  307. package/lib/module/components/MessageInput/components/AttachmentPreview/ImageAttachmentUploadPreview.js +5 -5
  308. package/lib/module/components/MessageInput/components/AttachmentPreview/ImageAttachmentUploadPreview.js.map +1 -1
  309. package/lib/module/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.js +5 -5
  310. package/lib/module/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.js.map +1 -1
  311. package/lib/module/components/MessageInput/components/InputButtons/index.js +4 -4
  312. package/lib/module/components/MessageInput/components/InputButtons/index.js.map +1 -1
  313. package/lib/module/components/MessageInput/components/LinkPreviewList.js +3 -2
  314. package/lib/module/components/MessageInput/components/LinkPreviewList.js.map +1 -1
  315. package/lib/module/components/MessageInput/components/OutputButtons/index.js +7 -13
  316. package/lib/module/components/MessageInput/components/OutputButtons/index.js.map +1 -1
  317. package/lib/module/components/MessageList/MessageFlashList.js +14 -40
  318. package/lib/module/components/MessageList/MessageFlashList.js.map +1 -1
  319. package/lib/module/components/MessageList/MessageList.js +12 -38
  320. package/lib/module/components/MessageList/MessageList.js.map +1 -1
  321. package/lib/module/components/MessageList/StickyHeader.js +3 -1
  322. package/lib/module/components/MessageList/StickyHeader.js.map +1 -1
  323. package/lib/module/components/MessageMenu/MessageActionList.js +4 -2
  324. package/lib/module/components/MessageMenu/MessageActionList.js.map +1 -1
  325. package/lib/module/components/MessageMenu/MessageMenu.js.map +1 -1
  326. package/lib/module/components/MessageMenu/MessageUserReactions.js +4 -8
  327. package/lib/module/components/MessageMenu/MessageUserReactions.js.map +1 -1
  328. package/lib/module/components/MessageMenu/MessageUserReactionsItem.js +4 -2
  329. package/lib/module/components/MessageMenu/MessageUserReactionsItem.js.map +1 -1
  330. package/lib/module/components/Poll/CreatePollContent.js +8 -4
  331. package/lib/module/components/Poll/CreatePollContent.js.map +1 -1
  332. package/lib/module/components/Poll/Poll.js +12 -9
  333. package/lib/module/components/Poll/Poll.js.map +1 -1
  334. package/lib/module/components/Poll/components/MultipleAnswersField.js +5 -3
  335. package/lib/module/components/Poll/components/MultipleAnswersField.js.map +1 -1
  336. package/lib/module/components/Poll/components/MultipleVotesSettings.js +5 -3
  337. package/lib/module/components/Poll/components/MultipleVotesSettings.js.map +1 -1
  338. package/lib/module/components/Poll/components/PollAnswersList.js +5 -3
  339. package/lib/module/components/Poll/components/PollAnswersList.js.map +1 -1
  340. package/lib/module/components/Poll/components/PollInputDialog.js +2 -1
  341. package/lib/module/components/Poll/components/PollInputDialog.js.map +1 -1
  342. package/lib/module/components/Poll/components/PollOption.js +5 -3
  343. package/lib/module/components/Poll/components/PollOption.js.map +1 -1
  344. package/lib/module/components/Poll/components/PollResults/PollOptionFullResults.js +5 -5
  345. package/lib/module/components/Poll/components/PollResults/PollOptionFullResults.js.map +1 -1
  346. package/lib/module/components/Poll/components/PollResults/PollResults.js +5 -3
  347. package/lib/module/components/Poll/components/PollResults/PollResults.js.map +1 -1
  348. package/lib/module/components/Reply/Reply.js +11 -4
  349. package/lib/module/components/Reply/Reply.js.map +1 -1
  350. package/lib/module/components/Thread/Thread.js +4 -8
  351. package/lib/module/components/Thread/Thread.js.map +1 -1
  352. package/lib/module/components/Thread/components/ThreadFooterComponent.js +4 -6
  353. package/lib/module/components/Thread/components/ThreadFooterComponent.js.map +1 -1
  354. package/lib/module/components/ThreadList/ThreadList.js +12 -15
  355. package/lib/module/components/ThreadList/ThreadList.js.map +1 -1
  356. package/lib/module/components/ThreadList/ThreadListItem.js +8 -11
  357. package/lib/module/components/ThreadList/ThreadListItem.js.map +1 -1
  358. package/lib/module/components/ui/Avatar/Avatar.js +3 -3
  359. package/lib/module/components/ui/Avatar/Avatar.js.map +1 -1
  360. package/lib/module/contexts/attachmentPickerContext/AttachmentPickerContext.js.map +1 -1
  361. package/lib/module/contexts/channelContext/ChannelContext.js.map +1 -1
  362. package/lib/module/contexts/channelsContext/ChannelsContext.js.map +1 -1
  363. package/lib/module/contexts/chatContext/ChatContext.js.map +1 -1
  364. package/lib/module/contexts/componentsContext/ComponentsContext.js +37 -0
  365. package/lib/module/contexts/componentsContext/ComponentsContext.js.map +1 -0
  366. package/lib/module/contexts/componentsContext/PLAN.md +148 -0
  367. package/lib/module/contexts/componentsContext/defaultComponents.js +286 -0
  368. package/lib/module/contexts/componentsContext/defaultComponents.js.map +1 -0
  369. package/lib/module/contexts/imageGalleryContext/ImageGalleryContext.js +1 -9
  370. package/lib/module/contexts/imageGalleryContext/ImageGalleryContext.js.map +1 -1
  371. package/lib/module/contexts/imageGalleryContext/ImageGalleryContextBase.js.map +1 -1
  372. package/lib/module/contexts/index.js +11 -0
  373. package/lib/module/contexts/index.js.map +1 -1
  374. package/lib/module/contexts/messageInputContext/MessageInputContext.js.map +1 -1
  375. package/lib/module/contexts/messageInputContext/hooks/useCreateMessageInputContext.js +2 -76
  376. package/lib/module/contexts/messageInputContext/hooks/useCreateMessageInputContext.js.map +1 -1
  377. package/lib/module/contexts/messagesContext/MessagesContext.js.map +1 -1
  378. package/lib/module/contexts/overlayContext/MessageOverlayHostLayer.js +7 -5
  379. package/lib/module/contexts/overlayContext/MessageOverlayHostLayer.js.map +1 -1
  380. package/lib/module/contexts/overlayContext/OverlayContext.js.map +1 -1
  381. package/lib/module/contexts/overlayContext/OverlayProvider.js +1 -4
  382. package/lib/module/contexts/overlayContext/OverlayProvider.js.map +1 -1
  383. package/lib/module/contexts/threadsContext/ThreadsContext.js.map +1 -1
  384. package/lib/module/hooks/messagePreview/useMessagePreviewText.js +28 -13
  385. package/lib/module/hooks/messagePreview/useMessagePreviewText.js.map +1 -1
  386. package/lib/module/i18n/en.json +20 -0
  387. package/lib/module/i18n/es.json +20 -0
  388. package/lib/module/i18n/fr.json +20 -0
  389. package/lib/module/i18n/he.json +20 -0
  390. package/lib/module/i18n/hi.json +20 -0
  391. package/lib/module/i18n/it.json +20 -0
  392. package/lib/module/i18n/ja.json +20 -0
  393. package/lib/module/i18n/ko.json +20 -0
  394. package/lib/module/i18n/nl.json +20 -0
  395. package/lib/module/i18n/pt-br.json +20 -0
  396. package/lib/module/i18n/ru.json +20 -0
  397. package/lib/module/i18n/tr.json +20 -0
  398. package/lib/module/icons/arrow-up-right.js +10 -6
  399. package/lib/module/icons/arrow-up-right.js.map +1 -1
  400. package/lib/module/icons/audio.js +10 -6
  401. package/lib/module/icons/audio.js.map +1 -1
  402. package/lib/module/icons/chevron-left.js +10 -6
  403. package/lib/module/icons/chevron-left.js.map +1 -1
  404. package/lib/module/icons/leave.js +10 -6
  405. package/lib/module/icons/leave.js.map +1 -1
  406. package/lib/module/icons/message-bubble.js +10 -6
  407. package/lib/module/icons/message-bubble.js.map +1 -1
  408. package/lib/module/icons/mute.js +11 -7
  409. package/lib/module/icons/mute.js.map +1 -1
  410. package/lib/module/icons/reply.js +10 -6
  411. package/lib/module/icons/reply.js.map +1 -1
  412. package/lib/module/icons/search.js +11 -7
  413. package/lib/module/icons/search.js.map +1 -1
  414. package/lib/module/icons/send.js +11 -7
  415. package/lib/module/icons/send.js.map +1 -1
  416. package/lib/module/icons/thread.js +10 -6
  417. package/lib/module/icons/thread.js.map +1 -1
  418. package/lib/module/icons/video-fill.js +2 -0
  419. package/lib/module/icons/video-fill.js.map +1 -1
  420. package/lib/module/icons/video.js +10 -6
  421. package/lib/module/icons/video.js.map +1 -1
  422. package/lib/module/utils/rtlMirrorSwitchStyle.js +20 -0
  423. package/lib/module/utils/rtlMirrorSwitchStyle.js.map +1 -0
  424. package/lib/module/version.json +1 -1
  425. package/lib/typescript/components/Attachment/Attachment.d.ts +1 -1
  426. package/lib/typescript/components/Attachment/Attachment.d.ts.map +1 -1
  427. package/lib/typescript/components/Attachment/FileAttachment.d.ts +1 -1
  428. package/lib/typescript/components/Attachment/FileAttachment.d.ts.map +1 -1
  429. package/lib/typescript/components/Attachment/FileAttachmentGroup.d.ts +1 -2
  430. package/lib/typescript/components/Attachment/FileAttachmentGroup.d.ts.map +1 -1
  431. package/lib/typescript/components/Attachment/FilePreview.d.ts +2 -3
  432. package/lib/typescript/components/Attachment/FilePreview.d.ts.map +1 -1
  433. package/lib/typescript/components/Attachment/Gallery.d.ts +1 -1
  434. package/lib/typescript/components/Attachment/Gallery.d.ts.map +1 -1
  435. package/lib/typescript/components/Attachment/GalleryImage.d.ts +3 -2
  436. package/lib/typescript/components/Attachment/GalleryImage.d.ts.map +1 -1
  437. package/lib/typescript/components/Attachment/Giphy/GiphyImage.d.ts +4 -2
  438. package/lib/typescript/components/Attachment/Giphy/GiphyImage.d.ts.map +1 -1
  439. package/lib/typescript/components/Attachment/UnsupportedAttachment.d.ts +2 -3
  440. package/lib/typescript/components/Attachment/UnsupportedAttachment.d.ts.map +1 -1
  441. package/lib/typescript/components/Attachment/UrlPreview/URLPreview.d.ts +4 -3
  442. package/lib/typescript/components/Attachment/UrlPreview/URLPreview.d.ts.map +1 -1
  443. package/lib/typescript/components/Attachment/UrlPreview/URLPreviewCompact.d.ts +4 -3
  444. package/lib/typescript/components/Attachment/UrlPreview/URLPreviewCompact.d.ts.map +1 -1
  445. package/lib/typescript/components/AttachmentPicker/AttachmentPicker.d.ts.map +1 -1
  446. package/lib/typescript/components/AttachmentPicker/components/AttachmentMediaPicker/AttachmentPickerItem.d.ts.map +1 -1
  447. package/lib/typescript/components/AutoCompleteInput/AutoCompleteSuggestionList.d.ts +2 -3
  448. package/lib/typescript/components/AutoCompleteInput/AutoCompleteSuggestionList.d.ts.map +1 -1
  449. package/lib/typescript/components/Channel/Channel.d.ts +3 -28
  450. package/lib/typescript/components/Channel/Channel.d.ts.map +1 -1
  451. package/lib/typescript/components/Channel/hooks/useCreateChannelContext.d.ts +1 -1
  452. package/lib/typescript/components/Channel/hooks/useCreateChannelContext.d.ts.map +1 -1
  453. package/lib/typescript/components/Channel/hooks/useCreateInputMessageInputContext.d.ts +1 -1
  454. package/lib/typescript/components/Channel/hooks/useCreateInputMessageInputContext.d.ts.map +1 -1
  455. package/lib/typescript/components/Channel/hooks/useCreateMessagesContext.d.ts +1 -1
  456. package/lib/typescript/components/Channel/hooks/useCreateMessagesContext.d.ts.map +1 -1
  457. package/lib/typescript/components/Channel/hooks/useMessageListPagination.d.ts.map +1 -1
  458. package/lib/typescript/components/ChannelList/ChannelList.d.ts +2 -10
  459. package/lib/typescript/components/ChannelList/ChannelList.d.ts.map +1 -1
  460. package/lib/typescript/components/ChannelList/ChannelListLoadingIndicator.d.ts.map +1 -1
  461. package/lib/typescript/components/ChannelList/ChannelListView.d.ts +1 -1
  462. package/lib/typescript/components/ChannelList/ChannelListView.d.ts.map +1 -1
  463. package/lib/typescript/components/ChannelList/hooks/useCreateChannelsContext.d.ts +1 -1
  464. package/lib/typescript/components/ChannelList/hooks/useCreateChannelsContext.d.ts.map +1 -1
  465. package/lib/typescript/components/ChannelPreview/ChannelDetailsBottomSheet.d.ts +1 -2
  466. package/lib/typescript/components/ChannelPreview/ChannelDetailsBottomSheet.d.ts.map +1 -1
  467. package/lib/typescript/components/ChannelPreview/ChannelPreview.d.ts +1 -1
  468. package/lib/typescript/components/ChannelPreview/ChannelPreview.d.ts.map +1 -1
  469. package/lib/typescript/components/ChannelPreview/ChannelPreviewMessage.d.ts +1 -2
  470. package/lib/typescript/components/ChannelPreview/ChannelPreviewMessage.d.ts.map +1 -1
  471. package/lib/typescript/components/ChannelPreview/ChannelPreviewView.d.ts +1 -1
  472. package/lib/typescript/components/ChannelPreview/ChannelPreviewView.d.ts.map +1 -1
  473. package/lib/typescript/components/ChannelPreview/ChannelSwipableWrapper.d.ts +1 -3
  474. package/lib/typescript/components/ChannelPreview/ChannelSwipableWrapper.d.ts.map +1 -1
  475. package/lib/typescript/components/Chat/Chat.d.ts +1 -7
  476. package/lib/typescript/components/Chat/Chat.d.ts.map +1 -1
  477. package/lib/typescript/components/Chat/hooks/useCreateChatContext.d.ts +1 -1
  478. package/lib/typescript/components/Chat/hooks/useCreateChatContext.d.ts.map +1 -1
  479. package/lib/typescript/components/ImageGallery/ImageGallery.d.ts +6 -1
  480. package/lib/typescript/components/ImageGallery/ImageGallery.d.ts.map +1 -1
  481. package/lib/typescript/components/ImageGallery/components/ImageGalleryFooter.d.ts.map +1 -1
  482. package/lib/typescript/components/ImageGallery/components/types.d.ts +0 -2
  483. package/lib/typescript/components/ImageGallery/components/types.d.ts.map +1 -1
  484. package/lib/typescript/components/Message/Message.d.ts +1 -1
  485. package/lib/typescript/components/Message/Message.d.ts.map +1 -1
  486. package/lib/typescript/components/Message/MessageItemView/MessageBubble.d.ts +1 -2
  487. package/lib/typescript/components/Message/MessageItemView/MessageBubble.d.ts.map +1 -1
  488. package/lib/typescript/components/Message/MessageItemView/MessageContent.d.ts +1 -1
  489. package/lib/typescript/components/Message/MessageItemView/MessageContent.d.ts.map +1 -1
  490. package/lib/typescript/components/Message/MessageItemView/MessageDeleted.d.ts +1 -2
  491. package/lib/typescript/components/Message/MessageItemView/MessageDeleted.d.ts.map +1 -1
  492. package/lib/typescript/components/Message/MessageItemView/MessageFooter.d.ts +0 -2
  493. package/lib/typescript/components/Message/MessageItemView/MessageFooter.d.ts.map +1 -1
  494. package/lib/typescript/components/Message/MessageItemView/MessageHeader.d.ts.map +1 -1
  495. package/lib/typescript/components/Message/MessageItemView/MessageItemView.d.ts +1 -1
  496. package/lib/typescript/components/Message/MessageItemView/MessageItemView.d.ts.map +1 -1
  497. package/lib/typescript/components/Message/MessageItemView/MessageReplies.d.ts +1 -2
  498. package/lib/typescript/components/Message/MessageItemView/MessageReplies.d.ts.map +1 -1
  499. package/lib/typescript/components/Message/MessageItemView/MessageTextContainer.d.ts +1 -1
  500. package/lib/typescript/components/Message/MessageItemView/MessageTextContainer.d.ts.map +1 -1
  501. package/lib/typescript/components/Message/MessageItemView/MessageWrapper.d.ts.map +1 -1
  502. package/lib/typescript/components/Message/MessageItemView/ReactionList/ReactionListBottom.d.ts +1 -1
  503. package/lib/typescript/components/Message/MessageItemView/ReactionList/ReactionListBottom.d.ts.map +1 -1
  504. package/lib/typescript/components/Message/MessageItemView/ReactionList/ReactionListTop.d.ts +1 -1
  505. package/lib/typescript/components/Message/MessageItemView/ReactionList/ReactionListTop.d.ts.map +1 -1
  506. package/lib/typescript/components/Message/MessageItemView/utils/renderText.d.ts.map +1 -1
  507. package/lib/typescript/components/MessageInput/MessageComposer.d.ts +1 -2
  508. package/lib/typescript/components/MessageInput/MessageComposer.d.ts.map +1 -1
  509. package/lib/typescript/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.d.ts +3 -4
  510. package/lib/typescript/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.d.ts.map +1 -1
  511. package/lib/typescript/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.d.ts +1 -1
  512. package/lib/typescript/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.d.ts.map +1 -1
  513. package/lib/typescript/components/MessageInput/components/InputButtons/index.d.ts +1 -1
  514. package/lib/typescript/components/MessageInput/components/InputButtons/index.d.ts.map +1 -1
  515. package/lib/typescript/components/MessageInput/components/LinkPreviewList.d.ts.map +1 -1
  516. package/lib/typescript/components/MessageInput/components/OutputButtons/index.d.ts +1 -1
  517. package/lib/typescript/components/MessageInput/components/OutputButtons/index.d.ts.map +1 -1
  518. package/lib/typescript/components/MessageList/MessageFlashList.d.ts +1 -1
  519. package/lib/typescript/components/MessageList/MessageFlashList.d.ts.map +1 -1
  520. package/lib/typescript/components/MessageList/MessageList.d.ts +1 -1
  521. package/lib/typescript/components/MessageList/MessageList.d.ts.map +1 -1
  522. package/lib/typescript/components/MessageList/StickyHeader.d.ts +2 -3
  523. package/lib/typescript/components/MessageList/StickyHeader.d.ts.map +1 -1
  524. package/lib/typescript/components/MessageMenu/MessageActionList.d.ts +1 -2
  525. package/lib/typescript/components/MessageMenu/MessageActionList.d.ts.map +1 -1
  526. package/lib/typescript/components/MessageMenu/MessageMenu.d.ts +1 -2
  527. package/lib/typescript/components/MessageMenu/MessageMenu.d.ts.map +1 -1
  528. package/lib/typescript/components/MessageMenu/MessageUserReactions.d.ts +1 -1
  529. package/lib/typescript/components/MessageMenu/MessageUserReactions.d.ts.map +1 -1
  530. package/lib/typescript/components/MessageMenu/MessageUserReactionsItem.d.ts +2 -3
  531. package/lib/typescript/components/MessageMenu/MessageUserReactionsItem.d.ts.map +1 -1
  532. package/lib/typescript/components/Poll/CreatePollContent.d.ts +2 -2
  533. package/lib/typescript/components/Poll/CreatePollContent.d.ts.map +1 -1
  534. package/lib/typescript/components/Poll/Poll.d.ts +5 -8
  535. package/lib/typescript/components/Poll/Poll.d.ts.map +1 -1
  536. package/lib/typescript/components/Poll/components/MultipleVotesSettings.d.ts.map +1 -1
  537. package/lib/typescript/components/Poll/components/PollAnswersList.d.ts +1 -2
  538. package/lib/typescript/components/Poll/components/PollAnswersList.d.ts.map +1 -1
  539. package/lib/typescript/components/Poll/components/PollOption.d.ts +1 -2
  540. package/lib/typescript/components/Poll/components/PollOption.d.ts.map +1 -1
  541. package/lib/typescript/components/Poll/components/PollResults/PollOptionFullResults.d.ts +1 -4
  542. package/lib/typescript/components/Poll/components/PollResults/PollOptionFullResults.d.ts.map +1 -1
  543. package/lib/typescript/components/Poll/components/PollResults/PollResults.d.ts +1 -2
  544. package/lib/typescript/components/Poll/components/PollResults/PollResults.d.ts.map +1 -1
  545. package/lib/typescript/components/Reply/Reply.d.ts +4 -3
  546. package/lib/typescript/components/Reply/Reply.d.ts.map +1 -1
  547. package/lib/typescript/components/Thread/Thread.d.ts +2 -8
  548. package/lib/typescript/components/Thread/Thread.d.ts.map +1 -1
  549. package/lib/typescript/components/Thread/components/ThreadFooterComponent.d.ts +1 -2
  550. package/lib/typescript/components/Thread/components/ThreadFooterComponent.d.ts.map +1 -1
  551. package/lib/typescript/components/ThreadList/ThreadList.d.ts +2 -3
  552. package/lib/typescript/components/ThreadList/ThreadList.d.ts.map +1 -1
  553. package/lib/typescript/components/ThreadList/ThreadListItem.d.ts.map +1 -1
  554. package/lib/typescript/contexts/attachmentPickerContext/AttachmentPickerContext.d.ts +0 -17
  555. package/lib/typescript/contexts/attachmentPickerContext/AttachmentPickerContext.d.ts.map +1 -1
  556. package/lib/typescript/contexts/channelContext/ChannelContext.d.ts +0 -23
  557. package/lib/typescript/contexts/channelContext/ChannelContext.d.ts.map +1 -1
  558. package/lib/typescript/contexts/channelsContext/ChannelsContext.d.ts +0 -112
  559. package/lib/typescript/contexts/channelsContext/ChannelsContext.d.ts.map +1 -1
  560. package/lib/typescript/contexts/chatContext/ChatContext.d.ts +0 -5
  561. package/lib/typescript/contexts/chatContext/ChatContext.d.ts.map +1 -1
  562. package/lib/typescript/contexts/componentsContext/ComponentsContext.d.ts +321 -0
  563. package/lib/typescript/contexts/componentsContext/ComponentsContext.d.ts.map +1 -0
  564. package/lib/typescript/contexts/componentsContext/defaultComponents.d.ts +296 -0
  565. package/lib/typescript/contexts/componentsContext/defaultComponents.d.ts.map +1 -0
  566. package/lib/typescript/contexts/imageGalleryContext/ImageGalleryContext.d.ts.map +1 -1
  567. package/lib/typescript/contexts/imageGalleryContext/ImageGalleryContextBase.d.ts +0 -5
  568. package/lib/typescript/contexts/imageGalleryContext/ImageGalleryContextBase.d.ts.map +1 -1
  569. package/lib/typescript/contexts/index.d.ts +1 -0
  570. package/lib/typescript/contexts/index.d.ts.map +1 -1
  571. package/lib/typescript/contexts/messageInputContext/MessageInputContext.d.ts +1 -169
  572. package/lib/typescript/contexts/messageInputContext/MessageInputContext.d.ts.map +1 -1
  573. package/lib/typescript/contexts/messageInputContext/hooks/useCreateMessageInputContext.d.ts +1 -1
  574. package/lib/typescript/contexts/messageInputContext/hooks/useCreateMessageInputContext.d.ts.map +1 -1
  575. package/lib/typescript/contexts/messagesContext/MessagesContext.d.ts +3 -332
  576. package/lib/typescript/contexts/messagesContext/MessagesContext.d.ts.map +1 -1
  577. package/lib/typescript/contexts/overlayContext/MessageOverlayHostLayer.d.ts +2 -5
  578. package/lib/typescript/contexts/overlayContext/MessageOverlayHostLayer.d.ts.map +1 -1
  579. package/lib/typescript/contexts/overlayContext/OverlayContext.d.ts +0 -4
  580. package/lib/typescript/contexts/overlayContext/OverlayContext.d.ts.map +1 -1
  581. package/lib/typescript/contexts/overlayContext/OverlayProvider.d.ts.map +1 -1
  582. package/lib/typescript/contexts/threadsContext/ThreadsContext.d.ts +0 -9
  583. package/lib/typescript/contexts/threadsContext/ThreadsContext.d.ts.map +1 -1
  584. package/lib/typescript/hooks/messagePreview/useMessagePreviewText.d.ts.map +1 -1
  585. package/lib/typescript/i18n/en.json +20 -0
  586. package/lib/typescript/i18n/es.json +20 -0
  587. package/lib/typescript/i18n/fr.json +20 -0
  588. package/lib/typescript/i18n/he.json +20 -0
  589. package/lib/typescript/i18n/hi.json +20 -0
  590. package/lib/typescript/i18n/it.json +20 -0
  591. package/lib/typescript/i18n/ja.json +20 -0
  592. package/lib/typescript/i18n/ko.json +20 -0
  593. package/lib/typescript/i18n/nl.json +20 -0
  594. package/lib/typescript/i18n/pt-br.json +20 -0
  595. package/lib/typescript/i18n/ru.json +20 -0
  596. package/lib/typescript/i18n/tr.json +20 -0
  597. package/lib/typescript/icons/arrow-up-right.d.ts.map +1 -1
  598. package/lib/typescript/icons/audio.d.ts.map +1 -1
  599. package/lib/typescript/icons/chevron-left.d.ts.map +1 -1
  600. package/lib/typescript/icons/leave.d.ts.map +1 -1
  601. package/lib/typescript/icons/message-bubble.d.ts.map +1 -1
  602. package/lib/typescript/icons/mute.d.ts.map +1 -1
  603. package/lib/typescript/icons/reply.d.ts.map +1 -1
  604. package/lib/typescript/icons/search.d.ts.map +1 -1
  605. package/lib/typescript/icons/send.d.ts.map +1 -1
  606. package/lib/typescript/icons/thread.d.ts.map +1 -1
  607. package/lib/typescript/icons/video-fill.d.ts.map +1 -1
  608. package/lib/typescript/icons/video.d.ts.map +1 -1
  609. package/lib/typescript/utils/i18n/Streami18n.d.ts +20 -0
  610. package/lib/typescript/utils/i18n/Streami18n.d.ts.map +1 -1
  611. package/lib/typescript/utils/rtlMirrorSwitchStyle.d.ts +9 -0
  612. package/lib/typescript/utils/rtlMirrorSwitchStyle.d.ts.map +1 -0
  613. package/package.json +1 -1
  614. package/src/__tests__/offline-support/offline-feature.js +64 -67
  615. package/src/components/Attachment/Attachment.tsx +7 -69
  616. package/src/components/Attachment/FileAttachment.tsx +4 -7
  617. package/src/components/Attachment/FileAttachmentGroup.tsx +9 -19
  618. package/src/components/Attachment/FilePreview.tsx +4 -9
  619. package/src/components/Attachment/Gallery.tsx +6 -83
  620. package/src/components/Attachment/GalleryImage.tsx +5 -4
  621. package/src/components/Attachment/Giphy/GiphyImage.tsx +15 -37
  622. package/src/components/Attachment/UnsupportedAttachment.tsx +5 -10
  623. package/src/components/Attachment/UrlPreview/URLPreview.tsx +6 -4
  624. package/src/components/Attachment/UrlPreview/URLPreviewCompact.tsx +6 -4
  625. package/src/components/AttachmentPicker/AttachmentPicker.tsx +2 -2
  626. package/src/components/AttachmentPicker/components/AttachmentMediaPicker/AttachmentPickerItem.tsx +5 -4
  627. package/src/components/AutoCompleteInput/AutoCompleteSuggestionList.tsx +4 -20
  628. package/src/components/Channel/Channel.tsx +31 -438
  629. package/src/components/Channel/__tests__/isAttachmentEqualHandler.test.js +12 -9
  630. package/src/components/Channel/hooks/useCreateChannelContext.ts +0 -8
  631. package/src/components/Channel/hooks/useCreateInputMessageInputContext.ts +1 -81
  632. package/src/components/Channel/hooks/useCreateMessagesContext.ts +0 -130
  633. package/src/components/ChannelList/ChannelList.tsx +3 -76
  634. package/src/components/ChannelList/ChannelListLoadingIndicator.tsx +3 -1
  635. package/src/components/ChannelList/ChannelListView.tsx +12 -33
  636. package/src/components/ChannelList/__tests__/ChannelList.test.js +173 -116
  637. package/src/components/ChannelList/__tests__/ChannelListView.test.js +64 -41
  638. package/src/components/ChannelList/hooks/useCreateChannelsContext.ts +0 -39
  639. package/src/components/ChannelPreview/ChannelDetailsBottomSheet.tsx +2 -2
  640. package/src/components/ChannelPreview/ChannelPreview.tsx +6 -14
  641. package/src/components/ChannelPreview/ChannelPreviewMessage.tsx +7 -33
  642. package/src/components/ChannelPreview/ChannelPreviewView.tsx +11 -40
  643. package/src/components/ChannelPreview/ChannelSwipableWrapper.tsx +2 -4
  644. package/src/components/ChannelPreview/__tests__/ChannelDetailsBottomSheet.test.tsx +16 -12
  645. package/src/components/ChannelPreview/__tests__/ChannelPreview.test.tsx +25 -24
  646. package/src/components/ChannelPreview/__tests__/ChannelSwipableWrapper.test.tsx +11 -6
  647. package/src/components/Chat/Chat.tsx +5 -12
  648. package/src/components/Chat/hooks/useCreateChatContext.ts +0 -2
  649. package/src/components/ImageGallery/ImageGallery.tsx +14 -16
  650. package/src/components/ImageGallery/__tests__/ImageGallery.test.tsx +0 -8
  651. package/src/components/ImageGallery/__tests__/ImageGalleryFooter.test.tsx +25 -21
  652. package/src/components/ImageGallery/components/ImageGalleryFooter.tsx +3 -1
  653. package/src/components/ImageGallery/components/types.ts +0 -3
  654. package/src/components/Message/Message.tsx +11 -32
  655. package/src/components/Message/MessageItemView/MessageBubble.tsx +11 -7
  656. package/src/components/Message/MessageItemView/MessageContent.tsx +14 -47
  657. package/src/components/Message/MessageItemView/MessageDeleted.tsx +3 -9
  658. package/src/components/Message/MessageItemView/MessageFooter.tsx +2 -14
  659. package/src/components/Message/MessageItemView/MessageHeader.tsx +11 -29
  660. package/src/components/Message/MessageItemView/MessageItemView.tsx +10 -42
  661. package/src/components/Message/MessageItemView/MessageReplies.tsx +2 -8
  662. package/src/components/Message/MessageItemView/MessageTextContainer.tsx +4 -8
  663. package/src/components/Message/MessageItemView/MessageWrapper.tsx +4 -9
  664. package/src/components/Message/MessageItemView/ReactionList/ReactionListBottom.tsx +4 -12
  665. package/src/components/Message/MessageItemView/ReactionList/ReactionListTop.tsx +4 -20
  666. package/src/components/Message/MessageItemView/__tests__/MessageContent.test.js +47 -30
  667. package/src/components/Message/MessageItemView/__tests__/MessageItemView.test.js +16 -7
  668. package/src/components/Message/MessageItemView/__tests__/MessageTextContainer.test.tsx +8 -4
  669. package/src/components/Message/MessageItemView/__tests__/__snapshots__/MessageTextContainer.test.tsx.snap +1 -0
  670. package/src/components/Message/MessageItemView/utils/renderText.tsx +2 -0
  671. package/src/components/MessageInput/MessageComposer.tsx +16 -76
  672. package/src/components/MessageInput/MessageInputHeaderView.tsx +3 -3
  673. package/src/components/MessageInput/__tests__/__snapshots__/SendButton.test.js.snap +54 -36
  674. package/src/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.tsx +7 -35
  675. package/src/components/MessageInput/components/AttachmentPreview/FileAttachmentUploadPreview.tsx +2 -2
  676. package/src/components/MessageInput/components/AttachmentPreview/ImageAttachmentUploadPreview.tsx +2 -2
  677. package/src/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.tsx +6 -4
  678. package/src/components/MessageInput/components/InputButtons/index.tsx +4 -5
  679. package/src/components/MessageInput/components/LinkPreviewList.tsx +3 -2
  680. package/src/components/MessageInput/components/OutputButtons/index.tsx +4 -23
  681. package/src/components/MessageList/MessageFlashList.tsx +13 -57
  682. package/src/components/MessageList/MessageList.tsx +15 -57
  683. package/src/components/MessageList/StickyHeader.tsx +4 -3
  684. package/src/components/MessageMenu/MessageActionList.tsx +4 -3
  685. package/src/components/MessageMenu/MessageMenu.tsx +35 -47
  686. package/src/components/MessageMenu/MessageUserReactions.tsx +7 -27
  687. package/src/components/MessageMenu/MessageUserReactionsItem.tsx +3 -6
  688. package/src/components/MessageMenu/__tests__/MessageUserReactions.test.tsx +12 -11
  689. package/src/components/Poll/CreatePollContent.tsx +7 -6
  690. package/src/components/Poll/Poll.tsx +22 -24
  691. package/src/components/Poll/components/MultipleAnswersField.tsx +4 -3
  692. package/src/components/Poll/components/MultipleVotesSettings.tsx +4 -2
  693. package/src/components/Poll/components/PollAnswersList.tsx +9 -11
  694. package/src/components/Poll/components/PollInputDialog.tsx +1 -0
  695. package/src/components/Poll/components/PollOption.tsx +9 -11
  696. package/src/components/Poll/components/PollResults/PollOptionFullResults.tsx +10 -11
  697. package/src/components/Poll/components/PollResults/PollResults.tsx +9 -15
  698. package/src/components/Reply/Reply.tsx +25 -10
  699. package/src/components/Thread/Thread.tsx +3 -18
  700. package/src/components/Thread/__tests__/__snapshots__/Thread.test.js.snap +31 -18
  701. package/src/components/Thread/components/ThreadFooterComponent.tsx +10 -11
  702. package/src/components/ThreadList/ThreadList.tsx +14 -22
  703. package/src/components/ThreadList/ThreadListItem.tsx +6 -11
  704. package/src/components/ui/Avatar/Avatar.tsx +2 -2
  705. package/src/contexts/attachmentPickerContext/AttachmentPickerContext.tsx +0 -15
  706. package/src/contexts/channelContext/ChannelContext.tsx +0 -24
  707. package/src/contexts/channelsContext/ChannelsContext.tsx +0 -113
  708. package/src/contexts/chatContext/ChatContext.tsx +0 -5
  709. package/src/contexts/componentsContext/ComponentsContext.tsx +62 -0
  710. package/src/contexts/componentsContext/PLAN.md +148 -0
  711. package/src/contexts/componentsContext/__tests__/defaultComponents.test.ts +44 -0
  712. package/src/contexts/componentsContext/defaultComponents.ts +332 -0
  713. package/src/contexts/imageGalleryContext/ImageGalleryContext.tsx +0 -8
  714. package/src/contexts/imageGalleryContext/ImageGalleryContextBase.tsx +0 -10
  715. package/src/contexts/index.ts +1 -0
  716. package/src/contexts/messageInputContext/MessageInputContext.tsx +0 -185
  717. package/src/contexts/messageInputContext/hooks/useCreateMessageInputContext.ts +1 -75
  718. package/src/contexts/messagesContext/MessagesContext.tsx +3 -358
  719. package/src/contexts/overlayContext/MessageOverlayHostLayer.tsx +5 -7
  720. package/src/contexts/overlayContext/OverlayContext.tsx +0 -4
  721. package/src/contexts/overlayContext/OverlayProvider.tsx +1 -2
  722. package/src/contexts/overlayContext/__tests__/MessageOverlayHostLayer.test.tsx +21 -6
  723. package/src/contexts/threadsContext/ThreadsContext.tsx +0 -9
  724. package/src/hooks/messagePreview/useMessagePreviewText.tsx +17 -13
  725. package/src/i18n/en.json +20 -0
  726. package/src/i18n/es.json +20 -0
  727. package/src/i18n/fr.json +20 -0
  728. package/src/i18n/he.json +20 -0
  729. package/src/i18n/hi.json +20 -0
  730. package/src/i18n/it.json +20 -0
  731. package/src/i18n/ja.json +20 -0
  732. package/src/i18n/ko.json +20 -0
  733. package/src/i18n/nl.json +20 -0
  734. package/src/i18n/pt-br.json +20 -0
  735. package/src/i18n/ru.json +20 -0
  736. package/src/i18n/tr.json +20 -0
  737. package/src/icons/arrow-up-right.tsx +11 -8
  738. package/src/icons/audio.tsx +11 -8
  739. package/src/icons/chevron-left.tsx +11 -8
  740. package/src/icons/leave.tsx +11 -8
  741. package/src/icons/message-bubble.tsx +11 -8
  742. package/src/icons/mute.tsx +12 -9
  743. package/src/icons/reply.tsx +11 -8
  744. package/src/icons/search.tsx +12 -9
  745. package/src/icons/send.tsx +12 -9
  746. package/src/icons/thread.tsx +11 -8
  747. package/src/icons/video-fill.tsx +5 -1
  748. package/src/icons/video.tsx +11 -8
  749. package/src/utils/rtlMirrorSwitchStyle.ts +20 -0
  750. package/src/version.json +1 -1
@@ -12,6 +12,10 @@ import {
12
12
  } from '@testing-library/react-native';
13
13
 
14
14
  import { useChannelsContext } from '../../../contexts/channelsContext/ChannelsContext';
15
+ import {
16
+ useComponentsContext,
17
+ WithComponents,
18
+ } from '../../../contexts/componentsContext/ComponentsContext';
15
19
  import { getOrCreateChannelApi } from '../../../mock-builders/api/getOrCreateChannel';
16
20
 
17
21
  import { queryChannelsApi } from '../../../mock-builders/api/queryChannels';
@@ -30,7 +34,6 @@ import { generateChannel, generateChannelResponse } from '../../../mock-builders
30
34
  import { generateMessage } from '../../../mock-builders/generator/message';
31
35
  import { generateUser } from '../../../mock-builders/generator/user';
32
36
  import { getTestClientWithUser } from '../../../mock-builders/mock';
33
- import { ChannelPreview } from '../../ChannelPreview/ChannelPreview';
34
37
  import { Chat } from '../../Chat/Chat';
35
38
  import { ChannelList } from '../ChannelList';
36
39
 
@@ -43,60 +46,38 @@ jest.mock('../../ChannelPreview/ChannelSwipableWrapper', () => ({
43
46
  }));
44
47
 
45
48
  /**
46
- * We are gonna use following custom UI components for preview and list.
47
- * If we use ChannelPreviewView or ChannelPreviewLastMessage here, then changes
48
- * to those components might end up breaking tests for ChannelList, which will be quite painful
49
- * to debug.
49
+ * Custom Preview component used via WithComponents to verify channel rendering.
50
+ * Receives { channel, muted, unread, lastMessage } from ChannelPreview.
50
51
  */
51
- const ChannelPreviewComponent = ({ channel, setActiveChannel }) => (
52
- <View accessibilityLabel='list-item' onPress={setActiveChannel} testID={channel.id}>
52
+ const ChannelPreviewComponent = ({ channel }) => (
53
+ <View accessibilityLabel='list-item' testID={channel.id}>
53
54
  <Text>{channel.data?.name}</Text>
54
55
  <Text>{channel.state.messages[0]?.text}</Text>
55
56
  </View>
56
57
  );
57
58
 
58
- const ChannelListComponent = (props) => {
59
- const { channels, onSelect } = useChannelsContext();
60
- return (
61
- <View testID='channel-list'>
62
- {channels?.map((channel) => (
63
- <ChannelPreviewComponent
64
- {...props}
65
- channel={channel}
66
- key={channel.id}
67
- setActiveChannel={onSelect}
68
- />
69
- ))}
70
- </View>
71
- );
72
- };
73
-
74
- const ChannelListSwipeActionsProbe = () => {
59
+ /**
60
+ * Probe that reads swipeActionsEnabled from ChannelsContext.
61
+ * Used as a Preview override to inspect context values.
62
+ */
63
+ const SwipeActionsProbe = () => {
75
64
  const { swipeActionsEnabled } = useChannelsContext();
76
65
  return <Text testID='swipe-actions-enabled'>{`${swipeActionsEnabled}`}</Text>;
77
66
  };
78
67
 
79
- const ChannelListRefreshingProbe = () => {
68
+ /**
69
+ * Probe that reads refreshing from ChannelsContext.
70
+ */
71
+ const RefreshingProbe = () => {
80
72
  const { refreshing } = useChannelsContext();
81
73
  return <Text testID='refreshing'>{`${refreshing}`}</Text>;
82
74
  };
83
75
 
84
76
  const ChannelPreviewContent = ({ unread }) => <Text testID='preview-unread'>{`${unread}`}</Text>;
85
77
 
86
- const ChannelListWithChannelPreview = () => {
87
- const { channels } = useChannelsContext();
88
- return (
89
- <View testID='channel-list-with-channel-preview'>
90
- {channels?.map((channel) => (
91
- <ChannelPreview channel={channel} key={channel.id} Preview={ChannelPreviewContent} />
92
- ))}
93
- </View>
94
- );
95
- };
96
-
97
78
  let expectedChannelDetailsBottomSheetOverride;
98
- const ChannelListChannelDetailsBottomSheetProbe = () => {
99
- const { ChannelDetailsBottomSheet } = useChannelsContext();
79
+ const ChannelDetailsBottomSheetProbe = () => {
80
+ const { ChannelDetailsBottomSheet } = useComponentsContext();
100
81
  return (
101
82
  <Text testID='channel-details-bottom-sheet-override'>
102
83
  {`${ChannelDetailsBottomSheet === expectedChannelDetailsBottomSheetOverride}`}
@@ -120,8 +101,6 @@ describe('ChannelList', () => {
120
101
  let testChannel3;
121
102
  const props = {
122
103
  filters: {},
123
- List: ChannelListComponent,
124
- Preview: ChannelPreviewComponent,
125
104
  };
126
105
 
127
106
  beforeEach(async () => {
@@ -140,11 +119,13 @@ describe('ChannelList', () => {
140
119
 
141
120
  const { getByTestId } = render(
142
121
  <Chat client={chatClient}>
143
- <ChannelList {...props} />
122
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
123
+ <ChannelList {...props} />
124
+ </WithComponents>
144
125
  </Chat>,
145
126
  );
146
127
 
147
- await waitFor(() => expect(getByTestId('channel-list')).toBeTruthy());
128
+ await waitFor(() => expect(getByTestId('channel-list-view')).toBeTruthy());
148
129
  });
149
130
 
150
131
  it('should render a preview of each channel', async () => {
@@ -152,7 +133,9 @@ describe('ChannelList', () => {
152
133
 
153
134
  const { getByTestId } = render(
154
135
  <Chat client={chatClient}>
155
- <ChannelList {...props} />
136
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
137
+ <ChannelList {...props} />
138
+ </WithComponents>
156
139
  </Chat>,
157
140
  );
158
141
 
@@ -164,12 +147,14 @@ describe('ChannelList', () => {
164
147
 
165
148
  render(
166
149
  <Chat client={chatClient}>
167
- <ChannelList {...props} />
150
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
151
+ <ChannelList {...props} />
152
+ </WithComponents>
168
153
  </Chat>,
169
154
  );
170
155
 
171
156
  await waitFor(() => {
172
- expect(screen.getByTestId('channel-list')).toBeTruthy();
157
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
173
158
  expect(screen.getByTestId(testChannel1.channel.id)).toBeTruthy();
174
159
  });
175
160
 
@@ -177,7 +162,9 @@ describe('ChannelList', () => {
177
162
 
178
163
  screen.rerender(
179
164
  <Chat client={chatClient}>
180
- <ChannelList {...props} filters={{ dummyFilter: true }} />
165
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
166
+ <ChannelList {...props} filters={{ dummyFilter: true }} />
167
+ </WithComponents>
181
168
  </Chat>,
182
169
  );
183
170
 
@@ -191,8 +178,22 @@ describe('ChannelList', () => {
191
178
  const deferredCallForFreshFilter = new DeferredPromise();
192
179
  const staleFilter = { 'initial-filter': { a: { $gt: 'c' } } };
193
180
  const freshFilter = { 'new-filter': { a: { $gt: 'c' } } };
194
- const staleChannel = [generateChannel({ id: 'stale-channel' })];
195
- const freshChannel = [generateChannel({ id: 'new-channel' })];
181
+ const createMockChannel = (id) => {
182
+ const channel = generateChannel({
183
+ data: { name: id },
184
+ id,
185
+ state: { latestMessages: [], members: {}, messages: [], setIsUpToDate: jest.fn() },
186
+ });
187
+ channel.countUnread = () => 0;
188
+ channel.muteStatus = () => ({ muted: false });
189
+ channel.on = jest.fn(() => ({ unsubscribe: jest.fn() }));
190
+ channel.messageComposer = {
191
+ registerDraftEventSubscriptions: jest.fn(() => jest.fn()),
192
+ };
193
+ return channel;
194
+ };
195
+ const staleChannel = [createMockChannel('stale-channel')];
196
+ const freshChannel = [createMockChannel('new-channel')];
196
197
  const spy = jest.spyOn(chatClient, 'queryChannels');
197
198
  spy.mockImplementation((filters = {}) => {
198
199
  if (Object.prototype.hasOwnProperty.call(filters, 'new-filter')) {
@@ -203,7 +204,9 @@ describe('ChannelList', () => {
203
204
 
204
205
  const { rerender, queryByTestId } = render(
205
206
  <Chat client={chatClient}>
206
- <ChannelList {...props} filters={staleFilter} />
207
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
208
+ <ChannelList {...props} filters={staleFilter} />
209
+ </WithComponents>
207
210
  </Chat>,
208
211
  );
209
212
 
@@ -216,12 +219,14 @@ describe('ChannelList', () => {
216
219
  );
217
220
 
218
221
  await waitFor(() => {
219
- expect(queryByTestId('channel-list')).toBeTruthy();
222
+ expect(queryByTestId('channel-list-view')).toBeTruthy();
220
223
  });
221
224
 
222
225
  rerender(
223
226
  <Chat client={chatClient}>
224
- <ChannelList {...props} filters={freshFilter} />
227
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
228
+ <ChannelList {...props} filters={freshFilter} />
229
+ </WithComponents>
225
230
  </Chat>,
226
231
  );
227
232
 
@@ -238,7 +243,7 @@ describe('ChannelList', () => {
238
243
  deferredCallForFreshFilter.resolve(freshChannel);
239
244
  });
240
245
  await waitFor(() => {
241
- expect(queryByTestId('channel-list')).toBeTruthy();
246
+ expect(queryByTestId('channel-list-view')).toBeTruthy();
242
247
  expect(queryByTestId('new-channel')).toBeTruthy();
243
248
  });
244
249
  });
@@ -249,7 +254,9 @@ describe('ChannelList', () => {
249
254
 
250
255
  render(
251
256
  <Chat client={chatClient}>
252
- <ChannelList {...props} onSelect={setActiveChannel} />
257
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
258
+ <ChannelList {...props} onSelect={setActiveChannel} />
259
+ </WithComponents>
253
260
  </Chat>,
254
261
  );
255
262
 
@@ -269,7 +276,9 @@ describe('ChannelList', () => {
269
276
 
270
277
  const { getByTestId } = render(
271
278
  <Chat client={chatClient}>
272
- <ChannelList {...props} List={ChannelListSwipeActionsProbe} swipeActionsEnabled={false} />
279
+ <WithComponents overrides={{ Preview: SwipeActionsProbe }}>
280
+ <ChannelList {...props} swipeActionsEnabled={false} />
281
+ </WithComponents>
273
282
  </Chat>,
274
283
  );
275
284
 
@@ -282,7 +291,9 @@ describe('ChannelList', () => {
282
291
 
283
292
  const { getByTestId } = render(
284
293
  <Chat client={chatClient}>
285
- <ChannelList {...props} List={ChannelListSwipeActionsProbe} />
294
+ <WithComponents overrides={{ Preview: SwipeActionsProbe }}>
295
+ <ChannelList {...props} />
296
+ </WithComponents>
286
297
  </Chat>,
287
298
  );
288
299
 
@@ -295,11 +306,13 @@ describe('ChannelList', () => {
295
306
 
296
307
  const { getByTestId, queryByTestId } = render(
297
308
  <Chat client={chatClient}>
298
- <ChannelList {...props} List={ChannelListWithChannelPreview} swipeActionsEnabled={false} />
309
+ <WithComponents overrides={{ Preview: ChannelPreviewContent }}>
310
+ <ChannelList {...props} swipeActionsEnabled={false} />
311
+ </WithComponents>
299
312
  </Chat>,
300
313
  );
301
314
 
302
- await waitFor(() => expect(getByTestId('channel-list-with-channel-preview')).toBeTruthy());
315
+ await waitFor(() => expect(getByTestId('channel-list-view')).toBeTruthy());
303
316
  expect(getByTestId('preview-unread')).toHaveTextContent('0');
304
317
  expect(queryByTestId('swipe-wrapper')).toBeNull();
305
318
  expect(mockChannelSwipableWrapper).not.toHaveBeenCalled();
@@ -310,27 +323,32 @@ describe('ChannelList', () => {
310
323
 
311
324
  const { getByTestId } = render(
312
325
  <Chat client={chatClient}>
313
- <ChannelList {...props} List={ChannelListWithChannelPreview} swipeActionsEnabled={true} />
326
+ <WithComponents overrides={{ Preview: ChannelPreviewContent }}>
327
+ <ChannelList {...props} swipeActionsEnabled={true} />
328
+ </WithComponents>
314
329
  </Chat>,
315
330
  );
316
331
 
317
- await waitFor(() => expect(getByTestId('channel-list-with-channel-preview')).toBeTruthy());
332
+ await waitFor(() => expect(getByTestId('channel-list-view')).toBeTruthy());
318
333
  expect(getByTestId('swipe-wrapper')).toBeTruthy();
319
334
  expect(mockChannelSwipableWrapper).toHaveBeenCalledTimes(1);
320
335
  });
321
336
 
322
- it('should expose ChannelDetailsBottomSheet override in ChannelsContext', async () => {
337
+ it('should expose ChannelDetailsBottomSheet override via WithComponents', async () => {
323
338
  useMockedApis(chatClient, [queryChannelsApi([testChannel1])]);
324
339
  const ChannelDetailsBottomSheetOverride = () => null;
325
340
  expectedChannelDetailsBottomSheetOverride = ChannelDetailsBottomSheetOverride;
326
341
 
327
342
  const { getByTestId } = render(
328
343
  <Chat client={chatClient}>
329
- <ChannelList
330
- {...props}
331
- ChannelDetailsBottomSheet={ChannelDetailsBottomSheetOverride}
332
- List={ChannelListChannelDetailsBottomSheetProbe}
333
- />
344
+ <WithComponents
345
+ overrides={{
346
+ ChannelDetailsBottomSheet: ChannelDetailsBottomSheetOverride,
347
+ Preview: ChannelDetailsBottomSheetProbe,
348
+ }}
349
+ >
350
+ <ChannelList {...props} />
351
+ </WithComponents>
334
352
  </Chat>,
335
353
  );
336
354
 
@@ -341,24 +359,23 @@ describe('ChannelList', () => {
341
359
  it('should pass ChannelDetailsBottomSheet override to ChannelSwipableWrapper', async () => {
342
360
  useMockedApis(chatClient, [queryChannelsApi([testChannel1])]);
343
361
  const ChannelDetailsBottomSheetOverride = () => null;
362
+ expectedChannelDetailsBottomSheetOverride = ChannelDetailsBottomSheetOverride;
344
363
 
345
- render(
364
+ const { getByTestId } = render(
346
365
  <Chat client={chatClient}>
347
- <ChannelList
348
- {...props}
349
- ChannelDetailsBottomSheet={ChannelDetailsBottomSheetOverride}
350
- List={ChannelListWithChannelPreview}
351
- />
366
+ <WithComponents
367
+ overrides={{
368
+ ChannelDetailsBottomSheet: ChannelDetailsBottomSheetOverride,
369
+ Preview: ChannelDetailsBottomSheetProbe,
370
+ }}
371
+ >
372
+ <ChannelList {...props} />
373
+ </WithComponents>
352
374
  </Chat>,
353
375
  );
354
376
 
355
- await waitFor(() => expect(mockChannelSwipableWrapper).toHaveBeenCalled());
356
- const swipableWrapperProps = mockChannelSwipableWrapper.mock.calls[0]?.[0];
357
- expect(swipableWrapperProps).toEqual(
358
- expect.objectContaining({
359
- ChannelDetailsBottomSheet: ChannelDetailsBottomSheetOverride,
360
- }),
361
- );
377
+ await waitFor(() => expect(getByTestId('channel-details-bottom-sheet-override')).toBeTruthy());
378
+ expect(getByTestId('channel-details-bottom-sheet-override')).toHaveTextContent('true');
362
379
  });
363
380
 
364
381
  describe('Event handling', () => {
@@ -378,11 +395,13 @@ describe('ChannelList', () => {
378
395
  it('should move channel to top of the list by default', async () => {
379
396
  render(
380
397
  <Chat client={chatClient}>
381
- <ChannelList {...props} />
398
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
399
+ <ChannelList {...props} />
400
+ </WithComponents>
382
401
  </Chat>,
383
402
  );
384
403
 
385
- await waitFor(() => expect(screen.getByTestId('channel-list')).toBeTruthy());
404
+ await waitFor(() => expect(screen.getByTestId('channel-list-view')).toBeTruthy());
386
405
 
387
406
  const newMessage = sendNewMessageOnChannel3();
388
407
 
@@ -400,11 +419,13 @@ describe('ChannelList', () => {
400
419
  it('should add channel to top if channel is hidden from the list', async () => {
401
420
  render(
402
421
  <Chat client={chatClient}>
403
- <ChannelList {...props} />
422
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
423
+ <ChannelList {...props} />
424
+ </WithComponents>
404
425
  </Chat>,
405
426
  );
406
427
 
407
- await waitFor(() => expect(screen.getByTestId('channel-list')).toBeTruthy());
428
+ await waitFor(() => expect(screen.getByTestId('channel-list-view')).toBeTruthy());
408
429
  act(() => dispatchChannelHiddenEvent(chatClient, testChannel3.channel));
409
430
 
410
431
  const newItems = screen.getAllByLabelText('list-item');
@@ -428,7 +449,9 @@ describe('ChannelList', () => {
428
449
  it('should not alter order if `lockChannelOrder` prop is true', async () => {
429
450
  render(
430
451
  <Chat client={chatClient}>
431
- <ChannelList lockChannelOrder={true} Preview={props.Preview} />
452
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
453
+ <ChannelList lockChannelOrder={true} />
454
+ </WithComponents>
432
455
  </Chat>,
433
456
  );
434
457
 
@@ -452,12 +475,14 @@ describe('ChannelList', () => {
452
475
  const onNewMessage = jest.fn();
453
476
  render(
454
477
  <Chat client={chatClient}>
455
- <ChannelList {...props} onNewMessage={onNewMessage} />
478
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
479
+ <ChannelList {...props} onNewMessage={onNewMessage} />
480
+ </WithComponents>
456
481
  </Chat>,
457
482
  );
458
483
 
459
484
  await waitFor(() => {
460
- expect(screen.getByTestId('channel-list')).toBeTruthy();
485
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
461
486
  });
462
487
 
463
488
  act(() => dispatchMessageNewEvent(chatClient, testChannel2.channel));
@@ -479,11 +504,13 @@ describe('ChannelList', () => {
479
504
  it('should move a channel to top of the list by default', async () => {
480
505
  render(
481
506
  <Chat client={chatClient}>
482
- <ChannelList {...props} />
507
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
508
+ <ChannelList {...props} />
509
+ </WithComponents>
483
510
  </Chat>,
484
511
  );
485
512
  await waitFor(() => {
486
- expect(screen.getByTestId('channel-list')).toBeTruthy();
513
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
487
514
  });
488
515
 
489
516
  act(() => dispatchNotificationMessageNewEvent(chatClient, testChannel3.channel));
@@ -501,12 +528,14 @@ describe('ChannelList', () => {
501
528
  const onNewMessage = jest.fn();
502
529
  render(
503
530
  <Chat client={chatClient}>
504
- <ChannelList {...props} onNewMessage={onNewMessage} />
531
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
532
+ <ChannelList {...props} onNewMessage={onNewMessage} />
533
+ </WithComponents>
505
534
  </Chat>,
506
535
  );
507
536
 
508
537
  await waitFor(() => {
509
- expect(screen.getByTestId('channel-list')).toBeTruthy();
538
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
510
539
  });
511
540
 
512
541
  act(() => dispatchMessageNewEvent(chatClient, testChannel2.channel));
@@ -520,12 +549,14 @@ describe('ChannelList', () => {
520
549
  const onNewMessageNotification = jest.fn();
521
550
  render(
522
551
  <Chat client={chatClient}>
523
- <ChannelList {...props} onNewMessageNotification={onNewMessageNotification} />
552
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
553
+ <ChannelList {...props} onNewMessageNotification={onNewMessageNotification} />
554
+ </WithComponents>
524
555
  </Chat>,
525
556
  );
526
557
 
527
558
  await waitFor(() => {
528
- expect(screen.getByTestId('channel-list')).toBeTruthy();
559
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
529
560
  });
530
561
 
531
562
  act(() => dispatchNotificationMessageNewEvent(chatClient, testChannel2.channel));
@@ -547,12 +578,14 @@ describe('ChannelList', () => {
547
578
  it('should move a channel to top of the list by default', async () => {
548
579
  render(
549
580
  <Chat client={chatClient}>
550
- <ChannelList {...props} />
581
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
582
+ <ChannelList {...props} />
583
+ </WithComponents>
551
584
  </Chat>,
552
585
  );
553
586
 
554
587
  await waitFor(() => {
555
- expect(screen.getByTestId('channel-list')).toBeTruthy();
588
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
556
589
  });
557
590
 
558
591
  act(() => dispatchNotificationAddedToChannelEvent(chatClient, testChannel3.channel));
@@ -572,12 +605,14 @@ describe('ChannelList', () => {
572
605
  const onAddedToChannel = jest.fn();
573
606
  render(
574
607
  <Chat client={chatClient}>
575
- <ChannelList {...props} onAddedToChannel={onAddedToChannel} />
608
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
609
+ <ChannelList {...props} onAddedToChannel={onAddedToChannel} />
610
+ </WithComponents>
576
611
  </Chat>,
577
612
  );
578
613
 
579
614
  await waitFor(() => {
580
- expect(screen.getByTestId('channel-list')).toBeTruthy();
615
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
581
616
  });
582
617
 
583
618
  act(() => dispatchNotificationAddedToChannelEvent(chatClient, testChannel3.channel));
@@ -596,12 +631,14 @@ describe('ChannelList', () => {
596
631
  it('should remove the channel from list by default', async () => {
597
632
  render(
598
633
  <Chat client={chatClient}>
599
- <ChannelList {...props} />
634
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
635
+ <ChannelList {...props} />
636
+ </WithComponents>
600
637
  </Chat>,
601
638
  );
602
639
 
603
640
  await waitFor(() => {
604
- expect(screen.getByTestId('channel-list')).toBeTruthy();
641
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
605
642
  });
606
643
 
607
644
  const items = screen.getAllByLabelText('list-item');
@@ -621,12 +658,14 @@ describe('ChannelList', () => {
621
658
  const onRemovedFromChannel = jest.fn();
622
659
  render(
623
660
  <Chat client={chatClient}>
624
- <ChannelList {...props} onRemovedFromChannel={onRemovedFromChannel} />
661
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
662
+ <ChannelList {...props} onRemovedFromChannel={onRemovedFromChannel} />
663
+ </WithComponents>
625
664
  </Chat>,
626
665
  );
627
666
 
628
667
  await waitFor(() => {
629
- expect(screen.getByTestId('channel-list')).toBeTruthy();
668
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
630
669
  });
631
670
 
632
671
  act(() => dispatchNotificationRemovedFromChannel(chatClient, testChannel3.channel));
@@ -645,12 +684,14 @@ describe('ChannelList', () => {
645
684
  it('should update a channel in the list by default', async () => {
646
685
  render(
647
686
  <Chat client={chatClient}>
648
- <ChannelList {...props} />
687
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
688
+ <ChannelList {...props} />
689
+ </WithComponents>
649
690
  </Chat>,
650
691
  );
651
692
 
652
693
  await waitFor(() => {
653
- expect(screen.getByTestId('channel-list')).toBeTruthy();
694
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
654
695
  });
655
696
 
656
697
  act(() =>
@@ -669,12 +710,14 @@ describe('ChannelList', () => {
669
710
  const onChannelUpdated = jest.fn();
670
711
  render(
671
712
  <Chat client={chatClient}>
672
- <ChannelList {...props} onChannelUpdated={onChannelUpdated} />
713
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
714
+ <ChannelList {...props} onChannelUpdated={onChannelUpdated} />
715
+ </WithComponents>
673
716
  </Chat>,
674
717
  );
675
718
 
676
719
  await waitFor(() => {
677
- expect(screen.getByTestId('channel-list')).toBeTruthy();
720
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
678
721
  });
679
722
 
680
723
  act(() =>
@@ -698,12 +741,14 @@ describe('ChannelList', () => {
698
741
  it('should remove a channel from the list by default', async () => {
699
742
  render(
700
743
  <Chat client={chatClient}>
701
- <ChannelList {...props} />
744
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
745
+ <ChannelList {...props} />
746
+ </WithComponents>
702
747
  </Chat>,
703
748
  );
704
749
 
705
750
  await waitFor(() => {
706
- expect(screen.getByTestId('channel-list')).toBeTruthy();
751
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
707
752
  });
708
753
 
709
754
  const items = screen.getAllByLabelText('list-item');
@@ -723,12 +768,14 @@ describe('ChannelList', () => {
723
768
  const onChannelDeleted = jest.fn();
724
769
  render(
725
770
  <Chat client={chatClient}>
726
- <ChannelList {...props} onChannelDeleted={onChannelDeleted} />
771
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
772
+ <ChannelList {...props} onChannelDeleted={onChannelDeleted} />
773
+ </WithComponents>
727
774
  </Chat>,
728
775
  );
729
776
 
730
777
  await waitFor(() => {
731
- expect(screen.getByTestId('channel-list')).toBeTruthy();
778
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
732
779
  });
733
780
 
734
781
  act(() => dispatchChannelDeletedEvent(chatClient, testChannel2.channel));
@@ -747,12 +794,14 @@ describe('ChannelList', () => {
747
794
  it('should hide a channel from the list by default', async () => {
748
795
  render(
749
796
  <Chat client={chatClient}>
750
- <ChannelList {...props} />
797
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
798
+ <ChannelList {...props} />
799
+ </WithComponents>
751
800
  </Chat>,
752
801
  );
753
802
 
754
803
  await waitFor(() => {
755
- expect(screen.getByTestId('channel-list')).toBeTruthy();
804
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
756
805
  });
757
806
 
758
807
  const items = screen.getAllByLabelText('list-item');
@@ -772,12 +821,14 @@ describe('ChannelList', () => {
772
821
  const onChannelHidden = jest.fn();
773
822
  render(
774
823
  <Chat client={chatClient}>
775
- <ChannelList {...props} onChannelHidden={onChannelHidden} />
824
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
825
+ <ChannelList {...props} onChannelHidden={onChannelHidden} />
826
+ </WithComponents>
776
827
  </Chat>,
777
828
  );
778
829
 
779
830
  await waitFor(() => {
780
- expect(screen.getByTestId('channel-list')).toBeTruthy();
831
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
781
832
  });
782
833
 
783
834
  act(() => dispatchChannelHiddenEvent(chatClient, testChannel2.channel));
@@ -795,12 +846,14 @@ describe('ChannelList', () => {
795
846
 
796
847
  render(
797
848
  <Chat client={chatClient}>
798
- <ChannelList {...props} />
849
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
850
+ <ChannelList {...props} />
851
+ </WithComponents>
799
852
  </Chat>,
800
853
  );
801
854
 
802
855
  await waitFor(() => {
803
- expect(screen.getByTestId('channel-list')).toBeTruthy();
856
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
804
857
  });
805
858
 
806
859
  act(() => dispatchConnectionRecoveredEvent(chatClient));
@@ -821,7 +874,9 @@ describe('ChannelList', () => {
821
874
 
822
875
  render(
823
876
  <Chat client={chatClient}>
824
- <ChannelList {...props} List={ChannelListRefreshingProbe} />
877
+ <WithComponents overrides={{ Preview: RefreshingProbe }}>
878
+ <ChannelList {...props} />
879
+ </WithComponents>
825
880
  </Chat>,
826
881
  );
827
882
 
@@ -854,12 +909,14 @@ describe('ChannelList', () => {
854
909
  const onChannelTruncated = jest.fn();
855
910
  render(
856
911
  <Chat client={chatClient}>
857
- <ChannelList {...props} onChannelTruncated={onChannelTruncated} />
912
+ <WithComponents overrides={{ Preview: ChannelPreviewComponent }}>
913
+ <ChannelList {...props} onChannelTruncated={onChannelTruncated} />
914
+ </WithComponents>
858
915
  </Chat>,
859
916
  );
860
917
 
861
918
  await waitFor(() => {
862
- expect(screen.getByTestId('channel-list')).toBeTruthy();
919
+ expect(screen.getByTestId('channel-list-view')).toBeTruthy();
863
920
  });
864
921
 
865
922
  act(() => dispatchChannelTruncatedEvent(chatClient, testChannel1.channel));