@sendbird/uikit-react 3.6.11-beta.2 → 3.7.0-rc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (994) hide show
  1. package/App.js +272 -345
  2. package/App.js.map +1 -1
  3. package/CHANGELOG.md +134 -0
  4. package/Channel/components/ChannelHeader.js +45 -50
  5. package/Channel/components/ChannelHeader.js.map +1 -1
  6. package/Channel/components/ChannelUI.js +76 -77
  7. package/Channel/components/ChannelUI.js.map +1 -1
  8. package/Channel/components/FileViewer.js +53 -58
  9. package/Channel/components/FileViewer.js.map +1 -1
  10. package/Channel/components/FrozenNotification.js +9 -12
  11. package/Channel/components/FrozenNotification.js.map +1 -1
  12. package/Channel/components/Message.js +198 -176
  13. package/Channel/components/Message.js.map +1 -1
  14. package/Channel/components/MessageInput.js +137 -130
  15. package/Channel/components/MessageInput.js.map +1 -1
  16. package/Channel/components/MessageList.js +171 -161
  17. package/Channel/components/MessageList.js.map +1 -1
  18. package/Channel/components/RemoveMessageModal.js +40 -41
  19. package/Channel/components/RemoveMessageModal.js.map +1 -1
  20. package/Channel/components/SuggestedMentionList.js +156 -136
  21. package/Channel/components/SuggestedMentionList.js.map +1 -1
  22. package/Channel/components/TypingIndicator.js +47 -48
  23. package/Channel/components/TypingIndicator.js.map +1 -1
  24. package/Channel/components/UnreadCount.js +17 -18
  25. package/Channel/components/UnreadCount.js.map +1 -1
  26. package/Channel/context.js +17 -17
  27. package/Channel/utils/compareMessagesForGrouping.js +11 -11
  28. package/Channel/utils/compareMessagesForGrouping.js.map +1 -1
  29. package/Channel/utils/getMessagePartsInfo.js +32 -26
  30. package/Channel/utils/getMessagePartsInfo.js.map +1 -1
  31. package/Channel.js +54 -51
  32. package/Channel.js.map +1 -1
  33. package/ChannelList/components/AddChannel.js +32 -30
  34. package/ChannelList/components/AddChannel.js.map +1 -1
  35. package/ChannelList/components/ChannelListHeader.js +22 -31
  36. package/ChannelList/components/ChannelListHeader.js.map +1 -1
  37. package/ChannelList/components/ChannelListUI.js +93 -88
  38. package/ChannelList/components/ChannelListUI.js.map +1 -1
  39. package/ChannelList/components/ChannelPreview.js +79 -75
  40. package/ChannelList/components/ChannelPreview.js.map +1 -1
  41. package/ChannelList/components/ChannelPreviewAction.js +85 -91
  42. package/ChannelList/components/ChannelPreviewAction.js.map +1 -1
  43. package/ChannelList/context.js +9 -10
  44. package/ChannelList/context.js.map +1 -1
  45. package/ChannelList.js +38 -35
  46. package/ChannelList.js.map +1 -1
  47. package/ChannelListProvider-f520f5b3.js +1051 -0
  48. package/ChannelListProvider-f520f5b3.js.map +1 -0
  49. package/ChannelProvider-7f6fd1f8.js +2080 -0
  50. package/ChannelProvider-7f6fd1f8.js.map +1 -0
  51. package/ChannelSettings/components/ChannelProfile.js +42 -37
  52. package/ChannelSettings/components/ChannelProfile.js.map +1 -1
  53. package/ChannelSettings/components/ChannelSettingsUI.js +44 -47
  54. package/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
  55. package/ChannelSettings/components/EditDetailsModal.js +54 -52
  56. package/ChannelSettings/components/EditDetailsModal.js.map +1 -1
  57. package/ChannelSettings/components/LeaveChannel.js +39 -41
  58. package/ChannelSettings/components/LeaveChannel.js.map +1 -1
  59. package/ChannelSettings/components/ModerationPanel.js +552 -509
  60. package/ChannelSettings/components/ModerationPanel.js.map +1 -1
  61. package/ChannelSettings/components/UserListItem.js +66 -66
  62. package/ChannelSettings/components/UserListItem.js.map +1 -1
  63. package/ChannelSettings/components/UserPanel.js +29 -26
  64. package/ChannelSettings/components/UserPanel.js.map +1 -1
  65. package/ChannelSettings/context.js +52 -57
  66. package/ChannelSettings/context.js.map +1 -1
  67. package/ChannelSettings.js +20 -19
  68. package/ChannelSettings.js.map +1 -1
  69. package/CreateChannel/components/CreateChannelUI.js +23 -25
  70. package/CreateChannel/components/CreateChannelUI.js.map +1 -1
  71. package/CreateChannel/components/InviteUsers.js +106 -102
  72. package/CreateChannel/components/InviteUsers.js.map +1 -1
  73. package/CreateChannel/components/SelectChannelType.js +38 -43
  74. package/CreateChannel/components/SelectChannelType.js.map +1 -1
  75. package/CreateChannel/context.js +4 -4
  76. package/CreateChannel.js +22 -23
  77. package/CreateChannel.js.map +1 -1
  78. package/CreateChannelProvider-c25dd81b.js +48 -0
  79. package/{CreateChannelProvider-a2fad282.js.map → CreateChannelProvider-c25dd81b.js.map} +1 -1
  80. package/CreateOpenChannel/components/CreateOpenChannelUI.js +38 -36
  81. package/CreateOpenChannel/components/CreateOpenChannelUI.js.map +1 -1
  82. package/CreateOpenChannel/context.js +29 -34
  83. package/CreateOpenChannel/context.js.map +1 -1
  84. package/CreateOpenChannel.js +20 -21
  85. package/CreateOpenChannel.js.map +1 -1
  86. package/EditUserProfile/components/EditUserProfileUI.js +152 -21
  87. package/EditUserProfile/components/EditUserProfileUI.js.map +1 -1
  88. package/EditUserProfile/context.js +13 -13
  89. package/EditUserProfile/context.js.map +1 -1
  90. package/EditUserProfile.js +19 -19
  91. package/EditUserProfile.js.map +1 -1
  92. package/LocalizationContext-d18a86d8.js +20 -0
  93. package/{LocalizationContext-2463058b.js.map → LocalizationContext-d18a86d8.js.map} +1 -1
  94. package/MediaQueryContext-3eeeec4f.js +85 -0
  95. package/MediaQueryContext-3eeeec4f.js.map +1 -0
  96. package/MemberList-469dae9b.js +422 -0
  97. package/{MemberList-593867cb.js.map → MemberList-469dae9b.js.map} +1 -1
  98. package/Message/context.js +11 -12
  99. package/Message/context.js.map +1 -1
  100. package/Message/hooks/useDirtyGetMentions.js +21 -26
  101. package/Message/hooks/useDirtyGetMentions.js.map +1 -1
  102. package/MessageSearch/components/MessageSearchUI.js +56 -61
  103. package/MessageSearch/components/MessageSearchUI.js.map +1 -1
  104. package/MessageSearch/context.js +166 -177
  105. package/MessageSearch/context.js.map +1 -1
  106. package/MessageSearch.js +49 -47
  107. package/MessageSearch.js.map +1 -1
  108. package/OpenChannel/components/FrozenChannelNotification.js +6 -8
  109. package/OpenChannel/components/FrozenChannelNotification.js.map +1 -1
  110. package/OpenChannel/components/OpenChannelHeader.js +22 -27
  111. package/OpenChannel/components/OpenChannelHeader.js.map +1 -1
  112. package/OpenChannel/components/OpenChannelInput.js +32 -35
  113. package/OpenChannel/components/OpenChannelInput.js.map +1 -1
  114. package/OpenChannel/components/OpenChannelMessage.js +170 -171
  115. package/OpenChannel/components/OpenChannelMessage.js.map +1 -1
  116. package/OpenChannel/components/OpenChannelMessageList.js +70 -64
  117. package/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
  118. package/OpenChannel/components/OpenChannelUI.js +53 -54
  119. package/OpenChannel/components/OpenChannelUI.js.map +1 -1
  120. package/OpenChannel/context.js +8 -9
  121. package/OpenChannel/context.js.map +1 -1
  122. package/OpenChannel.js +37 -35
  123. package/OpenChannel.js.map +1 -1
  124. package/OpenChannelList/components/OpenChannelListUI.js +63 -61
  125. package/OpenChannelList/components/OpenChannelListUI.js.map +1 -1
  126. package/OpenChannelList/components/OpenChannelPreview.js +22 -21
  127. package/OpenChannelList/components/OpenChannelPreview.js.map +1 -1
  128. package/OpenChannelList/context.js +3 -3
  129. package/OpenChannelList.js +27 -27
  130. package/OpenChannelList.js.map +1 -1
  131. package/{OpenChannelListProvider-a0a09f0b.js → OpenChannelListProvider-24e735a1.js} +156 -178
  132. package/{OpenChannelListProvider-a0a09f0b.js.map → OpenChannelListProvider-24e735a1.js.map} +1 -1
  133. package/OpenChannelProvider-e9cb0f98.js +1850 -0
  134. package/{OpenChannelProvider-3e4b8c8e.js.map → OpenChannelProvider-e9cb0f98.js.map} +1 -1
  135. package/OpenChannelSettings/components/EditDetailsModal.js +52 -51
  136. package/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
  137. package/OpenChannelSettings/components/OpenChannelProfile.js +30 -29
  138. package/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
  139. package/OpenChannelSettings/components/OpenChannelSettingsUI.js +39 -47
  140. package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
  141. package/OpenChannelSettings/components/OperatorUI.js +550 -518
  142. package/OpenChannelSettings/components/OperatorUI.js.map +1 -1
  143. package/OpenChannelSettings/components/ParticipantUI.js +16 -15
  144. package/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
  145. package/OpenChannelSettings/context.js +58 -57
  146. package/OpenChannelSettings/context.js.map +1 -1
  147. package/OpenChannelSettings.js +20 -19
  148. package/OpenChannelSettings.js.map +1 -1
  149. package/README.md +4 -4
  150. package/RemoveMessageModal-f0cd37a5.js +33 -0
  151. package/RemoveMessageModal-f0cd37a5.js.map +1 -0
  152. package/SendbirdProvider.js +726 -690
  153. package/SendbirdProvider.js.map +1 -1
  154. package/Thread/components/ParentMessageInfo.js +194 -181
  155. package/Thread/components/ParentMessageInfo.js.map +1 -1
  156. package/Thread/components/ParentMessageInfoItem.js +86 -79
  157. package/Thread/components/ParentMessageInfoItem.js.map +1 -1
  158. package/Thread/components/ThreadHeader.js +22 -22
  159. package/Thread/components/ThreadHeader.js.map +1 -1
  160. package/Thread/components/ThreadList.js +126 -94
  161. package/Thread/components/ThreadList.js.map +1 -1
  162. package/Thread/components/ThreadListItem.js +260 -241
  163. package/Thread/components/ThreadListItem.js.map +1 -1
  164. package/Thread/components/ThreadMessageInput.js +121 -120
  165. package/Thread/components/ThreadMessageInput.js.map +1 -1
  166. package/Thread/components/ThreadUI.js +128 -144
  167. package/Thread/components/ThreadUI.js.map +1 -1
  168. package/Thread/context/types.js +9 -9
  169. package/Thread/context/types.js.map +1 -1
  170. package/Thread/context.js +1678 -19
  171. package/Thread/context.js.map +1 -1
  172. package/Thread.js +76 -73
  173. package/Thread.js.map +1 -1
  174. package/UserProfileContext-26e71f9a.js +34 -0
  175. package/UserProfileContext-26e71f9a.js.map +1 -0
  176. package/VoicePlayer/context.js +3 -3
  177. package/VoicePlayer/useVoicePlayer.js +52 -46
  178. package/VoicePlayer/useVoicePlayer.js.map +1 -1
  179. package/VoiceRecorder/context.js +68 -64
  180. package/VoiceRecorder/context.js.map +1 -1
  181. package/VoiceRecorder/useVoiceRecorder.js +50 -52
  182. package/VoiceRecorder/useVoiceRecorder.js.map +1 -1
  183. package/{WebAudioUtils-f9386235.js → WebAudioUtils-dbb010a5.js} +38 -38
  184. package/{WebAudioUtils-f9386235.js.map → WebAudioUtils-dbb010a5.js.map} +1 -1
  185. package/{_rollupPluginBabelHelpers-50c9576f.js → _rollupPluginBabelHelpers-07dcbc2b.js} +17 -17
  186. package/_rollupPluginBabelHelpers-07dcbc2b.js.map +1 -0
  187. package/{actionTypes-501b8c11.js → actionTypes-3cd49b5c.js} +2 -2
  188. package/{actionTypes-501b8c11.js.map → actionTypes-3cd49b5c.js.map} +1 -1
  189. package/cjs/App.js +270 -344
  190. package/cjs/App.js.map +1 -1
  191. package/cjs/Channel/components/ChannelHeader.js +44 -49
  192. package/cjs/Channel/components/ChannelHeader.js.map +1 -1
  193. package/cjs/Channel/components/ChannelUI.js +79 -80
  194. package/cjs/Channel/components/ChannelUI.js.map +1 -1
  195. package/cjs/Channel/components/FileViewer.js +52 -57
  196. package/cjs/Channel/components/FileViewer.js.map +1 -1
  197. package/cjs/Channel/components/FrozenNotification.js +9 -12
  198. package/cjs/Channel/components/FrozenNotification.js.map +1 -1
  199. package/cjs/Channel/components/Message.js +197 -175
  200. package/cjs/Channel/components/Message.js.map +1 -1
  201. package/cjs/Channel/components/MessageInput.js +136 -129
  202. package/cjs/Channel/components/MessageInput.js.map +1 -1
  203. package/cjs/Channel/components/MessageList.js +173 -163
  204. package/cjs/Channel/components/MessageList.js.map +1 -1
  205. package/cjs/Channel/components/RemoveMessageModal.js +41 -42
  206. package/cjs/Channel/components/RemoveMessageModal.js.map +1 -1
  207. package/cjs/Channel/components/SuggestedMentionList.js +155 -135
  208. package/cjs/Channel/components/SuggestedMentionList.js.map +1 -1
  209. package/cjs/Channel/components/TypingIndicator.js +46 -47
  210. package/cjs/Channel/components/TypingIndicator.js.map +1 -1
  211. package/cjs/Channel/components/UnreadCount.js +17 -18
  212. package/cjs/Channel/components/UnreadCount.js.map +1 -1
  213. package/cjs/Channel/context.js +17 -17
  214. package/cjs/Channel/utils/compareMessagesForGrouping.js +11 -11
  215. package/cjs/Channel/utils/compareMessagesForGrouping.js.map +1 -1
  216. package/cjs/Channel/utils/getMessagePartsInfo.js +32 -26
  217. package/cjs/Channel/utils/getMessagePartsInfo.js.map +1 -1
  218. package/cjs/Channel.js +54 -51
  219. package/cjs/Channel.js.map +1 -1
  220. package/cjs/ChannelList/components/AddChannel.js +31 -29
  221. package/cjs/ChannelList/components/AddChannel.js.map +1 -1
  222. package/cjs/ChannelList/components/ChannelListHeader.js +21 -30
  223. package/cjs/ChannelList/components/ChannelListHeader.js.map +1 -1
  224. package/cjs/ChannelList/components/ChannelListUI.js +96 -91
  225. package/cjs/ChannelList/components/ChannelListUI.js.map +1 -1
  226. package/cjs/ChannelList/components/ChannelPreview.js +78 -74
  227. package/cjs/ChannelList/components/ChannelPreview.js.map +1 -1
  228. package/cjs/ChannelList/components/ChannelPreviewAction.js +84 -91
  229. package/cjs/ChannelList/components/ChannelPreviewAction.js.map +1 -1
  230. package/cjs/ChannelList/context.js +9 -10
  231. package/cjs/ChannelList/context.js.map +1 -1
  232. package/cjs/ChannelList.js +38 -35
  233. package/cjs/ChannelList.js.map +1 -1
  234. package/cjs/ChannelListProvider-a418de2e.js +1060 -0
  235. package/cjs/ChannelListProvider-a418de2e.js.map +1 -0
  236. package/cjs/ChannelProvider-7fa98120.js +2088 -0
  237. package/cjs/ChannelProvider-7fa98120.js.map +1 -0
  238. package/cjs/ChannelSettings/components/ChannelProfile.js +41 -36
  239. package/cjs/ChannelSettings/components/ChannelProfile.js.map +1 -1
  240. package/cjs/ChannelSettings/components/ChannelSettingsUI.js +44 -47
  241. package/cjs/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
  242. package/cjs/ChannelSettings/components/EditDetailsModal.js +54 -52
  243. package/cjs/ChannelSettings/components/EditDetailsModal.js.map +1 -1
  244. package/cjs/ChannelSettings/components/LeaveChannel.js +38 -40
  245. package/cjs/ChannelSettings/components/LeaveChannel.js.map +1 -1
  246. package/cjs/ChannelSettings/components/ModerationPanel.js +559 -516
  247. package/cjs/ChannelSettings/components/ModerationPanel.js.map +1 -1
  248. package/cjs/ChannelSettings/components/UserListItem.js +66 -66
  249. package/cjs/ChannelSettings/components/UserListItem.js.map +1 -1
  250. package/cjs/ChannelSettings/components/UserPanel.js +29 -26
  251. package/cjs/ChannelSettings/components/UserPanel.js.map +1 -1
  252. package/cjs/ChannelSettings/context.js +51 -56
  253. package/cjs/ChannelSettings/context.js.map +1 -1
  254. package/cjs/ChannelSettings.js +20 -19
  255. package/cjs/ChannelSettings.js.map +1 -1
  256. package/cjs/CreateChannel/components/CreateChannelUI.js +23 -25
  257. package/cjs/CreateChannel/components/CreateChannelUI.js.map +1 -1
  258. package/cjs/CreateChannel/components/InviteUsers.js +106 -102
  259. package/cjs/CreateChannel/components/InviteUsers.js.map +1 -1
  260. package/cjs/CreateChannel/components/SelectChannelType.js +37 -42
  261. package/cjs/CreateChannel/components/SelectChannelType.js.map +1 -1
  262. package/cjs/CreateChannel/context.js +4 -4
  263. package/cjs/CreateChannel.js +22 -23
  264. package/cjs/CreateChannel.js.map +1 -1
  265. package/cjs/CreateChannelProvider-70c9cb7c.js +55 -0
  266. package/cjs/{CreateChannelProvider-8b8a557c.js.map → CreateChannelProvider-70c9cb7c.js.map} +1 -1
  267. package/cjs/CreateOpenChannel/components/CreateOpenChannelUI.js +39 -37
  268. package/cjs/CreateOpenChannel/components/CreateOpenChannelUI.js.map +1 -1
  269. package/cjs/CreateOpenChannel/context.js +28 -33
  270. package/cjs/CreateOpenChannel/context.js.map +1 -1
  271. package/cjs/CreateOpenChannel.js +20 -21
  272. package/cjs/CreateOpenChannel.js.map +1 -1
  273. package/cjs/EditUserProfile/components/EditUserProfileUI.js +153 -22
  274. package/cjs/EditUserProfile/components/EditUserProfileUI.js.map +1 -1
  275. package/cjs/EditUserProfile/context.js +13 -13
  276. package/cjs/EditUserProfile/context.js.map +1 -1
  277. package/cjs/EditUserProfile.js +21 -21
  278. package/cjs/EditUserProfile.js.map +1 -1
  279. package/cjs/{LocalizationContext-482c1343.js → LocalizationContext-5009012e.js} +9 -9
  280. package/cjs/{LocalizationContext-482c1343.js.map → LocalizationContext-5009012e.js.map} +1 -1
  281. package/cjs/MediaQueryContext-d6fdbe43.js +92 -0
  282. package/cjs/MediaQueryContext-d6fdbe43.js.map +1 -0
  283. package/cjs/MemberList-529a0086.js +428 -0
  284. package/cjs/{MemberList-26b8de48.js.map → MemberList-529a0086.js.map} +1 -1
  285. package/cjs/Message/context.js +11 -12
  286. package/cjs/Message/context.js.map +1 -1
  287. package/cjs/Message/hooks/useDirtyGetMentions.js +21 -26
  288. package/cjs/Message/hooks/useDirtyGetMentions.js.map +1 -1
  289. package/cjs/MessageSearch/components/MessageSearchUI.js +60 -65
  290. package/cjs/MessageSearch/components/MessageSearchUI.js.map +1 -1
  291. package/cjs/MessageSearch/context.js +165 -176
  292. package/cjs/MessageSearch/context.js.map +1 -1
  293. package/cjs/MessageSearch.js +49 -47
  294. package/cjs/MessageSearch.js.map +1 -1
  295. package/cjs/OpenChannel/components/FrozenChannelNotification.js +6 -8
  296. package/cjs/OpenChannel/components/FrozenChannelNotification.js.map +1 -1
  297. package/cjs/OpenChannel/components/OpenChannelHeader.js +22 -27
  298. package/cjs/OpenChannel/components/OpenChannelHeader.js.map +1 -1
  299. package/cjs/OpenChannel/components/OpenChannelInput.js +32 -35
  300. package/cjs/OpenChannel/components/OpenChannelInput.js.map +1 -1
  301. package/cjs/OpenChannel/components/OpenChannelMessage.js +169 -170
  302. package/cjs/OpenChannel/components/OpenChannelMessage.js.map +1 -1
  303. package/cjs/OpenChannel/components/OpenChannelMessageList.js +69 -63
  304. package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
  305. package/cjs/OpenChannel/components/OpenChannelUI.js +56 -57
  306. package/cjs/OpenChannel/components/OpenChannelUI.js.map +1 -1
  307. package/cjs/OpenChannel/context.js +8 -9
  308. package/cjs/OpenChannel/context.js.map +1 -1
  309. package/cjs/OpenChannel.js +37 -35
  310. package/cjs/OpenChannel.js.map +1 -1
  311. package/cjs/OpenChannelList/components/OpenChannelListUI.js +66 -64
  312. package/cjs/OpenChannelList/components/OpenChannelListUI.js.map +1 -1
  313. package/cjs/OpenChannelList/components/OpenChannelPreview.js +22 -21
  314. package/cjs/OpenChannelList/components/OpenChannelPreview.js.map +1 -1
  315. package/cjs/OpenChannelList/context.js +3 -3
  316. package/cjs/OpenChannelList.js +27 -27
  317. package/cjs/OpenChannelList.js.map +1 -1
  318. package/cjs/OpenChannelListProvider-0b8cd3bf.js +416 -0
  319. package/cjs/{OpenChannelListProvider-2e3ee48d.js.map → OpenChannelListProvider-0b8cd3bf.js.map} +1 -1
  320. package/cjs/OpenChannelProvider-d8cc11fe.js +1859 -0
  321. package/cjs/{OpenChannelProvider-8577ea58.js.map → OpenChannelProvider-d8cc11fe.js.map} +1 -1
  322. package/cjs/OpenChannelSettings/components/EditDetailsModal.js +53 -52
  323. package/cjs/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
  324. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js +29 -28
  325. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
  326. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js +40 -48
  327. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
  328. package/cjs/OpenChannelSettings/components/OperatorUI.js +557 -525
  329. package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -1
  330. package/cjs/OpenChannelSettings/components/ParticipantUI.js +16 -15
  331. package/cjs/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
  332. package/cjs/OpenChannelSettings/context.js +57 -56
  333. package/cjs/OpenChannelSettings/context.js.map +1 -1
  334. package/cjs/OpenChannelSettings.js +20 -19
  335. package/cjs/OpenChannelSettings.js.map +1 -1
  336. package/cjs/RemoveMessageModal-f029d40e.js +39 -0
  337. package/cjs/RemoveMessageModal-f029d40e.js.map +1 -0
  338. package/cjs/SendbirdProvider.js +733 -693
  339. package/cjs/SendbirdProvider.js.map +1 -1
  340. package/cjs/Thread/components/ParentMessageInfo.js +193 -180
  341. package/cjs/Thread/components/ParentMessageInfo.js.map +1 -1
  342. package/cjs/Thread/components/ParentMessageInfoItem.js +86 -79
  343. package/cjs/Thread/components/ParentMessageInfoItem.js.map +1 -1
  344. package/cjs/Thread/components/ThreadHeader.js +22 -22
  345. package/cjs/Thread/components/ThreadHeader.js.map +1 -1
  346. package/cjs/Thread/components/ThreadList.js +125 -93
  347. package/cjs/Thread/components/ThreadList.js.map +1 -1
  348. package/cjs/Thread/components/ThreadListItem.js +263 -244
  349. package/cjs/Thread/components/ThreadListItem.js.map +1 -1
  350. package/cjs/Thread/components/ThreadMessageInput.js +120 -119
  351. package/cjs/Thread/components/ThreadMessageInput.js.map +1 -1
  352. package/cjs/Thread/components/ThreadUI.js +134 -150
  353. package/cjs/Thread/components/ThreadUI.js.map +1 -1
  354. package/cjs/Thread/context/types.js +9 -13
  355. package/cjs/Thread/context/types.js.map +1 -1
  356. package/cjs/Thread/context.js +1680 -21
  357. package/cjs/Thread/context.js.map +1 -1
  358. package/cjs/Thread.js +76 -73
  359. package/cjs/Thread.js.map +1 -1
  360. package/cjs/UserProfileContext-922a43ec.js +41 -0
  361. package/cjs/UserProfileContext-922a43ec.js.map +1 -0
  362. package/cjs/VoicePlayer/context.js +3 -3
  363. package/cjs/VoicePlayer/useVoicePlayer.js +52 -46
  364. package/cjs/VoicePlayer/useVoicePlayer.js.map +1 -1
  365. package/cjs/VoiceRecorder/context.js +67 -63
  366. package/cjs/VoiceRecorder/context.js.map +1 -1
  367. package/cjs/VoiceRecorder/useVoiceRecorder.js +49 -51
  368. package/cjs/VoiceRecorder/useVoiceRecorder.js.map +1 -1
  369. package/cjs/{WebAudioUtils-142344fd.js → WebAudioUtils-29717597.js} +38 -38
  370. package/cjs/{WebAudioUtils-142344fd.js.map → WebAudioUtils-29717597.js.map} +1 -1
  371. package/cjs/{_rollupPluginBabelHelpers-83d7e84b.js → _rollupPluginBabelHelpers-94c18dc1.js} +16 -17
  372. package/cjs/_rollupPluginBabelHelpers-94c18dc1.js.map +1 -0
  373. package/cjs/{actionTypes-1d118952.js → actionTypes-7fa02f94.js} +2 -2
  374. package/cjs/{actionTypes-1d118952.js.map → actionTypes-7fa02f94.js.map} +1 -1
  375. package/cjs/{color-d83b77ac.js → color-477ddbd4.js} +12 -13
  376. package/cjs/color-477ddbd4.js.map +1 -0
  377. package/cjs/{compareIds-bef997cb.js → compareIds-de541666.js} +7 -6
  378. package/cjs/compareIds-de541666.js.map +1 -0
  379. package/cjs/{const-1726bde0.js → const-640252c1.js} +4 -4
  380. package/cjs/{const-1726bde0.js.map → const-640252c1.js.map} +1 -1
  381. package/cjs/const-9def5c09.js +19 -0
  382. package/cjs/{const-67ff9e34.js.map → const-9def5c09.js.map} +1 -1
  383. package/cjs/consts-54f5c12d.js +6 -0
  384. package/cjs/consts-54f5c12d.js.map +1 -0
  385. package/cjs/consts-85cd42fa.js +6 -0
  386. package/cjs/{consts-bf228385.js.map → consts-85cd42fa.js.map} +1 -1
  387. package/cjs/{consts-fb07c671.js → consts-95462b21.js} +18 -25
  388. package/cjs/{consts-fb07c671.js.map → consts-95462b21.js.map} +1 -1
  389. package/cjs/consts-a3b7ae99.js +6 -0
  390. package/cjs/{consts-d3b53f23.js.map → consts-a3b7ae99.js.map} +1 -1
  391. package/cjs/{context-bd2878ff.js → context-9814fafe.js} +5 -6
  392. package/cjs/{context-bd2878ff.js.map → context-9814fafe.js.map} +1 -1
  393. package/cjs/dist/index.css +110 -95
  394. package/cjs/dist/index.css.map +1 -1
  395. package/cjs/handlers/OpenChannelHandler.js.map +1 -1
  396. package/cjs/handlers/SessionHandler.js.map +1 -1
  397. package/cjs/hooks/useModal.js +84 -0
  398. package/cjs/hooks/useModal.js.map +1 -0
  399. package/cjs/{index-81baccd0.js → index-0a25b9b2.js} +166 -154
  400. package/cjs/index-0a25b9b2.js.map +1 -0
  401. package/cjs/index-0ec5a831.js +308 -0
  402. package/cjs/{index-1f6b30ea.js.map → index-0ec5a831.js.map} +1 -1
  403. package/cjs/{index-18720f0d.js → index-35820a94.js} +2 -2
  404. package/cjs/{index-18720f0d.js.map → index-35820a94.js.map} +1 -1
  405. package/cjs/index-609b07a2.js +7 -0
  406. package/cjs/index-609b07a2.js.map +1 -0
  407. package/cjs/index-6b0644d7.js +369 -0
  408. package/cjs/index-6b0644d7.js.map +1 -0
  409. package/cjs/{index-857630c5.js → index-7b0c6630.js} +104 -114
  410. package/cjs/index-7b0c6630.js.map +1 -0
  411. package/cjs/index-80a11b6a.js +197 -0
  412. package/cjs/{index-6ab9a40d.js.map → index-80a11b6a.js.map} +1 -1
  413. package/cjs/{index-4eb7e2b5.js → index-826b76d5.js} +2 -4
  414. package/cjs/index-826b76d5.js.map +1 -0
  415. package/cjs/{index-11f9cc0f.js → index-83d2aed9.js} +3 -12
  416. package/cjs/index-83d2aed9.js.map +1 -0
  417. package/cjs/index-aeb36f01.js +173 -0
  418. package/cjs/index-aeb36f01.js.map +1 -0
  419. package/cjs/{index-c9b003b3.js → index-b6d51e74.js} +56 -193
  420. package/cjs/index-b6d51e74.js.map +1 -0
  421. package/cjs/index-b995f638.js +741 -0
  422. package/cjs/index-b995f638.js.map +1 -0
  423. package/cjs/{index-759f2a26.js → index-bdf7089c.js} +72 -80
  424. package/cjs/{index-759f2a26.js.map → index-bdf7089c.js.map} +1 -1
  425. package/cjs/{index-7c374c20.js → index-c22e0cbf.js} +25 -28
  426. package/cjs/{index-7c374c20.js.map → index-c22e0cbf.js.map} +1 -1
  427. package/cjs/index-daf80c58.js +20 -0
  428. package/cjs/index-daf80c58.js.map +1 -0
  429. package/cjs/index-e81e2882.js +59 -0
  430. package/cjs/{index-2ab19f9b.js.map → index-e81e2882.js.map} +1 -1
  431. package/cjs/{index-91b4af96.js → index-ee3bf381.js} +39 -37
  432. package/cjs/{index-91b4af96.js.map → index-ee3bf381.js.map} +1 -1
  433. package/cjs/{index-d04f312e.js → index-fd8a0abb.js} +10 -30
  434. package/cjs/index-fd8a0abb.js.map +1 -0
  435. package/cjs/index.js +66 -63
  436. package/cjs/index.js.map +1 -1
  437. package/cjs/lame.all.js.map +1 -1
  438. package/cjs/package.json +2 -49
  439. package/cjs/{topics-adde627b.js → pubSub/topics.js} +6 -2
  440. package/cjs/pubSub/topics.js.map +1 -0
  441. package/cjs/{resolvedReplyType-85b4bd7c.js → resolvedReplyType-c20ef661.js} +1 -1
  442. package/cjs/{resolvedReplyType-85b4bd7c.js.map → resolvedReplyType-c20ef661.js.map} +1 -1
  443. package/cjs/sendbirdSelectors.js +381 -332
  444. package/cjs/sendbirdSelectors.js.map +1 -1
  445. package/cjs/stringFormatterUtils-e324636c.js +16 -0
  446. package/cjs/{stringFormatterUtils-8d6592ca.js.map → stringFormatterUtils-e324636c.js.map} +1 -1
  447. package/cjs/{stringSet-d00535a5.js → stringSet-98b52c49.js} +9 -2
  448. package/cjs/stringSet-98b52c49.js.map +1 -0
  449. package/cjs/{tokenize-9296fc47.js → tokenize-91bdbeb0.js} +56 -61
  450. package/cjs/{tokenize-9296fc47.js.map → tokenize-91bdbeb0.js.map} +1 -1
  451. package/cjs/tslib.es6-2f2b0bca.js +102 -0
  452. package/cjs/tslib.es6-2f2b0bca.js.map +1 -0
  453. package/cjs/types-31ed2276.js +11 -0
  454. package/cjs/types-31ed2276.js.map +1 -0
  455. package/cjs/types-66554668.js +15 -0
  456. package/cjs/types-66554668.js.map +1 -0
  457. package/cjs/ui/Accordion.js +18 -19
  458. package/cjs/ui/Accordion.js.map +1 -1
  459. package/cjs/ui/AccordionGroup.js +11 -10
  460. package/cjs/ui/AccordionGroup.js.map +1 -1
  461. package/cjs/ui/AdminMessage.js +10 -10
  462. package/cjs/ui/AdminMessage.js.map +1 -1
  463. package/cjs/ui/Avatar.js +59 -55
  464. package/cjs/ui/Avatar.js.map +1 -1
  465. package/cjs/ui/Badge.js +15 -16
  466. package/cjs/ui/Badge.js.map +1 -1
  467. package/cjs/ui/BottomSheet.js +15 -17
  468. package/cjs/ui/BottomSheet.js.map +1 -1
  469. package/cjs/ui/Button.js +31 -33
  470. package/cjs/ui/Button.js.map +1 -1
  471. package/cjs/ui/ChannelAvatar.js +41 -38
  472. package/cjs/ui/ChannelAvatar.js.map +1 -1
  473. package/cjs/ui/Checkbox.js +10 -9
  474. package/cjs/ui/Checkbox.js.map +1 -1
  475. package/cjs/ui/ConnectionStatus.js +5 -7
  476. package/cjs/ui/ConnectionStatus.js.map +1 -1
  477. package/cjs/ui/ContextMenu.js +143 -144
  478. package/cjs/ui/ContextMenu.js.map +1 -1
  479. package/cjs/ui/DateSeparator.js +14 -12
  480. package/cjs/ui/DateSeparator.js.map +1 -1
  481. package/cjs/ui/EmojiReactions.js +206 -176
  482. package/cjs/ui/EmojiReactions.js.map +1 -1
  483. package/cjs/ui/FileMessageItemBody.js +23 -23
  484. package/cjs/ui/FileMessageItemBody.js.map +1 -1
  485. package/cjs/ui/FileViewer.js +14 -12
  486. package/cjs/ui/FileViewer.js.map +1 -1
  487. package/cjs/ui/Icon.js +16 -16
  488. package/cjs/ui/Icon.js.map +1 -1
  489. package/cjs/ui/IconButton.js +28 -20
  490. package/cjs/ui/IconButton.js.map +1 -1
  491. package/cjs/ui/ImageRenderer.js +84 -64
  492. package/cjs/ui/ImageRenderer.js.map +1 -1
  493. package/cjs/ui/Input.js +14 -16
  494. package/cjs/ui/Input.js.map +1 -1
  495. package/cjs/ui/Label.js +2 -2
  496. package/cjs/ui/LinkLabel.js +2 -2
  497. package/cjs/ui/LinkLabel.js.map +1 -1
  498. package/cjs/ui/Loader.js +12 -10
  499. package/cjs/ui/Loader.js.map +1 -1
  500. package/cjs/ui/MentionLabel.js +63 -59
  501. package/cjs/ui/MentionLabel.js.map +1 -1
  502. package/cjs/ui/MentionUserLabel.js +10 -10
  503. package/cjs/ui/MentionUserLabel.js.map +1 -1
  504. package/cjs/ui/MessageContent.js +187 -171
  505. package/cjs/ui/MessageContent.js.map +1 -1
  506. package/cjs/ui/MessageInput/hooks/usePaste.js +5 -4
  507. package/cjs/ui/MessageInput/hooks/usePaste.js.map +1 -1
  508. package/cjs/ui/MessageInput.js +55 -57
  509. package/cjs/ui/MessageInput.js.map +1 -1
  510. package/cjs/ui/MessageItemMenu.js +93 -72
  511. package/cjs/ui/MessageItemMenu.js.map +1 -1
  512. package/cjs/ui/MessageItemReactionMenu.js +64 -56
  513. package/cjs/ui/MessageItemReactionMenu.js.map +1 -1
  514. package/cjs/ui/MessageSearchFileItem.js +40 -49
  515. package/cjs/ui/MessageSearchFileItem.js.map +1 -1
  516. package/cjs/ui/MessageSearchItem.js +32 -40
  517. package/cjs/ui/MessageSearchItem.js.map +1 -1
  518. package/cjs/ui/MessageStatus.js +11 -11
  519. package/cjs/ui/Modal.js +57 -59
  520. package/cjs/ui/Modal.js.map +1 -1
  521. package/cjs/ui/MutedAvatarOverlay.js +10 -10
  522. package/cjs/ui/MutedAvatarOverlay.js.map +1 -1
  523. package/cjs/ui/OGMessageItemBody.js +47 -47
  524. package/cjs/ui/OGMessageItemBody.js.map +1 -1
  525. package/cjs/ui/OpenChannelAdminMessage.js +7 -8
  526. package/cjs/ui/OpenChannelAdminMessage.js.map +1 -1
  527. package/cjs/ui/OpenChannelAvatar.js +17 -18
  528. package/cjs/ui/OpenChannelAvatar.js.map +1 -1
  529. package/cjs/ui/OpenchannelConversationHeader.js +13 -17
  530. package/cjs/ui/OpenchannelConversationHeader.js.map +1 -1
  531. package/cjs/ui/OpenchannelFileMessage.js +147 -139
  532. package/cjs/ui/OpenchannelFileMessage.js.map +1 -1
  533. package/cjs/ui/OpenchannelOGMessage.js +185 -178
  534. package/cjs/ui/OpenchannelOGMessage.js.map +1 -1
  535. package/cjs/ui/OpenchannelThumbnailMessage.js +220 -213
  536. package/cjs/ui/OpenchannelThumbnailMessage.js.map +1 -1
  537. package/cjs/ui/OpenchannelUserMessage.js +172 -164
  538. package/cjs/ui/OpenchannelUserMessage.js.map +1 -1
  539. package/cjs/ui/PlaceHolder.js +108 -10
  540. package/cjs/ui/PlaceHolder.js.map +1 -1
  541. package/cjs/ui/PlaybackTime.js +16 -15
  542. package/cjs/ui/PlaybackTime.js.map +1 -1
  543. package/cjs/ui/ProgressBar.js +15 -13
  544. package/cjs/ui/ProgressBar.js.map +1 -1
  545. package/cjs/ui/QuoteMessage.js +41 -44
  546. package/cjs/ui/QuoteMessage.js.map +1 -1
  547. package/cjs/ui/QuoteMessageInput.js +45 -31
  548. package/cjs/ui/QuoteMessageInput.js.map +1 -1
  549. package/cjs/ui/ReactionBadge.js +17 -13
  550. package/cjs/ui/ReactionBadge.js.map +1 -1
  551. package/cjs/ui/ReactionButton.js +19 -19
  552. package/cjs/ui/ReactionButton.js.map +1 -1
  553. package/cjs/ui/SortByRow.js +14 -14
  554. package/cjs/ui/SortByRow.js.map +1 -1
  555. package/cjs/ui/TextButton.js +21 -13
  556. package/cjs/ui/TextButton.js.map +1 -1
  557. package/cjs/ui/TextMessageItemBody.js +33 -31
  558. package/cjs/ui/TextMessageItemBody.js.map +1 -1
  559. package/cjs/ui/ThreadReplies.js +21 -25
  560. package/cjs/ui/ThreadReplies.js.map +1 -1
  561. package/cjs/ui/ThumbnailMessageItemBody.js +37 -28
  562. package/cjs/ui/ThumbnailMessageItemBody.js.map +1 -1
  563. package/cjs/ui/Toggle.js +85 -77
  564. package/cjs/ui/Toggle.js.map +1 -1
  565. package/cjs/ui/Tooltip.js +9 -8
  566. package/cjs/ui/Tooltip.js.map +1 -1
  567. package/cjs/ui/TooltipWrapper.js +18 -17
  568. package/cjs/ui/TooltipWrapper.js.map +1 -1
  569. package/cjs/ui/UnknownMessageItemBody.js +19 -20
  570. package/cjs/ui/UnknownMessageItemBody.js.map +1 -1
  571. package/cjs/ui/UserListItem.js +80 -75
  572. package/cjs/ui/UserListItem.js.map +1 -1
  573. package/cjs/ui/UserProfile.js +28 -33
  574. package/cjs/ui/UserProfile.js.map +1 -1
  575. package/cjs/ui/VoiceMessageItemBody.js +49 -43
  576. package/cjs/ui/VoiceMessageItemBody.js.map +1 -1
  577. package/cjs/ui/VoiceMessgeInput.js +8 -7
  578. package/cjs/ui/VoiceMessgeInput.js.map +1 -1
  579. package/cjs/ui/Word.js +29 -27
  580. package/cjs/ui/Word.js.map +1 -1
  581. package/cjs/{useHandleUploadFiles-b2fc56e5.js → useHandleUploadFiles-fbe6ad64.js} +114 -127
  582. package/cjs/useHandleUploadFiles-fbe6ad64.js.map +1 -0
  583. package/cjs/useLongPress-c1da8ba7.js +105 -0
  584. package/cjs/useLongPress-c1da8ba7.js.map +1 -0
  585. package/cjs/useSendMultipleFilesMessage-87e0ffa3.js +316 -0
  586. package/cjs/useSendMultipleFilesMessage-87e0ffa3.js.map +1 -0
  587. package/cjs/useSendbirdStateContext.js +8 -3
  588. package/cjs/useSendbirdStateContext.js.map +1 -1
  589. package/cjs/useStatefulFileInfoList-aa70b6b9.js +228 -0
  590. package/cjs/useStatefulFileInfoList-aa70b6b9.js.map +1 -0
  591. package/cjs/utils/message/getOutgoingMessageState.js +14 -16
  592. package/cjs/utils/message/getOutgoingMessageState.js.map +1 -1
  593. package/cjs/utils/message/isVoiceMessage.js +4 -4
  594. package/cjs/utils/message/isVoiceMessage.js.map +1 -1
  595. package/cjs/utils-0fac6ad1.js +27 -0
  596. package/cjs/utils-0fac6ad1.js.map +1 -0
  597. package/cjs/utils-180c6bc8.js +10 -0
  598. package/cjs/utils-180c6bc8.js.map +1 -0
  599. package/cjs/{utils-991911af.js → utils-46483130.js} +3 -3
  600. package/cjs/{utils-991911af.js.map → utils-46483130.js.map} +1 -1
  601. package/cjs/utils-55fc6797.js +170 -0
  602. package/cjs/utils-55fc6797.js.map +1 -0
  603. package/cjs/utils-851724e0.js +62 -0
  604. package/cjs/utils-851724e0.js.map +1 -0
  605. package/cjs/utils-e313131f.js +35 -0
  606. package/cjs/utils-e313131f.js.map +1 -0
  607. package/cjs/uuid-c74bbbb6.js +17 -0
  608. package/cjs/{uuid-b2806cf5.js.map → uuid-c74bbbb6.js.map} +1 -1
  609. package/cjs/withSendbird.js +16 -22
  610. package/cjs/withSendbird.js.map +1 -1
  611. package/{color-b7f211a8.js → color-1383d4ab.js} +5 -5
  612. package/{color-b7f211a8.js.map → color-1383d4ab.js.map} +1 -1
  613. package/compareIds-b56b02f1.js +16 -0
  614. package/compareIds-b56b02f1.js.map +1 -0
  615. package/{const-74ec9eb4.js → const-4bc3721f.js} +4 -4
  616. package/{const-74ec9eb4.js.map → const-4bc3721f.js.map} +1 -1
  617. package/const-e3326913.js +13 -0
  618. package/{const-711048c3.js.map → const-e3326913.js.map} +1 -1
  619. package/consts-7f4d53a3.js +4 -0
  620. package/consts-7f4d53a3.js.map +1 -0
  621. package/consts-833420ed.js +4 -0
  622. package/{consts-6ee24012.js.map → consts-833420ed.js.map} +1 -1
  623. package/consts-aa64aca8.js +30 -0
  624. package/{consts-691a3935.js.map → consts-aa64aca8.js.map} +1 -1
  625. package/consts-f0ba9b80.js +4 -0
  626. package/consts-f0ba9b80.js.map +1 -0
  627. package/context-ae47ac54.js +12 -0
  628. package/{context-b4c70964.js.map → context-ae47ac54.js.map} +1 -1
  629. package/dist/index.css +110 -95
  630. package/dist/index.css.map +1 -1
  631. package/handlers/OpenChannelHandler.js.map +1 -1
  632. package/handlers/SessionHandler.js.map +1 -1
  633. package/hooks/useModal.js +73 -0
  634. package/hooks/useModal.js.map +1 -0
  635. package/{index-aa520474.js → index-12103973.js} +2 -2
  636. package/{index-aa520474.js.map → index-12103973.js.map} +1 -1
  637. package/index-124a5766.js +298 -0
  638. package/{index-e15f6b6a.js.map → index-124a5766.js.map} +1 -1
  639. package/{index-13401b87.js → index-1432c287.js} +2 -4
  640. package/index-1432c287.js.map +1 -0
  641. package/{index-b22c4150.js → index-1969ccd8.js} +25 -28
  642. package/{index-b22c4150.js.map → index-1969ccd8.js.map} +1 -1
  643. package/index-3d508585.js +53 -0
  644. package/{index-ae7ef8cf.js.map → index-3d508585.js.map} +1 -1
  645. package/{index-8a01c364.js → index-40447645.js} +73 -81
  646. package/{index-8a01c364.js.map → index-40447645.js.map} +1 -1
  647. package/{index-c421b228.js → index-7a1085b6.js} +99 -109
  648. package/index-7a1085b6.js.map +1 -0
  649. package/index-89b3b8ba.js +362 -0
  650. package/index-89b3b8ba.js.map +1 -0
  651. package/index-8c72f0bd.js +182 -0
  652. package/{index-98138798.js.map → index-8c72f0bd.js.map} +1 -1
  653. package/index-942c5fa2.js +161 -0
  654. package/index-942c5fa2.js.map +1 -0
  655. package/index-c6095960.js +4 -0
  656. package/index-c6095960.js.map +1 -0
  657. package/index-c7ed4aef.js +13 -0
  658. package/index-c7ed4aef.js.map +1 -0
  659. package/{index-daa3ae67.js → index-c81fd6ec.js} +56 -193
  660. package/index-c81fd6ec.js.map +1 -0
  661. package/{index-7700a436.js → index-d3f61405.js} +10 -30
  662. package/index-d3f61405.js.map +1 -0
  663. package/{index-5cb32ab5.js → index-dc1827ea.js} +3 -12
  664. package/index-dc1827ea.js.map +1 -0
  665. package/{index-3530f4f6.js → index-ec0c048b.js} +39 -37
  666. package/{index-3530f4f6.js.map → index-ec0c048b.js.map} +1 -1
  667. package/{index-b25ffa7e.js → index-eec0ce47.js} +166 -154
  668. package/index-eec0ce47.js.map +1 -0
  669. package/index-fc1642cb.js +692 -0
  670. package/index-fc1642cb.js.map +1 -0
  671. package/index.d.ts +143 -79
  672. package/index.js +66 -63
  673. package/index.js.map +1 -1
  674. package/lame.all.js.map +1 -1
  675. package/package.json +3 -3
  676. package/{topics-5659403d.js → pubSub/topics.js} +4 -3
  677. package/pubSub/topics.js.map +1 -0
  678. package/{resolvedReplyType-1a128514.js → resolvedReplyType-0532593c.js} +1 -1
  679. package/{resolvedReplyType-1a128514.js.map → resolvedReplyType-0532593c.js.map} +1 -1
  680. package/sendbirdSelectors.js +381 -332
  681. package/sendbirdSelectors.js.map +1 -1
  682. package/stringFormatterUtils-444f6f4c.js +14 -0
  683. package/{stringFormatterUtils-dbad592d.js.map → stringFormatterUtils-444f6f4c.js.map} +1 -1
  684. package/{stringSet-2814bf17.js → stringSet-1106c8ec.js} +9 -2
  685. package/stringSet-1106c8ec.js.map +1 -0
  686. package/{tokenize-4b153552.js → tokenize-d17bf862.js} +56 -61
  687. package/{tokenize-4b153552.js.map → tokenize-d17bf862.js.map} +1 -1
  688. package/tslib.es6-0c779aab.js +97 -0
  689. package/tslib.es6-0c779aab.js.map +1 -0
  690. package/types-4ffc52f6.js +15 -0
  691. package/types-4ffc52f6.js.map +1 -0
  692. package/types-50e412d8.js +9 -0
  693. package/types-50e412d8.js.map +1 -0
  694. package/ui/Accordion.js +18 -19
  695. package/ui/Accordion.js.map +1 -1
  696. package/ui/AccordionGroup.js +11 -10
  697. package/ui/AccordionGroup.js.map +1 -1
  698. package/ui/AdminMessage.js +10 -10
  699. package/ui/AdminMessage.js.map +1 -1
  700. package/ui/Avatar.js +59 -55
  701. package/ui/Avatar.js.map +1 -1
  702. package/ui/Badge.js +15 -16
  703. package/ui/Badge.js.map +1 -1
  704. package/ui/BottomSheet.js +15 -17
  705. package/ui/BottomSheet.js.map +1 -1
  706. package/ui/Button.js +19 -26
  707. package/ui/Button.js.map +1 -1
  708. package/ui/ChannelAvatar.js +41 -38
  709. package/ui/ChannelAvatar.js.map +1 -1
  710. package/ui/Checkbox.js +10 -9
  711. package/ui/Checkbox.js.map +1 -1
  712. package/ui/ConnectionStatus.js +5 -7
  713. package/ui/ConnectionStatus.js.map +1 -1
  714. package/ui/ContextMenu.js +143 -144
  715. package/ui/ContextMenu.js.map +1 -1
  716. package/ui/DateSeparator.js +14 -12
  717. package/ui/DateSeparator.js.map +1 -1
  718. package/ui/EmojiReactions.js +207 -177
  719. package/ui/EmojiReactions.js.map +1 -1
  720. package/ui/FileMessageItemBody.js +23 -23
  721. package/ui/FileMessageItemBody.js.map +1 -1
  722. package/ui/FileViewer.js +14 -12
  723. package/ui/FileViewer.js.map +1 -1
  724. package/ui/Icon.js +2 -2
  725. package/ui/Icon.js.map +1 -1
  726. package/ui/IconButton.js +28 -20
  727. package/ui/IconButton.js.map +1 -1
  728. package/ui/ImageRenderer.js +84 -65
  729. package/ui/ImageRenderer.js.map +1 -1
  730. package/ui/Input.js +14 -16
  731. package/ui/Input.js.map +1 -1
  732. package/ui/Label.js +2 -2
  733. package/ui/LinkLabel.js +2 -2
  734. package/ui/LinkLabel.js.map +1 -1
  735. package/ui/Loader.js +12 -10
  736. package/ui/Loader.js.map +1 -1
  737. package/ui/MentionLabel.js +64 -60
  738. package/ui/MentionLabel.js.map +1 -1
  739. package/ui/MentionUserLabel.js +10 -10
  740. package/ui/MentionUserLabel.js.map +1 -1
  741. package/ui/MessageContent.js +186 -170
  742. package/ui/MessageContent.js.map +1 -1
  743. package/ui/MessageInput/hooks/usePaste.js +5 -4
  744. package/ui/MessageInput/hooks/usePaste.js.map +1 -1
  745. package/ui/MessageInput.js +48 -50
  746. package/ui/MessageInput.js.map +1 -1
  747. package/ui/MessageItemMenu.js +93 -72
  748. package/ui/MessageItemMenu.js.map +1 -1
  749. package/ui/MessageItemReactionMenu.js +64 -56
  750. package/ui/MessageItemReactionMenu.js.map +1 -1
  751. package/ui/MessageSearchFileItem.js +40 -49
  752. package/ui/MessageSearchFileItem.js.map +1 -1
  753. package/ui/MessageSearchItem.js +32 -40
  754. package/ui/MessageSearchItem.js.map +1 -1
  755. package/ui/MessageStatus.js +11 -11
  756. package/ui/Modal.js +57 -59
  757. package/ui/Modal.js.map +1 -1
  758. package/ui/MutedAvatarOverlay.js +10 -10
  759. package/ui/MutedAvatarOverlay.js.map +1 -1
  760. package/ui/OGMessageItemBody.js +47 -47
  761. package/ui/OGMessageItemBody.js.map +1 -1
  762. package/ui/OpenChannelAdminMessage.js +7 -8
  763. package/ui/OpenChannelAdminMessage.js.map +1 -1
  764. package/ui/OpenChannelAvatar.js +17 -18
  765. package/ui/OpenChannelAvatar.js.map +1 -1
  766. package/ui/OpenchannelConversationHeader.js +13 -17
  767. package/ui/OpenchannelConversationHeader.js.map +1 -1
  768. package/ui/OpenchannelFileMessage.js +147 -139
  769. package/ui/OpenchannelFileMessage.js.map +1 -1
  770. package/ui/OpenchannelOGMessage.js +185 -178
  771. package/ui/OpenchannelOGMessage.js.map +1 -1
  772. package/ui/OpenchannelThumbnailMessage.js +220 -213
  773. package/ui/OpenchannelThumbnailMessage.js.map +1 -1
  774. package/ui/OpenchannelUserMessage.js +172 -164
  775. package/ui/OpenchannelUserMessage.js.map +1 -1
  776. package/ui/PlaceHolder.js +106 -8
  777. package/ui/PlaceHolder.js.map +1 -1
  778. package/ui/PlaybackTime.js +16 -15
  779. package/ui/PlaybackTime.js.map +1 -1
  780. package/ui/ProgressBar.js +15 -13
  781. package/ui/ProgressBar.js.map +1 -1
  782. package/ui/QuoteMessage.js +41 -44
  783. package/ui/QuoteMessage.js.map +1 -1
  784. package/ui/QuoteMessageInput.js +45 -31
  785. package/ui/QuoteMessageInput.js.map +1 -1
  786. package/ui/ReactionBadge.js +17 -13
  787. package/ui/ReactionBadge.js.map +1 -1
  788. package/ui/ReactionButton.js +19 -19
  789. package/ui/ReactionButton.js.map +1 -1
  790. package/ui/SortByRow.js +14 -14
  791. package/ui/SortByRow.js.map +1 -1
  792. package/ui/TextButton.js +21 -13
  793. package/ui/TextButton.js.map +1 -1
  794. package/ui/TextMessageItemBody.js +33 -31
  795. package/ui/TextMessageItemBody.js.map +1 -1
  796. package/ui/ThreadReplies.js +21 -25
  797. package/ui/ThreadReplies.js.map +1 -1
  798. package/ui/ThumbnailMessageItemBody.js +37 -28
  799. package/ui/ThumbnailMessageItemBody.js.map +1 -1
  800. package/ui/Toggle.js +86 -78
  801. package/ui/Toggle.js.map +1 -1
  802. package/ui/Tooltip.js +9 -8
  803. package/ui/Tooltip.js.map +1 -1
  804. package/ui/TooltipWrapper.js +18 -17
  805. package/ui/TooltipWrapper.js.map +1 -1
  806. package/ui/UnknownMessageItemBody.js +19 -20
  807. package/ui/UnknownMessageItemBody.js.map +1 -1
  808. package/ui/UserListItem.js +80 -75
  809. package/ui/UserListItem.js.map +1 -1
  810. package/ui/UserProfile.js +29 -34
  811. package/ui/UserProfile.js.map +1 -1
  812. package/ui/VoiceMessageItemBody.js +49 -43
  813. package/ui/VoiceMessageItemBody.js.map +1 -1
  814. package/ui/VoiceMessgeInput.js +8 -7
  815. package/ui/VoiceMessgeInput.js.map +1 -1
  816. package/ui/Word.js +29 -27
  817. package/ui/Word.js.map +1 -1
  818. package/{useHandleUploadFiles-406a6c9c.js → useHandleUploadFiles-33aff88e.js} +111 -124
  819. package/useHandleUploadFiles-33aff88e.js.map +1 -0
  820. package/useLongPress-322bb6a3.js +103 -0
  821. package/useLongPress-322bb6a3.js.map +1 -0
  822. package/useSendMultipleFilesMessage-4489a0f6.js +283 -0
  823. package/useSendMultipleFilesMessage-4489a0f6.js.map +1 -0
  824. package/useSendbirdStateContext.js +5 -3
  825. package/useSendbirdStateContext.js.map +1 -1
  826. package/useStatefulFileInfoList-dd95f949.js +219 -0
  827. package/useStatefulFileInfoList-dd95f949.js.map +1 -0
  828. package/utils/message/getOutgoingMessageState.js +8 -9
  829. package/utils/message/getOutgoingMessageState.js.map +1 -1
  830. package/utils/message/isVoiceMessage.js +4 -4
  831. package/utils/message/isVoiceMessage.js.map +1 -1
  832. package/{utils-7cc92ac2.js → utils-158c1683.js} +3 -3
  833. package/{utils-7cc92ac2.js.map → utils-158c1683.js.map} +1 -1
  834. package/utils-3660243c.js +25 -0
  835. package/utils-3660243c.js.map +1 -0
  836. package/utils-40040f8e.js +157 -0
  837. package/utils-40040f8e.js.map +1 -0
  838. package/utils-48a3ef27.js +31 -0
  839. package/utils-48a3ef27.js.map +1 -0
  840. package/utils-74c161a0.js +7 -0
  841. package/utils-74c161a0.js.map +1 -0
  842. package/utils-e98a7f8c.js +57 -0
  843. package/utils-e98a7f8c.js.map +1 -0
  844. package/uuid-3c77ef7b.js +15 -0
  845. package/{uuid-16373bba.js.map → uuid-3c77ef7b.js.map} +1 -1
  846. package/withSendbird.js +16 -22
  847. package/withSendbird.js.map +1 -1
  848. package/ChannelListProvider-1188e373.js +0 -1028
  849. package/ChannelListProvider-1188e373.js.map +0 -1
  850. package/ChannelProvider-9de00431.js +0 -1933
  851. package/ChannelProvider-9de00431.js.map +0 -1
  852. package/CreateChannelProvider-a2fad282.js +0 -44
  853. package/LocalizationContext-2463058b.js +0 -20
  854. package/MediaQueryContext-e3429d12.js +0 -87
  855. package/MediaQueryContext-e3429d12.js.map +0 -1
  856. package/MemberList-593867cb.js +0 -404
  857. package/OpenChannelProvider-3e4b8c8e.js +0 -1890
  858. package/RemoveMessageModal-9162aebe.js +0 -38
  859. package/RemoveMessageModal-9162aebe.js.map +0 -1
  860. package/ThreadProvider-9a3b145f.js +0 -1778
  861. package/ThreadProvider-9a3b145f.js.map +0 -1
  862. package/UserProfileContext-4ae968eb.js +0 -41
  863. package/UserProfileContext-4ae968eb.js.map +0 -1
  864. package/_rollupPluginBabelHelpers-50c9576f.js.map +0 -1
  865. package/cjs/ChannelListProvider-e55e6242.js +0 -1037
  866. package/cjs/ChannelListProvider-e55e6242.js.map +0 -1
  867. package/cjs/ChannelProvider-6fa73019.js +0 -1941
  868. package/cjs/ChannelProvider-6fa73019.js.map +0 -1
  869. package/cjs/CreateChannelProvider-8b8a557c.js +0 -52
  870. package/cjs/MediaQueryContext-73aac8cf.js +0 -94
  871. package/cjs/MediaQueryContext-73aac8cf.js.map +0 -1
  872. package/cjs/MemberList-26b8de48.js +0 -410
  873. package/cjs/OpenChannelListProvider-2e3ee48d.js +0 -439
  874. package/cjs/OpenChannelProvider-8577ea58.js +0 -1899
  875. package/cjs/RemoveMessageModal-dfeeb36a.js +0 -44
  876. package/cjs/RemoveMessageModal-dfeeb36a.js.map +0 -1
  877. package/cjs/ThreadProvider-8b0cf491.js +0 -1787
  878. package/cjs/ThreadProvider-8b0cf491.js.map +0 -1
  879. package/cjs/UserProfileContext-fa8d0383.js +0 -49
  880. package/cjs/UserProfileContext-fa8d0383.js.map +0 -1
  881. package/cjs/_rollupPluginBabelHelpers-83d7e84b.js.map +0 -1
  882. package/cjs/color-d83b77ac.js.map +0 -1
  883. package/cjs/compareIds-bef997cb.js.map +0 -1
  884. package/cjs/const-67ff9e34.js +0 -20
  885. package/cjs/consts-b018b1ed.js +0 -6
  886. package/cjs/consts-b018b1ed.js.map +0 -1
  887. package/cjs/consts-bf228385.js +0 -6
  888. package/cjs/consts-d3b53f23.js +0 -6
  889. package/cjs/index-11f9cc0f.js.map +0 -1
  890. package/cjs/index-1a9fdbb4.js +0 -368
  891. package/cjs/index-1a9fdbb4.js.map +0 -1
  892. package/cjs/index-1f6b30ea.js +0 -330
  893. package/cjs/index-2ab19f9b.js +0 -57
  894. package/cjs/index-4b5a006d.js +0 -139
  895. package/cjs/index-4b5a006d.js.map +0 -1
  896. package/cjs/index-4eb7e2b5.js.map +0 -1
  897. package/cjs/index-56a25735.js +0 -171
  898. package/cjs/index-56a25735.js.map +0 -1
  899. package/cjs/index-6ab9a40d.js +0 -202
  900. package/cjs/index-7f41c4b6.js +0 -118
  901. package/cjs/index-7f41c4b6.js.map +0 -1
  902. package/cjs/index-81baccd0.js.map +0 -1
  903. package/cjs/index-857630c5.js.map +0 -1
  904. package/cjs/index-8ec12d1d.js +0 -164
  905. package/cjs/index-8ec12d1d.js.map +0 -1
  906. package/cjs/index-c9b003b3.js.map +0 -1
  907. package/cjs/index-cbcacbee.js +0 -9
  908. package/cjs/index-cbcacbee.js.map +0 -1
  909. package/cjs/index-d04f312e.js.map +0 -1
  910. package/cjs/index-e9ac5ae1.js +0 -58
  911. package/cjs/index-e9ac5ae1.js.map +0 -1
  912. package/cjs/index-fbe9cc73.js +0 -647
  913. package/cjs/index-fbe9cc73.js.map +0 -1
  914. package/cjs/index.module-a24e9cd7.js +0 -6
  915. package/cjs/index.module-a24e9cd7.js.map +0 -1
  916. package/cjs/stringFormatterUtils-8d6592ca.js +0 -16
  917. package/cjs/stringSet-d00535a5.js.map +0 -1
  918. package/cjs/topics-adde627b.js.map +0 -1
  919. package/cjs/types-0b5148cb.js +0 -17
  920. package/cjs/types-0b5148cb.js.map +0 -1
  921. package/cjs/useHandleUploadFiles-b2fc56e5.js.map +0 -1
  922. package/cjs/useLongPress-1c0f4696.js +0 -87
  923. package/cjs/useLongPress-1c0f4696.js.map +0 -1
  924. package/cjs/useSendMultipleFilesMessage-81cdc9d0.js +0 -109
  925. package/cjs/useSendMultipleFilesMessage-81cdc9d0.js.map +0 -1
  926. package/cjs/utils-418b4438.js +0 -62
  927. package/cjs/utils-418b4438.js.map +0 -1
  928. package/cjs/utils-5bfb4516.js +0 -35
  929. package/cjs/utils-5bfb4516.js.map +0 -1
  930. package/cjs/utils-68aa6bf6.js +0 -345
  931. package/cjs/utils-68aa6bf6.js.map +0 -1
  932. package/cjs/utils-b34d4e2c.js +0 -31
  933. package/cjs/utils-b34d4e2c.js.map +0 -1
  934. package/cjs/utils-c47c68b1.js +0 -6
  935. package/cjs/utils-c47c68b1.js.map +0 -1
  936. package/cjs/uuid-b2806cf5.js +0 -15
  937. package/compareIds-8ed6e36a.js +0 -15
  938. package/compareIds-8ed6e36a.js.map +0 -1
  939. package/const-711048c3.js +0 -13
  940. package/consts-675764c9.js +0 -4
  941. package/consts-675764c9.js.map +0 -1
  942. package/consts-691a3935.js +0 -37
  943. package/consts-6ee24012.js +0 -4
  944. package/consts-eb77e905.js +0 -4
  945. package/consts-eb77e905.js.map +0 -1
  946. package/context-b4c70964.js +0 -13
  947. package/index-128523eb.js +0 -110
  948. package/index-128523eb.js.map +0 -1
  949. package/index-13401b87.js.map +0 -1
  950. package/index-5cb32ab5.js.map +0 -1
  951. package/index-5d6a0f12.js +0 -598
  952. package/index-5d6a0f12.js.map +0 -1
  953. package/index-60a7bf91.js +0 -164
  954. package/index-60a7bf91.js.map +0 -1
  955. package/index-7700a436.js.map +0 -1
  956. package/index-7946293f.js +0 -152
  957. package/index-7946293f.js.map +0 -1
  958. package/index-7b7478f5.js +0 -132
  959. package/index-7b7478f5.js.map +0 -1
  960. package/index-82178c6a.js +0 -361
  961. package/index-82178c6a.js.map +0 -1
  962. package/index-98138798.js +0 -187
  963. package/index-98887e8d.js +0 -7
  964. package/index-98887e8d.js.map +0 -1
  965. package/index-ae7ef8cf.js +0 -51
  966. package/index-b25ffa7e.js.map +0 -1
  967. package/index-c421b228.js.map +0 -1
  968. package/index-d99155f7.js +0 -51
  969. package/index-d99155f7.js.map +0 -1
  970. package/index-daa3ae67.js.map +0 -1
  971. package/index-e15f6b6a.js +0 -320
  972. package/index.module-60af77d3.js +0 -4
  973. package/index.module-60af77d3.js.map +0 -1
  974. package/stringFormatterUtils-dbad592d.js +0 -14
  975. package/stringSet-2814bf17.js.map +0 -1
  976. package/topics-5659403d.js.map +0 -1
  977. package/types-89092633.js +0 -15
  978. package/types-89092633.js.map +0 -1
  979. package/useHandleUploadFiles-406a6c9c.js.map +0 -1
  980. package/useLongPress-5e1ad951.js +0 -85
  981. package/useLongPress-5e1ad951.js.map +0 -1
  982. package/useSendMultipleFilesMessage-a3a2c84b.js +0 -107
  983. package/useSendMultipleFilesMessage-a3a2c84b.js.map +0 -1
  984. package/utils-0c22998a.js +0 -306
  985. package/utils-0c22998a.js.map +0 -1
  986. package/utils-407da489.js +0 -4
  987. package/utils-407da489.js.map +0 -1
  988. package/utils-b97d5113.js +0 -57
  989. package/utils-b97d5113.js.map +0 -1
  990. package/utils-cae84d8a.js +0 -29
  991. package/utils-cae84d8a.js.map +0 -1
  992. package/utils-ebf008e2.js +0 -31
  993. package/utils-ebf008e2.js.map +0 -1
  994. package/uuid-16373bba.js +0 -13
