stream-chat-react-native-core 9.0.0-beta.31 → 9.0.0-beta.33

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 (598) 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 -421
  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 -134
  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 +14 -23
  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 +6 -8
  46. package/lib/commonjs/components/ChannelPreview/ChannelPreview.js.map +1 -1
  47. package/lib/commonjs/components/ChannelPreview/ChannelPreviewMessage.js +12 -24
  48. package/lib/commonjs/components/ChannelPreview/ChannelPreviewMessage.js.map +1 -1
  49. package/lib/commonjs/components/ChannelPreview/ChannelPreviewView.js +15 -35
  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/MessageInput/MessageComposer.js +15 -55
  86. package/lib/commonjs/components/MessageInput/MessageComposer.js.map +1 -1
  87. package/lib/commonjs/components/MessageInput/MessageInputHeaderView.js +5 -5
  88. package/lib/commonjs/components/MessageInput/MessageInputHeaderView.js.map +1 -1
  89. package/lib/commonjs/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.js +9 -17
  90. package/lib/commonjs/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.js.map +1 -1
  91. package/lib/commonjs/components/MessageInput/components/AttachmentPreview/FileAttachmentUploadPreview.js +5 -5
  92. package/lib/commonjs/components/MessageInput/components/AttachmentPreview/FileAttachmentUploadPreview.js.map +1 -1
  93. package/lib/commonjs/components/MessageInput/components/AttachmentPreview/ImageAttachmentUploadPreview.js +5 -5
  94. package/lib/commonjs/components/MessageInput/components/AttachmentPreview/ImageAttachmentUploadPreview.js.map +1 -1
  95. package/lib/commonjs/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.js +5 -5
  96. package/lib/commonjs/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.js.map +1 -1
  97. package/lib/commonjs/components/MessageInput/components/InputButtons/index.js +4 -4
  98. package/lib/commonjs/components/MessageInput/components/InputButtons/index.js.map +1 -1
  99. package/lib/commonjs/components/MessageInput/components/LinkPreviewList.js +3 -2
  100. package/lib/commonjs/components/MessageInput/components/LinkPreviewList.js.map +1 -1
  101. package/lib/commonjs/components/MessageInput/components/OutputButtons/index.js +7 -13
  102. package/lib/commonjs/components/MessageInput/components/OutputButtons/index.js.map +1 -1
  103. package/lib/commonjs/components/MessageList/MessageFlashList.js +14 -40
  104. package/lib/commonjs/components/MessageList/MessageFlashList.js.map +1 -1
  105. package/lib/commonjs/components/MessageList/MessageList.js +12 -38
  106. package/lib/commonjs/components/MessageList/MessageList.js.map +1 -1
  107. package/lib/commonjs/components/MessageList/StickyHeader.js +3 -1
  108. package/lib/commonjs/components/MessageList/StickyHeader.js.map +1 -1
  109. package/lib/commonjs/components/MessageList/hooks/useMessageList.js +2 -35
  110. package/lib/commonjs/components/MessageList/hooks/useMessageList.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 +3 -1
  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/PollAnswersList.js +5 -3
  123. package/lib/commonjs/components/Poll/components/PollAnswersList.js.map +1 -1
  124. package/lib/commonjs/components/Poll/components/PollOption.js +5 -3
  125. package/lib/commonjs/components/Poll/components/PollOption.js.map +1 -1
  126. package/lib/commonjs/components/Poll/components/PollResults/PollOptionFullResults.js +5 -5
  127. package/lib/commonjs/components/Poll/components/PollResults/PollOptionFullResults.js.map +1 -1
  128. package/lib/commonjs/components/Poll/components/PollResults/PollResults.js +5 -3
  129. package/lib/commonjs/components/Poll/components/PollResults/PollResults.js.map +1 -1
  130. package/lib/commonjs/components/Reply/Reply.js +4 -2
  131. package/lib/commonjs/components/Reply/Reply.js.map +1 -1
  132. package/lib/commonjs/components/Thread/Thread.js +4 -8
  133. package/lib/commonjs/components/Thread/Thread.js.map +1 -1
  134. package/lib/commonjs/components/Thread/components/ThreadFooterComponent.js +4 -6
  135. package/lib/commonjs/components/Thread/components/ThreadFooterComponent.js.map +1 -1
  136. package/lib/commonjs/components/ThreadList/ThreadList.js +12 -15
  137. package/lib/commonjs/components/ThreadList/ThreadList.js.map +1 -1
  138. package/lib/commonjs/components/ThreadList/ThreadListItem.js +8 -11
  139. package/lib/commonjs/components/ThreadList/ThreadListItem.js.map +1 -1
  140. package/lib/commonjs/components/ui/Avatar/Avatar.js +3 -3
  141. package/lib/commonjs/components/ui/Avatar/Avatar.js.map +1 -1
  142. package/lib/commonjs/contexts/attachmentPickerContext/AttachmentPickerContext.js.map +1 -1
  143. package/lib/commonjs/contexts/channelContext/ChannelContext.js.map +1 -1
  144. package/lib/commonjs/contexts/channelsContext/ChannelsContext.js.map +1 -1
  145. package/lib/commonjs/contexts/chatContext/ChatContext.js.map +1 -1
  146. package/lib/commonjs/contexts/componentsContext/ComponentsContext.js +37 -0
  147. package/lib/commonjs/contexts/componentsContext/ComponentsContext.js.map +1 -0
  148. package/lib/commonjs/contexts/componentsContext/PLAN.md +148 -0
  149. package/lib/commonjs/contexts/componentsContext/defaultComponents.js +287 -0
  150. package/lib/commonjs/contexts/componentsContext/defaultComponents.js.map +1 -0
  151. package/lib/commonjs/contexts/imageGalleryContext/ImageGalleryContext.js +1 -9
  152. package/lib/commonjs/contexts/imageGalleryContext/ImageGalleryContext.js.map +1 -1
  153. package/lib/commonjs/contexts/imageGalleryContext/ImageGalleryContextBase.js.map +1 -1
  154. package/lib/commonjs/contexts/index.js +11 -0
  155. package/lib/commonjs/contexts/index.js.map +1 -1
  156. package/lib/commonjs/contexts/messageInputContext/MessageInputContext.js.map +1 -1
  157. package/lib/commonjs/contexts/messageInputContext/hooks/useCreateMessageInputContext.js +2 -76
  158. package/lib/commonjs/contexts/messageInputContext/hooks/useCreateMessageInputContext.js.map +1 -1
  159. package/lib/commonjs/contexts/messagesContext/MessagesContext.js.map +1 -1
  160. package/lib/commonjs/contexts/overlayContext/MessageOverlayHostLayer.js +37 -27
  161. package/lib/commonjs/contexts/overlayContext/MessageOverlayHostLayer.js.map +1 -1
  162. package/lib/commonjs/contexts/overlayContext/OverlayContext.js.map +1 -1
  163. package/lib/commonjs/contexts/overlayContext/OverlayProvider.js +1 -4
  164. package/lib/commonjs/contexts/overlayContext/OverlayProvider.js.map +1 -1
  165. package/lib/commonjs/contexts/threadsContext/ThreadsContext.js.map +1 -1
  166. package/lib/commonjs/version.json +1 -1
  167. package/lib/module/components/Attachment/Attachment.js +15 -52
  168. package/lib/module/components/Attachment/Attachment.js.map +1 -1
  169. package/lib/module/components/Attachment/FileAttachment.js +4 -6
  170. package/lib/module/components/Attachment/FileAttachment.js.map +1 -1
  171. package/lib/module/components/Attachment/FileAttachmentGroup.js +4 -10
  172. package/lib/module/components/Attachment/FileAttachmentGroup.js.map +1 -1
  173. package/lib/module/components/Attachment/FilePreview.js +3 -6
  174. package/lib/module/components/Attachment/FilePreview.js.map +1 -1
  175. package/lib/module/components/Attachment/Gallery.js +9 -28
  176. package/lib/module/components/Attachment/Gallery.js.map +1 -1
  177. package/lib/module/components/Attachment/GalleryImage.js +3 -3
  178. package/lib/module/components/Attachment/GalleryImage.js.map +1 -1
  179. package/lib/module/components/Attachment/Giphy/GiphyImage.js +7 -13
  180. package/lib/module/components/Attachment/Giphy/GiphyImage.js.map +1 -1
  181. package/lib/module/components/Attachment/UnsupportedAttachment.js +4 -6
  182. package/lib/module/components/Attachment/UnsupportedAttachment.js.map +1 -1
  183. package/lib/module/components/Attachment/UrlPreview/URLPreview.js +3 -3
  184. package/lib/module/components/Attachment/UrlPreview/URLPreview.js.map +1 -1
  185. package/lib/module/components/Attachment/UrlPreview/URLPreviewCompact.js +3 -3
  186. package/lib/module/components/Attachment/UrlPreview/URLPreviewCompact.js.map +1 -1
  187. package/lib/module/components/AttachmentPicker/AttachmentPicker.js +4 -2
  188. package/lib/module/components/AttachmentPicker/AttachmentPicker.js.map +1 -1
  189. package/lib/module/components/AttachmentPicker/components/AttachmentMediaPicker/AttachmentPickerItem.js +7 -4
  190. package/lib/module/components/AttachmentPicker/components/AttachmentMediaPicker/AttachmentPickerItem.js.map +1 -1
  191. package/lib/module/components/AutoCompleteInput/AutoCompleteSuggestionList.js +9 -13
  192. package/lib/module/components/AutoCompleteInput/AutoCompleteSuggestionList.js.map +1 -1
  193. package/lib/module/components/Channel/Channel.js +9 -421
  194. package/lib/module/components/Channel/Channel.js.map +1 -1
  195. package/lib/module/components/Channel/hooks/useCreateChannelContext.js +0 -8
  196. package/lib/module/components/Channel/hooks/useCreateChannelContext.js.map +1 -1
  197. package/lib/module/components/Channel/hooks/useCreateInputMessageInputContext.js +3 -77
  198. package/lib/module/components/Channel/hooks/useCreateInputMessageInputContext.js.map +1 -1
  199. package/lib/module/components/Channel/hooks/useCreateMessagesContext.js +2 -134
  200. package/lib/module/components/Channel/hooks/useCreateMessagesContext.js.map +1 -1
  201. package/lib/module/components/ChannelList/ChannelList.js +1 -57
  202. package/lib/module/components/ChannelList/ChannelList.js.map +1 -1
  203. package/lib/module/components/ChannelList/ChannelListLoadingIndicator.js +4 -2
  204. package/lib/module/components/ChannelList/ChannelListLoadingIndicator.js.map +1 -1
  205. package/lib/module/components/ChannelList/ChannelListView.js +14 -23
  206. package/lib/module/components/ChannelList/ChannelListView.js.map +1 -1
  207. package/lib/module/components/ChannelList/hooks/useCreateChannelsContext.js +1 -39
  208. package/lib/module/components/ChannelList/hooks/useCreateChannelsContext.js.map +1 -1
  209. package/lib/module/components/ChannelPreview/ChannelDetailsBottomSheet.js +3 -2
  210. package/lib/module/components/ChannelPreview/ChannelDetailsBottomSheet.js.map +1 -1
  211. package/lib/module/components/ChannelPreview/ChannelPreview.js +6 -8
  212. package/lib/module/components/ChannelPreview/ChannelPreview.js.map +1 -1
  213. package/lib/module/components/ChannelPreview/ChannelPreviewMessage.js +12 -24
  214. package/lib/module/components/ChannelPreview/ChannelPreviewMessage.js.map +1 -1
  215. package/lib/module/components/ChannelPreview/ChannelPreviewView.js +15 -35
  216. package/lib/module/components/ChannelPreview/ChannelPreviewView.js.map +1 -1
  217. package/lib/module/components/ChannelPreview/ChannelSwipableWrapper.js +3 -3
  218. package/lib/module/components/ChannelPreview/ChannelSwipableWrapper.js.map +1 -1
  219. package/lib/module/components/Chat/Chat.js +4 -6
  220. package/lib/module/components/Chat/Chat.js.map +1 -1
  221. package/lib/module/components/Chat/hooks/useCreateChatContext.js +0 -2
  222. package/lib/module/components/Chat/hooks/useCreateChatContext.js.map +1 -1
  223. package/lib/module/components/ImageGallery/ImageGallery.js +7 -9
  224. package/lib/module/components/ImageGallery/ImageGallery.js.map +1 -1
  225. package/lib/module/components/ImageGallery/components/ImageGalleryFooter.js +4 -2
  226. package/lib/module/components/ImageGallery/components/ImageGalleryFooter.js.map +1 -1
  227. package/lib/module/components/Message/Message.js +9 -13
  228. package/lib/module/components/Message/Message.js.map +1 -1
  229. package/lib/module/components/Message/MessageItemView/MessageBubble.js +4 -2
  230. package/lib/module/components/Message/MessageItemView/MessageBubble.js.map +1 -1
  231. package/lib/module/components/Message/MessageItemView/MessageContent.js +18 -39
  232. package/lib/module/components/Message/MessageItemView/MessageContent.js.map +1 -1
  233. package/lib/module/components/Message/MessageItemView/MessageDeleted.js +5 -7
  234. package/lib/module/components/Message/MessageItemView/MessageDeleted.js.map +1 -1
  235. package/lib/module/components/Message/MessageItemView/MessageFooter.js +4 -8
  236. package/lib/module/components/Message/MessageItemView/MessageFooter.js.map +1 -1
  237. package/lib/module/components/Message/MessageItemView/MessageHeader.js +8 -16
  238. package/lib/module/components/Message/MessageItemView/MessageHeader.js.map +1 -1
  239. package/lib/module/components/Message/MessageItemView/MessageItemView.js +13 -35
  240. package/lib/module/components/Message/MessageItemView/MessageItemView.js.map +1 -1
  241. package/lib/module/components/Message/MessageItemView/MessageReplies.js +3 -5
  242. package/lib/module/components/Message/MessageItemView/MessageReplies.js.map +1 -1
  243. package/lib/module/components/Message/MessageItemView/MessageTextContainer.js +3 -3
  244. package/lib/module/components/Message/MessageItemView/MessageTextContainer.js.map +1 -1
  245. package/lib/module/components/Message/MessageItemView/MessageWrapper.js +6 -4
  246. package/lib/module/components/Message/MessageItemView/MessageWrapper.js.map +1 -1
  247. package/lib/module/components/Message/MessageItemView/ReactionList/ReactionListBottom.js +6 -8
  248. package/lib/module/components/Message/MessageItemView/ReactionList/ReactionListBottom.js.map +1 -1
  249. package/lib/module/components/Message/MessageItemView/ReactionList/ReactionListTop.js +7 -11
  250. package/lib/module/components/Message/MessageItemView/ReactionList/ReactionListTop.js.map +1 -1
  251. package/lib/module/components/MessageInput/MessageComposer.js +15 -55
  252. package/lib/module/components/MessageInput/MessageComposer.js.map +1 -1
  253. package/lib/module/components/MessageInput/MessageInputHeaderView.js +5 -5
  254. package/lib/module/components/MessageInput/MessageInputHeaderView.js.map +1 -1
  255. package/lib/module/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.js +9 -17
  256. package/lib/module/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.js.map +1 -1
  257. package/lib/module/components/MessageInput/components/AttachmentPreview/FileAttachmentUploadPreview.js +5 -5
  258. package/lib/module/components/MessageInput/components/AttachmentPreview/FileAttachmentUploadPreview.js.map +1 -1
  259. package/lib/module/components/MessageInput/components/AttachmentPreview/ImageAttachmentUploadPreview.js +5 -5
  260. package/lib/module/components/MessageInput/components/AttachmentPreview/ImageAttachmentUploadPreview.js.map +1 -1
  261. package/lib/module/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.js +5 -5
  262. package/lib/module/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.js.map +1 -1
  263. package/lib/module/components/MessageInput/components/InputButtons/index.js +4 -4
  264. package/lib/module/components/MessageInput/components/InputButtons/index.js.map +1 -1
  265. package/lib/module/components/MessageInput/components/LinkPreviewList.js +3 -2
  266. package/lib/module/components/MessageInput/components/LinkPreviewList.js.map +1 -1
  267. package/lib/module/components/MessageInput/components/OutputButtons/index.js +7 -13
  268. package/lib/module/components/MessageInput/components/OutputButtons/index.js.map +1 -1
  269. package/lib/module/components/MessageList/MessageFlashList.js +14 -40
  270. package/lib/module/components/MessageList/MessageFlashList.js.map +1 -1
  271. package/lib/module/components/MessageList/MessageList.js +12 -38
  272. package/lib/module/components/MessageList/MessageList.js.map +1 -1
  273. package/lib/module/components/MessageList/StickyHeader.js +3 -1
  274. package/lib/module/components/MessageList/StickyHeader.js.map +1 -1
  275. package/lib/module/components/MessageList/hooks/useMessageList.js +2 -35
  276. package/lib/module/components/MessageList/hooks/useMessageList.js.map +1 -1
  277. package/lib/module/components/MessageMenu/MessageActionList.js +4 -2
  278. package/lib/module/components/MessageMenu/MessageActionList.js.map +1 -1
  279. package/lib/module/components/MessageMenu/MessageMenu.js.map +1 -1
  280. package/lib/module/components/MessageMenu/MessageUserReactions.js +4 -8
  281. package/lib/module/components/MessageMenu/MessageUserReactions.js.map +1 -1
  282. package/lib/module/components/MessageMenu/MessageUserReactionsItem.js +4 -2
  283. package/lib/module/components/MessageMenu/MessageUserReactionsItem.js.map +1 -1
  284. package/lib/module/components/Poll/CreatePollContent.js +3 -1
  285. package/lib/module/components/Poll/CreatePollContent.js.map +1 -1
  286. package/lib/module/components/Poll/Poll.js +12 -9
  287. package/lib/module/components/Poll/Poll.js.map +1 -1
  288. package/lib/module/components/Poll/components/PollAnswersList.js +5 -3
  289. package/lib/module/components/Poll/components/PollAnswersList.js.map +1 -1
  290. package/lib/module/components/Poll/components/PollOption.js +5 -3
  291. package/lib/module/components/Poll/components/PollOption.js.map +1 -1
  292. package/lib/module/components/Poll/components/PollResults/PollOptionFullResults.js +5 -5
  293. package/lib/module/components/Poll/components/PollResults/PollOptionFullResults.js.map +1 -1
  294. package/lib/module/components/Poll/components/PollResults/PollResults.js +5 -3
  295. package/lib/module/components/Poll/components/PollResults/PollResults.js.map +1 -1
  296. package/lib/module/components/Reply/Reply.js +4 -2
  297. package/lib/module/components/Reply/Reply.js.map +1 -1
  298. package/lib/module/components/Thread/Thread.js +4 -8
  299. package/lib/module/components/Thread/Thread.js.map +1 -1
  300. package/lib/module/components/Thread/components/ThreadFooterComponent.js +4 -6
  301. package/lib/module/components/Thread/components/ThreadFooterComponent.js.map +1 -1
  302. package/lib/module/components/ThreadList/ThreadList.js +12 -15
  303. package/lib/module/components/ThreadList/ThreadList.js.map +1 -1
  304. package/lib/module/components/ThreadList/ThreadListItem.js +8 -11
  305. package/lib/module/components/ThreadList/ThreadListItem.js.map +1 -1
  306. package/lib/module/components/ui/Avatar/Avatar.js +3 -3
  307. package/lib/module/components/ui/Avatar/Avatar.js.map +1 -1
  308. package/lib/module/contexts/attachmentPickerContext/AttachmentPickerContext.js.map +1 -1
  309. package/lib/module/contexts/channelContext/ChannelContext.js.map +1 -1
  310. package/lib/module/contexts/channelsContext/ChannelsContext.js.map +1 -1
  311. package/lib/module/contexts/chatContext/ChatContext.js.map +1 -1
  312. package/lib/module/contexts/componentsContext/ComponentsContext.js +37 -0
  313. package/lib/module/contexts/componentsContext/ComponentsContext.js.map +1 -0
  314. package/lib/module/contexts/componentsContext/PLAN.md +148 -0
  315. package/lib/module/contexts/componentsContext/defaultComponents.js +287 -0
  316. package/lib/module/contexts/componentsContext/defaultComponents.js.map +1 -0
  317. package/lib/module/contexts/imageGalleryContext/ImageGalleryContext.js +1 -9
  318. package/lib/module/contexts/imageGalleryContext/ImageGalleryContext.js.map +1 -1
  319. package/lib/module/contexts/imageGalleryContext/ImageGalleryContextBase.js.map +1 -1
  320. package/lib/module/contexts/index.js +11 -0
  321. package/lib/module/contexts/index.js.map +1 -1
  322. package/lib/module/contexts/messageInputContext/MessageInputContext.js.map +1 -1
  323. package/lib/module/contexts/messageInputContext/hooks/useCreateMessageInputContext.js +2 -76
  324. package/lib/module/contexts/messageInputContext/hooks/useCreateMessageInputContext.js.map +1 -1
  325. package/lib/module/contexts/messagesContext/MessagesContext.js.map +1 -1
  326. package/lib/module/contexts/overlayContext/MessageOverlayHostLayer.js +37 -27
  327. package/lib/module/contexts/overlayContext/MessageOverlayHostLayer.js.map +1 -1
  328. package/lib/module/contexts/overlayContext/OverlayContext.js.map +1 -1
  329. package/lib/module/contexts/overlayContext/OverlayProvider.js +1 -4
  330. package/lib/module/contexts/overlayContext/OverlayProvider.js.map +1 -1
  331. package/lib/module/contexts/threadsContext/ThreadsContext.js.map +1 -1
  332. package/lib/module/version.json +1 -1
  333. package/lib/typescript/components/Attachment/Attachment.d.ts +1 -1
  334. package/lib/typescript/components/Attachment/Attachment.d.ts.map +1 -1
  335. package/lib/typescript/components/Attachment/FileAttachment.d.ts +1 -1
  336. package/lib/typescript/components/Attachment/FileAttachment.d.ts.map +1 -1
  337. package/lib/typescript/components/Attachment/FileAttachmentGroup.d.ts +1 -2
  338. package/lib/typescript/components/Attachment/FileAttachmentGroup.d.ts.map +1 -1
  339. package/lib/typescript/components/Attachment/FilePreview.d.ts +2 -3
  340. package/lib/typescript/components/Attachment/FilePreview.d.ts.map +1 -1
  341. package/lib/typescript/components/Attachment/Gallery.d.ts +1 -1
  342. package/lib/typescript/components/Attachment/Gallery.d.ts.map +1 -1
  343. package/lib/typescript/components/Attachment/GalleryImage.d.ts +3 -2
  344. package/lib/typescript/components/Attachment/GalleryImage.d.ts.map +1 -1
  345. package/lib/typescript/components/Attachment/Giphy/GiphyImage.d.ts +4 -2
  346. package/lib/typescript/components/Attachment/Giphy/GiphyImage.d.ts.map +1 -1
  347. package/lib/typescript/components/Attachment/UnsupportedAttachment.d.ts +2 -3
  348. package/lib/typescript/components/Attachment/UnsupportedAttachment.d.ts.map +1 -1
  349. package/lib/typescript/components/Attachment/UrlPreview/URLPreview.d.ts +4 -3
  350. package/lib/typescript/components/Attachment/UrlPreview/URLPreview.d.ts.map +1 -1
  351. package/lib/typescript/components/Attachment/UrlPreview/URLPreviewCompact.d.ts +4 -3
  352. package/lib/typescript/components/Attachment/UrlPreview/URLPreviewCompact.d.ts.map +1 -1
  353. package/lib/typescript/components/AttachmentPicker/AttachmentPicker.d.ts.map +1 -1
  354. package/lib/typescript/components/AttachmentPicker/components/AttachmentMediaPicker/AttachmentPickerItem.d.ts.map +1 -1
  355. package/lib/typescript/components/AutoCompleteInput/AutoCompleteSuggestionList.d.ts +2 -3
  356. package/lib/typescript/components/AutoCompleteInput/AutoCompleteSuggestionList.d.ts.map +1 -1
  357. package/lib/typescript/components/Channel/Channel.d.ts +3 -28
  358. package/lib/typescript/components/Channel/Channel.d.ts.map +1 -1
  359. package/lib/typescript/components/Channel/hooks/useCreateChannelContext.d.ts +1 -1
  360. package/lib/typescript/components/Channel/hooks/useCreateChannelContext.d.ts.map +1 -1
  361. package/lib/typescript/components/Channel/hooks/useCreateInputMessageInputContext.d.ts +1 -1
  362. package/lib/typescript/components/Channel/hooks/useCreateInputMessageInputContext.d.ts.map +1 -1
  363. package/lib/typescript/components/Channel/hooks/useCreateMessagesContext.d.ts +1 -1
  364. package/lib/typescript/components/Channel/hooks/useCreateMessagesContext.d.ts.map +1 -1
  365. package/lib/typescript/components/Channel/hooks/useMessageListPagination.d.ts.map +1 -1
  366. package/lib/typescript/components/ChannelList/ChannelList.d.ts +2 -10
  367. package/lib/typescript/components/ChannelList/ChannelList.d.ts.map +1 -1
  368. package/lib/typescript/components/ChannelList/ChannelListLoadingIndicator.d.ts.map +1 -1
  369. package/lib/typescript/components/ChannelList/ChannelListView.d.ts +1 -1
  370. package/lib/typescript/components/ChannelList/ChannelListView.d.ts.map +1 -1
  371. package/lib/typescript/components/ChannelList/hooks/useCreateChannelsContext.d.ts +1 -1
  372. package/lib/typescript/components/ChannelList/hooks/useCreateChannelsContext.d.ts.map +1 -1
  373. package/lib/typescript/components/ChannelPreview/ChannelDetailsBottomSheet.d.ts +1 -2
  374. package/lib/typescript/components/ChannelPreview/ChannelDetailsBottomSheet.d.ts.map +1 -1
  375. package/lib/typescript/components/ChannelPreview/ChannelPreview.d.ts +1 -1
  376. package/lib/typescript/components/ChannelPreview/ChannelPreview.d.ts.map +1 -1
  377. package/lib/typescript/components/ChannelPreview/ChannelPreviewMessage.d.ts +1 -2
  378. package/lib/typescript/components/ChannelPreview/ChannelPreviewMessage.d.ts.map +1 -1
  379. package/lib/typescript/components/ChannelPreview/ChannelPreviewView.d.ts +1 -1
  380. package/lib/typescript/components/ChannelPreview/ChannelPreviewView.d.ts.map +1 -1
  381. package/lib/typescript/components/ChannelPreview/ChannelSwipableWrapper.d.ts +1 -3
  382. package/lib/typescript/components/ChannelPreview/ChannelSwipableWrapper.d.ts.map +1 -1
  383. package/lib/typescript/components/Chat/Chat.d.ts +1 -7
  384. package/lib/typescript/components/Chat/Chat.d.ts.map +1 -1
  385. package/lib/typescript/components/Chat/hooks/useCreateChatContext.d.ts +1 -1
  386. package/lib/typescript/components/Chat/hooks/useCreateChatContext.d.ts.map +1 -1
  387. package/lib/typescript/components/ImageGallery/ImageGallery.d.ts +6 -1
  388. package/lib/typescript/components/ImageGallery/ImageGallery.d.ts.map +1 -1
  389. package/lib/typescript/components/ImageGallery/components/ImageGalleryFooter.d.ts.map +1 -1
  390. package/lib/typescript/components/ImageGallery/components/types.d.ts +0 -2
  391. package/lib/typescript/components/ImageGallery/components/types.d.ts.map +1 -1
  392. package/lib/typescript/components/Message/Message.d.ts +1 -1
  393. package/lib/typescript/components/Message/Message.d.ts.map +1 -1
  394. package/lib/typescript/components/Message/MessageItemView/MessageBubble.d.ts +1 -2
  395. package/lib/typescript/components/Message/MessageItemView/MessageBubble.d.ts.map +1 -1
  396. package/lib/typescript/components/Message/MessageItemView/MessageContent.d.ts +1 -1
  397. package/lib/typescript/components/Message/MessageItemView/MessageContent.d.ts.map +1 -1
  398. package/lib/typescript/components/Message/MessageItemView/MessageDeleted.d.ts +1 -2
  399. package/lib/typescript/components/Message/MessageItemView/MessageDeleted.d.ts.map +1 -1
  400. package/lib/typescript/components/Message/MessageItemView/MessageFooter.d.ts +0 -2
  401. package/lib/typescript/components/Message/MessageItemView/MessageFooter.d.ts.map +1 -1
  402. package/lib/typescript/components/Message/MessageItemView/MessageHeader.d.ts.map +1 -1
  403. package/lib/typescript/components/Message/MessageItemView/MessageItemView.d.ts +1 -1
  404. package/lib/typescript/components/Message/MessageItemView/MessageItemView.d.ts.map +1 -1
  405. package/lib/typescript/components/Message/MessageItemView/MessageReplies.d.ts +1 -2
  406. package/lib/typescript/components/Message/MessageItemView/MessageReplies.d.ts.map +1 -1
  407. package/lib/typescript/components/Message/MessageItemView/MessageTextContainer.d.ts +1 -1
  408. package/lib/typescript/components/Message/MessageItemView/MessageTextContainer.d.ts.map +1 -1
  409. package/lib/typescript/components/Message/MessageItemView/MessageWrapper.d.ts.map +1 -1
  410. package/lib/typescript/components/Message/MessageItemView/ReactionList/ReactionListBottom.d.ts +1 -1
  411. package/lib/typescript/components/Message/MessageItemView/ReactionList/ReactionListBottom.d.ts.map +1 -1
  412. package/lib/typescript/components/Message/MessageItemView/ReactionList/ReactionListTop.d.ts +1 -1
  413. package/lib/typescript/components/Message/MessageItemView/ReactionList/ReactionListTop.d.ts.map +1 -1
  414. package/lib/typescript/components/MessageInput/MessageComposer.d.ts +1 -2
  415. package/lib/typescript/components/MessageInput/MessageComposer.d.ts.map +1 -1
  416. package/lib/typescript/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.d.ts +3 -4
  417. package/lib/typescript/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.d.ts.map +1 -1
  418. package/lib/typescript/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.d.ts +1 -1
  419. package/lib/typescript/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.d.ts.map +1 -1
  420. package/lib/typescript/components/MessageInput/components/InputButtons/index.d.ts +1 -1
  421. package/lib/typescript/components/MessageInput/components/InputButtons/index.d.ts.map +1 -1
  422. package/lib/typescript/components/MessageInput/components/LinkPreviewList.d.ts.map +1 -1
  423. package/lib/typescript/components/MessageInput/components/OutputButtons/index.d.ts +1 -1
  424. package/lib/typescript/components/MessageInput/components/OutputButtons/index.d.ts.map +1 -1
  425. package/lib/typescript/components/MessageList/MessageFlashList.d.ts +1 -1
  426. package/lib/typescript/components/MessageList/MessageFlashList.d.ts.map +1 -1
  427. package/lib/typescript/components/MessageList/MessageList.d.ts +1 -1
  428. package/lib/typescript/components/MessageList/MessageList.d.ts.map +1 -1
  429. package/lib/typescript/components/MessageList/StickyHeader.d.ts +2 -3
  430. package/lib/typescript/components/MessageList/StickyHeader.d.ts.map +1 -1
  431. package/lib/typescript/components/MessageList/hooks/useMessageList.d.ts +0 -5
  432. package/lib/typescript/components/MessageList/hooks/useMessageList.d.ts.map +1 -1
  433. package/lib/typescript/components/MessageMenu/MessageActionList.d.ts +1 -2
  434. package/lib/typescript/components/MessageMenu/MessageActionList.d.ts.map +1 -1
  435. package/lib/typescript/components/MessageMenu/MessageMenu.d.ts +1 -2
  436. package/lib/typescript/components/MessageMenu/MessageMenu.d.ts.map +1 -1
  437. package/lib/typescript/components/MessageMenu/MessageUserReactions.d.ts +1 -1
  438. package/lib/typescript/components/MessageMenu/MessageUserReactions.d.ts.map +1 -1
  439. package/lib/typescript/components/MessageMenu/MessageUserReactionsItem.d.ts +2 -3
  440. package/lib/typescript/components/MessageMenu/MessageUserReactionsItem.d.ts.map +1 -1
  441. package/lib/typescript/components/Poll/CreatePollContent.d.ts +2 -2
  442. package/lib/typescript/components/Poll/CreatePollContent.d.ts.map +1 -1
  443. package/lib/typescript/components/Poll/Poll.d.ts +5 -8
  444. package/lib/typescript/components/Poll/Poll.d.ts.map +1 -1
  445. package/lib/typescript/components/Poll/components/PollAnswersList.d.ts +1 -2
  446. package/lib/typescript/components/Poll/components/PollAnswersList.d.ts.map +1 -1
  447. package/lib/typescript/components/Poll/components/PollOption.d.ts +1 -2
  448. package/lib/typescript/components/Poll/components/PollOption.d.ts.map +1 -1
  449. package/lib/typescript/components/Poll/components/PollResults/PollOptionFullResults.d.ts +1 -4
  450. package/lib/typescript/components/Poll/components/PollResults/PollOptionFullResults.d.ts.map +1 -1
  451. package/lib/typescript/components/Poll/components/PollResults/PollResults.d.ts +1 -2
  452. package/lib/typescript/components/Poll/components/PollResults/PollResults.d.ts.map +1 -1
  453. package/lib/typescript/components/Reply/Reply.d.ts +4 -3
  454. package/lib/typescript/components/Reply/Reply.d.ts.map +1 -1
  455. package/lib/typescript/components/Thread/Thread.d.ts +2 -8
  456. package/lib/typescript/components/Thread/Thread.d.ts.map +1 -1
  457. package/lib/typescript/components/Thread/components/ThreadFooterComponent.d.ts +1 -2
  458. package/lib/typescript/components/Thread/components/ThreadFooterComponent.d.ts.map +1 -1
  459. package/lib/typescript/components/ThreadList/ThreadList.d.ts +2 -3
  460. package/lib/typescript/components/ThreadList/ThreadList.d.ts.map +1 -1
  461. package/lib/typescript/components/ThreadList/ThreadListItem.d.ts.map +1 -1
  462. package/lib/typescript/contexts/attachmentPickerContext/AttachmentPickerContext.d.ts +0 -17
  463. package/lib/typescript/contexts/attachmentPickerContext/AttachmentPickerContext.d.ts.map +1 -1
  464. package/lib/typescript/contexts/channelContext/ChannelContext.d.ts +0 -23
  465. package/lib/typescript/contexts/channelContext/ChannelContext.d.ts.map +1 -1
  466. package/lib/typescript/contexts/channelsContext/ChannelsContext.d.ts +2 -113
  467. package/lib/typescript/contexts/channelsContext/ChannelsContext.d.ts.map +1 -1
  468. package/lib/typescript/contexts/chatContext/ChatContext.d.ts +0 -5
  469. package/lib/typescript/contexts/chatContext/ChatContext.d.ts.map +1 -1
  470. package/lib/typescript/contexts/componentsContext/ComponentsContext.d.ts +322 -0
  471. package/lib/typescript/contexts/componentsContext/ComponentsContext.d.ts.map +1 -0
  472. package/lib/typescript/contexts/componentsContext/defaultComponents.d.ts +298 -0
  473. package/lib/typescript/contexts/componentsContext/defaultComponents.d.ts.map +1 -0
  474. package/lib/typescript/contexts/imageGalleryContext/ImageGalleryContext.d.ts.map +1 -1
  475. package/lib/typescript/contexts/imageGalleryContext/ImageGalleryContextBase.d.ts +0 -5
  476. package/lib/typescript/contexts/imageGalleryContext/ImageGalleryContextBase.d.ts.map +1 -1
  477. package/lib/typescript/contexts/index.d.ts +1 -0
  478. package/lib/typescript/contexts/index.d.ts.map +1 -1
  479. package/lib/typescript/contexts/messageInputContext/MessageInputContext.d.ts +1 -169
  480. package/lib/typescript/contexts/messageInputContext/MessageInputContext.d.ts.map +1 -1
  481. package/lib/typescript/contexts/messageInputContext/hooks/useCreateMessageInputContext.d.ts +1 -1
  482. package/lib/typescript/contexts/messageInputContext/hooks/useCreateMessageInputContext.d.ts.map +1 -1
  483. package/lib/typescript/contexts/messagesContext/MessagesContext.d.ts +3 -340
  484. package/lib/typescript/contexts/messagesContext/MessagesContext.d.ts.map +1 -1
  485. package/lib/typescript/contexts/overlayContext/MessageOverlayHostLayer.d.ts +8 -4
  486. package/lib/typescript/contexts/overlayContext/MessageOverlayHostLayer.d.ts.map +1 -1
  487. package/lib/typescript/contexts/overlayContext/OverlayContext.d.ts +0 -4
  488. package/lib/typescript/contexts/overlayContext/OverlayContext.d.ts.map +1 -1
  489. package/lib/typescript/contexts/overlayContext/OverlayProvider.d.ts.map +1 -1
  490. package/lib/typescript/contexts/threadsContext/ThreadsContext.d.ts +0 -9
  491. package/lib/typescript/contexts/threadsContext/ThreadsContext.d.ts.map +1 -1
  492. package/package.json +1 -1
  493. package/src/__tests__/offline-support/offline-feature.js +64 -67
  494. package/src/components/Attachment/Attachment.tsx +7 -69
  495. package/src/components/Attachment/FileAttachment.tsx +4 -7
  496. package/src/components/Attachment/FileAttachmentGroup.tsx +9 -19
  497. package/src/components/Attachment/FilePreview.tsx +4 -9
  498. package/src/components/Attachment/Gallery.tsx +6 -83
  499. package/src/components/Attachment/GalleryImage.tsx +5 -4
  500. package/src/components/Attachment/Giphy/GiphyImage.tsx +15 -37
  501. package/src/components/Attachment/UnsupportedAttachment.tsx +5 -10
  502. package/src/components/Attachment/UrlPreview/URLPreview.tsx +6 -4
  503. package/src/components/Attachment/UrlPreview/URLPreviewCompact.tsx +6 -4
  504. package/src/components/AttachmentPicker/AttachmentPicker.tsx +2 -2
  505. package/src/components/AttachmentPicker/components/AttachmentMediaPicker/AttachmentPickerItem.tsx +5 -4
  506. package/src/components/AutoCompleteInput/AutoCompleteSuggestionList.tsx +4 -20
  507. package/src/components/Channel/Channel.tsx +31 -441
  508. package/src/components/Channel/__tests__/isAttachmentEqualHandler.test.js +12 -9
  509. package/src/components/Channel/hooks/useCreateChannelContext.ts +0 -8
  510. package/src/components/Channel/hooks/useCreateInputMessageInputContext.ts +1 -81
  511. package/src/components/Channel/hooks/useCreateMessagesContext.ts +0 -132
  512. package/src/components/ChannelList/ChannelList.tsx +3 -76
  513. package/src/components/ChannelList/ChannelListLoadingIndicator.tsx +3 -1
  514. package/src/components/ChannelList/ChannelListView.tsx +16 -36
  515. package/src/components/ChannelList/__tests__/ChannelList.test.js +173 -116
  516. package/src/components/ChannelList/__tests__/ChannelListView.test.js +64 -41
  517. package/src/components/ChannelList/hooks/useCreateChannelsContext.ts +0 -39
  518. package/src/components/ChannelPreview/ChannelDetailsBottomSheet.tsx +2 -2
  519. package/src/components/ChannelPreview/ChannelPreview.tsx +8 -16
  520. package/src/components/ChannelPreview/ChannelPreviewMessage.tsx +15 -38
  521. package/src/components/ChannelPreview/ChannelPreviewView.tsx +22 -47
  522. package/src/components/ChannelPreview/ChannelSwipableWrapper.tsx +2 -4
  523. package/src/components/ChannelPreview/__tests__/ChannelDetailsBottomSheet.test.tsx +16 -12
  524. package/src/components/ChannelPreview/__tests__/ChannelPreview.test.tsx +25 -24
  525. package/src/components/ChannelPreview/__tests__/ChannelSwipableWrapper.test.tsx +11 -6
  526. package/src/components/Chat/Chat.tsx +5 -12
  527. package/src/components/Chat/hooks/useCreateChatContext.ts +0 -2
  528. package/src/components/ImageGallery/ImageGallery.tsx +14 -16
  529. package/src/components/ImageGallery/__tests__/ImageGallery.test.tsx +0 -8
  530. package/src/components/ImageGallery/__tests__/ImageGalleryFooter.test.tsx +25 -21
  531. package/src/components/ImageGallery/components/ImageGalleryFooter.tsx +3 -1
  532. package/src/components/ImageGallery/components/types.ts +0 -3
  533. package/src/components/Message/Message.tsx +11 -32
  534. package/src/components/Message/MessageItemView/MessageBubble.tsx +11 -7
  535. package/src/components/Message/MessageItemView/MessageContent.tsx +14 -47
  536. package/src/components/Message/MessageItemView/MessageDeleted.tsx +3 -9
  537. package/src/components/Message/MessageItemView/MessageFooter.tsx +2 -14
  538. package/src/components/Message/MessageItemView/MessageHeader.tsx +11 -29
  539. package/src/components/Message/MessageItemView/MessageItemView.tsx +10 -42
  540. package/src/components/Message/MessageItemView/MessageReplies.tsx +2 -8
  541. package/src/components/Message/MessageItemView/MessageTextContainer.tsx +4 -8
  542. package/src/components/Message/MessageItemView/MessageWrapper.tsx +4 -9
  543. package/src/components/Message/MessageItemView/ReactionList/ReactionListBottom.tsx +4 -12
  544. package/src/components/Message/MessageItemView/ReactionList/ReactionListTop.tsx +4 -20
  545. package/src/components/Message/MessageItemView/__tests__/MessageContent.test.js +47 -30
  546. package/src/components/Message/MessageItemView/__tests__/MessageItemView.test.js +16 -7
  547. package/src/components/Message/MessageItemView/__tests__/MessageTextContainer.test.tsx +8 -4
  548. package/src/components/MessageInput/MessageComposer.tsx +16 -76
  549. package/src/components/MessageInput/MessageInputHeaderView.tsx +3 -3
  550. package/src/components/MessageInput/components/AttachmentPreview/AttachmentUploadPreviewList.tsx +7 -35
  551. package/src/components/MessageInput/components/AttachmentPreview/FileAttachmentUploadPreview.tsx +2 -2
  552. package/src/components/MessageInput/components/AttachmentPreview/ImageAttachmentUploadPreview.tsx +2 -2
  553. package/src/components/MessageInput/components/AudioRecorder/AudioRecordingInProgress.tsx +6 -4
  554. package/src/components/MessageInput/components/InputButtons/index.tsx +4 -5
  555. package/src/components/MessageInput/components/LinkPreviewList.tsx +3 -2
  556. package/src/components/MessageInput/components/OutputButtons/index.tsx +4 -23
  557. package/src/components/MessageList/MessageFlashList.tsx +13 -57
  558. package/src/components/MessageList/MessageList.tsx +15 -57
  559. package/src/components/MessageList/StickyHeader.tsx +4 -3
  560. package/src/components/MessageList/__tests__/MessageList.test.js +1 -130
  561. package/src/components/MessageList/hooks/useMessageList.ts +1 -41
  562. package/src/components/MessageMenu/MessageActionList.tsx +4 -3
  563. package/src/components/MessageMenu/MessageMenu.tsx +35 -47
  564. package/src/components/MessageMenu/MessageUserReactions.tsx +7 -27
  565. package/src/components/MessageMenu/MessageUserReactionsItem.tsx +3 -6
  566. package/src/components/MessageMenu/__tests__/MessageUserReactions.test.tsx +12 -11
  567. package/src/components/Poll/CreatePollContent.tsx +3 -4
  568. package/src/components/Poll/Poll.tsx +22 -24
  569. package/src/components/Poll/components/PollAnswersList.tsx +9 -11
  570. package/src/components/Poll/components/PollOption.tsx +9 -11
  571. package/src/components/Poll/components/PollResults/PollOptionFullResults.tsx +10 -11
  572. package/src/components/Poll/components/PollResults/PollResults.tsx +9 -15
  573. package/src/components/Reply/Reply.tsx +18 -5
  574. package/src/components/Thread/Thread.tsx +3 -18
  575. package/src/components/Thread/components/ThreadFooterComponent.tsx +10 -11
  576. package/src/components/ThreadList/ThreadList.tsx +14 -22
  577. package/src/components/ThreadList/ThreadListItem.tsx +6 -11
  578. package/src/components/ui/Avatar/Avatar.tsx +2 -2
  579. package/src/contexts/attachmentPickerContext/AttachmentPickerContext.tsx +0 -15
  580. package/src/contexts/channelContext/ChannelContext.tsx +0 -24
  581. package/src/contexts/channelsContext/ChannelsContext.tsx +2 -114
  582. package/src/contexts/chatContext/ChatContext.tsx +0 -5
  583. package/src/contexts/componentsContext/ComponentsContext.tsx +62 -0
  584. package/src/contexts/componentsContext/PLAN.md +148 -0
  585. package/src/contexts/componentsContext/__tests__/defaultComponents.test.ts +45 -0
  586. package/src/contexts/componentsContext/defaultComponents.ts +334 -0
  587. package/src/contexts/imageGalleryContext/ImageGalleryContext.tsx +0 -8
  588. package/src/contexts/imageGalleryContext/ImageGalleryContextBase.tsx +0 -10
  589. package/src/contexts/index.ts +1 -0
  590. package/src/contexts/messageInputContext/MessageInputContext.tsx +0 -185
  591. package/src/contexts/messageInputContext/hooks/useCreateMessageInputContext.ts +1 -75
  592. package/src/contexts/messagesContext/MessagesContext.tsx +3 -367
  593. package/src/contexts/overlayContext/MessageOverlayHostLayer.tsx +38 -20
  594. package/src/contexts/overlayContext/OverlayContext.tsx +0 -4
  595. package/src/contexts/overlayContext/OverlayProvider.tsx +1 -2
  596. package/src/contexts/overlayContext/__tests__/MessageOverlayHostLayer.test.tsx +80 -7
  597. package/src/contexts/threadsContext/ThreadsContext.tsx +0 -9
  598. package/src/version.json +1 -1
