@sendbird/uikit-react 3.5.0-rc.1 → 3.5.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 (936) hide show
  1. package/App.js +312 -235
  2. package/App.js.map +1 -1
  3. package/CHANGELOG.md +544 -0
  4. package/Channel/components/ChannelHeader.js +46 -41
  5. package/Channel/components/ChannelHeader.js.map +1 -1
  6. package/Channel/components/ChannelUI.js +104 -131
  7. package/Channel/components/ChannelUI.js.map +1 -1
  8. package/Channel/components/FileViewer.js +56 -52
  9. package/Channel/components/FileViewer.js.map +1 -1
  10. package/Channel/components/FrozenNotification.js +12 -7
  11. package/Channel/components/FrozenNotification.js.map +1 -1
  12. package/Channel/components/Message.js +240 -230
  13. package/Channel/components/Message.js.map +1 -1
  14. package/Channel/components/MessageInput.js +152 -129
  15. package/Channel/components/MessageInput.js.map +1 -1
  16. package/Channel/components/MessageList.js +260 -175
  17. package/Channel/components/MessageList.js.map +1 -1
  18. package/Channel/components/RemoveMessageModal.js +34 -30
  19. package/Channel/components/RemoveMessageModal.js.map +1 -1
  20. package/Channel/components/SuggestedMentionList.js +139 -193
  21. package/Channel/components/SuggestedMentionList.js.map +1 -1
  22. package/Channel/components/TypingIndicator.js +44 -61
  23. package/Channel/components/TypingIndicator.js.map +1 -1
  24. package/Channel/components/UnreadCount.js +18 -20
  25. package/Channel/components/UnreadCount.js.map +1 -1
  26. package/Channel/context.js +12 -19
  27. package/Channel/context.js.map +1 -1
  28. package/Channel.js +69 -44
  29. package/Channel.js.map +1 -1
  30. package/ChannelList/components/AddChannel.js +29 -30
  31. package/ChannelList/components/AddChannel.js.map +1 -1
  32. package/ChannelList/components/ChannelListHeader.js +32 -28
  33. package/ChannelList/components/ChannelListHeader.js.map +1 -1
  34. package/ChannelList/components/ChannelListUI.js +101 -142
  35. package/ChannelList/components/ChannelListUI.js.map +1 -1
  36. package/ChannelList/components/ChannelPreview.js +72 -82
  37. package/ChannelList/components/ChannelPreview.js.map +1 -1
  38. package/ChannelList/components/ChannelPreviewAction.js +36 -36
  39. package/ChannelList/components/ChannelPreviewAction.js.map +1 -1
  40. package/ChannelList/context.js +7 -8
  41. package/ChannelList/context.js.map +1 -1
  42. package/ChannelList.js +32 -31
  43. package/ChannelList.js.map +1 -1
  44. package/{ChannelListProvider-1d36e2e9.js → ChannelListProvider-4cf5c0f5.js} +233 -285
  45. package/ChannelListProvider-4cf5c0f5.js.map +1 -0
  46. package/{ChannelProvider-289cd35f.js → ChannelProvider-6e8e99df.js} +659 -726
  47. package/ChannelProvider-6e8e99df.js.map +1 -0
  48. package/ChannelSettings/components/ChannelProfile.js +33 -46
  49. package/ChannelSettings/components/ChannelProfile.js.map +1 -1
  50. package/ChannelSettings/components/ChannelSettingsUI.js +45 -48
  51. package/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
  52. package/ChannelSettings/components/EditDetailsModal.js +47 -58
  53. package/ChannelSettings/components/EditDetailsModal.js.map +1 -1
  54. package/ChannelSettings/components/LeaveChannel.js +40 -46
  55. package/ChannelSettings/components/LeaveChannel.js.map +1 -1
  56. package/ChannelSettings/components/ModerationPanel.js +522 -605
  57. package/ChannelSettings/components/ModerationPanel.js.map +1 -1
  58. package/ChannelSettings/components/UserListItem.js +71 -72
  59. package/ChannelSettings/components/UserListItem.js.map +1 -1
  60. package/ChannelSettings/components/UserPanel.js +29 -32
  61. package/ChannelSettings/components/UserPanel.js.map +1 -1
  62. package/ChannelSettings/context.js +53 -57
  63. package/ChannelSettings/context.js.map +1 -1
  64. package/ChannelSettings.js +20 -20
  65. package/ChannelSettings.js.map +1 -1
  66. package/CreateChannel/components/CreateChannelUI.js +24 -24
  67. package/CreateChannel/components/CreateChannelUI.js.map +1 -1
  68. package/CreateChannel/components/InviteUsers.js +102 -124
  69. package/CreateChannel/components/InviteUsers.js.map +1 -1
  70. package/CreateChannel/components/SelectChannelType.js +41 -42
  71. package/CreateChannel/components/SelectChannelType.js.map +1 -1
  72. package/CreateChannel/context.js +4 -4
  73. package/CreateChannel.js +22 -21
  74. package/CreateChannel.js.map +1 -1
  75. package/CreateChannelProvider-34603fa5.js +44 -0
  76. package/CreateChannelProvider-34603fa5.js.map +1 -0
  77. package/CreateOpenChannel/components/CreateOpenChannelUI.js +33 -43
  78. package/CreateOpenChannel/components/CreateOpenChannelUI.js.map +1 -1
  79. package/CreateOpenChannel/context.js +33 -33
  80. package/CreateOpenChannel/context.js.map +1 -1
  81. package/CreateOpenChannel.js +18 -17
  82. package/CreateOpenChannel.js.map +1 -1
  83. package/EditUserProfile/components/EditUserProfileUI.js +12 -13
  84. package/EditUserProfile/components/EditUserProfileUI.js.map +1 -1
  85. package/EditUserProfile/context.js +0 -2
  86. package/EditUserProfile/context.js.map +1 -1
  87. package/EditUserProfile.js +18 -17
  88. package/EditUserProfile.js.map +1 -1
  89. package/LocalizationContext-04c0c9dc.js +20 -0
  90. package/{LocalizationContext-289c1917.js.map → LocalizationContext-04c0c9dc.js.map} +1 -1
  91. package/MediaQueryContext-ff9dca2b.js +87 -0
  92. package/MediaQueryContext-ff9dca2b.js.map +1 -0
  93. package/MemberList-9bf26111.js +403 -0
  94. package/MemberList-9bf26111.js.map +1 -0
  95. package/Message/context.js +31 -0
  96. package/Message/context.js.map +1 -0
  97. package/MessageSearch/components/MessageSearchUI.js +62 -71
  98. package/MessageSearch/components/MessageSearchUI.js.map +1 -1
  99. package/MessageSearch/context.js +201 -224
  100. package/MessageSearch/context.js.map +1 -1
  101. package/MessageSearch.js +46 -58
  102. package/MessageSearch.js.map +1 -1
  103. package/OpenChannel/components/FrozenChannelNotification.js +8 -6
  104. package/OpenChannel/components/FrozenChannelNotification.js.map +1 -1
  105. package/OpenChannel/components/OpenChannelHeader.js +27 -25
  106. package/OpenChannel/components/OpenChannelHeader.js.map +1 -1
  107. package/OpenChannel/components/OpenChannelInput.js +50 -35
  108. package/OpenChannel/components/OpenChannelInput.js.map +1 -1
  109. package/OpenChannel/components/OpenChannelMessage.js +174 -191
  110. package/OpenChannel/components/OpenChannelMessage.js.map +1 -1
  111. package/OpenChannel/components/OpenChannelMessageList.js +72 -92
  112. package/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
  113. package/OpenChannel/components/OpenChannelUI.js +52 -49
  114. package/OpenChannel/components/OpenChannelUI.js.map +1 -1
  115. package/OpenChannel/context.js +8 -9
  116. package/OpenChannel/context.js.map +1 -1
  117. package/OpenChannel.js +36 -30
  118. package/OpenChannel.js.map +1 -1
  119. package/OpenChannelList/components/OpenChannelListUI.js +61 -76
  120. package/OpenChannelList/components/OpenChannelListUI.js.map +1 -1
  121. package/OpenChannelList/components/OpenChannelPreview.js +21 -22
  122. package/OpenChannelList/components/OpenChannelPreview.js.map +1 -1
  123. package/OpenChannelList/context.js +3 -4
  124. package/OpenChannelList/context.js.map +1 -1
  125. package/OpenChannelList.js +26 -24
  126. package/OpenChannelList.js.map +1 -1
  127. package/OpenChannelListProvider-d7372692.js +429 -0
  128. package/OpenChannelListProvider-d7372692.js.map +1 -0
  129. package/OpenChannelProvider-24cd68b9.js +1885 -0
  130. package/OpenChannelProvider-24cd68b9.js.map +1 -0
  131. package/OpenChannelSettings/components/EditDetailsModal.js +47 -56
  132. package/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
  133. package/OpenChannelSettings/components/OpenChannelProfile.js +26 -31
  134. package/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
  135. package/OpenChannelSettings/components/OpenChannelSettingsUI.js +45 -43
  136. package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
  137. package/OpenChannelSettings/components/OperatorUI.js +516 -586
  138. package/OpenChannelSettings/components/OperatorUI.js.map +1 -1
  139. package/OpenChannelSettings/components/ParticipantUI.js +15 -16
  140. package/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
  141. package/OpenChannelSettings/context.js +56 -69
  142. package/OpenChannelSettings/context.js.map +1 -1
  143. package/OpenChannelSettings.js +19 -20
  144. package/OpenChannelSettings.js.map +1 -1
  145. package/README.md +62 -13
  146. package/RemoveMessageModal-94e2bf9e.js +36 -0
  147. package/RemoveMessageModal-94e2bf9e.js.map +1 -0
  148. package/SendbirdProvider.js +749 -408
  149. package/SendbirdProvider.js.map +1 -1
  150. package/Thread/components/ParentMessageInfo.js +238 -217
  151. package/Thread/components/ParentMessageInfo.js.map +1 -1
  152. package/Thread/components/ParentMessageInfoItem.js +112 -89
  153. package/Thread/components/ParentMessageInfoItem.js.map +1 -1
  154. package/Thread/components/ThreadHeader.js +22 -23
  155. package/Thread/components/ThreadHeader.js.map +1 -1
  156. package/Thread/components/ThreadList.js +108 -83
  157. package/Thread/components/ThreadList.js.map +1 -1
  158. package/Thread/components/ThreadListItem.js +306 -276
  159. package/Thread/components/ThreadListItem.js.map +1 -1
  160. package/Thread/components/ThreadMessageInput.js +146 -113
  161. package/Thread/components/ThreadMessageInput.js.map +1 -1
  162. package/Thread/components/ThreadUI.js +169 -138
  163. package/Thread/components/ThreadUI.js.map +1 -1
  164. package/Thread/context/types.js +9 -14
  165. package/Thread/context/types.js.map +1 -1
  166. package/Thread/context.js +8 -8
  167. package/Thread.js +87 -57
  168. package/Thread.js.map +1 -1
  169. package/ThreadProvider-203b94f3.js +1695 -0
  170. package/ThreadProvider-203b94f3.js.map +1 -0
  171. package/{UserProfileContext-e3530842.js → UserProfileContext-c776d522.js} +1 -4
  172. package/{UserProfileContext-e3530842.js.map → UserProfileContext-c776d522.js.map} +1 -1
  173. package/VoiceMessageInputWrapper-77d8f487.js +170 -0
  174. package/VoiceMessageInputWrapper-77d8f487.js.map +1 -0
  175. package/VoicePlayer/context.js +7 -0
  176. package/{NotificationChannel → VoicePlayer}/context.js.map +1 -1
  177. package/VoicePlayer/useVoicePlayer.js +84 -0
  178. package/VoicePlayer/useVoicePlayer.js.map +1 -0
  179. package/VoiceRecorder/context.js +156 -0
  180. package/VoiceRecorder/context.js.map +1 -0
  181. package/VoiceRecorder/useVoiceRecorder.js +121 -0
  182. package/VoiceRecorder/useVoiceRecorder.js.map +1 -0
  183. package/WebAudioUtils-62e6d3a7.js +123 -0
  184. package/WebAudioUtils-62e6d3a7.js.map +1 -0
  185. package/{_rollupPluginBabelHelpers-519f674b.js → _rollupPluginBabelHelpers-fb0e05a4.js} +17 -11
  186. package/_rollupPluginBabelHelpers-fb0e05a4.js.map +1 -0
  187. package/actionTypes-1db5749d.js +8 -0
  188. package/actionTypes-1db5749d.js.map +1 -0
  189. package/cjs/App.js +312 -235
  190. package/cjs/App.js.map +1 -1
  191. package/cjs/Channel/components/ChannelHeader.js +46 -41
  192. package/cjs/Channel/components/ChannelHeader.js.map +1 -1
  193. package/cjs/Channel/components/ChannelUI.js +102 -129
  194. package/cjs/Channel/components/ChannelUI.js.map +1 -1
  195. package/cjs/Channel/components/FileViewer.js +56 -52
  196. package/cjs/Channel/components/FileViewer.js.map +1 -1
  197. package/cjs/Channel/components/FrozenNotification.js +12 -7
  198. package/cjs/Channel/components/FrozenNotification.js.map +1 -1
  199. package/cjs/Channel/components/Message.js +243 -233
  200. package/cjs/Channel/components/Message.js.map +1 -1
  201. package/cjs/Channel/components/MessageInput.js +151 -128
  202. package/cjs/Channel/components/MessageInput.js.map +1 -1
  203. package/cjs/Channel/components/MessageList.js +260 -175
  204. package/cjs/Channel/components/MessageList.js.map +1 -1
  205. package/cjs/Channel/components/RemoveMessageModal.js +34 -30
  206. package/cjs/Channel/components/RemoveMessageModal.js.map +1 -1
  207. package/cjs/Channel/components/SuggestedMentionList.js +139 -193
  208. package/cjs/Channel/components/SuggestedMentionList.js.map +1 -1
  209. package/cjs/Channel/components/TypingIndicator.js +44 -61
  210. package/cjs/Channel/components/TypingIndicator.js.map +1 -1
  211. package/cjs/Channel/components/UnreadCount.js +18 -20
  212. package/cjs/Channel/components/UnreadCount.js.map +1 -1
  213. package/cjs/Channel/context.js +12 -23
  214. package/cjs/Channel/context.js.map +1 -1
  215. package/cjs/Channel.js +69 -44
  216. package/cjs/Channel.js.map +1 -1
  217. package/cjs/ChannelList/components/AddChannel.js +29 -30
  218. package/cjs/ChannelList/components/AddChannel.js.map +1 -1
  219. package/cjs/ChannelList/components/ChannelListHeader.js +32 -28
  220. package/cjs/ChannelList/components/ChannelListHeader.js.map +1 -1
  221. package/cjs/ChannelList/components/ChannelListUI.js +100 -141
  222. package/cjs/ChannelList/components/ChannelListUI.js.map +1 -1
  223. package/cjs/ChannelList/components/ChannelPreview.js +72 -82
  224. package/cjs/ChannelList/components/ChannelPreview.js.map +1 -1
  225. package/cjs/ChannelList/components/ChannelPreviewAction.js +36 -36
  226. package/cjs/ChannelList/components/ChannelPreviewAction.js.map +1 -1
  227. package/cjs/ChannelList/context.js +7 -8
  228. package/cjs/ChannelList/context.js.map +1 -1
  229. package/cjs/ChannelList.js +32 -31
  230. package/cjs/ChannelList.js.map +1 -1
  231. package/cjs/{ChannelListProvider-0de52d2b.js → ChannelListProvider-e0ce316a.js} +232 -284
  232. package/cjs/ChannelListProvider-e0ce316a.js.map +1 -0
  233. package/cjs/{ChannelProvider-fc58e60e.js → ChannelProvider-0df75472.js} +657 -724
  234. package/cjs/ChannelProvider-0df75472.js.map +1 -0
  235. package/cjs/ChannelSettings/components/ChannelProfile.js +33 -46
  236. package/cjs/ChannelSettings/components/ChannelProfile.js.map +1 -1
  237. package/cjs/ChannelSettings/components/ChannelSettingsUI.js +45 -48
  238. package/cjs/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
  239. package/cjs/ChannelSettings/components/EditDetailsModal.js +47 -58
  240. package/cjs/ChannelSettings/components/EditDetailsModal.js.map +1 -1
  241. package/cjs/ChannelSettings/components/LeaveChannel.js +40 -46
  242. package/cjs/ChannelSettings/components/LeaveChannel.js.map +1 -1
  243. package/cjs/ChannelSettings/components/ModerationPanel.js +522 -605
  244. package/cjs/ChannelSettings/components/ModerationPanel.js.map +1 -1
  245. package/cjs/ChannelSettings/components/UserListItem.js +71 -72
  246. package/cjs/ChannelSettings/components/UserListItem.js.map +1 -1
  247. package/cjs/ChannelSettings/components/UserPanel.js +29 -32
  248. package/cjs/ChannelSettings/components/UserPanel.js.map +1 -1
  249. package/cjs/ChannelSettings/context.js +55 -59
  250. package/cjs/ChannelSettings/context.js.map +1 -1
  251. package/cjs/ChannelSettings.js +20 -20
  252. package/cjs/ChannelSettings.js.map +1 -1
  253. package/cjs/CreateChannel/components/CreateChannelUI.js +24 -24
  254. package/cjs/CreateChannel/components/CreateChannelUI.js.map +1 -1
  255. package/cjs/CreateChannel/components/InviteUsers.js +102 -124
  256. package/cjs/CreateChannel/components/InviteUsers.js.map +1 -1
  257. package/cjs/CreateChannel/components/SelectChannelType.js +41 -42
  258. package/cjs/CreateChannel/components/SelectChannelType.js.map +1 -1
  259. package/cjs/CreateChannel/context.js +4 -4
  260. package/cjs/CreateChannel.js +22 -21
  261. package/cjs/CreateChannel.js.map +1 -1
  262. package/cjs/CreateChannelProvider-c0fca0a5.js +52 -0
  263. package/cjs/CreateChannelProvider-c0fca0a5.js.map +1 -0
  264. package/cjs/CreateOpenChannel/components/CreateOpenChannelUI.js +33 -43
  265. package/cjs/CreateOpenChannel/components/CreateOpenChannelUI.js.map +1 -1
  266. package/cjs/CreateOpenChannel/context.js +33 -33
  267. package/cjs/CreateOpenChannel/context.js.map +1 -1
  268. package/cjs/CreateOpenChannel.js +18 -17
  269. package/cjs/CreateOpenChannel.js.map +1 -1
  270. package/cjs/EditUserProfile/components/EditUserProfileUI.js +12 -13
  271. package/cjs/EditUserProfile/components/EditUserProfileUI.js.map +1 -1
  272. package/cjs/EditUserProfile/context.js +0 -2
  273. package/cjs/EditUserProfile/context.js.map +1 -1
  274. package/cjs/EditUserProfile.js +18 -17
  275. package/cjs/EditUserProfile.js.map +1 -1
  276. package/cjs/{LocalizationContext-bddc5c2b.js → LocalizationContext-0e429c3d.js} +9 -11
  277. package/cjs/{LocalizationContext-bddc5c2b.js.map → LocalizationContext-0e429c3d.js.map} +1 -1
  278. package/cjs/MediaQueryContext-33fc3b17.js +94 -0
  279. package/cjs/MediaQueryContext-33fc3b17.js.map +1 -0
  280. package/cjs/MemberList-a45a51c4.js +409 -0
  281. package/cjs/MemberList-a45a51c4.js.map +1 -0
  282. package/cjs/Message/context.js +40 -0
  283. package/cjs/Message/context.js.map +1 -0
  284. package/cjs/MessageSearch/components/MessageSearchUI.js +61 -70
  285. package/cjs/MessageSearch/components/MessageSearchUI.js.map +1 -1
  286. package/cjs/MessageSearch/context.js +201 -224
  287. package/cjs/MessageSearch/context.js.map +1 -1
  288. package/cjs/MessageSearch.js +46 -58
  289. package/cjs/MessageSearch.js.map +1 -1
  290. package/cjs/OpenChannel/components/FrozenChannelNotification.js +8 -6
  291. package/cjs/OpenChannel/components/FrozenChannelNotification.js.map +1 -1
  292. package/cjs/OpenChannel/components/OpenChannelHeader.js +27 -25
  293. package/cjs/OpenChannel/components/OpenChannelHeader.js.map +1 -1
  294. package/cjs/OpenChannel/components/OpenChannelInput.js +50 -35
  295. package/cjs/OpenChannel/components/OpenChannelInput.js.map +1 -1
  296. package/cjs/OpenChannel/components/OpenChannelMessage.js +174 -191
  297. package/cjs/OpenChannel/components/OpenChannelMessage.js.map +1 -1
  298. package/cjs/OpenChannel/components/OpenChannelMessageList.js +72 -92
  299. package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
  300. package/cjs/OpenChannel/components/OpenChannelUI.js +52 -49
  301. package/cjs/OpenChannel/components/OpenChannelUI.js.map +1 -1
  302. package/cjs/OpenChannel/context.js +8 -9
  303. package/cjs/OpenChannel/context.js.map +1 -1
  304. package/cjs/OpenChannel.js +36 -30
  305. package/cjs/OpenChannel.js.map +1 -1
  306. package/cjs/OpenChannelList/components/OpenChannelListUI.js +61 -76
  307. package/cjs/OpenChannelList/components/OpenChannelListUI.js.map +1 -1
  308. package/cjs/OpenChannelList/components/OpenChannelPreview.js +21 -22
  309. package/cjs/OpenChannelList/components/OpenChannelPreview.js.map +1 -1
  310. package/cjs/OpenChannelList/context.js +3 -4
  311. package/cjs/OpenChannelList/context.js.map +1 -1
  312. package/cjs/OpenChannelList.js +26 -24
  313. package/cjs/OpenChannelList.js.map +1 -1
  314. package/cjs/OpenChannelListProvider-fc8b53ee.js +439 -0
  315. package/cjs/OpenChannelListProvider-fc8b53ee.js.map +1 -0
  316. package/cjs/OpenChannelProvider-217a8ac2.js +1894 -0
  317. package/cjs/OpenChannelProvider-217a8ac2.js.map +1 -0
  318. package/cjs/OpenChannelSettings/components/EditDetailsModal.js +47 -56
  319. package/cjs/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
  320. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js +26 -31
  321. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
  322. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js +45 -43
  323. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
  324. package/cjs/OpenChannelSettings/components/OperatorUI.js +516 -586
  325. package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -1
  326. package/cjs/OpenChannelSettings/components/ParticipantUI.js +15 -16
  327. package/cjs/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
  328. package/cjs/OpenChannelSettings/context.js +57 -70
  329. package/cjs/OpenChannelSettings/context.js.map +1 -1
  330. package/cjs/OpenChannelSettings.js +19 -20
  331. package/cjs/OpenChannelSettings.js.map +1 -1
  332. package/cjs/{RemoveMessageModal-9169766a.js → RemoveMessageModal-5903f232.js} +19 -14
  333. package/cjs/RemoveMessageModal-5903f232.js.map +1 -0
  334. package/cjs/SendbirdProvider.js +748 -408
  335. package/cjs/SendbirdProvider.js.map +1 -1
  336. package/cjs/Thread/components/ParentMessageInfo.js +237 -216
  337. package/cjs/Thread/components/ParentMessageInfo.js.map +1 -1
  338. package/cjs/Thread/components/ParentMessageInfoItem.js +111 -88
  339. package/cjs/Thread/components/ParentMessageInfoItem.js.map +1 -1
  340. package/cjs/Thread/components/ThreadHeader.js +22 -23
  341. package/cjs/Thread/components/ThreadHeader.js.map +1 -1
  342. package/cjs/Thread/components/ThreadList.js +108 -83
  343. package/cjs/Thread/components/ThreadList.js.map +1 -1
  344. package/cjs/Thread/components/ThreadListItem.js +305 -275
  345. package/cjs/Thread/components/ThreadListItem.js.map +1 -1
  346. package/cjs/Thread/components/ThreadMessageInput.js +146 -113
  347. package/cjs/Thread/components/ThreadMessageInput.js.map +1 -1
  348. package/cjs/Thread/components/ThreadUI.js +170 -139
  349. package/cjs/Thread/components/ThreadUI.js.map +1 -1
  350. package/cjs/Thread/context/types.js +13 -14
  351. package/cjs/Thread/context/types.js.map +1 -1
  352. package/cjs/Thread/context.js +8 -8
  353. package/cjs/Thread.js +87 -57
  354. package/cjs/Thread.js.map +1 -1
  355. package/cjs/ThreadProvider-8ee179c2.js +1704 -0
  356. package/cjs/ThreadProvider-8ee179c2.js.map +1 -0
  357. package/cjs/{UserProfileContext-8d0dee57.js → UserProfileContext-87580795.js} +1 -4
  358. package/cjs/{UserProfileContext-8d0dee57.js.map → UserProfileContext-87580795.js.map} +1 -1
  359. package/cjs/VoiceMessageInputWrapper-4fdc8ef1.js +176 -0
  360. package/cjs/VoiceMessageInputWrapper-4fdc8ef1.js.map +1 -0
  361. package/cjs/VoicePlayer/context.js +17 -0
  362. package/cjs/{NotificationChannel → VoicePlayer}/context.js.map +1 -1
  363. package/cjs/VoicePlayer/useVoicePlayer.js +88 -0
  364. package/cjs/VoicePlayer/useVoicePlayer.js.map +1 -0
  365. package/cjs/VoiceRecorder/context.js +166 -0
  366. package/cjs/VoiceRecorder/context.js.map +1 -0
  367. package/cjs/VoiceRecorder/useVoiceRecorder.js +126 -0
  368. package/cjs/VoiceRecorder/useVoiceRecorder.js.map +1 -0
  369. package/cjs/WebAudioUtils-e226789c.js +126 -0
  370. package/cjs/WebAudioUtils-e226789c.js.map +1 -0
  371. package/cjs/{_rollupPluginBabelHelpers-fed1e122.js → _rollupPluginBabelHelpers-c89f311a.js} +17 -10
  372. package/cjs/_rollupPluginBabelHelpers-c89f311a.js.map +1 -0
  373. package/cjs/actionTypes-0fa2943d.js +10 -0
  374. package/cjs/actionTypes-0fa2943d.js.map +1 -0
  375. package/cjs/{color-f47044b3.js → color-bada0fc7.js} +13 -21
  376. package/cjs/color-bada0fc7.js.map +1 -0
  377. package/cjs/{compareIds-4124b297.js → compareIds-ccccfe86.js} +5 -6
  378. package/cjs/compareIds-ccccfe86.js.map +1 -0
  379. package/cjs/const-a85f3364.js +20 -0
  380. package/cjs/const-a85f3364.js.map +1 -0
  381. package/cjs/{const-fd64914b.js → const-d8cece19.js} +4 -4
  382. package/cjs/const-d8cece19.js.map +1 -0
  383. package/cjs/consts-1c3020ad.js +6 -0
  384. package/cjs/consts-1c3020ad.js.map +1 -0
  385. package/cjs/consts-1d94dc61.js +6 -0
  386. package/cjs/consts-1d94dc61.js.map +1 -0
  387. package/cjs/consts-5e0f96b3.js +41 -0
  388. package/cjs/consts-5e0f96b3.js.map +1 -0
  389. package/cjs/consts-740f60b8.js +6 -0
  390. package/cjs/consts-740f60b8.js.map +1 -0
  391. package/cjs/{context-7a0e057b.js → context-8e7e8457.js} +6 -5
  392. package/cjs/{context-7a0e057b.js.map → context-8e7e8457.js.map} +1 -1
  393. package/cjs/dist/index.css +1640 -1187
  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/{index-d14a43c4.js → index-016f7106.js} +1 -1
  398. package/cjs/{index-d14a43c4.js.map → index-016f7106.js.map} +1 -1
  399. package/cjs/{index-9ca07037.js → index-1613ae03.js} +29 -37
  400. package/cjs/index-1613ae03.js.map +1 -0
  401. package/cjs/index-2be14d85.js +57 -0
  402. package/cjs/index-2be14d85.js.map +1 -0
  403. package/cjs/index-3b30939e.js +79 -0
  404. package/cjs/index-3b30939e.js.map +1 -0
  405. package/cjs/index-5231fde8.js +585 -0
  406. package/cjs/index-5231fde8.js.map +1 -0
  407. package/cjs/index-648c06ed.js +330 -0
  408. package/cjs/index-648c06ed.js.map +1 -0
  409. package/cjs/{index-5d5497c2.js → index-6cb0d040.js} +11 -25
  410. package/cjs/index-6cb0d040.js.map +1 -0
  411. package/cjs/{index-c475c3c8.js → index-71fdaa1b.js} +55 -63
  412. package/cjs/index-71fdaa1b.js.map +1 -0
  413. package/cjs/{index-343cd84a.js → index-7d125728.js} +2 -2
  414. package/cjs/{index-343cd84a.js.map → index-7d125728.js.map} +1 -1
  415. package/cjs/{index-3a4f8219.js → index-7f6bbe0c.js} +42 -51
  416. package/cjs/index-7f6bbe0c.js.map +1 -0
  417. package/cjs/{index-8de8f28a.js → index-869e9a94.js} +2 -2
  418. package/cjs/{index-8de8f28a.js.map → index-869e9a94.js.map} +1 -1
  419. package/cjs/index-89d81dad.js +456 -0
  420. package/cjs/index-89d81dad.js.map +1 -0
  421. package/cjs/{index-abbc8024.js → index-8affdde5.js} +57 -3
  422. package/cjs/index-8affdde5.js.map +1 -0
  423. package/cjs/index-99f16473.js +202 -0
  424. package/cjs/index-99f16473.js.map +1 -0
  425. package/cjs/index-c9d348b6.js +367 -0
  426. package/cjs/index-c9d348b6.js.map +1 -0
  427. package/cjs/index-e8c0080f.js +161 -0
  428. package/cjs/index-e8c0080f.js.map +1 -0
  429. package/cjs/{index-c5cd589d.js → index-f570d25c.js} +1 -1
  430. package/cjs/index-f570d25c.js.map +1 -0
  431. package/cjs/index.js +84 -63
  432. package/cjs/index.js.map +1 -1
  433. package/cjs/index.module-0585715f.js +6 -0
  434. package/cjs/index.module-0585715f.js.map +1 -0
  435. package/cjs/lame.all.js +2541 -0
  436. package/cjs/lame.all.js.map +1 -0
  437. package/cjs/resolvedReplyType-67e78c63.js +32 -0
  438. package/cjs/resolvedReplyType-67e78c63.js.map +1 -0
  439. package/cjs/sendbirdSelectors.js +307 -417
  440. package/cjs/sendbirdSelectors.js.map +1 -1
  441. package/cjs/{stringSet-3e6167ef.js → stringSet-106da549.js} +112 -90
  442. package/cjs/stringSet-106da549.js.map +1 -0
  443. package/cjs/tokenize-2aa0f876.js +164 -0
  444. package/cjs/tokenize-2aa0f876.js.map +1 -0
  445. package/cjs/topics-b384e6b3.js +18 -0
  446. package/cjs/topics-b384e6b3.js.map +1 -0
  447. package/cjs/types-e0b77c8c.js +17 -0
  448. package/cjs/types-e0b77c8c.js.map +1 -0
  449. package/cjs/ui/Accordion.js +21 -24
  450. package/cjs/ui/Accordion.js.map +1 -1
  451. package/cjs/ui/AccordionGroup.js +10 -13
  452. package/cjs/ui/AccordionGroup.js.map +1 -1
  453. package/cjs/ui/AdminMessage.js +10 -13
  454. package/cjs/ui/AdminMessage.js.map +1 -1
  455. package/cjs/ui/Avatar.js +57 -79
  456. package/cjs/ui/Avatar.js.map +1 -1
  457. package/cjs/ui/Badge.js +16 -15
  458. package/cjs/ui/Badge.js.map +1 -1
  459. package/cjs/ui/BottomSheet.js +14 -12
  460. package/cjs/ui/BottomSheet.js.map +1 -1
  461. package/cjs/ui/Button.js +20 -35
  462. package/cjs/ui/Button.js.map +1 -1
  463. package/cjs/ui/ChannelAvatar.js +38 -41
  464. package/cjs/ui/ChannelAvatar.js.map +1 -1
  465. package/cjs/ui/Checkbox.js +11 -13
  466. package/cjs/ui/Checkbox.js.map +1 -1
  467. package/cjs/ui/ConnectionStatus.js +7 -5
  468. package/cjs/ui/ConnectionStatus.js.map +1 -1
  469. package/cjs/ui/ContextMenu.js +175 -199
  470. package/cjs/ui/ContextMenu.js.map +1 -1
  471. package/cjs/ui/DateSeparator.js +12 -14
  472. package/cjs/ui/DateSeparator.js.map +1 -1
  473. package/cjs/ui/EmojiReactions.js +299 -107
  474. package/cjs/ui/EmojiReactions.js.map +1 -1
  475. package/cjs/ui/FileMessageItemBody.js +22 -23
  476. package/cjs/ui/FileMessageItemBody.js.map +1 -1
  477. package/cjs/ui/FileViewer.js +36 -36
  478. package/cjs/ui/FileViewer.js.map +1 -1
  479. package/cjs/ui/Icon.js +447 -623
  480. package/cjs/ui/Icon.js.map +1 -1
  481. package/cjs/ui/IconButton.js +20 -31
  482. package/cjs/ui/IconButton.js.map +1 -1
  483. package/cjs/ui/ImageRenderer.js +34 -43
  484. package/cjs/ui/ImageRenderer.js.map +1 -1
  485. package/cjs/ui/Input.js +16 -16
  486. package/cjs/ui/Input.js.map +1 -1
  487. package/cjs/ui/Label.js +2 -2
  488. package/cjs/ui/LinkLabel.js +4 -3
  489. package/cjs/ui/LinkLabel.js.map +1 -1
  490. package/cjs/ui/Loader.js +10 -12
  491. package/cjs/ui/Loader.js.map +1 -1
  492. package/cjs/ui/MentionLabel.js +58 -65
  493. package/cjs/ui/MentionLabel.js.map +1 -1
  494. package/cjs/ui/MentionUserLabel.js +12 -10
  495. package/cjs/ui/MentionUserLabel.js.map +1 -1
  496. package/cjs/ui/MessageContent.js +212 -548
  497. package/cjs/ui/MessageContent.js.map +1 -1
  498. package/cjs/ui/MessageInput.js +392 -119
  499. package/cjs/ui/MessageInput.js.map +1 -1
  500. package/cjs/ui/MessageItemMenu.js +83 -83
  501. package/cjs/ui/MessageItemMenu.js.map +1 -1
  502. package/cjs/ui/MessageItemReactionMenu.js +58 -62
  503. package/cjs/ui/MessageItemReactionMenu.js.map +1 -1
  504. package/cjs/ui/MessageSearchFileItem.js +56 -51
  505. package/cjs/ui/MessageSearchFileItem.js.map +1 -1
  506. package/cjs/ui/MessageSearchItem.js +42 -41
  507. package/cjs/ui/MessageSearchItem.js.map +1 -1
  508. package/cjs/ui/MessageStatus.js +10 -11
  509. package/cjs/ui/MessageStatus.js.map +1 -1
  510. package/cjs/ui/Modal.js +52 -46
  511. package/cjs/ui/Modal.js.map +1 -1
  512. package/cjs/ui/MutedAvatarOverlay.js +10 -10
  513. package/cjs/ui/MutedAvatarOverlay.js.map +1 -1
  514. package/cjs/ui/OGMessageItemBody.js +67 -63
  515. package/cjs/ui/OGMessageItemBody.js.map +1 -1
  516. package/cjs/ui/OpenChannelAdminMessage.js +8 -7
  517. package/cjs/ui/OpenChannelAdminMessage.js.map +1 -1
  518. package/cjs/ui/OpenChannelAvatar.js +18 -17
  519. package/cjs/ui/OpenChannelAvatar.js.map +1 -1
  520. package/cjs/ui/OpenchannelConversationHeader.js +17 -13
  521. package/cjs/ui/OpenchannelConversationHeader.js.map +1 -1
  522. package/cjs/ui/OpenchannelFileMessage.js +140 -151
  523. package/cjs/ui/OpenchannelFileMessage.js.map +1 -1
  524. package/cjs/ui/OpenchannelOGMessage.js +204 -233
  525. package/cjs/ui/OpenchannelOGMessage.js.map +1 -1
  526. package/cjs/ui/OpenchannelThumbnailMessage.js +215 -222
  527. package/cjs/ui/OpenchannelThumbnailMessage.js.map +1 -1
  528. package/cjs/ui/OpenchannelUserMessage.js +168 -178
  529. package/cjs/ui/OpenchannelUserMessage.js.map +1 -1
  530. package/cjs/ui/PlaceHolder.js +5 -6
  531. package/cjs/ui/PlaceHolder.js.map +1 -1
  532. package/cjs/ui/PlaybackTime.js +35 -0
  533. package/cjs/ui/PlaybackTime.js.map +1 -0
  534. package/cjs/ui/ProgressBar.js +40 -0
  535. package/cjs/ui/ProgressBar.js.map +1 -0
  536. package/cjs/ui/QuoteMessage.js +50 -44
  537. package/cjs/ui/QuoteMessage.js.map +1 -1
  538. package/cjs/ui/QuoteMessageInput.js +31 -29
  539. package/cjs/ui/QuoteMessageInput.js.map +1 -1
  540. package/cjs/ui/ReactionBadge.js +13 -21
  541. package/cjs/ui/ReactionBadge.js.map +1 -1
  542. package/cjs/ui/ReactionButton.js +30 -27
  543. package/cjs/ui/ReactionButton.js.map +1 -1
  544. package/cjs/ui/SortByRow.js +14 -18
  545. package/cjs/ui/SortByRow.js.map +1 -1
  546. package/cjs/ui/TextButton.js +13 -21
  547. package/cjs/ui/TextButton.js.map +1 -1
  548. package/cjs/ui/TextMessageItemBody.js +41 -48
  549. package/cjs/ui/TextMessageItemBody.js.map +1 -1
  550. package/cjs/ui/ThreadReplies.js +25 -22
  551. package/cjs/ui/ThreadReplies.js.map +1 -1
  552. package/cjs/ui/ThumbnailMessageItemBody.js +36 -45
  553. package/cjs/ui/ThumbnailMessageItemBody.js.map +1 -1
  554. package/cjs/ui/Toggle.js +202 -0
  555. package/cjs/ui/Toggle.js.map +1 -0
  556. package/cjs/ui/Tooltip.js +8 -9
  557. package/cjs/ui/Tooltip.js.map +1 -1
  558. package/cjs/ui/TooltipWrapper.js +17 -20
  559. package/cjs/ui/TooltipWrapper.js.map +1 -1
  560. package/cjs/ui/UnknownMessageItemBody.js +21 -22
  561. package/cjs/ui/UnknownMessageItemBody.js.map +1 -1
  562. package/cjs/ui/UserListItem.js +76 -76
  563. package/cjs/ui/UserListItem.js.map +1 -1
  564. package/cjs/ui/UserProfile.js +31 -29
  565. package/cjs/ui/UserProfile.js.map +1 -1
  566. package/cjs/ui/VoiceMessageItemBody.js +119 -0
  567. package/cjs/ui/VoiceMessageItemBody.js.map +1 -0
  568. package/cjs/ui/VoiceMessgeInput.js +22 -0
  569. package/cjs/ui/VoiceMessgeInput.js.map +1 -0
  570. package/cjs/ui/Word.js +31 -39
  571. package/cjs/ui/Word.js.map +1 -1
  572. package/cjs/useDirtyGetMentions-b8ca5675.js +77 -0
  573. package/cjs/useDirtyGetMentions-b8ca5675.js.map +1 -0
  574. package/cjs/useLongPress-8037894e.js +87 -0
  575. package/cjs/useLongPress-8037894e.js.map +1 -0
  576. package/cjs/useSendbirdStateContext.js +2 -3
  577. package/cjs/useSendbirdStateContext.js.map +1 -1
  578. package/cjs/utils/message/getOutgoingMessageState.js +16 -21
  579. package/cjs/utils/message/getOutgoingMessageState.js.map +1 -1
  580. package/cjs/utils/message/isVoiceMessage.js +12 -0
  581. package/cjs/utils/message/isVoiceMessage.js.map +1 -0
  582. package/cjs/{utils-5f86a394.js → utils-01ff5332.js} +3 -7
  583. package/cjs/{utils-5f86a394.js.map → utils-01ff5332.js.map} +1 -1
  584. package/cjs/utils-2edcddc8.js +35 -0
  585. package/cjs/utils-2edcddc8.js.map +1 -0
  586. package/cjs/utils-5ac3db44.js +31 -0
  587. package/cjs/utils-5ac3db44.js.map +1 -0
  588. package/cjs/{utils-374d57b4.js → utils-ad7b5b82.js} +1 -1
  589. package/cjs/{utils-374d57b4.js.map → utils-ad7b5b82.js.map} +1 -1
  590. package/cjs/uuid-12b01f73.js +15 -0
  591. package/cjs/{uuid-2475ef6c.js.map → uuid-12b01f73.js.map} +1 -1
  592. package/cjs/withSendbird.js +5 -6
  593. package/cjs/withSendbird.js.map +1 -1
  594. package/{color-163ba24d.js → color-347926b6.js} +5 -14
  595. package/{color-163ba24d.js.map → color-347926b6.js.map} +1 -1
  596. package/{compareIds-ef41eb2c.js → compareIds-3a43c11b.js} +5 -6
  597. package/compareIds-3a43c11b.js.map +1 -0
  598. package/const-18dba7a4.js +13 -0
  599. package/const-18dba7a4.js.map +1 -0
  600. package/{const-76d87f47.js → const-c608f749.js} +4 -4
  601. package/const-c608f749.js.map +1 -0
  602. package/consts-6bca01c7.js +4 -0
  603. package/consts-6bca01c7.js.map +1 -0
  604. package/consts-7a169a0f.js +4 -0
  605. package/consts-7a169a0f.js.map +1 -0
  606. package/consts-c1baf70a.js +27 -0
  607. package/consts-c1baf70a.js.map +1 -0
  608. package/consts-fb4d475a.js +4 -0
  609. package/consts-fb4d475a.js.map +1 -0
  610. package/context-786ef1a2.js +13 -0
  611. package/{context-10475c77.js.map → context-786ef1a2.js.map} +1 -1
  612. package/dist/index.css +1640 -1187
  613. package/dist/index.css.map +1 -1
  614. package/handlers/OpenChannelHandler.js.map +1 -1
  615. package/handlers/SessionHandler.js.map +1 -1
  616. package/{index-12754b45.js → index-06b854f7.js} +55 -63
  617. package/index-06b854f7.js.map +1 -0
  618. package/index-2673effb.js +360 -0
  619. package/index-2673effb.js.map +1 -0
  620. package/{index-4ebfc7a7.js → index-319984d0.js} +1 -1
  621. package/{index-4ebfc7a7.js.map → index-319984d0.js.map} +1 -1
  622. package/{index-3c013a28.js → index-4455855e.js} +2 -2
  623. package/{index-3c013a28.js.map → index-4455855e.js.map} +1 -1
  624. package/index-6663ce18.js +450 -0
  625. package/index-6663ce18.js.map +1 -0
  626. package/{index-a02da5bd.js → index-6c252d25.js} +2 -2
  627. package/{index-a02da5bd.js.map → index-6c252d25.js.map} +1 -1
  628. package/index-71a20863.js +320 -0
  629. package/index-71a20863.js.map +1 -0
  630. package/index-7d71b26c.js +154 -0
  631. package/index-7d71b26c.js.map +1 -0
  632. package/{index-2f346069.js → index-9a4e0846.js} +1 -1
  633. package/index-9a4e0846.js.map +1 -0
  634. package/{index-232388fa.js → index-9cd77b08.js} +29 -37
  635. package/index-9cd77b08.js.map +1 -0
  636. package/index-c149ea48.js +187 -0
  637. package/index-c149ea48.js.map +1 -0
  638. package/index-cf3939c6.js +76 -0
  639. package/index-cf3939c6.js.map +1 -0
  640. package/index-cf859f03.js +540 -0
  641. package/index-cf859f03.js.map +1 -0
  642. package/{index-2784bdd8.js → index-e33f7f55.js} +11 -25
  643. package/index-e33f7f55.js.map +1 -0
  644. package/{index-aea7b7d6.js → index-eabd1e7e.js} +39 -48
  645. package/index-eabd1e7e.js.map +1 -0
  646. package/index-ebb62af1.js +51 -0
  647. package/index-ebb62af1.js.map +1 -0
  648. package/{index-751f97ce.js → index-edf844f0.js} +57 -4
  649. package/index-edf844f0.js.map +1 -0
  650. package/index.d.ts +176 -124
  651. package/index.js +84 -63
  652. package/index.js.map +1 -1
  653. package/index.module-6b7ed635.js +4 -0
  654. package/index.module-6b7ed635.js.map +1 -0
  655. package/lame.all.js +2537 -0
  656. package/lame.all.js.map +1 -0
  657. package/package.json +62 -41
  658. package/resolvedReplyType-8776d777.js +29 -0
  659. package/resolvedReplyType-8776d777.js.map +1 -0
  660. package/sendbirdSelectors.js +307 -417
  661. package/sendbirdSelectors.js.map +1 -1
  662. package/{stringSet-9ae71b7d.js → stringSet-e0ee1265.js} +112 -90
  663. package/stringSet-e0ee1265.js.map +1 -0
  664. package/tokenize-1b053c86.js +159 -0
  665. package/tokenize-1b053c86.js.map +1 -0
  666. package/topics-70f569e9.js +16 -0
  667. package/topics-70f569e9.js.map +1 -0
  668. package/types-77bbdda6.js +15 -0
  669. package/types-77bbdda6.js.map +1 -0
  670. package/ui/Accordion.js +21 -24
  671. package/ui/Accordion.js.map +1 -1
  672. package/ui/AccordionGroup.js +10 -13
  673. package/ui/AccordionGroup.js.map +1 -1
  674. package/ui/AdminMessage.js +10 -13
  675. package/ui/AdminMessage.js.map +1 -1
  676. package/ui/Avatar.js +57 -79
  677. package/ui/Avatar.js.map +1 -1
  678. package/ui/Badge.js +16 -15
  679. package/ui/Badge.js.map +1 -1
  680. package/ui/BottomSheet.js +14 -12
  681. package/ui/BottomSheet.js.map +1 -1
  682. package/ui/Button.js +20 -35
  683. package/ui/Button.js.map +1 -1
  684. package/ui/ChannelAvatar.js +38 -41
  685. package/ui/ChannelAvatar.js.map +1 -1
  686. package/ui/Checkbox.js +11 -13
  687. package/ui/Checkbox.js.map +1 -1
  688. package/ui/ConnectionStatus.js +7 -5
  689. package/ui/ConnectionStatus.js.map +1 -1
  690. package/ui/ContextMenu.js +176 -200
  691. package/ui/ContextMenu.js.map +1 -1
  692. package/ui/DateSeparator.js +12 -14
  693. package/ui/DateSeparator.js.map +1 -1
  694. package/ui/EmojiReactions.js +300 -108
  695. package/ui/EmojiReactions.js.map +1 -1
  696. package/ui/FileMessageItemBody.js +22 -23
  697. package/ui/FileMessageItemBody.js.map +1 -1
  698. package/ui/FileViewer.js +36 -36
  699. package/ui/FileViewer.js.map +1 -1
  700. package/ui/Icon.js +448 -622
  701. package/ui/Icon.js.map +1 -1
  702. package/ui/IconButton.js +20 -31
  703. package/ui/IconButton.js.map +1 -1
  704. package/ui/ImageRenderer.js +34 -43
  705. package/ui/ImageRenderer.js.map +1 -1
  706. package/ui/Input.js +16 -16
  707. package/ui/Input.js.map +1 -1
  708. package/ui/Label.js +2 -2
  709. package/ui/LinkLabel.js +4 -3
  710. package/ui/LinkLabel.js.map +1 -1
  711. package/ui/Loader.js +10 -12
  712. package/ui/Loader.js.map +1 -1
  713. package/ui/MentionLabel.js +58 -65
  714. package/ui/MentionLabel.js.map +1 -1
  715. package/ui/MentionUserLabel.js +12 -10
  716. package/ui/MentionUserLabel.js.map +1 -1
  717. package/ui/MessageContent.js +215 -551
  718. package/ui/MessageContent.js.map +1 -1
  719. package/ui/MessageInput.js +392 -120
  720. package/ui/MessageInput.js.map +1 -1
  721. package/ui/MessageItemMenu.js +83 -83
  722. package/ui/MessageItemMenu.js.map +1 -1
  723. package/ui/MessageItemReactionMenu.js +58 -62
  724. package/ui/MessageItemReactionMenu.js.map +1 -1
  725. package/ui/MessageSearchFileItem.js +55 -50
  726. package/ui/MessageSearchFileItem.js.map +1 -1
  727. package/ui/MessageSearchItem.js +41 -40
  728. package/ui/MessageSearchItem.js.map +1 -1
  729. package/ui/MessageStatus.js +10 -11
  730. package/ui/MessageStatus.js.map +1 -1
  731. package/ui/Modal.js +52 -46
  732. package/ui/Modal.js.map +1 -1
  733. package/ui/MutedAvatarOverlay.js +10 -10
  734. package/ui/MutedAvatarOverlay.js.map +1 -1
  735. package/ui/OGMessageItemBody.js +68 -64
  736. package/ui/OGMessageItemBody.js.map +1 -1
  737. package/ui/OpenChannelAdminMessage.js +8 -7
  738. package/ui/OpenChannelAdminMessage.js.map +1 -1
  739. package/ui/OpenChannelAvatar.js +18 -17
  740. package/ui/OpenChannelAvatar.js.map +1 -1
  741. package/ui/OpenchannelConversationHeader.js +17 -13
  742. package/ui/OpenchannelConversationHeader.js.map +1 -1
  743. package/ui/OpenchannelFileMessage.js +140 -151
  744. package/ui/OpenchannelFileMessage.js.map +1 -1
  745. package/ui/OpenchannelOGMessage.js +204 -233
  746. package/ui/OpenchannelOGMessage.js.map +1 -1
  747. package/ui/OpenchannelThumbnailMessage.js +215 -222
  748. package/ui/OpenchannelThumbnailMessage.js.map +1 -1
  749. package/ui/OpenchannelUserMessage.js +168 -178
  750. package/ui/OpenchannelUserMessage.js.map +1 -1
  751. package/ui/PlaceHolder.js +5 -6
  752. package/ui/PlaceHolder.js.map +1 -1
  753. package/ui/PlaybackTime.js +26 -0
  754. package/ui/PlaybackTime.js.map +1 -0
  755. package/ui/ProgressBar.js +30 -0
  756. package/ui/ProgressBar.js.map +1 -0
  757. package/ui/QuoteMessage.js +50 -44
  758. package/ui/QuoteMessage.js.map +1 -1
  759. package/ui/QuoteMessageInput.js +31 -29
  760. package/ui/QuoteMessageInput.js.map +1 -1
  761. package/ui/ReactionBadge.js +13 -21
  762. package/ui/ReactionBadge.js.map +1 -1
  763. package/ui/ReactionButton.js +30 -27
  764. package/ui/ReactionButton.js.map +1 -1
  765. package/ui/SortByRow.js +14 -18
  766. package/ui/SortByRow.js.map +1 -1
  767. package/ui/TextButton.js +13 -21
  768. package/ui/TextButton.js.map +1 -1
  769. package/ui/TextMessageItemBody.js +41 -48
  770. package/ui/TextMessageItemBody.js.map +1 -1
  771. package/ui/ThreadReplies.js +25 -22
  772. package/ui/ThreadReplies.js.map +1 -1
  773. package/ui/ThumbnailMessageItemBody.js +36 -45
  774. package/ui/ThumbnailMessageItemBody.js.map +1 -1
  775. package/ui/Toggle.js +191 -0
  776. package/ui/Toggle.js.map +1 -0
  777. package/ui/Tooltip.js +8 -9
  778. package/ui/Tooltip.js.map +1 -1
  779. package/ui/TooltipWrapper.js +17 -20
  780. package/ui/TooltipWrapper.js.map +1 -1
  781. package/ui/UnknownMessageItemBody.js +21 -22
  782. package/ui/UnknownMessageItemBody.js.map +1 -1
  783. package/ui/UserListItem.js +76 -76
  784. package/ui/UserListItem.js.map +1 -1
  785. package/ui/UserProfile.js +31 -29
  786. package/ui/UserProfile.js.map +1 -1
  787. package/ui/VoiceMessageItemBody.js +110 -0
  788. package/ui/VoiceMessageItemBody.js.map +1 -0
  789. package/ui/VoiceMessgeInput.js +14 -0
  790. package/ui/VoiceMessgeInput.js.map +1 -0
  791. package/ui/Word.js +31 -39
  792. package/ui/Word.js.map +1 -1
  793. package/useDirtyGetMentions-f00f1f94.js +75 -0
  794. package/useDirtyGetMentions-f00f1f94.js.map +1 -0
  795. package/useLongPress-1ab49410.js +85 -0
  796. package/useLongPress-1ab49410.js.map +1 -0
  797. package/useSendbirdStateContext.js +2 -3
  798. package/useSendbirdStateContext.js.map +1 -1
  799. package/utils/message/getOutgoingMessageState.js +9 -15
  800. package/utils/message/getOutgoingMessageState.js.map +1 -1
  801. package/utils/message/isVoiceMessage.js +8 -0
  802. package/utils/message/isVoiceMessage.js.map +1 -0
  803. package/{utils-ea66f822.js → utils-56cb7de5.js} +1 -1
  804. package/{utils-ea66f822.js.map → utils-56cb7de5.js.map} +1 -1
  805. package/utils-77f7e8b2.js +29 -0
  806. package/utils-77f7e8b2.js.map +1 -0
  807. package/{utils-ddb0df4c.js → utils-7f3d0d8c.js} +3 -7
  808. package/{utils-ddb0df4c.js.map → utils-7f3d0d8c.js.map} +1 -1
  809. package/utils-af9b1c06.js +31 -0
  810. package/utils-af9b1c06.js.map +1 -0
  811. package/uuid-92d22300.js +13 -0
  812. package/{uuid-7e004f47.js.map → uuid-92d22300.js.map} +1 -1
  813. package/withSendbird.js +5 -6
  814. package/withSendbird.js.map +1 -1
  815. package/ChannelListProvider-1d36e2e9.js.map +0 -1
  816. package/ChannelProvider-289cd35f.js.map +0 -1
  817. package/CreateChannelProvider-72b655e9.js +0 -55
  818. package/CreateChannelProvider-72b655e9.js.map +0 -1
  819. package/LocalizationContext-289c1917.js +0 -22
  820. package/MediaQueryContext-273d29f6.js +0 -90
  821. package/MediaQueryContext-273d29f6.js.map +0 -1
  822. package/MemberList-7ad0fa0b.js +0 -435
  823. package/MemberList-7ad0fa0b.js.map +0 -1
  824. package/NotificationChannel/components/NotificationChannelUI.js +0 -119
  825. package/NotificationChannel/components/NotificationChannelUI.js.map +0 -1
  826. package/NotificationChannel/components/NotificationList.js +0 -111
  827. package/NotificationChannel/components/NotificationList.js.map +0 -1
  828. package/NotificationChannel/components/NotificationMessageWrap.js +0 -136
  829. package/NotificationChannel/components/NotificationMessageWrap.js.map +0 -1
  830. package/NotificationChannel/context.js +0 -12
  831. package/NotificationChannel.js +0 -58
  832. package/NotificationChannel.js.map +0 -1
  833. package/NotificationChannelProvider-ad556c64.js +0 -535
  834. package/NotificationChannelProvider-ad556c64.js.map +0 -1
  835. package/OpenChannelListProvider-0febf8b2.js +0 -434
  836. package/OpenChannelListProvider-0febf8b2.js.map +0 -1
  837. package/OpenChannelProvider-c254c663.js +0 -2000
  838. package/OpenChannelProvider-c254c663.js.map +0 -1
  839. package/RemoveMessageModal-d6cbf9fa.js +0 -31
  840. package/RemoveMessageModal-d6cbf9fa.js.map +0 -1
  841. package/ThreadProvider-8696ef31.js +0 -1644
  842. package/ThreadProvider-8696ef31.js.map +0 -1
  843. package/_rollupPluginBabelHelpers-519f674b.js.map +0 -1
  844. package/actionTypes-9f87e87f.js +0 -6
  845. package/actionTypes-9f87e87f.js.map +0 -1
  846. package/cjs/ChannelListProvider-0de52d2b.js.map +0 -1
  847. package/cjs/ChannelProvider-fc58e60e.js.map +0 -1
  848. package/cjs/CreateChannelProvider-a82d20f4.js +0 -62
  849. package/cjs/CreateChannelProvider-a82d20f4.js.map +0 -1
  850. package/cjs/MediaQueryContext-4711a81f.js +0 -97
  851. package/cjs/MediaQueryContext-4711a81f.js.map +0 -1
  852. package/cjs/MemberList-b2623166.js +0 -441
  853. package/cjs/MemberList-b2623166.js.map +0 -1
  854. package/cjs/NotificationChannel/components/NotificationChannelUI.js +0 -125
  855. package/cjs/NotificationChannel/components/NotificationChannelUI.js.map +0 -1
  856. package/cjs/NotificationChannel/components/NotificationList.js +0 -117
  857. package/cjs/NotificationChannel/components/NotificationList.js.map +0 -1
  858. package/cjs/NotificationChannel/components/NotificationMessageWrap.js +0 -142
  859. package/cjs/NotificationChannel/components/NotificationMessageWrap.js.map +0 -1
  860. package/cjs/NotificationChannel/context.js +0 -21
  861. package/cjs/NotificationChannel.js +0 -64
  862. package/cjs/NotificationChannel.js.map +0 -1
  863. package/cjs/NotificationChannelProvider-2cdc7ff4.js +0 -543
  864. package/cjs/NotificationChannelProvider-2cdc7ff4.js.map +0 -1
  865. package/cjs/OpenChannelListProvider-60bc3c69.js +0 -443
  866. package/cjs/OpenChannelListProvider-60bc3c69.js.map +0 -1
  867. package/cjs/OpenChannelProvider-3ed4eb6e.js +0 -2009
  868. package/cjs/OpenChannelProvider-3ed4eb6e.js.map +0 -1
  869. package/cjs/RemoveMessageModal-9169766a.js.map +0 -1
  870. package/cjs/ThreadProvider-389f5031.js +0 -1653
  871. package/cjs/ThreadProvider-389f5031.js.map +0 -1
  872. package/cjs/_rollupPluginBabelHelpers-fed1e122.js.map +0 -1
  873. package/cjs/actionTypes-2f90e726.js +0 -10
  874. package/cjs/actionTypes-2f90e726.js.map +0 -1
  875. package/cjs/color-f47044b3.js.map +0 -1
  876. package/cjs/compareIds-4124b297.js.map +0 -1
  877. package/cjs/const-015e5589.js +0 -20
  878. package/cjs/const-015e5589.js.map +0 -1
  879. package/cjs/const-fd64914b.js.map +0 -1
  880. package/cjs/index-30c97863.js +0 -194
  881. package/cjs/index-30c97863.js.map +0 -1
  882. package/cjs/index-3a4f8219.js.map +0 -1
  883. package/cjs/index-40e4653a.js +0 -59
  884. package/cjs/index-40e4653a.js.map +0 -1
  885. package/cjs/index-5d5497c2.js.map +0 -1
  886. package/cjs/index-62c1bdfc.js +0 -701
  887. package/cjs/index-62c1bdfc.js.map +0 -1
  888. package/cjs/index-9ca07037.js.map +0 -1
  889. package/cjs/index-9f3670d0.js +0 -360
  890. package/cjs/index-9f3670d0.js.map +0 -1
  891. package/cjs/index-abbc8024.js.map +0 -1
  892. package/cjs/index-c475c3c8.js.map +0 -1
  893. package/cjs/index-c5cd589d.js.map +0 -1
  894. package/cjs/stringSet-3e6167ef.js.map +0 -1
  895. package/cjs/topics-56842e14.js +0 -22
  896. package/cjs/topics-56842e14.js.map +0 -1
  897. package/cjs/tslib.es6-b8ba50ef.js +0 -110
  898. package/cjs/tslib.es6-b8ba50ef.js.map +0 -1
  899. package/cjs/useLongPress-99c66f7f.js +0 -118
  900. package/cjs/useLongPress-99c66f7f.js.map +0 -1
  901. package/cjs/utils-9adfd244.js +0 -38
  902. package/cjs/utils-9adfd244.js.map +0 -1
  903. package/cjs/utils-f6a96ebf.js +0 -32
  904. package/cjs/utils-f6a96ebf.js.map +0 -1
  905. package/cjs/uuid-2475ef6c.js +0 -19
  906. package/compareIds-ef41eb2c.js.map +0 -1
  907. package/const-76d87f47.js.map +0 -1
  908. package/const-da6f3d34.js +0 -14
  909. package/const-da6f3d34.js.map +0 -1
  910. package/context-10475c77.js +0 -12
  911. package/index-12754b45.js.map +0 -1
  912. package/index-1e46e582.js +0 -179
  913. package/index-1e46e582.js.map +0 -1
  914. package/index-232388fa.js.map +0 -1
  915. package/index-2784bdd8.js.map +0 -1
  916. package/index-2f346069.js.map +0 -1
  917. package/index-4637b0de.js +0 -57
  918. package/index-4637b0de.js.map +0 -1
  919. package/index-4900e890.js +0 -353
  920. package/index-4900e890.js.map +0 -1
  921. package/index-751f97ce.js.map +0 -1
  922. package/index-855ef33d.js +0 -662
  923. package/index-855ef33d.js.map +0 -1
  924. package/index-aea7b7d6.js.map +0 -1
  925. package/stringSet-9ae71b7d.js.map +0 -1
  926. package/topics-e2963bba.js +0 -13
  927. package/topics-e2963bba.js.map +0 -1
  928. package/tslib.es6-72df3331.js +0 -104
  929. package/tslib.es6-72df3331.js.map +0 -1
  930. package/useLongPress-1a777e9e.js +0 -116
  931. package/useLongPress-1a777e9e.js.map +0 -1
  932. package/utils-2976f2c1.js +0 -30
  933. package/utils-2976f2c1.js.map +0 -1
  934. package/utils-6b69fb18.js +0 -34
  935. package/utils-6b69fb18.js.map +0 -1
  936. package/uuid-7e004f47.js +0 -17