@@ -1,1028 +0,0 @@
1
- import { _ as _objectSpread2 } from './_rollupPluginBabelHelpers-50c9576f.js';
2
- import React__default, { useEffect, useCallback, useReducer, useState, useMemo, useContext } from 'react';
3
- import { GroupChannelHandler } from '@sendbird/chat/groupChannel';
4
- import { P as PUBSUB_TOPICS } from './topics-5659403d.js';
5
- import { u as uuidv4 } from './uuid-16373bba.js';
6
- import { n as noop } from './utils-407da489.js';
7
- import { b as DELIVERY_RECEIPT } from './consts-691a3935.js';
8
- import { U as UserProfileProvider } from './UserProfileContext-4ae968eb.js';
9
- import useSendbirdStateContext from './useSendbirdStateContext.js';
10
- import { f as filterChannelListParams, g as getChannelsWithUpsertedChannel } from './index-5d6a0f12.js';
11
-
12
- const RESET_CHANNEL_LIST = 'RESET_CHANNEL_LIST';
13
- const CREATE_CHANNEL = 'CREATE_CHANNEL';
14
- const USER_INVITED = 'USER_INVITED';
15
- const LEAVE_CHANNEL_SUCCESS = 'LEAVE_CHANNEL_SUCCESS';
16
- const SET_CURRENT_CHANNEL = 'SET_CURRENT_CHANNEL';
17
- const FETCH_CHANNELS_START = 'FETCH_CHANNELS_START';
18
- const FETCH_CHANNELS_SUCCESS = 'FETCH_CHANNELS_SUCCESS';
19
- const FETCH_CHANNELS_FAILURE = 'FETCH_CHANNELS_FAILURE';
20
- const INIT_CHANNELS_START = 'INIT_CHANNELS_START';
21
- const INIT_CHANNELS_SUCCESS = 'INIT_CHANNELS_SUCCESS';
22
- const INIT_CHANNELS_FAILURE = 'INIT_CHANNELS_FAILURE';
23
- const ON_USER_JOINED = 'ON_USER_JOINED';
24
- const ON_CHANNEL_DELETED = 'ON_CHANNEL_DELETED';
25
- const ON_LAST_MESSAGE_UPDATED = 'ON_LAST_MESSAGE_UPDATED';
26
- const ON_USER_LEFT = 'ON_USER_LEFT';
27
- const ON_CHANNEL_CHANGED = 'ON_CHANNEL_CHANGED';
28
- const ON_CHANNEL_ARCHIVED = 'ON_CHANNEL_ARCHIVED';
29
- const ON_CHANNEL_FROZEN = 'ON_CHANNEL_FROZEN';
30
- const ON_CHANNEL_UNFROZEN = 'ON_CHANNEL_UNFROZEN';
31
- const ON_READ_RECEIPT_UPDATED = 'ON_READ_RECEIPT_UPDATED';
32
- const ON_DELIVERY_RECEIPT_UPDATED = 'ON_DELIVERY_RECEIPT_UPDATED';
33
- const CHANNEL_REPLACED_TO_TOP = 'CHANNEL_REPLACED_TO_TOP';
34
- const CHANNEL_LIST_PARAMS_UPDATED = 'CHANNEL_LIST_PARAMS_UPDATED';
35
-
36
- const DELIVERY_RECIPT = 'delivery_receipt';
37
- const createEventHandler = _ref => {
38
- let {
39
- sdk,
40
- sdkChannelHandlerId,
41
- channelListDispatcher,
42
- logger
43
- } = _ref;
44
- const ChannelHandler = new GroupChannelHandler({
45
- onChannelChanged: channel => {
46
- logger.info('ChannelList: onChannelChanged', channel);
47
- channelListDispatcher({
48
- type: ON_CHANNEL_CHANGED,
49
- payload: channel
50
- });
51
- },
52
- onChannelDeleted: channelUrl => {
53
- logger.info('ChannelList: onChannelDeleted', channelUrl);
54
- channelListDispatcher({
55
- type: ON_CHANNEL_DELETED,
56
- payload: channelUrl
57
- });
58
- },
59
- onUserJoined: channel => {
60
- logger.info('ChannelList: onUserJoined', channel);
61
- if (channel !== null && channel !== void 0 && channel.lastMessage) {
62
- channelListDispatcher({
63
- type: ON_USER_JOINED,
64
- payload: channel
65
- });
66
- }
67
- },
68
- onUserReceivedInvitation: (channel, inviter, invitees) => {
69
- logger.info('ChannelList: onUserReceivedInvitation', {
70
- channel,
71
- inviter,
72
- invitees
73
- });
74
- const {
75
- currentUser
76
- } = sdk;
77
- const isInvited = invitees.find(user => (user === null || user === void 0 ? void 0 : user.userId) === (currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId));
78
- // The newly created channel should be displayed only when there's a message
79
- if (isInvited && channel !== null && channel !== void 0 && channel.lastMessage) {
80
- channelListDispatcher({
81
- type: USER_INVITED,
82
- payload: channel
83
- });
84
- }
85
- },
86
- onUserBanned: (channel, user) => {
87
- const {
88
- currentUser
89
- } = sdk;
90
- logger.info('Channel: onUserBanned', channel);
91
- if (user.userId === currentUser.userId) {
92
- channelListDispatcher({
93
- type: ON_USER_LEFT,
94
- payload: {
95
- channel,
96
- isMe: true
97
- }
98
- });
99
- } else {
100
- channelListDispatcher({
101
- type: ON_USER_LEFT,
102
- payload: {
103
- channel,
104
- isMe: false
105
- }
106
- });
107
- }
108
- },
109
- onUserLeft: (channel, leftUser) => {
110
- const {
111
- currentUser
112
- } = sdk;
113
- const isMe = currentUser.userId === leftUser.userId;
114
- logger.info('ChannelList: onUserLeft', channel);
115
- channelListDispatcher({
116
- type: ON_USER_LEFT,
117
- payload: {
118
- channel,
119
- isMe
120
- }
121
- });
122
- },
123
- onUnreadMemberStatusUpdated: channel => {
124
- logger.info('ChannelList: onUnreadMemberStatusUpdated', channel);
125
- channelListDispatcher({
126
- type: ON_READ_RECEIPT_UPDATED,
127
- payload: channel
128
- });
129
- },
130
- onUndeliveredMemberStatusUpdated: channel => {
131
- logger.info('ChannelList: onUndeliveredMemberStatusUpdated', channel);
132
- if (channel !== null && channel !== void 0 && channel.lastMessage) {
133
- channelListDispatcher({
134
- type: ON_DELIVERY_RECEIPT_UPDATED,
135
- payload: channel
136
- });
137
- }
138
- },
139
- onMessageUpdated: (channel, message) => {
140
- if (channel !== null && channel !== void 0 && channel.lastMessage.isEqual(message)) {
141
- logger.info('ChannelList: onMessageUpdated', channel);
142
- channelListDispatcher({
143
- type: ON_LAST_MESSAGE_UPDATED,
144
- payload: channel
145
- });
146
- }
147
- },
148
- onChannelHidden: channel => {
149
- logger.info('ChannelList: onChannelHidden', channel);
150
- channelListDispatcher({
151
- type: ON_CHANNEL_ARCHIVED,
152
- payload: channel
153
- });
154
- },
155
- onChannelFrozen: channel => {
156
- logger.info('ChannelList: onChannelFrozen', channel);
157
- channelListDispatcher({
158
- type: ON_CHANNEL_FROZEN,
159
- payload: channel
160
- });
161
- },
162
- onChannelUnfrozen: channel => {
163
- logger.info('ChannelList: onChannelUnfrozen', channel);
164
- channelListDispatcher({
165
- type: ON_CHANNEL_UNFROZEN,
166
- payload: channel
167
- });
168
- }
169
- });
170
- logger.info('ChannelList: Added channelHandler');
171
- sdk.groupChannel.addGroupChannelHandler(sdkChannelHandlerId, ChannelHandler);
172
- };
173
- const createChannelListQuery = _ref2 => {
174
- let {
175
- sdk,
176
- userFilledChannelListQuery = {}
177
- } = _ref2;
178
- const param = {};
179
- param.includeEmpty = false;
180
- param.limit = 20; // The value of pagination limit could be set up to 100.
181
- param.order = 'latest_last_message'; // 'chronological', 'latest_last_message', 'channel_name_alphabetical', and 'metadata_value_alphabetical'
182
-
183
- if (userFilledChannelListQuery) {
184
- Object.keys(userFilledChannelListQuery).forEach(key => {
185
- param[key] = userFilledChannelListQuery[key];
186
- });
187
- }
188
- const channelListQuery = sdk.groupChannel.createMyGroupChannelListQuery(param);
189
- return channelListQuery;
190
- };
191
-
192
- /**
193
- * Setup event listener
194
- * create channel source query
195
- * addloading screen
196
- */
197
- function setupChannelList(_ref3) {
198
- let {
199
- sdk,
200
- sdkChannelHandlerId,
201
- channelListDispatcher,
202
- setChannelSource,
203
- onChannelSelect,
204
- userFilledChannelListQuery,
205
- logger,
206
- sortChannelList,
207
- disableAutoSelect,
208
- markAsDeliveredScheduler,
209
- disableMarkAsDelivered
210
- } = _ref3;
211
- if (sdk !== null && sdk !== void 0 && sdk.groupChannel) {
212
- createEventHandler({
213
- sdk,
214
- channelListDispatcher,
215
- sdkChannelHandlerId,
216
- logger
217
- });
218
- } else {
219
- logger.warning('ChannelList - createEventHandler: sdk or sdk.ChannelHandler does not exist', sdk);
220
- }
221
- logger.info('ChannelList - creating query', {
222
- userFilledChannelListQuery
223
- });
224
- const channelListQuery = createChannelListQuery({
225
- sdk,
226
- userFilledChannelListQuery
227
- });
228
- logger.info('ChannelList - created query', channelListQuery);
229
- setChannelSource(channelListQuery);
230
- channelListDispatcher({
231
- type: INIT_CHANNELS_START
232
- });
233
- if (userFilledChannelListQuery) {
234
- logger.info('ChannelList - setting up channelListQuery', channelListQuery);
235
- channelListDispatcher({
236
- type: CHANNEL_LIST_PARAMS_UPDATED,
237
- payload: {
238
- channelListQuery,
239
- currentUserId: sdk && sdk.currentUser && sdk.currentUser.userId
240
- }
241
- });
242
- }
243
- logger.info('ChannelList - fetching channels');
244
- if (channelListQuery.hasNext) {
245
- channelListQuery.next().then(channelList => {
246
- var _sdk$appInfo, _sdk$appInfo$premiumF;
247
- logger.info('ChannelList - fetched channels', channelList);
248
- // select first channel
249
- logger.info('ChannelList - highlight channel', channelList[0]);
250
- let sortedChannelList = channelList;
251
- if (sortChannelList && typeof sortChannelList === 'function') {
252
- sortedChannelList = sortChannelList(channelList);
253
- logger.info('ChannelList - channel list sorted', sortedChannelList);
254
- }
255
- if (!disableAutoSelect) {
256
- onChannelSelect(sortedChannelList[0]);
257
- }
258
- channelListDispatcher({
259
- type: INIT_CHANNELS_SUCCESS,
260
- payload: {
261
- channelList: sortedChannelList,
262
- disableAutoSelect
263
- }
264
- });
265
- const canSetMarkAsDelivered = sdk === null || sdk === void 0 ? void 0 : (_sdk$appInfo = sdk.appInfo) === null || _sdk$appInfo === void 0 ? void 0 : (_sdk$appInfo$premiumF = _sdk$appInfo.premiumFeatureList) === null || _sdk$appInfo$premiumF === void 0 ? void 0 : _sdk$appInfo$premiumF.find(feature => feature === DELIVERY_RECIPT);
266
- if (canSetMarkAsDelivered && !disableMarkAsDelivered) {
267
- sortedChannelList.forEach(channel => {
268
- markAsDeliveredScheduler.push(channel);
269
- });
270
- }
271
- }).catch(err => {
272
- if (err) {
273
- logger.error('ChannelList - couldnt fetch channels', err);
274
- channelListDispatcher({
275
- type: INIT_CHANNELS_FAILURE
276
- });
277
- }
278
- });
279
- } else {
280
- logger.info('ChannelList - there are no more channels');
281
- }
282
- }
283
- const pubSubHandleRemover = subscriber => {
284
- subscriber.forEach(s => {
285
- try {
286
- s.remove();
287
- } catch (_unused) {
288
- //
289
- }
290
- });
291
- };
292
- const pubSubHandler = (pubSub, channelListDispatcher) => {
293
- const subscriber = new Map();
294
- if (!pubSub) return subscriber;
295
- subscriber.set(PUBSUB_TOPICS.CREATE_CHANNEL, pubSub.subscribe(PUBSUB_TOPICS.CREATE_CHANNEL, msg => {
296
- const {
297
- channel
298
- } = msg;
299
- channelListDispatcher({
300
- type: 'CREATE_CHANNEL',
301
- payload: channel
302
- });
303
- }));
304
- subscriber.set(PUBSUB_TOPICS.UPDATE_USER_MESSAGE, pubSub.subscribe(PUBSUB_TOPICS.UPDATE_USER_MESSAGE, msg => {
305
- var _updatedChannel$lastM;
306
- const {
307
- channel,
308
- message
309
- } = msg;
310
- const updatedChannel = channel;
311
- if ((updatedChannel === null || updatedChannel === void 0 ? void 0 : (_updatedChannel$lastM = updatedChannel.lastMessage) === null || _updatedChannel$lastM === void 0 ? void 0 : _updatedChannel$lastM.messageId) === message.messageId) {
312
- updatedChannel.lastMessage = message;
313
- }
314
- if (channel) {
315
- channelListDispatcher({
316
- type: ON_LAST_MESSAGE_UPDATED,
317
- payload: updatedChannel
318
- });
319
- }
320
- }));
321
- subscriber.set(PUBSUB_TOPICS.LEAVE_CHANNEL, pubSub.subscribe(PUBSUB_TOPICS.LEAVE_CHANNEL, msg => {
322
- const {
323
- channel
324
- } = msg;
325
- channelListDispatcher({
326
- type: LEAVE_CHANNEL_SUCCESS,
327
- payload: channel === null || channel === void 0 ? void 0 : channel.url
328
- });
329
- }));
330
- subscriber.set(PUBSUB_TOPICS.SEND_MESSAGE_START, pubSub.subscribe(PUBSUB_TOPICS.SEND_MESSAGE_START, msg => {
331
- const {
332
- channel
333
- } = msg;
334
- channelListDispatcher({
335
- type: CHANNEL_REPLACED_TO_TOP,
336
- payload: channel
337
- });
338
- }));
339
- return subscriber;
340
- };
341
-
342
- var channelListInitialState = {
343
- // we might not need this initialized state -> should remove
344
- initialized: false,
345
- loading: true,
346
- allChannels: [],
347
- currentChannel: null,
348
- channelListQuery: null,
349
- currentUserId: '',
350
- disableAutoSelect: false
351
- };
352
-
353
- function reducer(state, action) {
354
- switch (action.type) {
355
- case INIT_CHANNELS_START:
356
- return _objectSpread2(_objectSpread2({}, state), {}, {
357
- loading: true
358
- });
359
- case RESET_CHANNEL_LIST:
360
- return channelListInitialState;
361
- case INIT_CHANNELS_SUCCESS:
362
- {
363
- const {
364
- channelList,
365
- disableAutoSelect
366
- } = action.payload;
367
- return _objectSpread2(_objectSpread2({}, state), {}, {
368
- initialized: true,
369
- loading: false,
370
- allChannels: channelList,
371
- disableAutoSelect,
372
- currentChannel: !disableAutoSelect && channelList && channelList.length && channelList.length > 0 ? channelList[0] : null
373
- });
374
- }
375
- case FETCH_CHANNELS_SUCCESS:
376
- {
377
- const currentChannels = state.allChannels.map(c => c.url);
378
- const filteredChannels = action.payload.filter(_ref => {
379
- let {
380
- url
381
- } = _ref;
382
- return !currentChannels.find(c => c === url);
383
- });
384
- return _objectSpread2(_objectSpread2({}, state), {}, {
385
- allChannels: [...state.allChannels, ...filteredChannels]
386
- });
387
- }
388
- case USER_INVITED:
389
- {
390
- const channel = action.payload;
391
- if (state.channelListQuery) {
392
- if (filterChannelListParams(state.channelListQuery, channel, state.currentUserId)) {
393
- return _objectSpread2(_objectSpread2({}, state), {}, {
394
- allChannels: getChannelsWithUpsertedChannel(state.allChannels, channel)
395
- });
396
- }
397
- return _objectSpread2(_objectSpread2({}, state), {}, {
398
- currentChannel: channel
399
- });
400
- }
401
- return _objectSpread2(_objectSpread2({}, state), {}, {
402
- allChannels: [channel, ...state.allChannels.filter(ch => ch.url !== (channel === null || channel === void 0 ? void 0 : channel.url))]
403
- });
404
- }
405
- case CREATE_CHANNEL:
406
- {
407
- const channel = action.payload;
408
- if (state.channelListQuery) {
409
- if (filterChannelListParams(state.channelListQuery, channel, state.currentUserId)) {
410
- return _objectSpread2(_objectSpread2({}, state), {}, {
411
- currentChannel: channel,
412
- allChannels: getChannelsWithUpsertedChannel(state.allChannels, channel)
413
- });
414
- }
415
- return _objectSpread2(_objectSpread2({}, state), {}, {
416
- currentChannel: channel
417
- });
418
- }
419
- return _objectSpread2(_objectSpread2({}, state), {}, {
420
- allChannels: [channel, ...state.allChannels.filter(ch => ch.url !== (channel === null || channel === void 0 ? void 0 : channel.url))],
421
- currentChannel: channel
422
- });
423
- }
424
- case ON_CHANNEL_ARCHIVED:
425
- {
426
- var _state$currentChannel;
427
- const channel = action.payload;
428
- if (state.channelListQuery) {
429
- if (filterChannelListParams(state.channelListQuery, channel, state.currentUserId)) {
430
- return _objectSpread2(_objectSpread2({}, state), {}, {
431
- allChannels: getChannelsWithUpsertedChannel(state.allChannels, channel)
432
- });
433
- // TODO: Check if we have to set current channel
434
- }
435
- }
436
-
437
- const nextChannel = (channel === null || channel === void 0 ? void 0 : channel.url) === ((_state$currentChannel = state.currentChannel) === null || _state$currentChannel === void 0 ? void 0 : _state$currentChannel.url) ? state.allChannels[state.allChannels[0].url === (channel === null || channel === void 0 ? void 0 : channel.url) ? 1 : 0] : state.currentChannel;
438
- return _objectSpread2(_objectSpread2({}, state), {}, {
439
- allChannels: state.allChannels.filter(_ref2 => {
440
- let {
441
- url
442
- } = _ref2;
443
- return url !== (channel === null || channel === void 0 ? void 0 : channel.url);
444
- }),
445
- currentChannel: state.disableAutoSelect ? null : nextChannel
446
- });
447
- }
448
- case LEAVE_CHANNEL_SUCCESS:
449
- case ON_CHANNEL_DELETED:
450
- {
451
- var _state$currentChannel2;
452
- const channelUrl = action.payload;
453
- return _objectSpread2(_objectSpread2({}, state), {}, {
454
- currentChannel: channelUrl === ((_state$currentChannel2 = state.currentChannel) === null || _state$currentChannel2 === void 0 ? void 0 : _state$currentChannel2.url) ? state.allChannels[0] : state.currentChannel,
455
- allChannels: state.allChannels.filter(_ref3 => {
456
- let {
457
- url
458
- } = _ref3;
459
- return url !== channelUrl;
460
- })
461
- });
462
- }
463
- case ON_USER_LEFT:
464
- {
465
- var _state$currentChannel5;
466
- const {
467
- channel,
468
- isMe
469
- } = action.payload;
470
- if (state.channelListQuery) {
471
- var _state$currentChannel4;
472
- if (filterChannelListParams(state.channelListQuery, channel, state.currentUserId)) {
473
- var _state$currentChannel3;
474
- const filteredChannels = getChannelsWithUpsertedChannel(state.allChannels, channel);
475
- const nextChannel = isMe && (channel === null || channel === void 0 ? void 0 : channel.url) === ((_state$currentChannel3 = state.currentChannel) === null || _state$currentChannel3 === void 0 ? void 0 : _state$currentChannel3.url) ? filteredChannels[0] : state.currentChannel;
476
- return _objectSpread2(_objectSpread2({}, state), {}, {
477
- currentChannel: state.disableAutoSelect ? null : nextChannel,
478
- allChannels: filteredChannels
479
- });
480
- }
481
- const nextChannel = (channel === null || channel === void 0 ? void 0 : channel.url) === ((_state$currentChannel4 = state.currentChannel) === null || _state$currentChannel4 === void 0 ? void 0 : _state$currentChannel4.url) ? state.allChannels[0] : state.currentChannel;
482
- return _objectSpread2(_objectSpread2({}, state), {}, {
483
- currentChannel: state.disableAutoSelect ? null : nextChannel,
484
- allChannels: state.allChannels.filter(_ref4 => {
485
- let {
486
- url
487
- } = _ref4;
488
- return url !== (channel === null || channel === void 0 ? void 0 : channel.url);
489
- })
490
- });
491
- }
492
- const filteredChannels = state.allChannels.filter(c => !(c.url === (channel === null || channel === void 0 ? void 0 : channel.url) && isMe));
493
- const nextChannel = isMe && (channel === null || channel === void 0 ? void 0 : channel.url) === ((_state$currentChannel5 = state.currentChannel) === null || _state$currentChannel5 === void 0 ? void 0 : _state$currentChannel5.url) ? filteredChannels[0] : state.currentChannel;
494
- return _objectSpread2(_objectSpread2({}, state), {}, {
495
- currentChannel: state.disableAutoSelect ? null : nextChannel,
496
- allChannels: filteredChannels
497
- });
498
- }
499
- case ON_USER_JOINED:
500
- case ON_CHANNEL_CHANGED:
501
- case ON_READ_RECEIPT_UPDATED:
502
- case ON_DELIVERY_RECEIPT_UPDATED:
503
- {
504
- var _channel$lastMessage, _channel$lastMessage$;
505
- const {
506
- allChannels = []
507
- } = state;
508
- const channel = action.payload;
509
- const {
510
- unreadMessageCount
511
- } = channel;
512
- if (!(channel !== null && channel !== void 0 && channel.lastMessage)) return state;
513
- if (state.channelListQuery) {
514
- var _channel$url, _state$currentChannel6, _state$currentChannel7;
515
- if (filterChannelListParams(state.channelListQuery, channel, state.currentUserId)) {
516
- return _objectSpread2(_objectSpread2({}, state), {}, {
517
- allChannels: getChannelsWithUpsertedChannel(allChannels, channel)
518
- });
519
- }
520
- const newChannelUrl = (_channel$url = channel === null || channel === void 0 ? void 0 : channel.url) !== null && _channel$url !== void 0 ? _channel$url : '';
521
- const currentChannelUrl = (_state$currentChannel6 = state === null || state === void 0 ? void 0 : (_state$currentChannel7 = state.currentChannel) === null || _state$currentChannel7 === void 0 ? void 0 : _state$currentChannel7.url) !== null && _state$currentChannel6 !== void 0 ? _state$currentChannel6 : '';
522
- const nextChannel = newChannelUrl === currentChannelUrl ? state.allChannels[state.allChannels[0].url === (channel === null || channel === void 0 ? void 0 : channel.url) ? 1 : 0]
523
- // if coming channel is first of channel list, current channel will be the next one
524
- : state.currentChannel;
525
- return _objectSpread2(_objectSpread2({}, state), {}, {
526
- currentChannel: state.disableAutoSelect ? null : nextChannel,
527
- allChannels: state.allChannels.filter(_ref5 => {
528
- let {
529
- url
530
- } = _ref5;
531
- return url !== (channel === null || channel === void 0 ? void 0 : channel.url);
532
- })
533
- });
534
- }
535
- if (unreadMessageCount === 0
536
- // Do not move to the top when marking as read the channel
537
- && (channel === null || channel === void 0 ? void 0 : (_channel$lastMessage = channel.lastMessage) === null || _channel$lastMessage === void 0 ? void 0 : (_channel$lastMessage$ = _channel$lastMessage.sender) === null || _channel$lastMessage$ === void 0 ? void 0 : _channel$lastMessage$.userId) !== state.currentUserId
538
- // Move to the top when the current user but different peer sends the message
539
- ) {
540
- return _objectSpread2(_objectSpread2({}, state), {}, {
541
- allChannels: state.allChannels.map(ch => ch.url === (channel === null || channel === void 0 ? void 0 : channel.url) ? channel : ch)
542
- });
543
- }
544
- return _objectSpread2(_objectSpread2({}, state), {}, {
545
- allChannels: [channel, ...state.allChannels.filter(_ref6 => {
546
- let {
547
- url
548
- } = _ref6;
549
- return url !== action.payload.url;
550
- })]
551
- });
552
- }
553
- case SET_CURRENT_CHANNEL:
554
- return _objectSpread2(_objectSpread2({}, state), {}, {
555
- currentChannel: action.payload
556
- });
557
- case ON_LAST_MESSAGE_UPDATED:
558
- {
559
- return _objectSpread2(_objectSpread2({}, state), {}, {
560
- allChannels: state.allChannels.map(channel => (channel === null || channel === void 0 ? void 0 : channel.url) === action.payload.url ? action.payload : channel)
561
- });
562
- }
563
- case ON_CHANNEL_FROZEN:
564
- {
565
- const channel = action.payload;
566
- if (state.channelListQuery) {
567
- var _state$currentChannel8;
568
- if (filterChannelListParams(state.channelListQuery, channel, state.currentUserId)) {
569
- return _objectSpread2(_objectSpread2({}, state), {}, {
570
- allChannels: getChannelsWithUpsertedChannel(state.allChannels, channel)
571
- });
572
- }
573
- const nextChannel = (channel === null || channel === void 0 ? void 0 : channel.url) === ((_state$currentChannel8 = state.currentChannel) === null || _state$currentChannel8 === void 0 ? void 0 : _state$currentChannel8.url) ? state.allChannels[state.allChannels[0].url === (channel === null || channel === void 0 ? void 0 : channel.url) ? 1 : 0]
574
- // if coming channel is first of channel list, current channel will be the next one
575
- : state.currentChannel;
576
- return _objectSpread2(_objectSpread2({}, state), {}, {
577
- allChannels: state.allChannels.filter(_ref7 => {
578
- let {
579
- url
580
- } = _ref7;
581
- return url !== (channel === null || channel === void 0 ? void 0 : channel.url);
582
- }),
583
- currentChannel: state.disableAutoSelect ? null : nextChannel
584
- });
585
- }
586
- return _objectSpread2(_objectSpread2({}, state), {}, {
587
- allChannels: state.allChannels.map(ch => {
588
- if (ch.url === (channel === null || channel === void 0 ? void 0 : channel.url)) {
589
- // eslint-disable-next-line no-param-reassign
590
- ch.isFrozen = true;
591
- return ch;
592
- }
593
- return ch;
594
- })
595
- });
596
- }
597
- case ON_CHANNEL_UNFROZEN:
598
- {
599
- const channel = action.payload;
600
- if (state.channelListQuery) {
601
- var _state$currentChannel9;
602
- if (filterChannelListParams(state.channelListQuery, channel, state.currentUserId)) {
603
- return _objectSpread2(_objectSpread2({}, state), {}, {
604
- allChannels: getChannelsWithUpsertedChannel(state.allChannels, channel)
605
- });
606
- }
607
- const nextChannel = (channel === null || channel === void 0 ? void 0 : channel.url) === ((_state$currentChannel9 = state.currentChannel) === null || _state$currentChannel9 === void 0 ? void 0 : _state$currentChannel9.url) ? state.allChannels[state.allChannels[0].url === (channel === null || channel === void 0 ? void 0 : channel.url) ? 1 : 0]
608
- // if coming channel is first of channel list, current channel will be the next one
609
- : state.currentChannel;
610
- return _objectSpread2(_objectSpread2({}, state), {}, {
611
- allChannels: state.allChannels.filter(_ref8 => {
612
- let {
613
- url
614
- } = _ref8;
615
- return url !== (channel === null || channel === void 0 ? void 0 : channel.url);
616
- }),
617
- currentChannel: state.disableAutoSelect ? null : nextChannel
618
- });
619
- }
620
- return _objectSpread2(_objectSpread2({}, state), {}, {
621
- allChannels: state.allChannels.map(ch => {
622
- if (ch.url === (channel === null || channel === void 0 ? void 0 : channel.url)) {
623
- // eslint-disable-next-line no-param-reassign
624
- ch.isFrozen = false;
625
- return ch;
626
- }
627
- return ch;
628
- })
629
- });
630
- }
631
- case CHANNEL_REPLACED_TO_TOP:
632
- {
633
- if (state.channelListQuery) {
634
- if (filterChannelListParams(state.channelListQuery, action.payload, state.currentUserId)) {
635
- return _objectSpread2(_objectSpread2({}, state), {}, {
636
- allChannels: [action.payload, ...state.allChannels.filter(channel => (channel === null || channel === void 0 ? void 0 : channel.url) !== action.payload.url)]
637
- });
638
- }
639
- return state;
640
- }
641
- return _objectSpread2(_objectSpread2({}, state), {}, {
642
- allChannels: [action.payload, ...state.allChannels.filter(channel => (channel === null || channel === void 0 ? void 0 : channel.url) !== action.payload.url)]
643
- });
644
- }
645
- case CHANNEL_LIST_PARAMS_UPDATED:
646
- return _objectSpread2(_objectSpread2({}, state), {}, {
647
- currentUserId: action.payload.currentUserId,
648
- channelListQuery: action.payload.channelListQuery
649
- });
650
- default:
651
- return state;
652
- }
653
- }
654
-
655
- function useActiveChannelUrl(_ref, _ref2) {
656
- let {
657
- activeChannelUrl,
658
- channels,
659
- sdk
660
- } = _ref;
661
- let {
662
- logger,
663
- channelListDispatcher
664
- } = _ref2;
665
- return useEffect(() => {
666
- if (activeChannelUrl) {
667
- logger.info('ChannelListProvider: looking for active channel', {
668
- activeChannelUrl
669
- });
670
- const activeChannel = channels === null || channels === void 0 ? void 0 : channels.find(channel => channel.url === activeChannelUrl);
671
- if (activeChannel) {
672
- channelListDispatcher({
673
- type: SET_CURRENT_CHANNEL,
674
- payload: activeChannel
675
- });
676
- } else {
677
- var _sdk$groupChannel;
678
- logger.info('ChannelListProvider: searching backend for active channel', {
679
- activeChannelUrl
680
- });
681
- sdk === null || sdk === void 0 ? void 0 : (_sdk$groupChannel = sdk.groupChannel) === null || _sdk$groupChannel === void 0 ? void 0 : _sdk$groupChannel.getChannel(activeChannelUrl).then(channel => {
682
- channelListDispatcher({
683
- type: FETCH_CHANNELS_SUCCESS,
684
- payload: [channel]
685
- });
686
- channelListDispatcher({
687
- type: SET_CURRENT_CHANNEL,
688
- payload: channel
689
- });
690
- }).catch(() => {
691
- logger.warning('ChannelListProvider: Active channel not found');
692
- });
693
- }
694
- }
695
- }, [activeChannelUrl]);
696
- }
697
-
698
- const useFetchChannelList = (_ref, _ref2) => {
699
- let {
700
- channelSource,
701
- disableMarkAsDelivered
702
- } = _ref;
703
- let {
704
- channelListDispatcher,
705
- logger,
706
- markAsDeliveredScheduler
707
- } = _ref2;
708
- return useCallback(async () => {
709
- if (!(channelSource !== null && channelSource !== void 0 && channelSource.hasNext)) {
710
- logger.info('ChannelList: not able to fetch');
711
- return;
712
- }
713
- logger.info('ChannelList: starting fetch');
714
- channelListDispatcher({
715
- type: FETCH_CHANNELS_START,
716
- payload: null
717
- });
718
- try {
719
- const channelList = await channelSource.next();
720
- logger.info('ChannelList: succeeded fetch', {
721
- channelList
722
- });
723
- channelListDispatcher({
724
- type: FETCH_CHANNELS_SUCCESS,
725
- payload: channelList
726
- });
727
- if (!disableMarkAsDelivered) {
728
- logger.info('ChannelList: mark as delivered to fetched channels');
729
- // eslint-disable-next-line no-unused-expressions
730
- channelList === null || channelList === void 0 ? void 0 : channelList.forEach(channel => {
731
- if ((channel === null || channel === void 0 ? void 0 : channel.unreadMessageCount) > 0) {
732
- markAsDeliveredScheduler.push(channel);
733
- }
734
- });
735
- }
736
- } catch (error) {
737
- logger.error('ChannelList: failed fetch', {
738
- error
739
- });
740
- channelListDispatcher({
741
- type: FETCH_CHANNELS_FAILURE,
742
- payload: error
743
- });
744
- }
745
- }, [channelSource, disableMarkAsDelivered]);
746
- };
747
-
748
- const ChannelListContext = /*#__PURE__*/React__default.createContext({
749
- disableUserProfile: true,
750
- allowProfileEdit: true,
751
- onBeforeCreateChannel: null,
752
- onThemeChange: null,
753
- onProfileEditSuccess: null,
754
- onChannelSelect: null,
755
- queries: {},
756
- className: null,
757
- initialized: false,
758
- loading: false,
759
- allChannels: [],
760
- currentChannel: null,
761
- channelListQuery: {},
762
- currentUserId: null,
763
- channelListDispatcher: null,
764
- channelSource: null,
765
- typingChannels: []
766
- });
767
- const ChannelListProvider = props => {
768
- var _sdk$appInfo, _sdk$currentUser;
769
- // destruct props
770
- const {
771
- children,
772
- className,
773
- disableUserProfile,
774
- allowProfileEdit,
775
- queries,
776
- onProfileEditSuccess,
777
- onThemeChange,
778
- onBeforeCreateChannel,
779
- sortChannelList,
780
- overrideInviteUser,
781
- activeChannelUrl,
782
- isTypingIndicatorEnabled = null,
783
- isMessageReceiptStatusEnabled = null
784
- } = props;
785
- // disable autoselect, if activeChannelUrl is provided
786
- // useActiveChannelUrl should be executed when activeChannelUrl is present
787
- const disableAutoSelect = (props === null || props === void 0 ? void 0 : props.disableAutoSelect) || !!activeChannelUrl;
788
- const onChannelSelect = (props === null || props === void 0 ? void 0 : props.onChannelSelect) || noop;
789
- // fetch store from <SendbirdProvider />
790
- const globalStore = useSendbirdStateContext();
791
- const {
792
- config,
793
- stores
794
- } = globalStore;
795
- const {
796
- sdkStore
797
- } = stores;
798
- const {
799
- pubSub,
800
- logger,
801
- onUserProfileMessage
802
- } = config;
803
- const {
804
- markAsDeliveredScheduler,
805
- disableMarkAsDelivered = false,
806
- isTypingIndicatorEnabledOnChannelList = false,
807
- isMessageReceiptStatusEnabledOnChannelList = false
808
- } = config;
809
- const sdk = sdkStore === null || sdkStore === void 0 ? void 0 : sdkStore.sdk;
810
- const {
811
- premiumFeatureList = []
812
- } = (_sdk$appInfo = sdk === null || sdk === void 0 ? void 0 : sdk.appInfo) !== null && _sdk$appInfo !== void 0 ? _sdk$appInfo : {};
813
-
814
- // derive some variables
815
- // enable if it is true atleast once(both are flase by default)
816
- const userDefinedDisableUserProfile = disableUserProfile || (config === null || config === void 0 ? void 0 : config.disableUserProfile);
817
- const userDefinedRenderProfile = config === null || config === void 0 ? void 0 : config.renderUserProfile;
818
- const enableEditProfile = allowProfileEdit || (config === null || config === void 0 ? void 0 : config.allowProfileEdit);
819
- const userFilledChannelListQuery = queries === null || queries === void 0 ? void 0 : queries.channelListQuery;
820
- const userFilledApplicationUserListQuery = queries === null || queries === void 0 ? void 0 : queries.applicationUserListQuery;
821
- const sdkIntialized = sdkStore === null || sdkStore === void 0 ? void 0 : sdkStore.initialized;
822
- const [channelListStore, channelListDispatcher] = useReducer(reducer, channelListInitialState);
823
- const {
824
- currentChannel
825
- } = channelListStore;
826
- const [channelSource, setChannelSource] = useState(null);
827
- const [typingChannels, setTypingChannels] = useState([]);
828
- useEffect(() => {
829
- const subscriber = pubSubHandler(pubSub, channelListDispatcher);
830
- return () => {
831
- pubSubHandleRemover(subscriber);
832
- };
833
- }, [sdkIntialized]);
834
- useEffect(() => {
835
- const sdkChannelHandlerId = uuidv4();
836
- if (sdkIntialized) {
837
- logger.info('ChannelList: Setup channelHandlers');
838
- setupChannelList({
839
- sdk,
840
- sdkChannelHandlerId,
841
- channelListDispatcher,
842
- setChannelSource,
843
- onChannelSelect,
844
- userFilledChannelListQuery,
845
- logger,
846
- sortChannelList,
847
- disableAutoSelect,
848
- markAsDeliveredScheduler,
849
- disableMarkAsDelivered
850
- });
851
- } else {
852
- var _sdk$groupChannel;
853
- logger.info('ChannelList: Removing channelHandlers');
854
- // remove previous channelHandlers
855
- if (sdk !== null && sdk !== void 0 && (_sdk$groupChannel = sdk.groupChannel) !== null && _sdk$groupChannel !== void 0 && _sdk$groupChannel.removeGroupChannelHandler) {
856
- sdk.groupChannel.removeGroupChannelHandler(sdkChannelHandlerId);
857
- }
858
- // remove channelSource
859
- setChannelSource(null);
860
- // cleanup
861
- channelListDispatcher({
862
- type: RESET_CHANNEL_LIST,
863
- payload: null
864
- });
865
- }
866
- return () => {
867
- var _sdk$groupChannel2;
868
- logger.info('ChannelList: Removing channelHandlers');
869
- if (sdk !== null && sdk !== void 0 && (_sdk$groupChannel2 = sdk.groupChannel) !== null && _sdk$groupChannel2 !== void 0 && _sdk$groupChannel2.removeGroupChannelHandler) {
870
- var _sdk$groupChannel3;
871
- sdk === null || sdk === void 0 ? void 0 : (_sdk$groupChannel3 = sdk.groupChannel) === null || _sdk$groupChannel3 === void 0 ? void 0 : _sdk$groupChannel3.removeGroupChannelHandler(sdkChannelHandlerId);
872
- }
873
- };
874
- }, [sdkIntialized, userFilledChannelListQuery, sortChannelList]);
875
- useEffect(() => {
876
- var _sdk$groupChannel4;
877
- let typingHandlerId = '';
878
- if (sdk !== null && sdk !== void 0 && (_sdk$groupChannel4 = sdk.groupChannel) !== null && _sdk$groupChannel4 !== void 0 && _sdk$groupChannel4.addGroupChannelHandler) {
879
- var _sdk$groupChannel5;
880
- typingHandlerId = uuidv4();
881
- const handler = new GroupChannelHandler({
882
- onTypingStatusUpdated: channel => {
883
- var _channel$getTypingUse;
884
- const typingMemberCount = channel === null || channel === void 0 ? void 0 : (_channel$getTypingUse = channel.getTypingUsers()) === null || _channel$getTypingUse === void 0 ? void 0 : _channel$getTypingUse.length;
885
- const channelList = typingChannels.filter(ch => ch.url !== channel.url);
886
- if (typingMemberCount > 0) {
887
- setTypingChannels([...channelList, channel]);
888
- } else {
889
- setTypingChannels(channelList);
890
- }
891
- },
892
- onUnreadMemberStatusUpdated(channel) {
893
- channelListDispatcher({
894
- type: ON_LAST_MESSAGE_UPDATED,
895
- payload: channel
896
- });
897
- },
898
- onUndeliveredMemberStatusUpdated(channel) {
899
- channelListDispatcher({
900
- type: ON_LAST_MESSAGE_UPDATED,
901
- payload: channel
902
- });
903
- },
904
- onMessageUpdated(channel) {
905
- channelListDispatcher({
906
- type: ON_LAST_MESSAGE_UPDATED,
907
- payload: channel
908
- });
909
- sdk.groupChannel.getChannelWithoutCache(channel.url).then(ch => {
910
- channelListDispatcher({
911
- type: ON_LAST_MESSAGE_UPDATED,
912
- payload: ch
913
- });
914
- });
915
- },
916
- onMentionReceived(channel) {
917
- channelListDispatcher({
918
- type: ON_LAST_MESSAGE_UPDATED,
919
- payload: channel
920
- });
921
- sdk.groupChannel.getChannelWithoutCache(channel.url).then(ch => {
922
- channelListDispatcher({
923
- type: ON_LAST_MESSAGE_UPDATED,
924
- payload: ch
925
- });
926
- });
927
- }
928
- });
929
- sdk === null || sdk === void 0 ? void 0 : (_sdk$groupChannel5 = sdk.groupChannel) === null || _sdk$groupChannel5 === void 0 ? void 0 : _sdk$groupChannel5.addGroupChannelHandler(typingHandlerId, handler);
930
- }
931
- return () => {
932
- var _sdk$groupChannel6;
933
- if (sdk !== null && sdk !== void 0 && (_sdk$groupChannel6 = sdk.groupChannel) !== null && _sdk$groupChannel6 !== void 0 && _sdk$groupChannel6.removeGroupChannelHandler && typingHandlerId !== '') {
934
- sdk.groupChannel.removeGroupChannelHandler(typingHandlerId);
935
- }
936
- };
937
- }, [sdk === null || sdk === void 0 ? void 0 : (_sdk$currentUser = sdk.currentUser) === null || _sdk$currentUser === void 0 ? void 0 : _sdk$currentUser.userId]);
938
- const queries_ = useMemo(() => {
939
- return {
940
- applicationUserListQuery: userFilledApplicationUserListQuery,
941
- channelListQuery: userFilledChannelListQuery
942
- };
943
- }, [userFilledApplicationUserListQuery, userFilledChannelListQuery]);
944
- const {
945
- allChannels
946
- } = channelListStore;
947
- const sortedChannels = sortChannelList && typeof sortChannelList === 'function' ? sortChannelList(allChannels) : allChannels;
948
- if (sortedChannels.length !== allChannels.length) {
949
- const warning = `ChannelList: You have removed/added extra channels on sortChannelList
950
- this could cause unexpected problems`;
951
- // eslint-disable-next-line no-console
952
- console.warn(warning, {
953
- before: allChannels,
954
- after: sortedChannels
955
- });
956
- logger.warning(warning, {
957
- before: allChannels,
958
- after: sortedChannels
959
- });
960
- }
961
-
962
- // Set current channel (by on_channel_selected event)
963
- useEffect(() => {
964
- if (!sdk || !sdk.groupChannel || !currentChannel || !(currentChannel !== null && currentChannel !== void 0 && currentChannel.url)) {
965
- return;
966
- }
967
- sdk.groupChannel.getChannel(currentChannel.url).then(groupChannel => {
968
- if (groupChannel) {
969
- onChannelSelect(groupChannel);
970
- } else {
971
- onChannelSelect(null);
972
- }
973
- });
974
- }, [currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.url]);
975
-
976
- // Set active channel (by url)
977
- useActiveChannelUrl({
978
- activeChannelUrl,
979
- channels: sortedChannels,
980
- sdk
981
- }, {
982
- logger,
983
- channelListDispatcher
984
- });
985
- const fetchChannelList = useFetchChannelList({
986
- channelSource,
987
- disableMarkAsDelivered: disableMarkAsDelivered || !premiumFeatureList.some(feature => feature === DELIVERY_RECEIPT)
988
- }, {
989
- channelListDispatcher,
990
- logger,
991
- markAsDeliveredScheduler
992
- });
993
- return /*#__PURE__*/React__default.createElement(ChannelListContext.Provider, {
994
- value: _objectSpread2(_objectSpread2({
995
- className,
996
- disableUserProfile,
997
- queries: queries_,
998
- onProfileEditSuccess,
999
- onThemeChange,
1000
- onBeforeCreateChannel,
1001
- overrideInviteUser,
1002
- onChannelSelect,
1003
- sortChannelList,
1004
- allowProfileEdit: enableEditProfile,
1005
- channelListDispatcher,
1006
- channelSource
1007
- }, channelListStore), {}, {
1008
- allChannels: sortedChannels,
1009
- typingChannels,
1010
- isTypingIndicatorEnabled: isTypingIndicatorEnabled !== null ? isTypingIndicatorEnabled : isTypingIndicatorEnabledOnChannelList,
1011
- isMessageReceiptStatusEnabled: isMessageReceiptStatusEnabled !== null ? isMessageReceiptStatusEnabled : isMessageReceiptStatusEnabledOnChannelList,
1012
- fetchChannelList
1013
- })
1014
- }, /*#__PURE__*/React__default.createElement(UserProfileProvider, {
1015
- disableUserProfile: userDefinedDisableUserProfile !== null && userDefinedDisableUserProfile !== void 0 ? userDefinedDisableUserProfile : config === null || config === void 0 ? void 0 : config.disableUserProfile,
1016
- renderUserProfile: userDefinedRenderProfile,
1017
- onUserProfileMessage: onUserProfileMessage
1018
- }, /*#__PURE__*/React__default.createElement("div", {
1019
- className: `sendbird-channel-list ${className}`
1020
- }, children)));
1021
- };
1022
- function useChannelListContext() {
1023
- const context = useContext(ChannelListContext);
1024
- return context;
1025
- }
1026
-
1027
- export { ChannelListProvider as C, LEAVE_CHANNEL_SUCCESS as L, SET_CURRENT_CHANNEL as S, useChannelListContext as u };
1028
- //# sourceMappingURL=ChannelListProvider-1188e373.js.map