@@ -2,11 +2,6 @@ import { useMemo } from 'react';
2
2
 
3
3
  import type { LocalMessage } from 'stream-chat';
4
4
 
5
- import { useChatContext } from '../../../contexts/chatContext/ChatContext';
6
- import {
7
- DeletedMessagesVisibilityType,
8
- useMessagesContext,
9
- } from '../../../contexts/messagesContext/MessagesContext';
10
5
  import { usePaginatedMessageListContext } from '../../../contexts/paginatedMessageListContext/PaginatedMessageListContext';
11
6
  import { useThreadContext } from '../../../contexts/threadContext/ThreadContext';
12
7
 
@@ -27,35 +22,8 @@ export type MessageGroupStyles = {
27
22
  [key: string]: string[];
28
23
  };
29
24
 
30
- export const shouldIncludeMessageInList = (
31
- message: LocalMessage,
32
- options: { deletedMessagesVisibilityType?: DeletedMessagesVisibilityType; userId?: string },
33
- ) => {
34
- const { deletedMessagesVisibilityType, userId } = options;
35
- const isMessageTypeDeleted = message.type === 'deleted';
36
- const isSender = message.user?.id === userId;
37
-
38
- if (!isMessageTypeDeleted) {
39
- return true;
40
- }
41
-
42
- switch (deletedMessagesVisibilityType) {
43
- case 'always':
44
- return true;
45
- case 'sender':
46
- return isSender;
47
- case 'receiver':
48
- return !isSender;
49
- case 'never':
50
- default:
51
- return false;
52
- }
53
- };
54
-
55
25
  export const useMessageList = (params: UseMessageListParams) => {
56
26
  const { threadList, isLiveStreaming, isFlashList = false } = params;
57
- const { client } = useChatContext();
58
- const { deletedMessagesVisibilityType } = useMessagesContext();
59
27
  const { messages, viewabilityChangedCallback } = usePaginatedMessageListContext();
60
28
  const { threadMessages } = useThreadContext();
61
29
  const messageList = threadList ? threadMessages : messages;
@@ -63,14 +31,6 @@ export const useMessageList = (params: UseMessageListParams) => {
63
31
  const processedMessageList = useMemo<LocalMessage[]>(() => {
64
32
  const newMessageList = [];
65
33
  for (const message of messageList) {
66
- if (
67
- !shouldIncludeMessageInList(message, {
68
- deletedMessagesVisibilityType,
69
- userId: client.userID,
70
- })
71
- ) {
72
- continue;
73
- }
74
34
  if (isFlashList) {
75
35
  newMessageList.push(message);
76
36
  } else {
@@ -78,7 +38,7 @@ export const useMessageList = (params: UseMessageListParams) => {
78
38
  }
79
39
  }
80
40
  return newMessageList;
81
- }, [messageList, deletedMessagesVisibilityType, client.userID, isFlashList]);
41
+ }, [messageList, isFlashList]);
82
42
 
83
43
  const data = useRAFCoalescedValue(processedMessageList, isLiveStreaming);
84
44
 
@@ -5,11 +5,11 @@ import { ScrollView } from 'react-native-gesture-handler';
5
5
 
6
6
  import { MessageActionType } from './MessageActionListItem';
7
7
 
8
- import { MessagesContextValue } from '../../contexts/messagesContext/MessagesContext';
8
+ import { useComponentsContext } from '../../contexts/componentsContext/ComponentsContext';
9
9
  import { useTheme } from '../../contexts/themeContext/ThemeContext';
10
10
  import { primitives } from '../../theme';
11
11
 
12
- export type MessageActionListProps = Pick<MessagesContextValue, 'MessageActionListItem'> & {
12
+ export type MessageActionListProps = {
13
13
  /**
14
14
  * Function to close the message actions bottom sheet
15
15
  * @returns void
@@ -22,7 +22,8 @@ export type MessageActionListProps = Pick<MessagesContextValue, 'MessageActionLi
22
22
  };
23
23
 
24
24
  export const MessageActionList = (props: MessageActionListProps) => {
25
- const { MessageActionListItem, messageActions } = props;
25
+ const { messageActions } = props;
26
+ const { MessageActionListItem } = useComponentsContext();
26
27
  const {
27
28
  theme: {
28
29
  messageMenu: {
@@ -5,58 +5,46 @@ import { useWindowDimensions } from 'react-native';
5
5
  import { MessageActionType } from './MessageActionListItem';
6
6
 
7
7
  import { MessageContextValue } from '../../contexts/messageContext/MessageContext';
8
- import { MessagesContextValue } from '../../contexts/messagesContext/MessagesContext';
9
8
  import { useTheme } from '../../contexts/themeContext/ThemeContext';
10
9
  import { BottomSheetModal } from '../UIComponents/BottomSheetModal';
11
10
 
12
11
  export type MessageMenuProps = PropsWithChildren<
13
- Partial<
14
- Pick<
15
- MessagesContextValue,
16
- | 'MessageActionList'
17
- | 'MessageActionListItem'
18
- | 'MessageReactionPicker'
19
- | 'MessageUserReactions'
20
- | 'MessageUserReactionsAvatar'
21
- | 'MessageUserReactionsItem'
22
- >
23
- > &
24
- Partial<Pick<MessageContextValue, 'message'>> & {
25
- /**
26
- * Function to close the message actions bottom sheet
27
- * @returns void
28
- */
29
- dismissOverlay: () => void;
30
- /**
31
- * An array of message actions to render
32
- */
33
- messageActions: MessageActionType[];
34
- /**
35
- * Boolean to determine if there are message actions
36
- */
37
- showMessageReactions: boolean;
38
- /**
39
- * Boolean to determine if the overlay is visible.
40
- */
41
- visible: boolean;
42
- /**
43
- * Function to handle reaction on press
44
- * @param reactionType
45
- * @returns
46
- */
47
- handleReaction?: (reactionType: string) => Promise<void>;
48
- /**
49
- * The selected reaction
50
- */
51
- selectedReaction?: string;
12
+ Partial<Pick<MessageContextValue, 'message'>> & {
13
+ /**
14
+ * Function to close the message actions bottom sheet
15
+ * @returns void
16
+ */
17
+ dismissOverlay: () => void;
18
+ /**
19
+ * An array of message actions to render
20
+ */
21
+ messageActions: MessageActionType[];
22
+ /**
23
+ * Boolean to determine if there are message actions
24
+ */
25
+ showMessageReactions: boolean;
26
+ /**
27
+ * Boolean to determine if the overlay is visible.
28
+ */
29
+ visible: boolean;
30
+ /**
31
+ * Function to handle reaction on press
32
+ * @param reactionType
33
+ * @returns
34
+ */
35
+ handleReaction?: (reactionType: string) => Promise<void>;
36
+ /**
37
+ * The selected reaction
38
+ */
39
+ selectedReaction?: string;
52
40
 
53
- layout: {
54
- x: number;
55
- y: number;
56
- w: number;
57
- h: number;
58
- };
59
- }
41
+ layout: {
42
+ x: number;
43
+ y: number;
44
+ w: number;
45
+ h: number;
46
+ };
47
+ }
60
48
  >;
61
49
 
62
50
  // TODO: V9: Either remove this or refactor it so that it's useful again, as its logic
@@ -11,6 +11,7 @@ import { useFetchReactions } from './hooks/useFetchReactions';
11
11
  import { ReactionButton } from './ReactionButton';
12
12
 
13
13
  import { useBottomSheetContext } from '../../contexts';
14
+ import { useComponentsContext } from '../../contexts/componentsContext/ComponentsContext';
14
15
  import {
15
16
  MessageContextValue,
16
17
  useMessageContext,
@@ -39,12 +40,7 @@ const getItemLayout = (_, index: number) => ({
39
40
  index,
40
41
  });
41
42
 
42
- export type MessageUserReactionsProps = Partial<
43
- Pick<
44
- MessagesContextValue,
45
- 'MessageUserReactionsAvatar' | 'MessageUserReactionsItem' | 'supportedReactions'
46
- >
47
- > &
43
+ export type MessageUserReactionsProps = Partial<Pick<MessagesContextValue, 'supportedReactions'>> &
48
44
  Partial<Pick<MessageContextValue, 'message'>> & {
49
45
  /**
50
46
  * An array of reactions
@@ -99,13 +95,7 @@ const reactionSelectorKeyExtractor = (item: ReactionSelectorItemType) => item.ty
99
95
  export const MessageUserReactions = (props: MessageUserReactionsProps) => {
100
96
  const styles = useStyles();
101
97
  const [showMoreReactions, setShowMoreReactions] = useState(false);
102
- const {
103
- message,
104
- MessageUserReactionsAvatar: propMessageUserReactionsAvatar,
105
- MessageUserReactionsItem: propMessageUserReactionsItem,
106
- reactions: propReactions,
107
- supportedReactions: propSupportedReactions,
108
- } = props;
98
+ const { message, reactions: propReactions, supportedReactions: propSupportedReactions } = props;
109
99
  const selectorListRef = useRef<FlatList>(null);
110
100
  const { close } = useBottomSheetContext();
111
101
  const reactionTypes = useMemo(
@@ -113,16 +103,10 @@ export const MessageUserReactions = (props: MessageUserReactionsProps) => {
113
103
  [message?.reaction_groups],
114
104
  );
115
105
  const [selectedReaction, setSelectedReaction] = useState<string | undefined>(undefined);
116
- const {
117
- MessageUserReactionsAvatar: contextMessageUserReactionsAvatar,
118
- MessageUserReactionsItem: contextMessageUserReactionsItem,
119
- supportedReactions: contextSupportedReactions,
120
- } = useMessagesContext();
106
+ const { supportedReactions: contextSupportedReactions } = useMessagesContext();
107
+ const { MessageUserReactionsItem } = useComponentsContext();
121
108
  const { handleReaction } = useMessageContext();
122
109
  const supportedReactions = propSupportedReactions ?? contextSupportedReactions;
123
- const MessageUserReactionsAvatar =
124
- propMessageUserReactionsAvatar ?? contextMessageUserReactionsAvatar;
125
- const MessageUserReactionsItem = propMessageUserReactionsItem ?? contextMessageUserReactionsItem;
126
110
 
127
111
  const onSelectReaction = useStableCallback((reactionType: string) => {
128
112
  setSelectedReaction((currentReaction) =>
@@ -225,13 +209,9 @@ export const MessageUserReactions = (props: MessageUserReactionsProps) => {
225
209
 
226
210
  const renderItem = useCallback(
227
211
  ({ item }: { item: Reaction }) => (
228
- <MessageUserReactionsItem
229
- MessageUserReactionsAvatar={MessageUserReactionsAvatar}
230
- reaction={item}
231
- supportedReactions={supportedReactions ?? []}
232
- />
212
+ <MessageUserReactionsItem reaction={item} supportedReactions={supportedReactions ?? []} />
233
213
  ),
234
- [MessageUserReactionsAvatar, MessageUserReactionsItem, supportedReactions],
214
+ [MessageUserReactionsItem, supportedReactions],
235
215
  );
236
216
 
237
217
  const handleSelectReaction = useStableCallback((emoji: string) => {
@@ -4,7 +4,7 @@ import { Pressable, StyleSheet, Text, View } from 'react-native';
4
4
 
5
5
  import { useMessageContext } from '../../contexts';
6
6
  import { useChatContext } from '../../contexts/chatContext/ChatContext';
7
- import { MessagesContextValue } from '../../contexts/messagesContext/MessagesContext';
7
+ import { useComponentsContext } from '../../contexts/componentsContext/ComponentsContext';
8
8
  import { useTheme } from '../../contexts/themeContext/ThemeContext';
9
9
  import { useTranslationContext } from '../../contexts/translationContext/TranslationContext';
10
10
  import { useStableCallback } from '../../hooks';
@@ -14,10 +14,7 @@ import { primitives } from '../../theme';
14
14
  import type { Reaction } from '../../types/types';
15
15
  import { ReactionData } from '../../utils/utils';
16
16
 
17
- export type MessageUserReactionsItemProps = Pick<
18
- MessagesContextValue,
19
- 'MessageUserReactionsAvatar'
20
- > & {
17
+ export type MessageUserReactionsItemProps = {
21
18
  /**
22
19
  * The reaction object
23
20
  */
@@ -29,10 +26,10 @@ export type MessageUserReactionsItemProps = Pick<
29
26
  };
30
27
 
31
28
  export const MessageUserReactionsItem = ({
32
- MessageUserReactionsAvatar,
33
29
  reaction,
34
30
  supportedReactions,
35
31
  }: MessageUserReactionsItemProps) => {
32
+ const { MessageUserReactionsAvatar } = useComponentsContext();
36
33
  const { id, name, type } = reaction;
37
34
  const {
38
35
  theme: {
@@ -6,6 +6,7 @@ import { fireEvent, render } from '@testing-library/react-native';
6
6
 
7
7
  import { LocalMessage, ReactionResponse } from 'stream-chat';
8
8
 
9
+ import { WithComponents } from '../../../contexts/componentsContext/ComponentsContext';
9
10
  import {
10
11
  MessagesContextValue,
11
12
  MessagesProvider,
@@ -42,18 +43,18 @@ const renderComponent = (props = {}) =>
42
43
  render(
43
44
  <ThemeProvider theme={defaultTheme}>
44
45
  <TranslationProvider value={mockTranslations as unknown as TranslationContextValue}>
45
- <MessagesProvider
46
- value={
47
- {
48
- MessageUserReactionsAvatar: () => null,
49
- MessageUserReactionsItem: (props: MessageUserReactionsItemProps) => (
50
- <Text>{props.reaction.id + ' ' + props.reaction.type}</Text>
51
- ),
52
- } as unknown as MessagesContextValue
53
- }
46
+ <WithComponents
47
+ overrides={{
48
+ MessageUserReactionsAvatar: () => null,
49
+ MessageUserReactionsItem: (itemProps: MessageUserReactionsItemProps) => (
50
+ <Text>{itemProps.reaction.id + ' ' + itemProps.reaction.type}</Text>
51
+ ),
52
+ }}
54
53
  >
55
- <MessageUserReactions {...defaultProps} {...props} />
56
- </MessagesProvider>
54
+ <MessagesProvider value={{} as unknown as MessagesContextValue}>
55
+ <MessageUserReactions {...defaultProps} {...props} />
56
+ </MessagesProvider>
57
+ </WithComponents>
57
58
  </TranslationProvider>
58
59
  </ThemeProvider>,
59
60
  );
@@ -16,11 +16,11 @@ import {
16
16
  CreatePollModalState,
17
17
  CreatePollContentContextValue,
18
18
  CreatePollContentProvider,
19
- InputMessageInputContextValue,
20
19
  useCreatePollContentContext,
21
20
  useTheme,
22
21
  useTranslationContext,
23
22
  } from '../../contexts';
23
+ import { useComponentsContext } from '../../contexts/componentsContext/ComponentsContext';
24
24
  import { useMessageComposer } from '../../contexts/messageInputContext/hooks/useMessageComposer';
25
25
  import { useStateStore } from '../../hooks/useStateStore';
26
26
  import { primitives } from '../../theme';
@@ -212,14 +212,13 @@ export const CreatePollContent = () => {
212
212
 
213
213
  export const CreatePoll = ({
214
214
  closePollCreationDialog,
215
- CreatePollContent: CreatePollContentOverride,
216
215
  createPollOptionGap = 8,
217
216
  sendMessage,
218
217
  }: Pick<
219
218
  CreatePollContentContextValue,
220
219
  'createPollOptionGap' | 'closePollCreationDialog' | 'sendMessage'
221
- > &
222
- Pick<InputMessageInputContextValue, 'CreatePollContent'>) => {
220
+ >) => {
221
+ const { CreatePollContent: CreatePollContentOverride } = useComponentsContext();
223
222
  const messageComposer = useMessageComposer();
224
223
  const [modalStateStore] = useState(
225
224
  () => new StateStore<CreatePollModalState>({ isClosing: false }),
@@ -3,28 +3,24 @@ import { StyleSheet, Text, View } from 'react-native';
3
3
 
4
4
  import { PollOption as PollOptionClass } from 'stream-chat';
5
5
 
6
- import { PollButtons, PollOption, ShowAllOptionsButton } from './components';
6
+ import { PollOption, ShowAllOptionsButton } from './components';
7
7
 
8
8
  import { usePollState } from './hooks/usePollState';
9
9
 
10
10
  import {
11
- MessagesContextValue,
12
11
  PollContextProvider,
13
12
  PollContextValue,
14
13
  useTheme,
15
14
  useTranslationContext,
16
15
  } from '../../contexts';
16
+ import { useComponentsContext } from '../../contexts/componentsContext/ComponentsContext';
17
17
 
18
18
  import { primitives } from '../../theme';
19
19
  import { defaultPollOptionCount } from '../../utils/constants';
20
20
 
21
- export type PollProps = Pick<PollContextValue, 'poll' | 'message'> &
22
- Pick<MessagesContextValue, 'PollContent'>;
21
+ export type PollProps = Pick<PollContextValue, 'poll' | 'message'>;
23
22
 
24
- export type PollContentProps = {
25
- PollButtons?: React.ComponentType;
26
- PollHeader?: React.ComponentType;
27
- };
23
+ export type PollContentProps = Record<string, never>;
28
24
 
29
25
  export const PollHeader = () => {
30
26
  const styles = useStyles();
@@ -60,12 +56,11 @@ export const PollHeader = () => {
60
56
  );
61
57
  };
62
58
 
63
- export const PollContent = ({
64
- PollButtons: PollButtonsOverride,
65
- PollHeader: PollHeaderOverride,
66
- }: PollContentProps) => {
59
+ export const PollContent = () => {
67
60
  const { options } = usePollState();
68
61
  const styles = useStyles();
62
+ const { PollButtons: PollButtonsComponent, PollHeader: PollHeaderComponent } =
63
+ useComponentsContext();
69
64
 
70
65
  const {
71
66
  theme: {
@@ -77,7 +72,7 @@ export const PollContent = ({
77
72
 
78
73
  return (
79
74
  <View style={[styles.container, container]}>
80
- {PollHeaderOverride ? <PollHeaderOverride /> : <PollHeader />}
75
+ <PollHeaderComponent />
81
76
  <View style={[styles.optionsWrapper, optionsWrapper]}>
82
77
  {options
83
78
  ?.slice(0, defaultPollOptionCount)
@@ -86,21 +81,24 @@ export const PollContent = ({
86
81
  ))}
87
82
  <ShowAllOptionsButton />
88
83
  </View>
89
- {PollButtonsOverride ? <PollButtonsOverride /> : <PollButtons />}
84
+ <PollButtonsComponent />
90
85
  </View>
91
86
  );
92
87
  };
93
88
 
94
- export const Poll = ({ message, poll, PollContent: PollContentOverride }: PollProps) => (
95
- <PollContextProvider
96
- value={{
97
- message,
98
- poll,
99
- }}
100
- >
101
- {PollContentOverride ? <PollContentOverride /> : <PollContent />}
102
- </PollContextProvider>
103
- );
89
+ export const Poll = ({ message, poll }: PollProps) => {
90
+ const { PollContent: PollContentOverride } = useComponentsContext();
91
+ return (
92
+ <PollContextProvider
93
+ value={{
94
+ message,
95
+ poll,
96
+ }}
97
+ >
98
+ {PollContentOverride ? <PollContentOverride /> : <PollContent />}
99
+ </PollContextProvider>
100
+ );
101
+ };
104
102
 
105
103
  const useStyles = () => {
106
104
  const {
@@ -14,6 +14,7 @@ import {
14
14
  useTheme,
15
15
  useTranslationContext,
16
16
  } from '../../../contexts';
17
+ import { useComponentsContext } from '../../../contexts/componentsContext/ComponentsContext';
17
18
  import { primitives } from '../../../theme';
18
19
  import { getDateString } from '../../../utils/i18n/getDateString';
19
20
  import { Button } from '../../ui';
@@ -64,7 +65,6 @@ export const AnswerListAddCommentButton = (props: PollButtonProps) => {
64
65
 
65
66
  export type PollAnswersListProps = PollContextValue & {
66
67
  additionalFlatListProps?: Partial<FlatListProps<PollAnswer>>;
67
- PollAnswersListContent?: React.ComponentType;
68
68
  };
69
69
 
70
70
  export const PollAnswerListItem = ({ answer }: { answer: PollAnswer }) => {
@@ -157,16 +157,14 @@ export const PollAnswersList = ({
157
157
  additionalFlatListProps,
158
158
  message,
159
159
  poll,
160
- PollAnswersListContent: PollAnswersListOverride,
161
- }: PollAnswersListProps) => (
162
- <PollContextProvider value={{ message, poll }}>
163
- {PollAnswersListOverride ? (
164
- <PollAnswersListOverride />
165
- ) : (
166
- <PollAnswersListContent additionalFlatListProps={additionalFlatListProps} />
167
- )}
168
- </PollContextProvider>
169
- );
160
+ }: PollAnswersListProps) => {
161
+ const { PollAnswersListContent: PollAnswersListContentComponent } = useComponentsContext();
162
+ return (
163
+ <PollContextProvider value={{ message, poll }}>
164
+ <PollAnswersListContentComponent additionalFlatListProps={additionalFlatListProps} />
165
+ </PollContextProvider>
166
+ );
167
+ };
170
168
 
171
169
  const useStyles = () => {
172
170
  const {
@@ -16,6 +16,7 @@ import {
16
16
  useTheme,
17
17
  useTranslationContext,
18
18
  } from '../../../contexts';
19
+ import { useComponentsContext } from '../../../contexts/componentsContext/ComponentsContext';
19
20
 
20
21
  import { Check } from '../../../icons';
21
22
  import { primitives } from '../../../theme';
@@ -32,7 +33,6 @@ export type PollOptionProps = {
32
33
 
33
34
  export type PollAllOptionsContentProps = PollContextValue & {
34
35
  additionalScrollViewProps?: Partial<ScrollViewProps>;
35
- PollAllOptionsContent?: React.ComponentType;
36
36
  };
37
37
 
38
38
  export const PollAllOptionsContent = ({
@@ -75,16 +75,14 @@ export const PollAllOptions = ({
75
75
  additionalScrollViewProps,
76
76
  message,
77
77
  poll,
78
- PollAllOptionsContent: PollAllOptionsContentOverride,
79
- }: PollAllOptionsContentProps) => (
80
- <PollContextProvider value={{ message, poll }}>
81
- {PollAllOptionsContentOverride ? (
82
- <PollAllOptionsContentOverride />
83
- ) : (
84
- <PollAllOptionsContent additionalScrollViewProps={additionalScrollViewProps} />
85
- )}
86
- </PollContextProvider>
87
- );
78
+ }: PollAllOptionsContentProps) => {
79
+ const { PollAllOptionsContent: PollAllOptionsContentComponent } = useComponentsContext();
80
+ return (
81
+ <PollContextProvider value={{ message, poll }}>
82
+ <PollAllOptionsContentComponent additionalScrollViewProps={additionalScrollViewProps} />
83
+ </PollContextProvider>
84
+ );
85
+ };
88
86
 
89
87
  export const PollOption = ({ option, showProgressBar = true, forceIncoming }: PollOptionProps) => {
90
88
  const { latestVotesByOption, voteCountsByOption, voteCount } = usePollState();
@@ -11,6 +11,7 @@ import {
11
11
  useTheme,
12
12
  useTranslationContext,
13
13
  } from '../../../../contexts';
14
+ import { useComponentsContext } from '../../../../contexts/componentsContext/ComponentsContext';
14
15
 
15
16
  import { primitives } from '../../../../theme';
16
17
  import { usePollOptionVotesPagination } from '../../hooks/usePollOptionVotesPagination';
@@ -19,7 +20,6 @@ import { usePollState } from '../../hooks/usePollState';
19
20
  export type PollOptionFullResultsProps = PollContextValue & {
20
21
  option: PollOption;
21
22
  additionalFlatListProps?: Partial<FlatListProps<PollVoteClass>>;
22
- PollOptionFullResultsContent?: React.ComponentType<{ option: PollOption }>;
23
23
  };
24
24
 
25
25
  export const renderPollOptionFullResultsItem = ({ item }: { item: PollVoteClass }) => (
@@ -86,19 +86,18 @@ export const PollOptionFullResults = ({
86
86
  message,
87
87
  option,
88
88
  poll,
89
- PollOptionFullResultsContent: PollOptionFullResultsContentOverride,
90
- }: PollOptionFullResultsProps) => (
91
- <PollContextProvider value={{ message, poll }}>
92
- {PollOptionFullResultsContentOverride ? (
93
- <PollOptionFullResultsContentOverride option={option} />
94
- ) : (
95
- <PollOptionFullResultsContent
89
+ }: PollOptionFullResultsProps) => {
90
+ const { PollOptionFullResultsContent: PollOptionFullResultsContentComponent } =
91
+ useComponentsContext();
92
+ return (
93
+ <PollContextProvider value={{ message, poll }}>
94
+ <PollOptionFullResultsContentComponent
96
95
  additionalFlatListProps={additionalFlatListProps}
97
96
  option={option}
98
97
  />
99
- )}
100
- </PollContextProvider>
101
- );
98
+ </PollContextProvider>
99
+ );
100
+ };
102
101
 
103
102
  const useStyles = () => {
104
103
  const {
@@ -11,12 +11,12 @@ import {
11
11
  useTheme,
12
12
  useTranslationContext,
13
13
  } from '../../../../contexts';
14
+ import { useComponentsContext } from '../../../../contexts/componentsContext/ComponentsContext';
14
15
  import { primitives } from '../../../../theme';
15
16
  import { usePollState } from '../../hooks/usePollState';
16
17
 
17
18
  export type PollResultsProps = PollContextValue & {
18
19
  additionalScrollViewProps?: Partial<ScrollViewProps>;
19
- PollResultsContent?: React.ComponentType;
20
20
  };
21
21
 
22
22
  export const PollResultsContent = ({
@@ -62,20 +62,14 @@ export const PollResultsContent = ({
62
62
  );
63
63
  };
64
64
 
65
- export const PollResults = ({
66
- additionalScrollViewProps,
67
- message,
68
- poll,
69
- PollResultsContent: PollResultsContentOverride,
70
- }: PollResultsProps) => (
71
- <PollContextProvider value={{ message, poll }}>
72
- {PollResultsContentOverride ? (
73
- <PollResultsContentOverride />
74
- ) : (
75
- <PollResultsContent additionalScrollViewProps={additionalScrollViewProps} />
76
- )}
77
- </PollContextProvider>
78
- );
65
+ export const PollResults = ({ additionalScrollViewProps, message, poll }: PollResultsProps) => {
66
+ const { PollResultsContent: PollResultsContentComponent } = useComponentsContext();
67
+ return (
68
+ <PollContextProvider value={{ message, poll }}>
69
+ <PollResultsContentComponent additionalScrollViewProps={additionalScrollViewProps} />
70
+ </PollContextProvider>
71
+ );
72
+ };
79
73
 
80
74
  const useStyles = () => {
81
75
  const {