@@ -1,2000 +0,0 @@
1
- import React__default, { useEffect, useCallback, useState, useReducer, useRef, useMemo } from 'react';
2
- import { f as format } from './index-3c013a28.js';
3
- import { U as UserProfileProvider } from './UserProfileContext-e3530842.js';
4
- import { _ as __assign, a as __spreadArray } from './tslib.es6-72df3331.js';
5
- import { c as compareIds } from './compareIds-ef41eb2c.js';
6
- import { a as SEND_USER_MESSAGE, S as SEND_MESSAGE_START, b as SEND_FILE_MESSAGE, U as UPDATE_USER_MESSAGE, D as DELETE_MESSAGE } from './topics-e2963bba.js';
7
- import { ChannelType } from '@sendbird/chat';
8
- import { OpenChannelHandler } from '@sendbird/chat/openChannel';
9
- import { u as uuidv4 } from './uuid-7e004f47.js';
10
- import useSendbirdStateContext from './useSendbirdStateContext.js';
11
-
12
- var getMessageCreatedAt = function (message) {
13
- return format(message.createdAt, 'p');
14
- };
15
- var shouldFetchMore = function (messageLength, maxMessages) {
16
- if (typeof maxMessages !== 'number') {
17
- return true;
18
- }
19
-
20
- if (typeof maxMessages === 'number' && maxMessages > messageLength) {
21
- return true;
22
- }
23
-
24
- return false;
25
- };
26
- var scrollIntoLast = function (initialTry, scrollRef) {
27
- if (initialTry === void 0) {
28
- initialTry = 0;
29
- }
30
-
31
- var MAX_TRIES = 10;
32
- var currentTry = initialTry;
33
-
34
- if (currentTry > MAX_TRIES) {
35
- return;
36
- }
37
-
38
- try {
39
- var scrollDOM = (scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current) || document.querySelector('.sendbird-openchannel-conversation-scroll__container__item-container'); // eslint-disable-next-line no-multi-assign
40
-
41
- scrollDOM.scrollTop = scrollDOM.scrollHeight;
42
- } catch (error) {
43
- setTimeout(function () {
44
- scrollIntoLast(currentTry + 1, scrollRef);
45
- }, 500 * currentTry);
46
- }
47
- };
48
- var isSameGroup = function (message, comparingMessage) {
49
- var _a, _b, _c, _d;
50
-
51
- if (!(message && comparingMessage && (message === null || message === void 0 ? void 0 : message.messageType) && message.messageType !== 'admin' && (comparingMessage === null || comparingMessage === void 0 ? void 0 : comparingMessage.messageType) && comparingMessage.messageType !== 'admin' && (message === null || message === void 0 ? void 0 : message.sender) && (comparingMessage === null || comparingMessage === void 0 ? void 0 : comparingMessage.sender) && (message === null || message === void 0 ? void 0 : message.createdAt) && (comparingMessage === null || comparingMessage === void 0 ? void 0 : comparingMessage.createdAt) && ((_a = message === null || message === void 0 ? void 0 : message.sender) === null || _a === void 0 ? void 0 : _a.userId) && ((_b = comparingMessage === null || comparingMessage === void 0 ? void 0 : comparingMessage.sender) === null || _b === void 0 ? void 0 : _b.userId))) {
52
- return false;
53
- } // to fix typecasting
54
-
55
-
56
- var message_ = message;
57
- var comparingMessage_ = comparingMessage;
58
- return (message_ === null || message_ === void 0 ? void 0 : message_.sendingStatus) === (comparingMessage_ === null || comparingMessage_ === void 0 ? void 0 : comparingMessage_.sendingStatus) && ((_c = message_ === null || message_ === void 0 ? void 0 : message_.sender) === null || _c === void 0 ? void 0 : _c.userId) === ((_d = comparingMessage_ === null || comparingMessage_ === void 0 ? void 0 : comparingMessage_.sender) === null || _d === void 0 ? void 0 : _d.userId) && getMessageCreatedAt(message) === getMessageCreatedAt(comparingMessage);
59
- };
60
- var compareMessagesForGrouping = function (prevMessage, currMessage, nextMessage) {
61
- return [isSameGroup(prevMessage, currMessage), isSameGroup(currMessage, nextMessage)];
62
- };
63
- var kFormatter = function (num) {
64
- if (Math.abs(num) > 999999) {
65
- return "".concat((Math.abs(num) / 1000000).toFixed(1), "M");
66
- }
67
-
68
- if (Math.abs(num) > 999) {
69
- return "".concat((Math.abs(num) / 1000).toFixed(1), "K");
70
- }
71
-
72
- return "".concat(num);
73
- };
74
- var isOperator = function (openChannel, userId) {
75
- var operators = openChannel === null || openChannel === void 0 ? void 0 : openChannel.operators;
76
-
77
- if (operators.map(function (operator) {
78
- return operator.userId;
79
- }).indexOf(userId) < 0) {
80
- return false;
81
- }
82
-
83
- return true;
84
- };
85
- var isDisabledBecauseFrozen = function (openChannel, userId) {
86
- var isFrozen = openChannel === null || openChannel === void 0 ? void 0 : openChannel.isFrozen;
87
- return isFrozen && !isOperator(openChannel, userId);
88
- };
89
- var isDisabledBecauseMuted = function (mutedParticipantIds, userId) {
90
- return mutedParticipantIds.indexOf(userId) > -1;
91
- };
92
- var fetchWithListQuery = function (listQuery, logger, eachQueryNextCallback) {
93
- var fetchList = function (query) {
94
- var hasNext = query.hasNext;
95
-
96
- if (hasNext) {
97
- query.next().then(function (users) {
98
- eachQueryNextCallback(users);
99
- fetchList(query);
100
- }).catch(function (error) {
101
- logger.warning('OpenChannel | FetchUserList failed', error);
102
- });
103
- } else {
104
- logger.info('OpenChannel | FetchUserList finished');
105
- }
106
- };
107
-
108
- logger.info('OpenChannel | FetchUserList start', listQuery);
109
- fetchList(listQuery);
110
- };
111
- var pxToNumber = function (px) {
112
- if (typeof px === 'number') {
113
- return px;
114
- }
115
-
116
- if (typeof px === 'string') {
117
- var parsed = Number.parseFloat(px);
118
-
119
- if (!Number.isNaN(parsed)) {
120
- return parsed;
121
- }
122
- }
123
-
124
- return null;
125
- };
126
-
127
- var SET_CURRENT_CHANNEL = 'SET_CURRENT_CHANNEL';
128
- var SET_CHANNEL_INVALID = 'SET_CHANNEL_INVALID';
129
- var RESET_MESSAGES = 'RESET_MESSAGES';
130
- var EXIT_CURRENT_CHANNEL = 'EXIT_CURRENT_CHANNEL';
131
- var GET_PREV_MESSAGES_START = 'GET_PREV_MESSAGES_START';
132
- var GET_PREV_MESSAGES_SUCESS = 'GET_PREV_MESSAGES_SUCESS';
133
- var GET_PREV_MESSAGES_FAIL = 'GET_PREV_MESSAGES_FAIL';
134
- var SENDING_MESSAGE_FAILED = 'SENDING_MESSAGE_FAILED';
135
- var SENDING_MESSAGE_SUCCEEDED = 'SENDING_MESSAGE_SUCCEEDED';
136
- var SENDING_MESSAGE_START = 'SENDING_MESSAGE_START';
137
- var RESENDING_MESSAGE_START = 'RESENDING_MESSAGE_START';
138
- var FETCH_PARTICIPANT_LIST = 'FETCH_PARTICIPANT_LIST';
139
- var FETCH_BANNED_USER_LIST = 'FETCH_BANNED_USER_LIST';
140
- var FETCH_MUTED_USER_LIST = 'FETCH_MUTED_USER_LIST';
141
- var TRIM_MESSAGE_LIST = 'TRIM_MESSAGE_LIST'; // event handlers
142
-
143
- var ON_MESSAGE_RECEIVED = 'ON_MESSAGE_RECEIVED';
144
- var ON_MESSAGE_UPDATED = 'ON_MESSAGE_UPDATED';
145
- var ON_MESSAGE_DELETED = 'ON_MESSAGE_DELETED';
146
- var ON_MESSAGE_DELETED_BY_REQ_ID = 'ON_MESSAGE_DELETED_BY_REQ_ID';
147
- var ON_OPERATOR_UPDATED = 'ON_OPERATOR_UPDATED';
148
- var ON_USER_ENTERED = 'ON_USER_ENTERED';
149
- var ON_USER_EXITED = 'ON_USER_EXITED';
150
- var ON_USER_MUTED = 'ON_USER_MUTED';
151
- var ON_USER_UNMUTED = 'ON_USER_UNMUTED';
152
- var ON_USER_BANNED = 'ON_USER_BANNED';
153
- var ON_USER_UNBANNED = 'ON_USER_UNBANNED';
154
- var ON_CHANNEL_FROZEN = 'ON_CHANNEL_FROZEN';
155
- var ON_CHANNEL_UNFROZEN = 'ON_CHANNEL_UNFROZEN';
156
- var ON_CHANNEL_CHANGED = 'ON_CHANNEL_CHANGED';
157
- var ON_CHANNEL_DELETED = 'ON_CHANNEL_DELETED';
158
- var ON_META_DATA_CREATED = 'ON_META_DATA_CREATED';
159
- var ON_META_DATA_UPDATED = 'ON_META_DATA_UPDATED';
160
- var ON_META_DATA_DELETED = 'ON_META_DATA_DELETED';
161
- var ON_META_COUNTERS_CREATED = 'ON_META_COUNTERS_CREATED';
162
- var ON_META_COUNTERS_UPDATED = 'ON_META_COUNTERS_UPDATED';
163
- var ON_META_COUNTERS_DELETED = 'ON_META_COUNTERS_DELETED';
164
- var ON_MENTION_RECEIVED = 'ON_MENTION_RECEIVED';
165
-
166
- function reducer(state, action) {
167
- var _a, _b, _c;
168
-
169
- switch (action.type) {
170
- case RESET_MESSAGES:
171
- {
172
- return __assign(__assign({}, state), {
173
- allMessages: []
174
- });
175
- }
176
-
177
- case EXIT_CURRENT_CHANNEL:
178
- {
179
- if (((_a = action.payload) === null || _a === void 0 ? void 0 : _a.url) === ((_b = state.currentOpenChannel) === null || _b === void 0 ? void 0 : _b.url)) {
180
- return __assign(__assign({}, state), {
181
- currentOpenChannel: null
182
- });
183
- }
184
-
185
- return state;
186
- }
187
-
188
- case SET_CURRENT_CHANNEL:
189
- {
190
- var gottenChannel = action.payload;
191
- var operators = gottenChannel.operators;
192
-
193
- if (!state.isInvalid && state.currentOpenChannel && state.currentOpenChannel.url && state.currentOpenChannel.url === gottenChannel.url) {
194
- return state;
195
- }
196
-
197
- return __assign(__assign({}, state), {
198
- currentOpenChannel: gottenChannel,
199
- isInvalid: false,
200
- operators: operators,
201
- participants: operators,
202
- bannedParticipantIds: [],
203
- mutedParticipantIds: []
204
- });
205
- }
206
-
207
- case SET_CHANNEL_INVALID:
208
- {
209
- return __assign(__assign({}, state), {
210
- isInvalid: true
211
- });
212
- }
213
-
214
- case GET_PREV_MESSAGES_START:
215
- {
216
- return __assign(__assign({}, state), {
217
- loading: true
218
- });
219
- }
220
-
221
- case GET_PREV_MESSAGES_SUCESS:
222
- case GET_PREV_MESSAGES_FAIL:
223
- {
224
- var isFailed = action.type === GET_PREV_MESSAGES_FAIL;
225
- var _d = action.payload,
226
- _e = _d.currentOpenChannel,
227
- currentOpenChannel = _e === void 0 ? {} : _e,
228
- _f = _d.messages,
229
- messages = _f === void 0 ? [] : _f,
230
- hasMore = _d.hasMore,
231
- lastMessageTimestamp = _d.lastMessageTimestamp;
232
- var actionChannelUrl = currentOpenChannel.url;
233
- var receivedMessages_1 = isFailed ? [] : messages;
234
-
235
- var _hasMore = isFailed ? false : hasMore;
236
-
237
- var _lastMessageTimestamp = isFailed ? 0 : lastMessageTimestamp;
238
-
239
- var stateChannel = state.currentOpenChannel;
240
- var stateChannelUrl = stateChannel.url;
241
-
242
- if (actionChannelUrl !== stateChannelUrl) {
243
- return state;
244
- }
245
-
246
- var filteredAllMessages = state.allMessages.filter(function (message) {
247
- return !receivedMessages_1.find(function (_a) {
248
- var messageId = _a.messageId;
249
- return compareIds(messageId, message.messageId);
250
- });
251
- });
252
- return __assign(__assign({}, state), {
253
- loading: false,
254
- initialized: true,
255
- hasMore: _hasMore,
256
- lastMessageTimestamp: _lastMessageTimestamp,
257
- allMessages: __spreadArray(__spreadArray([], receivedMessages_1, true), filteredAllMessages, true)
258
- });
259
- }
260
-
261
- case SENDING_MESSAGE_START:
262
- {
263
- var _g = action.payload,
264
- message_1 = _g.message,
265
- channel = _g.channel;
266
-
267
- if ((channel === null || channel === void 0 ? void 0 : channel.url) !== state.currentOpenChannel.url || state.allMessages.some(function (m) {
268
- return m.reqId === message_1.reqId;
269
- }) // Handing failed first than sending start issue
270
- ) {
271
- return state;
272
- }
273
-
274
- return __assign(__assign({}, state), {
275
- allMessages: __spreadArray(__spreadArray([], state.allMessages, true), [message_1], false)
276
- });
277
- }
278
-
279
- case SENDING_MESSAGE_SUCCEEDED:
280
- {
281
- var sentMessage_1 = action.payload;
282
- var newMessages = state.allMessages.map(function (m) {
283
- return compareIds(m.reqId, sentMessage_1.reqId) ? sentMessage_1 : m;
284
- });
285
- return __assign(__assign({}, state), {
286
- allMessages: newMessages
287
- });
288
- }
289
-
290
- case SENDING_MESSAGE_FAILED:
291
- {
292
- var sentMessage_2 = action.payload;
293
- sentMessage_2.sendingStatus = 'failed';
294
-
295
- if (!state.allMessages.some(function (m) {
296
- return (m === null || m === void 0 ? void 0 : m.reqId) === (sentMessage_2 === null || sentMessage_2 === void 0 ? void 0 : sentMessage_2.reqId);
297
- })) {
298
- // Handling failed first than sending start issue
299
- return __assign(__assign({}, state), {
300
- allMessages: __spreadArray(__spreadArray([], state.allMessages.filter(function (m) {
301
- return !compareIds(m.reqId, sentMessage_2);
302
- }), true), [sentMessage_2], false)
303
- });
304
- } else {
305
- return __assign(__assign({}, state), {
306
- allMessages: state.allMessages.map(function (m) {
307
- return compareIds(m.reqId, sentMessage_2.reqId) ? sentMessage_2 : m;
308
- })
309
- });
310
- }
311
- }
312
-
313
- case TRIM_MESSAGE_LIST:
314
- {
315
- var allMessages = state.allMessages;
316
- var messageLimit = (_c = action.payload) === null || _c === void 0 ? void 0 : _c.messageLimit;
317
-
318
- if (messageLimit && messageLimit > 0 && (allMessages === null || allMessages === void 0 ? void 0 : allMessages.length) > messageLimit) {
319
- var sliceAt = allMessages.length - messageLimit;
320
- return __assign(__assign({}, state), {
321
- allMessages: allMessages.slice(sliceAt)
322
- });
323
- }
324
-
325
- return state;
326
- }
327
-
328
- case RESENDING_MESSAGE_START:
329
- {
330
- var eventedChannel = action.payload.channel;
331
- var resentMessage_1 = action.payload.message;
332
-
333
- if (eventedChannel.url !== state.currentOpenChannel.url) {
334
- return state;
335
- }
336
-
337
- return __assign(__assign({}, state), {
338
- allMessages: state.allMessages.map(function (m) {
339
- return compareIds(m.reqId, resentMessage_1.reqId) ? resentMessage_1 : m;
340
- })
341
- });
342
- }
343
-
344
- case FETCH_PARTICIPANT_LIST:
345
- {
346
- var eventedChannel = action.payload.channel;
347
- var fetchedParticipantList = action.payload.users;
348
-
349
- if (eventedChannel.url !== state.currentOpenChannel.url) {
350
- return state;
351
- }
352
-
353
- return __assign(__assign({}, state), {
354
- participants: __spreadArray(__spreadArray([], state.participants, true), fetchedParticipantList, true)
355
- });
356
- }
357
-
358
- case FETCH_BANNED_USER_LIST:
359
- {
360
- var eventedChannel = action.payload.channel;
361
- var fetchedBannedUserList = action.payload.users;
362
-
363
- if (eventedChannel.url !== state.currentOpenChannel.url || !fetchedBannedUserList.every(function (user) {
364
- return typeof user.userId === 'string';
365
- })) {
366
- return state;
367
- }
368
-
369
- return __assign(__assign({}, state), {
370
- bannedParticipantIds: __spreadArray(__spreadArray([], state.bannedParticipantIds, true), fetchedBannedUserList.map(function (user) {
371
- return user.userId;
372
- }), true)
373
- });
374
- }
375
-
376
- case FETCH_MUTED_USER_LIST:
377
- {
378
- var eventedChannel = action.payload.channel;
379
- var fetchedMutedUserList = action.payload.users;
380
-
381
- if (eventedChannel.url !== state.currentOpenChannel.url || !fetchedMutedUserList.every(function (user) {
382
- return typeof user.userId === 'string';
383
- })) {
384
- return state;
385
- }
386
-
387
- return __assign(__assign({}, state), {
388
- mutedParticipantIds: __spreadArray(__spreadArray([], state.mutedParticipantIds, true), fetchedMutedUserList.map(function (user) {
389
- return user.userId;
390
- }), true)
391
- });
392
- }
393
- // events
394
-
395
- case ON_MESSAGE_RECEIVED:
396
- {
397
- var eventedChannel = action.payload.channel;
398
- var receivedMessage = action.payload.message;
399
- var currentOpenChannel = state.currentOpenChannel;
400
-
401
- if (!compareIds(eventedChannel.url, currentOpenChannel.url) || !(state.allMessages.map(function (message) {
402
- return message.messageId;
403
- }).indexOf(receivedMessage.messageId) < 0)) {
404
- return state;
405
- }
406
-
407
- return __assign(__assign({}, state), {
408
- allMessages: __spreadArray(__spreadArray([], state.allMessages, true), [receivedMessage], false)
409
- });
410
- }
411
-
412
- case ON_MESSAGE_UPDATED:
413
- {
414
- var eventedChannel = action.payload.channel;
415
- var updatedMessage_1 = action.payload.message;
416
- var currentChannel = state.currentOpenChannel;
417
-
418
- if (!currentChannel || currentChannel.url && currentChannel.url !== eventedChannel.url) {
419
- return state;
420
- }
421
-
422
- return __assign(__assign({}, state), {
423
- allMessages: state.allMessages.map(function (message) {
424
- return message.isIdentical(updatedMessage_1) ? updatedMessage_1 : message;
425
- })
426
- });
427
- }
428
-
429
- case ON_MESSAGE_DELETED:
430
- {
431
- var eventedChannel = action.payload.channel;
432
- var deletedMessageId_1 = action.payload.messageId;
433
- var currentChannel = state.currentOpenChannel;
434
-
435
- if (!currentChannel || currentChannel.url && currentChannel.url !== eventedChannel.url) {
436
- return state;
437
- }
438
-
439
- return __assign(__assign({}, state), {
440
- allMessages: state.allMessages.filter(function (message) {
441
- return !compareIds(message.messageId, deletedMessageId_1);
442
- })
443
- });
444
- }
445
-
446
- case ON_MESSAGE_DELETED_BY_REQ_ID:
447
- {
448
- return __assign(__assign({}, state), {
449
- allMessages: state.allMessages.filter(function (m) {
450
- return !compareIds(m.reqId, action.payload);
451
- })
452
- });
453
- }
454
-
455
- case ON_OPERATOR_UPDATED:
456
- {
457
- var eventedChannel = action.payload.channel;
458
- var updatedOperators = action.payload.operators;
459
- var currentChannel = state.currentOpenChannel;
460
-
461
- if (!currentChannel || currentChannel.url && currentChannel.url !== eventedChannel.url) {
462
- return state;
463
- }
464
-
465
- return __assign(__assign({}, state), {
466
- currentOpenChannel: eventedChannel,
467
- operators: updatedOperators
468
- });
469
- }
470
-
471
- case ON_USER_ENTERED:
472
- {
473
- var eventedChannel = action.payload.channel;
474
- var enteredUser = action.payload.user;
475
- var currentChannel = state.currentOpenChannel;
476
-
477
- if (!currentChannel || currentChannel.url && currentChannel.url !== eventedChannel.url) {
478
- return state;
479
- }
480
-
481
- return __assign(__assign({}, state), {
482
- participants: __spreadArray(__spreadArray([], state.participants, true), [enteredUser], false)
483
- });
484
- }
485
-
486
- case ON_USER_EXITED:
487
- {
488
- var eventedChannel = action.payload.channel;
489
- var exitedUser_1 = action.payload.user;
490
- var currentChannel = state.currentOpenChannel;
491
-
492
- if (!currentChannel || currentChannel.url && currentChannel.url !== eventedChannel.url) {
493
- return state;
494
- }
495
-
496
- return __assign(__assign({}, state), {
497
- participants: state.participants.filter(function (participant) {
498
- return !compareIds(participant.userId, exitedUser_1.userId);
499
- })
500
- });
501
- }
502
-
503
- case ON_USER_MUTED:
504
- {
505
- var eventedChannel = action.payload.channel;
506
- var mutedUser = action.payload.user;
507
- var currentChannel = state.currentOpenChannel;
508
-
509
- if (!currentChannel || currentChannel.url && currentChannel.url !== eventedChannel.url || state.mutedParticipantIds.indexOf(mutedUser.userId) >= 0) {
510
- return state;
511
- }
512
-
513
- return __assign(__assign({}, state), {
514
- mutedParticipantIds: __spreadArray(__spreadArray([], state.mutedParticipantIds, true), [mutedUser.userId], false)
515
- });
516
- }
517
-
518
- case ON_USER_UNMUTED:
519
- {
520
- var eventedChannel = action.payload.channel;
521
- var unmutedUser_1 = action.payload.user;
522
- var currentChannel = state.currentOpenChannel;
523
-
524
- if (!currentChannel || currentChannel.url && currentChannel.url !== eventedChannel.url || state.mutedParticipantIds.indexOf(unmutedUser_1.userId) < 0) {
525
- return state;
526
- }
527
-
528
- return __assign(__assign({}, state), {
529
- mutedParticipantIds: state.mutedParticipantIds.filter(function (userId) {
530
- return userId !== unmutedUser_1.userId;
531
- })
532
- });
533
- }
534
-
535
- case ON_USER_BANNED:
536
- {
537
- var eventedChannel = action.payload.channel;
538
- var bannedUser = action.payload.user;
539
- var currentUser = action.payload.currentUser;
540
- var currentChannel = state.currentOpenChannel;
541
-
542
- if ((currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.url) === (eventedChannel === null || eventedChannel === void 0 ? void 0 : eventedChannel.url) && (bannedUser === null || bannedUser === void 0 ? void 0 : bannedUser.userId) === (currentUser === null || currentUser === void 0 ? void 0 : currentUser.userId)) {
543
- return __assign(__assign({}, state), {
544
- currentOpenChannel: null
545
- });
546
- } else if ((currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.url) === (eventedChannel === null || eventedChannel === void 0 ? void 0 : eventedChannel.url)) {
547
- return __assign(__assign({}, state), {
548
- bannedParticipantIds: __spreadArray(__spreadArray([], state.bannedParticipantIds, true), [bannedUser.userId], false)
549
- });
550
- }
551
-
552
- return state;
553
- }
554
-
555
- case ON_USER_UNBANNED:
556
- {
557
- var eventedChannel = action.payload.channel;
558
- var unbannedUser_1 = action.payload.user;
559
- var currentChannel = state.currentOpenChannel;
560
-
561
- if ((currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.url) === (eventedChannel === null || eventedChannel === void 0 ? void 0 : eventedChannel.url)) {
562
- return __assign(__assign({}, state), {
563
- bannedParticipantIds: state.bannedParticipantIds.filter(function (userId) {
564
- return userId !== unbannedUser_1.userId;
565
- })
566
- });
567
- }
568
-
569
- return state;
570
- }
571
-
572
- case ON_CHANNEL_FROZEN:
573
- {
574
- var frozenChannel = action.payload;
575
- var currentChannel = state.currentOpenChannel;
576
-
577
- if (!currentChannel || currentChannel.url && currentChannel.url !== frozenChannel.url) {
578
- return state;
579
- }
580
-
581
- return __assign(__assign({}, state), {
582
- frozen: true
583
- });
584
- }
585
-
586
- case ON_CHANNEL_UNFROZEN:
587
- {
588
- var unfrozenChannel = action.payload;
589
- var currentChannel = state.currentOpenChannel;
590
-
591
- if (!currentChannel || currentChannel.url && currentChannel.url !== unfrozenChannel.url) {
592
- return state;
593
- }
594
-
595
- return __assign(__assign({}, state), {
596
- frozen: false
597
- });
598
- }
599
-
600
- case ON_CHANNEL_CHANGED:
601
- {
602
- var changedChannel = action.payload;
603
- var currentChannel = state.currentOpenChannel;
604
-
605
- if (!currentChannel || currentChannel.url && currentChannel.url !== changedChannel.url) {
606
- return state;
607
- }
608
-
609
- return __assign(__assign({}, state), {
610
- currentOpenChannel: changedChannel
611
- });
612
- }
613
-
614
- case ON_CHANNEL_DELETED:
615
- {
616
- var deletedChannelUrl = action.payload;
617
- var currentChannel = state === null || state === void 0 ? void 0 : state.currentOpenChannel;
618
-
619
- if ((currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.url) === deletedChannelUrl) {
620
- return __assign(__assign({}, state), {
621
- currentOpenChannel: null
622
- });
623
- }
624
-
625
- return state;
626
- }
627
-
628
- case ON_META_DATA_CREATED:
629
- {
630
- // const eventedChannel = action.payload.channel;
631
- // const createdMetaData = action.payload.metaData;
632
- // return {
633
- // ...state
634
- // };
635
- return state;
636
- }
637
-
638
- case ON_META_DATA_UPDATED:
639
- {
640
- // const eventedChannel = action.payload.channel;
641
- // const updatedMetaData = action.payload.metaData;
642
- // return {
643
- // ...state
644
- // };
645
- return state;
646
- }
647
-
648
- case ON_META_DATA_DELETED:
649
- {
650
- // const eventedChannel = action.payload.channel;
651
- // const deletedMetaDataKeys = action.payload.metaDataKeys;
652
- // return {
653
- // ...state
654
- // };
655
- return state;
656
- }
657
-
658
- case ON_META_COUNTERS_CREATED:
659
- {
660
- // const eventedChannel = action.payload.channel;
661
- // const createdMetaCounter = action.payload.metaCounter;
662
- // return {
663
- // ...state
664
- // };
665
- return state;
666
- }
667
-
668
- case ON_META_COUNTERS_UPDATED:
669
- {
670
- // const eventedChannel = action.payload.channel;
671
- // const updatedMetaCounter = action.payload.metaCounter;
672
- // return {
673
- // ...state
674
- // };
675
- return state;
676
- }
677
-
678
- case ON_META_COUNTERS_DELETED:
679
- {
680
- // const eventedChannel = action.payload.channel;
681
- // const deletedMetaCounterKeys = action.payload.metaCounterKeys;
682
- // return {
683
- // ...state
684
- // };
685
- return state;
686
- }
687
-
688
- case ON_MENTION_RECEIVED:
689
- {
690
- // const eventedChannel = action.payload.channel;
691
- // const mentionedMessage = action.payload.message;
692
- // return {
693
- // ...state
694
- // };
695
- return state;
696
- }
697
-
698
- default:
699
- return state;
700
- }
701
- }
702
-
703
- var initialState = {
704
- allMessages: [],
705
- loading: false,
706
- initialized: false,
707
- currentOpenChannel: null,
708
- isInvalid: false,
709
- hasMore: false,
710
- lastMessageTimestamp: 0,
711
- frozen: false,
712
- operators: [],
713
- participants: [],
714
- bannedParticipantIds: [],
715
- mutedParticipantIds: []
716
- };
717
-
718
- function useSetChannel(_a, _b) {
719
- var channelUrl = _a.channelUrl,
720
- sdkInit = _a.sdkInit,
721
- fetchingParticipants = _a.fetchingParticipants,
722
- userId = _a.userId,
723
- currentOpenChannel = _a.currentOpenChannel;
724
- var sdk = _b.sdk,
725
- logger = _b.logger,
726
- messagesDispatcher = _b.messagesDispatcher;
727
- useEffect(function () {
728
- var _a;
729
-
730
- if (channelUrl && sdkInit && (sdk === null || sdk === void 0 ? void 0 : sdk.openChannel)) {
731
- if (currentOpenChannel && (currentOpenChannel === null || currentOpenChannel === void 0 ? void 0 : currentOpenChannel.exit)) {
732
- (_a = currentOpenChannel.exit) === null || _a === void 0 ? void 0 : _a.call(currentOpenChannel).then(function () {
733
- logger.info('OpenChannel | useSetChannel: Exit from the previous open channel', currentOpenChannel === null || currentOpenChannel === void 0 ? void 0 : currentOpenChannel.url);
734
- messagesDispatcher({
735
- type: EXIT_CURRENT_CHANNEL,
736
- payload: currentOpenChannel
737
- });
738
- });
739
- }
740
-
741
- logger.info('OpenChannel | useSetChannel: Fetching channel', channelUrl);
742
- sdk.openChannel.getChannel(channelUrl).then(function (openChannel) {
743
- logger.info('OpenChannel | useSetChannel: Succeeded to fetch channel', openChannel);
744
- messagesDispatcher({
745
- type: SET_CURRENT_CHANNEL,
746
- payload: openChannel
747
- });
748
- openChannel.enter().then(function () {
749
- if (openChannel.isOperator(userId)) {
750
- // only operator has a permission to fetch these list
751
- var bannedParticipantListQuery = openChannel.createBannedUserListQuery();
752
- var mutedParticipantListQuery = openChannel.createMutedUserListQuery();
753
- fetchWithListQuery(bannedParticipantListQuery, logger, function (users) {
754
- messagesDispatcher({
755
- type: FETCH_BANNED_USER_LIST,
756
- payload: {
757
- channel: openChannel,
758
- users: users
759
- }
760
- });
761
- });
762
- fetchWithListQuery(mutedParticipantListQuery, logger, function (users) {
763
- messagesDispatcher({
764
- type: FETCH_MUTED_USER_LIST,
765
- payload: {
766
- channel: openChannel,
767
- users: users
768
- }
769
- });
770
- });
771
- } else {
772
- openChannel.getMyMutedInfo().then(function (mutedInfo) {
773
- if (mutedInfo === null || mutedInfo === void 0 ? void 0 : mutedInfo.isMuted) {
774
- messagesDispatcher({
775
- type: FETCH_MUTED_USER_LIST,
776
- payload: {
777
- channel: openChannel,
778
- users: [sdk === null || sdk === void 0 ? void 0 : sdk.currentUser]
779
- }
780
- });
781
- }
782
- });
783
- }
784
-
785
- if (fetchingParticipants) {
786
- // fetch participants list
787
- var participantListQuery = openChannel.createParticipantListQuery({
788
- limit: openChannel.participantCount
789
- });
790
- fetchWithListQuery(participantListQuery, logger, function (users) {
791
- messagesDispatcher({
792
- type: FETCH_PARTICIPANT_LIST,
793
- payload: {
794
- channel: openChannel,
795
- users: users
796
- }
797
- });
798
- });
799
- }
800
- }).catch(function (error) {
801
- logger.warning('OpenChannel | useSetChannel: Failed to enter channel', {
802
- channelUrl: channelUrl,
803
- error: error
804
- });
805
- messagesDispatcher({
806
- type: SET_CHANNEL_INVALID,
807
- payload: null
808
- });
809
- });
810
- }).catch(function (error) {
811
- logger.warning('OpenChannel | useSetChannel: Failed to fetch channel', {
812
- channelUrl: channelUrl,
813
- error: error
814
- });
815
- messagesDispatcher({
816
- type: SET_CHANNEL_INVALID,
817
- payload: null
818
- });
819
- });
820
- }
821
- }, [channelUrl, sdkInit, fetchingParticipants]);
822
- }
823
-
824
- function useHandleChannelEvents(_a, _b) {
825
- var currentOpenChannel = _a.currentOpenChannel,
826
- checkScrollBottom = _a.checkScrollBottom;
827
- var sdk = _b.sdk,
828
- logger = _b.logger,
829
- messagesDispatcher = _b.messagesDispatcher,
830
- scrollRef = _b.scrollRef;
831
- useEffect(function () {
832
- var _a, _b;
833
-
834
- var messageReceiverId = uuidv4();
835
-
836
- if (currentOpenChannel && currentOpenChannel.url && ((_a = sdk === null || sdk === void 0 ? void 0 : sdk.openChannel) === null || _a === void 0 ? void 0 : _a.addOpenChannelHandler)) {
837
- logger.info('OpenChannel | useHandleChannelEvents: Setup evnet handler', messageReceiverId);
838
- var channelHandlerParams = {
839
- onMessageReceived: function (channel, message) {
840
- var scrollToEnd = checkScrollBottom();
841
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
842
- logger.info('OpenChannel | useHandleChannelEvents: onMessageReceived', {
843
- channelUrl: channelUrl,
844
- message: message
845
- });
846
- messagesDispatcher({
847
- type: ON_MESSAGE_RECEIVED,
848
- payload: {
849
- channel: channel,
850
- message: message
851
- }
852
- });
853
-
854
- if (scrollToEnd) {
855
- try {
856
- setTimeout(function () {
857
- scrollIntoLast(0, scrollRef);
858
- });
859
- } catch (error) {
860
- logger.warning('OpenChannel | onMessageReceived | scroll to end failed');
861
- }
862
- }
863
- },
864
- onMessageUpdated: function (channel, message) {
865
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
866
- logger.info('OpenChannel | useHandleChannelEvents: onMessageUpdated', {
867
- channelUrl: channelUrl,
868
- message: message
869
- });
870
- messagesDispatcher({
871
- type: ON_MESSAGE_UPDATED,
872
- payload: {
873
- channel: channel,
874
- message: message
875
- }
876
- });
877
- },
878
- onMessageDeleted: function (channel, messageId) {
879
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
880
- logger.info('OpenChannel | useHandleChannelEvents: onMessageDeleted', {
881
- channelUrl: channelUrl,
882
- messageId: messageId
883
- });
884
- messagesDispatcher({
885
- type: ON_MESSAGE_DELETED,
886
- payload: {
887
- channel: channel,
888
- messageId: messageId
889
- }
890
- });
891
- },
892
- onOperatorUpdated: function (channel, operators) {
893
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
894
- logger.info('OpenChannel | useHandleChannelEvents: onOperatorUpdated', {
895
- channelUrl: channelUrl,
896
- operators: operators
897
- });
898
- messagesDispatcher({
899
- type: ON_OPERATOR_UPDATED,
900
- payload: {
901
- channel: channel,
902
- operators: operators
903
- }
904
- });
905
- },
906
- onUserEntered: function (channel, user) {
907
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
908
- logger.info('OpenChannel | useHandleChannelEvents: onUserEntered', {
909
- channelUrl: channelUrl,
910
- user: user
911
- });
912
- messagesDispatcher({
913
- type: ON_USER_ENTERED,
914
- payload: {
915
- channel: channel,
916
- user: user
917
- }
918
- });
919
- },
920
- onUserExited: function (channel, user) {
921
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
922
- logger.info('OpenChannel | useHandleChannelEvents: onUserExited', {
923
- channelUrl: channelUrl,
924
- user: user
925
- });
926
- messagesDispatcher({
927
- type: ON_USER_EXITED,
928
- payload: {
929
- channel: channel,
930
- user: user
931
- }
932
- });
933
- },
934
- onUserMuted: function (channel, user) {
935
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
936
- logger.info('OpenChannel | useHandleChannelEvents: onUserMuted', {
937
- channelUrl: channelUrl,
938
- user: user
939
- });
940
- messagesDispatcher({
941
- type: ON_USER_MUTED,
942
- payload: {
943
- channel: channel,
944
- user: user
945
- }
946
- });
947
- },
948
- onUserUnmuted: function (channel, user) {
949
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
950
- logger.info('OpenChannel | useHandleChannelEvents: onUserUnmuted', {
951
- channelUrl: channelUrl,
952
- user: user
953
- });
954
- messagesDispatcher({
955
- type: ON_USER_UNMUTED,
956
- payload: {
957
- channel: channel,
958
- user: user
959
- }
960
- });
961
- },
962
- onUserBanned: function (channel, user) {
963
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
964
- logger.info('OpenChannel | useHandleChannelEvents: onUserBanned', {
965
- channelUrl: channelUrl,
966
- user: user
967
- });
968
- messagesDispatcher({
969
- type: ON_USER_BANNED,
970
- payload: {
971
- channel: channel,
972
- user: user,
973
- currentUser: sdk === null || sdk === void 0 ? void 0 : sdk.currentUser
974
- }
975
- });
976
- },
977
- onUserUnbanned: function (channel, user) {
978
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
979
- logger.info('OpenChannel | useHandleChannelEvents: onUserUnbanned', {
980
- channelUrl: channelUrl,
981
- user: user
982
- });
983
- messagesDispatcher({
984
- type: ON_USER_UNBANNED,
985
- payload: {
986
- channel: channel,
987
- user: user
988
- }
989
- });
990
- },
991
- onChannelFrozen: function (channel) {
992
- logger.info('OpenChannel | useHandleChannelEvents: onChannelFrozen', channel);
993
- messagesDispatcher({
994
- type: ON_CHANNEL_FROZEN,
995
- payload: channel
996
- });
997
- },
998
- onChannelUnfrozen: function (channel) {
999
- logger.info('OpenChannel | useHandleChannelEvents: onChannelUnfrozen', channel);
1000
- messagesDispatcher({
1001
- type: ON_CHANNEL_UNFROZEN,
1002
- payload: channel
1003
- });
1004
- },
1005
- onChannelChanged: function (channel) {
1006
- logger.info('OpenChannel | useHandleChannelEvents: onChannelChanged', channel);
1007
- messagesDispatcher({
1008
- type: ON_CHANNEL_CHANGED,
1009
- payload: channel
1010
- });
1011
- },
1012
- onMetaDataCreated: function (channel, metaData) {
1013
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
1014
- logger.info('OpenChannel | useHandleChannelEvents: onMetaDataCreated', {
1015
- channelUrl: channelUrl,
1016
- metaData: metaData
1017
- });
1018
- messagesDispatcher({
1019
- type: ON_META_DATA_CREATED,
1020
- payload: {
1021
- channel: channel,
1022
- metaData: metaData
1023
- }
1024
- });
1025
- },
1026
- onMetaDataUpdated: function (channel, metaData) {
1027
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
1028
- logger.info('OpenChannel | useHandleChannelEvents: onMetaDataUpdated', {
1029
- channelUrl: channelUrl,
1030
- metaData: metaData
1031
- });
1032
- messagesDispatcher({
1033
- type: ON_META_DATA_UPDATED,
1034
- payload: {
1035
- channel: channel,
1036
- metaData: metaData
1037
- }
1038
- });
1039
- },
1040
- onMetaDataDeleted: function (channel, metaDataKeys) {
1041
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
1042
- logger.info('OpenChannel | useHandleChannelEvents: onMetaDataDeleted', {
1043
- channelUrl: channelUrl,
1044
- metaDataKeys: metaDataKeys
1045
- });
1046
- messagesDispatcher({
1047
- type: ON_META_DATA_DELETED,
1048
- payload: {
1049
- channel: channel,
1050
- metaDataKeys: metaDataKeys
1051
- }
1052
- });
1053
- },
1054
- onMetaCounterCreated: function (channel, metaCounter) {
1055
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
1056
- logger.info('OpenChannel | useHandleChannelEvents: onMetaCountersCreated', {
1057
- channelUrl: channelUrl,
1058
- metaCounter: metaCounter
1059
- });
1060
- messagesDispatcher({
1061
- type: ON_META_COUNTERS_CREATED,
1062
- payload: {
1063
- channel: channel,
1064
- metaCounter: metaCounter
1065
- }
1066
- });
1067
- },
1068
- onMetaCounterUpdated: function (channel, metaCounter) {
1069
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
1070
- logger.info('OpenChannel | useHandleChannelEvents: onMetaCountersUpdated', {
1071
- channelUrl: channelUrl,
1072
- metaCounter: metaCounter
1073
- });
1074
- messagesDispatcher({
1075
- type: ON_META_COUNTERS_UPDATED,
1076
- payload: {
1077
- channel: channel,
1078
- metaCounter: metaCounter
1079
- }
1080
- });
1081
- },
1082
- onMetaCounterDeleted: function (channel, metaCounterKeys) {
1083
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
1084
- logger.info('OpenChannel | useHandleChannelEvents: onMetaCountersDeleted', {
1085
- channelUrl: channelUrl,
1086
- metaCounterKeys: metaCounterKeys
1087
- });
1088
- messagesDispatcher({
1089
- type: ON_META_COUNTERS_DELETED,
1090
- payload: {
1091
- channel: channel,
1092
- metaCounterKeys: metaCounterKeys
1093
- }
1094
- });
1095
- },
1096
- onMentionReceived: function (channel, message) {
1097
- var channelUrl = channel === null || channel === void 0 ? void 0 : channel.url;
1098
- logger.info('OpenChannel | useHandleChannelEvents: onMentionReceived', {
1099
- channelUrl: channelUrl,
1100
- message: message
1101
- });
1102
- messagesDispatcher({
1103
- type: ON_MENTION_RECEIVED,
1104
- payload: {
1105
- channel: channel,
1106
- message: message
1107
- }
1108
- });
1109
- },
1110
- onChannelDeleted: function (channelUrl, channelType) {
1111
- if (channelType === ChannelType.OPEN && (currentOpenChannel === null || currentOpenChannel === void 0 ? void 0 : currentOpenChannel.url) === channelUrl) {
1112
- messagesDispatcher({
1113
- type: ON_CHANNEL_DELETED,
1114
- payload: channelUrl
1115
- });
1116
- }
1117
- }
1118
- };
1119
- var ChannelHandler = new OpenChannelHandler(channelHandlerParams);
1120
- (_b = sdk === null || sdk === void 0 ? void 0 : sdk.openChannel) === null || _b === void 0 ? void 0 : _b.addOpenChannelHandler(messageReceiverId, ChannelHandler);
1121
- }
1122
-
1123
- return function () {
1124
- var _a;
1125
-
1126
- if ((_a = sdk === null || sdk === void 0 ? void 0 : sdk.openChannel) === null || _a === void 0 ? void 0 : _a.removeOpenChannelHandler) {
1127
- logger.info('OpenChannel | useHandleChannelEvents: Removing message receiver handler', messageReceiverId);
1128
- sdk.openChannel.removeOpenChannelHandler(messageReceiverId);
1129
- }
1130
- };
1131
- }, [currentOpenChannel]);
1132
- }
1133
-
1134
- function useInitialMessagesFetch(_a, _b) {
1135
- var currentOpenChannel = _a.currentOpenChannel,
1136
- userFilledMessageListParams = _a.userFilledMessageListParams;
1137
- var logger = _b.logger,
1138
- messagesDispatcher = _b.messagesDispatcher,
1139
- scrollRef = _b.scrollRef;
1140
- useEffect(function () {
1141
- logger.info('OpenChannel | useInitialMessagesFetch: Setup started', currentOpenChannel);
1142
- messagesDispatcher({
1143
- type: RESET_MESSAGES,
1144
- payload: null
1145
- });
1146
-
1147
- if (currentOpenChannel && currentOpenChannel.getMessagesByTimestamp) {
1148
- var messageListParams_1 = {
1149
- nextResultSize: 0,
1150
- prevResultSize: 30,
1151
- isInclusive: true,
1152
- includeReactions: false
1153
- };
1154
-
1155
- if (userFilledMessageListParams) {
1156
- Object.keys(userFilledMessageListParams).forEach(function (key) {
1157
- messageListParams_1[key] = userFilledMessageListParams[key];
1158
- });
1159
- logger.info('OpenChannel | useInitialMessagesFetch: Used customizedMessageListParams');
1160
- }
1161
-
1162
- logger.info('OpenChannel | useInitialMessagesFetch: Fetching messages', {
1163
- currentOpenChannel: currentOpenChannel,
1164
- messageListParams: messageListParams_1
1165
- });
1166
- messagesDispatcher({
1167
- type: GET_PREV_MESSAGES_START,
1168
- payload: null
1169
- });
1170
- currentOpenChannel.getMessagesByTimestamp(new Date().getTime(), messageListParams_1).then(function (messages) {
1171
- logger.info('OpenChannel | useInitialMessagesFetch: Fetching messages succeeded', messages);
1172
- var hasMore = messages && messages.length > 0;
1173
- var lastMessageTimestamp = hasMore ? messages[0].createdAt : null;
1174
- messagesDispatcher({
1175
- type: GET_PREV_MESSAGES_SUCESS,
1176
- payload: {
1177
- currentOpenChannel: currentOpenChannel,
1178
- messages: messages,
1179
- hasMore: hasMore,
1180
- lastMessageTimestamp: lastMessageTimestamp
1181
- }
1182
- });
1183
- setTimeout(function () {
1184
- scrollIntoLast(0, scrollRef);
1185
- });
1186
- }).catch(function (error) {
1187
- logger.error('OpenChannel | useInitialMessagesFetch: Fetching messages failed', error);
1188
- messagesDispatcher({
1189
- type: GET_PREV_MESSAGES_FAIL,
1190
- payload: {
1191
- currentOpenChannel: currentOpenChannel,
1192
- messages: [],
1193
- hasMore: false,
1194
- lastMessageTimestamp: 0
1195
- }
1196
- });
1197
- });
1198
- }
1199
- }, [currentOpenChannel, userFilledMessageListParams]);
1200
- }
1201
-
1202
- function useScrollCallback(_a, _b) {
1203
- var currentOpenChannel = _a.currentOpenChannel,
1204
- lastMessageTimestamp = _a.lastMessageTimestamp,
1205
- fetchMore = _a.fetchMore;
1206
- var sdk = _b.sdk,
1207
- logger = _b.logger,
1208
- messagesDispatcher = _b.messagesDispatcher,
1209
- hasMore = _b.hasMore,
1210
- userFilledMessageListParams = _b.userFilledMessageListParams;
1211
- return useCallback(function (callback) {
1212
- if (fetchMore && hasMore) {
1213
- logger.info('OpenChannel | useScrollCallback: start');
1214
- var messageListParams_1 = {
1215
- prevResultSize: 30,
1216
- includeReactions: false,
1217
- nextResultSize: 0
1218
- };
1219
-
1220
- if (userFilledMessageListParams) {
1221
- Object.keys(userFilledMessageListParams).forEach(function (key) {
1222
- messageListParams_1[key] = userFilledMessageListParams[key];
1223
- });
1224
- logger.info('OpenChannel | useScrollCallback: Used userFilledMessageListParams', userFilledMessageListParams);
1225
- }
1226
-
1227
- logger.info('OpenChannel | useScrollCallback: Fetching messages', {
1228
- currentOpenChannel: currentOpenChannel,
1229
- messageListParams: messageListParams_1
1230
- });
1231
- currentOpenChannel.getMessagesByTimestamp(lastMessageTimestamp || new Date().getTime(), messageListParams_1).then(function (messages) {
1232
- logger.info('OpenChannel | useScrollCallback: Fetching messages succeeded', messages);
1233
- var hasMore = messages && messages.length > 0;
1234
- var lastMessageTimestamp = hasMore ? messages[0].createdAt : null;
1235
- messagesDispatcher({
1236
- type: GET_PREV_MESSAGES_SUCESS,
1237
- payload: {
1238
- currentOpenChannel: currentOpenChannel,
1239
- messages: messages,
1240
- hasMore: hasMore,
1241
- lastMessageTimestamp: lastMessageTimestamp
1242
- }
1243
- });
1244
- setTimeout(function () {
1245
- callback();
1246
- });
1247
- }).catch(function (error) {
1248
- logger.error('OpenChannel | useScrollCallback: Fetching messages failed', error);
1249
- messagesDispatcher({
1250
- type: GET_PREV_MESSAGES_FAIL,
1251
- payload: {
1252
- currentOpenChannel: currentOpenChannel,
1253
- messages: [],
1254
- hasMore: false,
1255
- lastMessageTimestamp: 0
1256
- }
1257
- });
1258
- });
1259
- }
1260
- }, [currentOpenChannel, lastMessageTimestamp, fetchMore, sdk]);
1261
- }
1262
-
1263
- function useCheckScrollBottom(_a, _b) {
1264
- var conversationScrollRef = _a.conversationScrollRef;
1265
- var logger = _b.logger;
1266
- return useCallback(function () {
1267
- var isBottom = true;
1268
-
1269
- if (conversationScrollRef && (conversationScrollRef === null || conversationScrollRef === void 0 ? void 0 : conversationScrollRef.current)) {
1270
- try {
1271
- var conversationScroll = conversationScrollRef.current;
1272
- isBottom = conversationScroll.scrollHeight <= conversationScroll.scrollTop + conversationScroll.clientHeight;
1273
- } catch (error) {
1274
- logger.error('OpenChannel | useCheckScrollBottom', error);
1275
- }
1276
- }
1277
-
1278
- return isBottom;
1279
- }, [conversationScrollRef]);
1280
- }
1281
-
1282
- function useSendMessageCallback(_a, _b) {
1283
- var currentOpenChannel = _a.currentOpenChannel,
1284
- onBeforeSendUserMessage = _a.onBeforeSendUserMessage,
1285
- checkScrollBottom = _a.checkScrollBottom,
1286
- messageInputRef = _a.messageInputRef;
1287
- var sdk = _b.sdk,
1288
- logger = _b.logger,
1289
- messagesDispatcher = _b.messagesDispatcher,
1290
- scrollRef = _b.scrollRef;
1291
- return useCallback(function () {
1292
- if (sdk) {
1293
- var text = messageInputRef.current.innerText;
1294
-
1295
- var createParamsDefault = function (txt) {
1296
- var message = (txt === null || txt === void 0 ? void 0 : txt.trim()) || txt;
1297
- var params = {
1298
- message: message
1299
- };
1300
- return params;
1301
- };
1302
-
1303
- var createCustomParams = onBeforeSendUserMessage && typeof onBeforeSendUserMessage === 'function';
1304
-
1305
- if (createCustomParams) {
1306
- logger.info('OpenChannel | useSendMessageCallback: Creating params using onBeforeSendUserMessage', onBeforeSendUserMessage);
1307
- }
1308
-
1309
- var params = onBeforeSendUserMessage ? onBeforeSendUserMessage(text) : createParamsDefault(text);
1310
- logger.info('OpenChannel | useSendMessageCallback: Sending message has started', params);
1311
- var isBottom_1 = checkScrollBottom();
1312
- var pendingMsg_1 = null;
1313
- currentOpenChannel.sendUserMessage(params).onPending(function (pendingMessage) {
1314
- messagesDispatcher({
1315
- type: SENDING_MESSAGE_START,
1316
- payload: {
1317
- message: pendingMessage,
1318
- channel: currentOpenChannel
1319
- }
1320
- });
1321
- pendingMsg_1 = pendingMessage;
1322
- }).onSucceeded(function (message) {
1323
- logger.info('OpenChannel | useSendMessageCallback: Sending message succeeded', message);
1324
- messagesDispatcher({
1325
- type: SENDING_MESSAGE_SUCCEEDED,
1326
- payload: message
1327
- });
1328
-
1329
- if (isBottom_1) {
1330
- setTimeout(function () {
1331
- scrollIntoLast(0, scrollRef);
1332
- });
1333
- }
1334
- }).onFailed(function (error) {
1335
- logger.warning('OpenChannel | useSendMessageCallback: Sending message failed', error);
1336
- messagesDispatcher({
1337
- type: SENDING_MESSAGE_FAILED,
1338
- payload: pendingMsg_1
1339
- }); // https://sendbird.com/docs/chat/v3/javascript/guides/error-codes#2-server-error-codes
1340
- // TODO: Do we need to handle the error cases?
1341
- // @ts-ignore
1342
-
1343
- if ((error === null || error === void 0 ? void 0 : error.code) === 900041) {
1344
- messagesDispatcher({
1345
- type: ON_USER_MUTED,
1346
- payload: {
1347
- channel: currentOpenChannel,
1348
- user: sdk.currentUser
1349
- }
1350
- });
1351
- }
1352
- });
1353
- }
1354
- }, [currentOpenChannel, onBeforeSendUserMessage, checkScrollBottom, messageInputRef]);
1355
- }
1356
-
1357
- function useFileUploadCallback(_a, _b) {
1358
- var currentOpenChannel = _a.currentOpenChannel,
1359
- checkScrollBottom = _a.checkScrollBottom,
1360
- _c = _a.imageCompression,
1361
- imageCompression = _c === void 0 ? {} : _c,
1362
- onBeforeSendFileMessage = _a.onBeforeSendFileMessage;
1363
- var sdk = _b.sdk,
1364
- logger = _b.logger,
1365
- messagesDispatcher = _b.messagesDispatcher,
1366
- scrollRef = _b.scrollRef;
1367
- return useCallback(function (file) {
1368
- if (sdk) {
1369
- var compressionRate_1 = imageCompression.compressionRate,
1370
- resizingWidth_1 = imageCompression.resizingWidth,
1371
- resizingHeight_1 = imageCompression.resizingHeight;
1372
- var createCustomParams_1 = onBeforeSendFileMessage && typeof onBeforeSendFileMessage === 'function';
1373
- var compressibleFileType = file.type === 'image/jpg' || file.type === 'image/png' || file.type === 'image/jpeg';
1374
- var compressibleRatio = compressionRate_1 > 0 && compressionRate_1 < 1; // pxToNumber returns null if values are invalid
1375
-
1376
- var compressibleDiamensions_1 = pxToNumber(resizingWidth_1) || pxToNumber(resizingHeight_1);
1377
- var canCompressImage = compressibleFileType && (compressibleRatio || compressibleDiamensions_1);
1378
-
1379
- var createParamsDefault_1 = function (file_) {
1380
- var params = {};
1381
- params.file = file_;
1382
- return params;
1383
- };
1384
-
1385
- if (canCompressImage) {
1386
- // Using image compression
1387
- try {
1388
- var image_1 = document.createElement('img');
1389
- image_1.src = URL.createObjectURL(file);
1390
-
1391
- image_1.onload = function () {
1392
- URL.revokeObjectURL(image_1.src);
1393
- var canvas = document.createElement('canvas');
1394
- var imageWidth = image_1.naturalWidth || image_1.width;
1395
- var imageHeight = image_1.naturalHeight || image_1.height;
1396
- var targetWidth = pxToNumber(resizingWidth_1) || imageWidth;
1397
- var targetHeight = pxToNumber(resizingHeight_1) || imageHeight; // In canvas.toBlob(callback, mimeType, qualityArgument)
1398
- // qualityArgument doesnt work
1399
- // so in case compressibleDiamensions are not present, we use ratio
1400
-
1401
- if (file.type === 'image/png' && !compressibleDiamensions_1) {
1402
- targetWidth *= compressionRate_1;
1403
- targetHeight *= compressionRate_1;
1404
- }
1405
-
1406
- canvas.width = targetWidth;
1407
- canvas.height = targetHeight;
1408
- var context = canvas.getContext('2d');
1409
- context.drawImage(image_1, 0, 0, targetWidth, targetHeight);
1410
- context.canvas.toBlob(function (newImageBlob) {
1411
- var compressedFile = new File([newImageBlob], file.name, {
1412
- type: file.type
1413
- });
1414
-
1415
- if (createCustomParams_1) {
1416
- logger.info('OpenChannel | useFileUploadCallback: Creating params using onBeforeSendFileMessage', onBeforeSendFileMessage);
1417
- }
1418
-
1419
- var params = onBeforeSendFileMessage ? onBeforeSendFileMessage(compressedFile) : createParamsDefault_1(compressedFile);
1420
- logger.info('OpenChannel | useFileUploadCallback: Uploading file message start', params);
1421
- var isBottom = checkScrollBottom();
1422
- currentOpenChannel.sendFileMessage(params).onPending(function (pendingMessage) {
1423
- messagesDispatcher({
1424
- type: SENDING_MESSAGE_START,
1425
- payload: {
1426
- message: __assign(__assign({}, pendingMessage), {
1427
- url: URL.createObjectURL(file),
1428
- // pending thumbnail message seems to be failed
1429
- requestState: 'pending'
1430
- }),
1431
- channel: currentOpenChannel
1432
- }
1433
- });
1434
- }).onSucceeded(function (message) {
1435
- logger.info('OpenChannel | useFileUploadCallback: Sending message succeeded', message);
1436
- messagesDispatcher({
1437
- type: SENDING_MESSAGE_SUCCEEDED,
1438
- payload: message
1439
- });
1440
-
1441
- if (isBottom) {
1442
- setTimeout(function () {
1443
- scrollIntoLast(0, scrollRef);
1444
- });
1445
- }
1446
- }).onFailed(function (error, message) {
1447
- logger.error('OpenChannel | useFileUploadCallback: Sending file message failed', {
1448
- message: message,
1449
- error: error
1450
- }); // @ts-ignore
1451
-
1452
- message.localUrl = URL.createObjectURL(file); // @ts-ignore
1453
-
1454
- message.file = file;
1455
- messagesDispatcher({
1456
- type: SENDING_MESSAGE_FAILED,
1457
- payload: message
1458
- });
1459
- });
1460
- }, file.type, compressionRate_1);
1461
- };
1462
- } catch (error) {
1463
- logger.warning('OpenChannel | useFileUploadCallback: Sending file message with image compression failed', error);
1464
- }
1465
- } else {
1466
- // Not using image compression
1467
- if (createCustomParams_1) {
1468
- logger.info('OpenChannel | useFileUploadCallback: Creating params using onBeforeSendFileMessage', onBeforeSendFileMessage);
1469
- }
1470
-
1471
- var params = onBeforeSendFileMessage ? onBeforeSendFileMessage(file) : createParamsDefault_1(file);
1472
- logger.info('OpenChannel | useFileUploadCallback: Uploading file message start', params);
1473
- var isBottom_1 = checkScrollBottom();
1474
- currentOpenChannel.sendFileMessage(params).onPending(function (pendingMessage) {
1475
- messagesDispatcher({
1476
- type: SENDING_MESSAGE_START,
1477
- payload: {
1478
- message: __assign(__assign({}, pendingMessage), {
1479
- url: URL.createObjectURL(file),
1480
- // pending thumbnail message seems to be failed
1481
- requestState: 'pending'
1482
- }),
1483
- channel: currentOpenChannel
1484
- }
1485
- });
1486
- }).onSucceeded(function (message) {
1487
- logger.info('OpenChannel | useFileUploadCallback: Sending message succeeded', message);
1488
- messagesDispatcher({
1489
- type: SENDING_MESSAGE_SUCCEEDED,
1490
- payload: message
1491
- });
1492
-
1493
- if (isBottom_1) {
1494
- setTimeout(function () {
1495
- scrollIntoLast(0, scrollRef);
1496
- });
1497
- }
1498
- }).onFailed(function (error, message) {
1499
- logger.error('OpenChannel | useFileUploadCallback: Sending file message failed', {
1500
- message: message,
1501
- error: error
1502
- }); // @ts-ignore
1503
-
1504
- message.localUrl = URL.createObjectURL(file); // @ts-ignore
1505
-
1506
- message.file = file;
1507
- messagesDispatcher({
1508
- type: SENDING_MESSAGE_FAILED,
1509
- payload: message
1510
- });
1511
- });
1512
- }
1513
- }
1514
- }, [currentOpenChannel, onBeforeSendFileMessage, checkScrollBottom, imageCompression]);
1515
- }
1516
-
1517
- function useUpdateMessageCallback(_a, _b) {
1518
- var currentOpenChannel = _a.currentOpenChannel,
1519
- onBeforeSendUserMessage = _a.onBeforeSendUserMessage;
1520
- var logger = _b.logger,
1521
- messagesDispatcher = _b.messagesDispatcher;
1522
- return useCallback(function (messageId, text, callback) {
1523
- var createParamsDefault = function (txt) {
1524
- var params = {
1525
- message: txt
1526
- };
1527
- return params;
1528
- };
1529
-
1530
- if (onBeforeSendUserMessage && typeof onBeforeSendUserMessage === 'function') {
1531
- logger.info('OpenChannel | useUpdateMessageCallback: Creating params using onBeforeUpdateUserMessage');
1532
- }
1533
-
1534
- var params = onBeforeSendUserMessage ? onBeforeSendUserMessage(text) : createParamsDefault(text);
1535
- currentOpenChannel.updateUserMessage(messageId, params).then(function (message) {
1536
- if (callback) {
1537
- callback();
1538
- }
1539
-
1540
- logger.info('OpenChannel | useUpdateMessageCallback: Updating message succeeded', {
1541
- message: message,
1542
- params: params
1543
- });
1544
- messagesDispatcher({
1545
- type: ON_MESSAGE_UPDATED,
1546
- payload: {
1547
- channel: currentOpenChannel,
1548
- message: message
1549
- }
1550
- });
1551
- });
1552
- }, [currentOpenChannel, onBeforeSendUserMessage]);
1553
- }
1554
-
1555
- function useDeleteMessageCallback(_a, _b) {
1556
- var currentOpenChannel = _a.currentOpenChannel;
1557
- var logger = _b.logger,
1558
- messagesDispatcher = _b.messagesDispatcher;
1559
- return useCallback(function (message, callback) {
1560
- logger.info('OpenChannel | useDeleteMessageCallback: Deleting message', message);
1561
- var sendingStatus = message.sendingStatus;
1562
- logger.info('OpenChannel | useDeleteMessageCallback: Deleting message requestState', sendingStatus);
1563
-
1564
- if (sendingStatus === 'failed' || sendingStatus === 'pending') {
1565
- logger.info('OpenChannel | useDeleteMessageCallback: Deleted message from local', message);
1566
- messagesDispatcher({
1567
- type: ON_MESSAGE_DELETED_BY_REQ_ID,
1568
- payload: message.reqId
1569
- });
1570
-
1571
- if (callback) {
1572
- callback();
1573
- }
1574
- } else {
1575
- if (!(message.messageType === 'file' || message.messageType === 'user')) {
1576
- return;
1577
- }
1578
-
1579
- var messageToDelete = message;
1580
- currentOpenChannel.deleteMessage(messageToDelete).then(function () {
1581
- logger.info('OpenChannel | useDeleteMessageCallback: Deleting message on server', sendingStatus);
1582
-
1583
- if (callback) {
1584
- callback();
1585
- }
1586
-
1587
- logger.info('OpenChannel | useDeleteMessageCallback: Deleting message succeeded', message);
1588
- messagesDispatcher({
1589
- type: ON_MESSAGE_DELETED,
1590
- payload: {
1591
- channel: currentOpenChannel,
1592
- messageId: message.messageId
1593
- }
1594
- });
1595
- }).catch(function (error) {
1596
- logger.warning('OpenChannel | useDeleteMessageCallback: Deleting message failed', error);
1597
- });
1598
- }
1599
- }, [currentOpenChannel]);
1600
- }
1601
-
1602
- function useResendMessageCallback(_a, _b) {
1603
- var currentOpenChannel = _a.currentOpenChannel;
1604
- var logger = _b.logger,
1605
- messagesDispatcher = _b.messagesDispatcher;
1606
- return useCallback(function (failedMessage) {
1607
- logger.info('OpenChannel | useResendMessageCallback: Resending message has started', failedMessage); // eslint-disable-next-line no-param-reassign
1608
-
1609
- var _a = failedMessage,
1610
- messageType = _a.messageType,
1611
- file = _a.file;
1612
-
1613
- if (failedMessage && typeof failedMessage.isResendable === 'function' && failedMessage.isResendable) {
1614
- // eslint-disable-next-line no-param-reassign
1615
- failedMessage.requestState = 'pending';
1616
- messagesDispatcher({
1617
- type: RESENDING_MESSAGE_START,
1618
- payload: {
1619
- channel: currentOpenChannel,
1620
- message: failedMessage
1621
- }
1622
- }); // userMessage
1623
-
1624
- if (messageType === 'user' && failedMessage.messageType === 'user') {
1625
- currentOpenChannel.resendUserMessage(failedMessage).then(function (message) {
1626
- logger.info('OpenChannel | useResendMessageCallback: Reseding message succeeded', message);
1627
- messagesDispatcher({
1628
- type: SENDING_MESSAGE_SUCCEEDED,
1629
- payload: message
1630
- });
1631
- }).catch(function (error) {
1632
- logger.warning('OpenChannel | useResendMessageCallback: Resending message failed', error); // eslint-disable-next-line no-param-reassign
1633
-
1634
- failedMessage.requestState = 'failed';
1635
- messagesDispatcher({
1636
- type: SENDING_MESSAGE_FAILED,
1637
- payload: failedMessage
1638
- });
1639
- });
1640
- } // fileMessage
1641
-
1642
-
1643
- if (messageType === 'file' && failedMessage.messageType === 'file') {
1644
- currentOpenChannel.resendFileMessage(failedMessage, file).then(function (message) {
1645
- logger.info('OpenChannel | useResendMessageCallback: Resending file message succeeded', message);
1646
- messagesDispatcher({
1647
- type: SENDING_MESSAGE_SUCCEEDED,
1648
- payload: message
1649
- });
1650
- }).catch(function (error) {
1651
- logger.warning('OpenChannel | useResendMessageCallback: Resending file message failed', error); // eslint-disable-next-line no-param-reassign
1652
-
1653
- failedMessage.requestState = 'failed';
1654
- messagesDispatcher({
1655
- type: SENDING_MESSAGE_FAILED,
1656
- payload: failedMessage
1657
- });
1658
- });
1659
- }
1660
- } else {
1661
- // to alert user on console
1662
- // eslint-disable-next-line no-console
1663
- console.error('OpenChannel | useResendMessageCallback: Message is not resendable');
1664
- logger.warning('OpenChannel | useResendMessageCallback: Message is not resendable', failedMessage);
1665
- }
1666
- }, [currentOpenChannel]);
1667
- }
1668
-
1669
- var THROTTLE_TIMER = 5000; // to trim message list so that we wont keep thousands of messages in memory
1670
- // We are throttling here; not debouncing
1671
- // it will be called once very 5 sec if messagesLength, messageLimit changes
1672
- // we check if messagesLength > messageLimit before dispatching action
1673
-
1674
- function useTrimMessageList(_a, _b) {
1675
- var messagesLength = _a.messagesLength,
1676
- messageLimit = _a.messageLimit;
1677
- var messagesDispatcher = _b.messagesDispatcher,
1678
- logger = _b.logger;
1679
-
1680
- var _c = useState(false),
1681
- inProgress = _c[0],
1682
- setInProgress = _c[1];
1683
-
1684
- useEffect(function () {
1685
- if (inProgress) {
1686
- return;
1687
- }
1688
-
1689
- if (typeof messagesLength === 'number' && messagesLength > messageLimit) {
1690
- logger.info('Trimming MessageList');
1691
- messagesDispatcher({
1692
- type: TRIM_MESSAGE_LIST,
1693
- payload: {
1694
- messageLimit: messageLimit
1695
- }
1696
- });
1697
- }
1698
-
1699
- setInProgress(true);
1700
- setTimeout(function () {
1701
- setInProgress(false);
1702
- }, THROTTLE_TIMER);
1703
- }, [messagesLength, messageLimit]);
1704
- }
1705
-
1706
- var OpenChannelContext = /*#__PURE__*/React__default.createContext(undefined);
1707
-
1708
- var OpenChannelProvider = function (props) {
1709
- var _a, _b, _c, _d, _e, _f;
1710
-
1711
- var channelUrl = props.channelUrl,
1712
- children = props.children,
1713
- _g = props.isMessageGroupingEnabled,
1714
- isMessageGroupingEnabled = _g === void 0 ? true : _g,
1715
- queries = props.queries,
1716
- onBeforeSendUserMessage = props.onBeforeSendUserMessage,
1717
- messageLimit = props.messageLimit,
1718
- onBeforeSendFileMessage = props.onBeforeSendFileMessage,
1719
- onChatHeaderActionClick = props.onChatHeaderActionClick,
1720
- onBackClick = props.onBackClick; // We didn't decide to support fetching participant list
1721
-
1722
- var fetchingParticipants = false;
1723
- var globalStore = useSendbirdStateContext();
1724
- var sdk = (_b = (_a = globalStore === null || globalStore === void 0 ? void 0 : globalStore.stores) === null || _a === void 0 ? void 0 : _a.sdkStore) === null || _b === void 0 ? void 0 : _b.sdk;
1725
- var sdkInit = (_d = (_c = globalStore === null || globalStore === void 0 ? void 0 : globalStore.stores) === null || _c === void 0 ? void 0 : _c.sdkStore) === null || _d === void 0 ? void 0 : _d.initialized;
1726
- var user = (_f = (_e = globalStore === null || globalStore === void 0 ? void 0 : globalStore.stores) === null || _e === void 0 ? void 0 : _e.userStore) === null || _f === void 0 ? void 0 : _f.user;
1727
- var config = globalStore === null || globalStore === void 0 ? void 0 : globalStore.config;
1728
- var userId = config.userId,
1729
- isOnline = config.isOnline,
1730
- logger = config.logger,
1731
- pubSub = config.pubSub,
1732
- imageCompression = config.imageCompression; // hook variables
1733
-
1734
- var _h = useReducer(reducer, initialState),
1735
- messagesStore = _h[0],
1736
- messagesDispatcher = _h[1];
1737
-
1738
- var allMessages = messagesStore.allMessages,
1739
- loading = messagesStore.loading,
1740
- initialized = messagesStore.initialized,
1741
- currentOpenChannel = messagesStore.currentOpenChannel,
1742
- isInvalid = messagesStore.isInvalid,
1743
- hasMore = messagesStore.hasMore,
1744
- lastMessageTimestamp = messagesStore.lastMessageTimestamp,
1745
- operators = messagesStore.operators,
1746
- bannedParticipantIds = messagesStore.bannedParticipantIds,
1747
- mutedParticipantIds = messagesStore.mutedParticipantIds; // ref
1748
-
1749
- var messageInputRef = useRef(null); // useSendMessageCallback
1750
-
1751
- var conversationScrollRef = useRef(null); // useScrollAfterSendMessageCallback
1752
- // const
1753
-
1754
- var userFilledMessageListParams = queries === null || queries === void 0 ? void 0 : queries.messageListParams;
1755
- var disabled = !initialized || !isOnline || isDisabledBecauseFrozen(currentOpenChannel, userId) || isDisabledBecauseMuted(mutedParticipantIds, userId); // useMemo
1756
-
1757
- var amIBanned = useMemo(function () {
1758
- return bannedParticipantIds.indexOf(user.userId) >= 0;
1759
- }, [channelUrl, bannedParticipantIds, user]);
1760
- var amIMuted = useMemo(function () {
1761
- return mutedParticipantIds.indexOf(user.userId) >= 0;
1762
- }, [channelUrl, mutedParticipantIds, user]);
1763
- var amIOperator = useMemo(function () {
1764
- return operators.map(function (operator) {
1765
- return operator.userId;
1766
- }).indexOf(user.userId) >= 0;
1767
- }, [channelUrl, operators, user]); // use hooks
1768
-
1769
- useSetChannel({
1770
- channelUrl: channelUrl,
1771
- sdkInit: sdkInit,
1772
- fetchingParticipants: fetchingParticipants,
1773
- userId: userId,
1774
- currentOpenChannel: currentOpenChannel
1775
- }, {
1776
- sdk: sdk,
1777
- logger: logger,
1778
- messagesDispatcher: messagesDispatcher
1779
- });
1780
- var checkScrollBottom = useCheckScrollBottom({
1781
- conversationScrollRef: conversationScrollRef
1782
- }, {
1783
- logger: logger
1784
- });
1785
- useHandleChannelEvents({
1786
- currentOpenChannel: currentOpenChannel,
1787
- checkScrollBottom: checkScrollBottom
1788
- }, {
1789
- sdk: sdk,
1790
- logger: logger,
1791
- messagesDispatcher: messagesDispatcher,
1792
- scrollRef: conversationScrollRef
1793
- });
1794
- useInitialMessagesFetch({
1795
- currentOpenChannel: currentOpenChannel,
1796
- userFilledMessageListParams: userFilledMessageListParams
1797
- }, {
1798
- logger: logger,
1799
- messagesDispatcher: messagesDispatcher,
1800
- scrollRef: conversationScrollRef
1801
- });
1802
- var fetchMore = shouldFetchMore(allMessages === null || allMessages === void 0 ? void 0 : allMessages.length, messageLimit); // donot fetch more for streaming
1803
-
1804
- var onScroll = useScrollCallback({
1805
- currentOpenChannel: currentOpenChannel,
1806
- lastMessageTimestamp: lastMessageTimestamp,
1807
- fetchMore: fetchMore
1808
- }, {
1809
- sdk: sdk,
1810
- logger: logger,
1811
- messagesDispatcher: messagesDispatcher,
1812
- hasMore: hasMore,
1813
- userFilledMessageListParams: userFilledMessageListParams
1814
- });
1815
- var handleSendMessage = useSendMessageCallback({
1816
- currentOpenChannel: currentOpenChannel,
1817
- onBeforeSendUserMessage: onBeforeSendUserMessage,
1818
- checkScrollBottom: checkScrollBottom,
1819
- messageInputRef: messageInputRef
1820
- }, {
1821
- sdk: sdk,
1822
- logger: logger,
1823
- messagesDispatcher: messagesDispatcher,
1824
- scrollRef: conversationScrollRef
1825
- });
1826
- var handleFileUpload = useFileUploadCallback({
1827
- currentOpenChannel: currentOpenChannel,
1828
- onBeforeSendFileMessage: onBeforeSendFileMessage,
1829
- checkScrollBottom: checkScrollBottom,
1830
- imageCompression: imageCompression
1831
- }, {
1832
- sdk: sdk,
1833
- logger: logger,
1834
- messagesDispatcher: messagesDispatcher,
1835
- scrollRef: conversationScrollRef
1836
- });
1837
- var updateMessage = useUpdateMessageCallback({
1838
- currentOpenChannel: currentOpenChannel,
1839
- onBeforeSendUserMessage: onBeforeSendUserMessage
1840
- }, {
1841
- logger: logger,
1842
- messagesDispatcher: messagesDispatcher
1843
- });
1844
- var deleteMessage = useDeleteMessageCallback({
1845
- currentOpenChannel: currentOpenChannel
1846
- }, {
1847
- logger: logger,
1848
- messagesDispatcher: messagesDispatcher
1849
- });
1850
- var resendMessage = useResendMessageCallback({
1851
- currentOpenChannel: currentOpenChannel
1852
- }, {
1853
- logger: logger,
1854
- messagesDispatcher: messagesDispatcher
1855
- });
1856
- useTrimMessageList({
1857
- messagesLength: allMessages === null || allMessages === void 0 ? void 0 : allMessages.length,
1858
- messageLimit: messageLimit
1859
- }, {
1860
- messagesDispatcher: messagesDispatcher,
1861
- logger: logger
1862
- }); // handle API calls from withSendbird
1863
-
1864
- useEffect(function () {
1865
- var subscriber = new Map();
1866
-
1867
- if (!pubSub || !pubSub.subscribe) {
1868
- return;
1869
- }
1870
-
1871
- subscriber.set(SEND_USER_MESSAGE, pubSub.subscribe(SEND_USER_MESSAGE, function (msg) {
1872
- var channel = msg.channel,
1873
- message = msg.message;
1874
- scrollIntoLast(0, conversationScrollRef);
1875
-
1876
- if (channel && channelUrl === (channel === null || channel === void 0 ? void 0 : channel.url)) {
1877
- messagesDispatcher({
1878
- type: SENDING_MESSAGE_SUCCEEDED,
1879
- payload: message
1880
- });
1881
- }
1882
- }));
1883
- subscriber.set(SEND_MESSAGE_START, pubSub.subscribe(SEND_MESSAGE_START, function (msg) {
1884
- var channel = msg.channel,
1885
- message = msg.message;
1886
-
1887
- if (channel && channelUrl === (channel === null || channel === void 0 ? void 0 : channel.url)) {
1888
- messagesDispatcher({
1889
- type: SENDING_MESSAGE_START,
1890
- payload: {
1891
- message: message,
1892
- channel: channel
1893
- }
1894
- });
1895
- }
1896
- }));
1897
- subscriber.set(SEND_FILE_MESSAGE, pubSub.subscribe(SEND_FILE_MESSAGE, function (msg) {
1898
- var channel = msg.channel,
1899
- message = msg.message;
1900
- scrollIntoLast(0, conversationScrollRef);
1901
-
1902
- if (channel && channelUrl === (channel === null || channel === void 0 ? void 0 : channel.url)) {
1903
- messagesDispatcher({
1904
- type: SENDING_MESSAGE_SUCCEEDED,
1905
- payload: {
1906
- message: message,
1907
- channel: channel
1908
- }
1909
- });
1910
- }
1911
- }));
1912
- subscriber.set(UPDATE_USER_MESSAGE, pubSub.subscribe(UPDATE_USER_MESSAGE, function (msg) {
1913
- var channel = msg.channel,
1914
- message = msg.message,
1915
- fromSelector = msg.fromSelector;
1916
-
1917
- if (fromSelector && channel && channelUrl === (channel === null || channel === void 0 ? void 0 : channel.url)) {
1918
- messagesDispatcher({
1919
- type: ON_MESSAGE_UPDATED,
1920
- payload: {
1921
- channel: channel,
1922
- message: message
1923
- }
1924
- });
1925
- }
1926
- }));
1927
- subscriber.set(DELETE_MESSAGE, pubSub.subscribe(DELETE_MESSAGE, function (msg) {
1928
- var channel = msg.channel,
1929
- messageId = msg.messageId;
1930
-
1931
- if (channel && channelUrl === (channel === null || channel === void 0 ? void 0 : channel.url)) {
1932
- messagesDispatcher({
1933
- type: ON_MESSAGE_DELETED,
1934
- payload: messageId
1935
- });
1936
- }
1937
- }));
1938
- return function () {
1939
- if (subscriber) {
1940
- subscriber.forEach(function (s) {
1941
- try {
1942
- s.remove();
1943
- } catch (_a) {//
1944
- }
1945
- });
1946
- }
1947
- };
1948
- }, [channelUrl, sdkInit]);
1949
- return /*#__PURE__*/React__default.createElement(OpenChannelContext.Provider, {
1950
- value: {
1951
- // props
1952
- channelUrl: channelUrl,
1953
- children: children,
1954
- isMessageGroupingEnabled: isMessageGroupingEnabled,
1955
- queries: queries,
1956
- onBeforeSendUserMessage: onBeforeSendUserMessage,
1957
- messageLimit: messageLimit,
1958
- onBeforeSendFileMessage: onBeforeSendFileMessage,
1959
- onChatHeaderActionClick: onChatHeaderActionClick,
1960
- onBackClick: onBackClick,
1961
- // store
1962
- allMessages: allMessages,
1963
- loading: loading,
1964
- initialized: initialized,
1965
- currentOpenChannel: currentOpenChannel,
1966
- isInvalid: isInvalid,
1967
- hasMore: hasMore,
1968
- lastMessageTimestamp: lastMessageTimestamp,
1969
- operators: operators,
1970
- bannedParticipantIds: bannedParticipantIds,
1971
- mutedParticipantIds: mutedParticipantIds,
1972
- // derived/utils
1973
- messageInputRef: messageInputRef,
1974
- conversationScrollRef: conversationScrollRef,
1975
- disabled: disabled,
1976
- amIBanned: amIBanned,
1977
- amIMuted: amIMuted,
1978
- amIOperator: amIOperator,
1979
- checkScrollBottom: checkScrollBottom,
1980
- fetchMore: fetchMore,
1981
- onScroll: onScroll,
1982
- handleSendMessage: handleSendMessage,
1983
- handleFileUpload: handleFileUpload,
1984
- updateMessage: updateMessage,
1985
- deleteMessage: deleteMessage,
1986
- resendMessage: resendMessage
1987
- }
1988
- }, /*#__PURE__*/React__default.createElement(UserProfileProvider, {
1989
- isOpenChannel: true,
1990
- renderUserProfile: props === null || props === void 0 ? void 0 : props.renderUserProfile,
1991
- disableUserProfile: props === null || props === void 0 ? void 0 : props.disableUserProfile
1992
- }, children));
1993
- };
1994
-
1995
- var useOpenChannelContext = function () {
1996
- return React__default.useContext(OpenChannelContext);
1997
- };
1998
-
1999
- export { OpenChannelProvider as O, compareMessagesForGrouping as c, kFormatter as k, useOpenChannelContext as u };
2000
- //# sourceMappingURL=OpenChannelProvider-c254c663.js.map