@sendbird/uikit-react 3.4.3 → 3.4.4-rc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (618) hide show
  1. package/App.js +41 -45
  2. package/App.js.map +1 -1
  3. package/CHANGELOG.md +11 -0
  4. package/Channel/components/ChannelHeader.js +19 -19
  5. package/Channel/components/ChannelUI.js +33 -34
  6. package/Channel/components/ChannelUI.js.map +1 -1
  7. package/Channel/components/FileViewer.js +15 -15
  8. package/Channel/components/FrozenNotification.js +4 -4
  9. package/Channel/components/Message.js +28 -29
  10. package/Channel/components/Message.js.map +1 -1
  11. package/Channel/components/MessageInput.js +24 -25
  12. package/Channel/components/MessageInput.js.map +1 -1
  13. package/Channel/components/MessageList.js +32 -33
  14. package/Channel/components/MessageList.js.map +1 -1
  15. package/Channel/components/RemoveMessageModal.js +17 -17
  16. package/Channel/components/SuggestedMentionList.js +17 -17
  17. package/Channel/components/TypingIndicator.js +15 -15
  18. package/Channel/components/UnreadCount.js +4 -4
  19. package/Channel/context.js +14 -14
  20. package/Channel.js +33 -34
  21. package/Channel.js.map +1 -1
  22. package/ChannelList/components/AddChannel.js +15 -15
  23. package/ChannelList/components/ChannelListHeader.js +6 -7
  24. package/ChannelList/components/ChannelListHeader.js.map +1 -1
  25. package/ChannelList/components/ChannelListUI.js +30 -30
  26. package/ChannelList/components/ChannelPreview.js +26 -26
  27. package/ChannelList/components/ChannelPreviewAction.js +14 -14
  28. package/ChannelList/context.js +8 -8
  29. package/ChannelList.js +30 -30
  30. package/{ChannelListProvider-74d39ce5.js → ChannelListProvider-02be684a.js} +12 -12
  31. package/ChannelListProvider-02be684a.js.map +1 -0
  32. package/{ChannelProvider-7b83d4fd.js → ChannelProvider-fcab0099.js} +21 -20
  33. package/ChannelProvider-fcab0099.js.map +1 -0
  34. package/ChannelSettings/components/ChannelProfile.js +11 -12
  35. package/ChannelSettings/components/ChannelProfile.js.map +1 -1
  36. package/ChannelSettings/components/ChannelSettingsUI.js +17 -18
  37. package/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
  38. package/ChannelSettings/components/EditDetailsModal.js +11 -12
  39. package/ChannelSettings/components/EditDetailsModal.js.map +1 -1
  40. package/ChannelSettings/components/LeaveChannel.js +11 -12
  41. package/ChannelSettings/components/LeaveChannel.js.map +1 -1
  42. package/ChannelSettings/components/ModerationPanel.js +14 -15
  43. package/ChannelSettings/components/ModerationPanel.js.map +1 -1
  44. package/ChannelSettings/components/UserListItem.js +10 -11
  45. package/ChannelSettings/components/UserListItem.js.map +1 -1
  46. package/ChannelSettings/components/UserPanel.js +13 -14
  47. package/ChannelSettings/components/UserPanel.js.map +1 -1
  48. package/ChannelSettings/context.js +3 -3
  49. package/ChannelSettings.js +17 -18
  50. package/ChannelSettings.js.map +1 -1
  51. package/CreateChannel/components/CreateChannelUI.js +13 -14
  52. package/CreateChannel/components/CreateChannelUI.js.map +1 -1
  53. package/CreateChannel/components/InviteUsers.js +13 -14
  54. package/CreateChannel/components/InviteUsers.js.map +1 -1
  55. package/CreateChannel/components/SelectChannelType.js +10 -11
  56. package/CreateChannel/components/SelectChannelType.js.map +1 -1
  57. package/CreateChannel/context.js +4 -4
  58. package/CreateChannel.js +13 -14
  59. package/CreateChannel.js.map +1 -1
  60. package/{CreateChannelProvider-488e930d.js → CreateChannelProvider-33fa0e76.js} +1 -1
  61. package/{CreateChannelProvider-488e930d.js.map → CreateChannelProvider-33fa0e76.js.map} +1 -1
  62. package/CreateOpenChannel/components/CreateOpenChannelUI.js +9 -10
  63. package/CreateOpenChannel/components/CreateOpenChannelUI.js.map +1 -1
  64. package/CreateOpenChannel/context.js +1 -1
  65. package/CreateOpenChannel.js +9 -10
  66. package/CreateOpenChannel.js.map +1 -1
  67. package/EditUserProfile/components/EditUserProfileUI.js +12 -13
  68. package/EditUserProfile/components/EditUserProfileUI.js.map +1 -1
  69. package/EditUserProfile.js +12 -13
  70. package/EditUserProfile.js.map +1 -1
  71. package/{LocalizationContext-4b25e6bc.js → LocalizationContext-21c445a7.js} +3 -3
  72. package/{LocalizationContext-4b25e6bc.js.map → LocalizationContext-21c445a7.js.map} +1 -1
  73. package/{MediaQueryContext-29dcaddb.js → MediaQueryContext-46321124.js} +1 -1
  74. package/{MediaQueryContext-29dcaddb.js.map → MediaQueryContext-46321124.js.map} +1 -1
  75. package/{MemberList-5cf25437.js → MemberList-eba5d99c.js} +5 -5
  76. package/{MemberList-5cf25437.js.map → MemberList-eba5d99c.js.map} +1 -1
  77. package/MessageSearch/components/MessageSearchUI.js +11 -12
  78. package/MessageSearch/components/MessageSearchUI.js.map +1 -1
  79. package/MessageSearch/context.js +1 -2
  80. package/MessageSearch/context.js.map +1 -1
  81. package/MessageSearch.js +11 -12
  82. package/MessageSearch.js.map +1 -1
  83. package/OpenChannel/components/FrozenChannelNotification.js +4 -4
  84. package/OpenChannel/components/OpenChannelHeader.js +12 -13
  85. package/OpenChannel/components/OpenChannelHeader.js.map +1 -1
  86. package/OpenChannel/components/OpenChannelInput.js +16 -16
  87. package/OpenChannel/components/OpenChannelMessage.js +23 -23
  88. package/OpenChannel/components/OpenChannelMessageList.js +58 -47
  89. package/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
  90. package/OpenChannel/components/OpenChannelUI.js +26 -25
  91. package/OpenChannel/components/OpenChannelUI.js.map +1 -1
  92. package/OpenChannel/context.js +8 -9
  93. package/OpenChannel/context.js.map +1 -1
  94. package/OpenChannel.js +26 -25
  95. package/OpenChannel.js.map +1 -1
  96. package/OpenChannelList/components/OpenChannelListUI.js +14 -14
  97. package/OpenChannelList/components/OpenChannelListUI.js.map +1 -1
  98. package/OpenChannelList/components/OpenChannelPreview.js +4 -4
  99. package/OpenChannelList/context.js +3 -4
  100. package/OpenChannelList/context.js.map +1 -1
  101. package/OpenChannelList.js +13 -13
  102. package/{OpenChannelListProvider-2685f3d5.js → OpenChannelListProvider-6ed76740.js} +4 -4
  103. package/OpenChannelListProvider-6ed76740.js.map +1 -0
  104. package/{OpenChannelProvider-9bd64275.js → OpenChannelProvider-5887d4bd.js} +12 -12
  105. package/OpenChannelProvider-5887d4bd.js.map +1 -0
  106. package/OpenChannelSettings/components/EditDetailsModal.js +13 -14
  107. package/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
  108. package/OpenChannelSettings/components/OpenChannelProfile.js +12 -13
  109. package/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
  110. package/OpenChannelSettings/components/OpenChannelSettingsUI.js +17 -18
  111. package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
  112. package/OpenChannelSettings/components/OperatorUI.js +16 -17
  113. package/OpenChannelSettings/components/OperatorUI.js.map +1 -1
  114. package/OpenChannelSettings/components/ParticipantUI.js +14 -15
  115. package/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
  116. package/OpenChannelSettings/context.js +3 -3
  117. package/OpenChannelSettings.js +17 -18
  118. package/OpenChannelSettings.js.map +1 -1
  119. package/{RemoveMessageModal-0182446a.js → RemoveMessageModal-99978eb5.js} +3 -3
  120. package/{RemoveMessageModal-0182446a.js.map → RemoveMessageModal-99978eb5.js.map} +1 -1
  121. package/SendbirdProvider.js +225 -244
  122. package/SendbirdProvider.js.map +1 -1
  123. package/Thread/components/ParentMessageInfo.js +26 -27
  124. package/Thread/components/ParentMessageInfo.js.map +1 -1
  125. package/Thread/components/ParentMessageInfoItem.js +15 -17
  126. package/Thread/components/ParentMessageInfoItem.js.map +1 -1
  127. package/Thread/components/ThreadHeader.js +6 -6
  128. package/Thread/components/ThreadList.js +28 -29
  129. package/Thread/components/ThreadList.js.map +1 -1
  130. package/Thread/components/ThreadListItem.js +28 -29
  131. package/Thread/components/ThreadListItem.js.map +1 -1
  132. package/Thread/components/ThreadMessageInput.js +25 -26
  133. package/Thread/components/ThreadMessageInput.js.map +1 -1
  134. package/Thread/components/ThreadUI.js +32 -33
  135. package/Thread/components/ThreadUI.js.map +1 -1
  136. package/Thread/context.js +8 -9
  137. package/Thread/context.js.map +1 -1
  138. package/Thread.js +32 -33
  139. package/Thread.js.map +1 -1
  140. package/{ThreadProvider-daedc3df.js → ThreadProvider-c3528b8f.js} +46 -29
  141. package/ThreadProvider-c3528b8f.js.map +1 -0
  142. package/{UserProfileContext-2ea97dc1.js → UserProfileContext-b722645f.js} +1 -1
  143. package/{UserProfileContext-2ea97dc1.js.map → UserProfileContext-b722645f.js.map} +1 -1
  144. package/{VoiceMessageInputWrapper-f65cc3ae.js → VoiceMessageInputWrapper-6bce7f18.js} +12 -8
  145. package/VoiceMessageInputWrapper-6bce7f18.js.map +1 -0
  146. package/VoicePlayer/context.js +5 -3
  147. package/VoicePlayer/context.js.map +1 -1
  148. package/VoicePlayer/useVoicePlayer.js +5 -4
  149. package/VoicePlayer/useVoicePlayer.js.map +1 -1
  150. package/VoiceRecorder/context.js +2553 -6
  151. package/VoiceRecorder/context.js.map +1 -1
  152. package/VoiceRecorder/useVoiceRecorder.js +2 -3
  153. package/VoiceRecorder/useVoiceRecorder.js.map +1 -1
  154. package/{_rollupPluginBabelHelpers-38fb8170.js → _rollupPluginBabelHelpers-06a0d79e.js} +1 -1
  155. package/_rollupPluginBabelHelpers-06a0d79e.js.map +1 -0
  156. package/{actionTypes-ce60cab6.js → actionTypes-77e04912.js} +1 -1
  157. package/{actionTypes-ce60cab6.js.map → actionTypes-77e04912.js.map} +1 -1
  158. package/cjs/App.js +41 -45
  159. package/cjs/App.js.map +1 -1
  160. package/cjs/Channel/components/ChannelHeader.js +19 -19
  161. package/cjs/Channel/components/ChannelUI.js +33 -34
  162. package/cjs/Channel/components/ChannelUI.js.map +1 -1
  163. package/cjs/Channel/components/FileViewer.js +15 -15
  164. package/cjs/Channel/components/FrozenNotification.js +4 -4
  165. package/cjs/Channel/components/Message.js +28 -29
  166. package/cjs/Channel/components/Message.js.map +1 -1
  167. package/cjs/Channel/components/MessageInput.js +24 -25
  168. package/cjs/Channel/components/MessageInput.js.map +1 -1
  169. package/cjs/Channel/components/MessageList.js +32 -33
  170. package/cjs/Channel/components/MessageList.js.map +1 -1
  171. package/cjs/Channel/components/RemoveMessageModal.js +17 -17
  172. package/cjs/Channel/components/SuggestedMentionList.js +17 -17
  173. package/cjs/Channel/components/TypingIndicator.js +15 -15
  174. package/cjs/Channel/components/UnreadCount.js +4 -4
  175. package/cjs/Channel/context.js +14 -14
  176. package/cjs/Channel.js +33 -34
  177. package/cjs/Channel.js.map +1 -1
  178. package/cjs/ChannelList/components/AddChannel.js +15 -15
  179. package/cjs/ChannelList/components/ChannelListHeader.js +6 -7
  180. package/cjs/ChannelList/components/ChannelListHeader.js.map +1 -1
  181. package/cjs/ChannelList/components/ChannelListUI.js +30 -30
  182. package/cjs/ChannelList/components/ChannelPreview.js +26 -26
  183. package/cjs/ChannelList/components/ChannelPreviewAction.js +14 -14
  184. package/cjs/ChannelList/context.js +8 -8
  185. package/cjs/ChannelList.js +30 -30
  186. package/cjs/{ChannelListProvider-4cf41348.js → ChannelListProvider-182857e2.js} +12 -12
  187. package/cjs/ChannelListProvider-182857e2.js.map +1 -0
  188. package/cjs/{ChannelProvider-af11f0e6.js → ChannelProvider-218991b0.js} +21 -20
  189. package/cjs/ChannelProvider-218991b0.js.map +1 -0
  190. package/cjs/ChannelSettings/components/ChannelProfile.js +11 -12
  191. package/cjs/ChannelSettings/components/ChannelProfile.js.map +1 -1
  192. package/cjs/ChannelSettings/components/ChannelSettingsUI.js +17 -18
  193. package/cjs/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
  194. package/cjs/ChannelSettings/components/EditDetailsModal.js +11 -12
  195. package/cjs/ChannelSettings/components/EditDetailsModal.js.map +1 -1
  196. package/cjs/ChannelSettings/components/LeaveChannel.js +11 -12
  197. package/cjs/ChannelSettings/components/LeaveChannel.js.map +1 -1
  198. package/cjs/ChannelSettings/components/ModerationPanel.js +14 -15
  199. package/cjs/ChannelSettings/components/ModerationPanel.js.map +1 -1
  200. package/cjs/ChannelSettings/components/UserListItem.js +10 -11
  201. package/cjs/ChannelSettings/components/UserListItem.js.map +1 -1
  202. package/cjs/ChannelSettings/components/UserPanel.js +13 -14
  203. package/cjs/ChannelSettings/components/UserPanel.js.map +1 -1
  204. package/cjs/ChannelSettings/context.js +3 -3
  205. package/cjs/ChannelSettings.js +17 -18
  206. package/cjs/ChannelSettings.js.map +1 -1
  207. package/cjs/CreateChannel/components/CreateChannelUI.js +13 -14
  208. package/cjs/CreateChannel/components/CreateChannelUI.js.map +1 -1
  209. package/cjs/CreateChannel/components/InviteUsers.js +13 -14
  210. package/cjs/CreateChannel/components/InviteUsers.js.map +1 -1
  211. package/cjs/CreateChannel/components/SelectChannelType.js +10 -11
  212. package/cjs/CreateChannel/components/SelectChannelType.js.map +1 -1
  213. package/cjs/CreateChannel/context.js +4 -4
  214. package/cjs/CreateChannel.js +13 -14
  215. package/cjs/CreateChannel.js.map +1 -1
  216. package/cjs/{CreateChannelProvider-1241284b.js → CreateChannelProvider-9b9a224f.js} +1 -1
  217. package/cjs/{CreateChannelProvider-1241284b.js.map → CreateChannelProvider-9b9a224f.js.map} +1 -1
  218. package/cjs/CreateOpenChannel/components/CreateOpenChannelUI.js +9 -10
  219. package/cjs/CreateOpenChannel/components/CreateOpenChannelUI.js.map +1 -1
  220. package/cjs/CreateOpenChannel/context.js +1 -1
  221. package/cjs/CreateOpenChannel.js +9 -10
  222. package/cjs/CreateOpenChannel.js.map +1 -1
  223. package/cjs/EditUserProfile/components/EditUserProfileUI.js +12 -13
  224. package/cjs/EditUserProfile/components/EditUserProfileUI.js.map +1 -1
  225. package/cjs/EditUserProfile.js +12 -13
  226. package/cjs/EditUserProfile.js.map +1 -1
  227. package/cjs/{LocalizationContext-d6a49817.js → LocalizationContext-51dc836f.js} +3 -3
  228. package/cjs/{LocalizationContext-d6a49817.js.map → LocalizationContext-51dc836f.js.map} +1 -1
  229. package/cjs/{MediaQueryContext-fe920821.js → MediaQueryContext-07055899.js} +1 -1
  230. package/cjs/{MediaQueryContext-fe920821.js.map → MediaQueryContext-07055899.js.map} +1 -1
  231. package/cjs/{MemberList-b3c99792.js → MemberList-8e959bdc.js} +5 -5
  232. package/cjs/{MemberList-b3c99792.js.map → MemberList-8e959bdc.js.map} +1 -1
  233. package/cjs/MessageSearch/components/MessageSearchUI.js +11 -12
  234. package/cjs/MessageSearch/components/MessageSearchUI.js.map +1 -1
  235. package/cjs/MessageSearch/context.js +1 -2
  236. package/cjs/MessageSearch/context.js.map +1 -1
  237. package/cjs/MessageSearch.js +11 -12
  238. package/cjs/MessageSearch.js.map +1 -1
  239. package/cjs/OpenChannel/components/FrozenChannelNotification.js +4 -4
  240. package/cjs/OpenChannel/components/OpenChannelHeader.js +12 -13
  241. package/cjs/OpenChannel/components/OpenChannelHeader.js.map +1 -1
  242. package/cjs/OpenChannel/components/OpenChannelInput.js +16 -16
  243. package/cjs/OpenChannel/components/OpenChannelMessage.js +23 -23
  244. package/cjs/OpenChannel/components/OpenChannelMessageList.js +57 -46
  245. package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
  246. package/cjs/OpenChannel/components/OpenChannelUI.js +26 -25
  247. package/cjs/OpenChannel/components/OpenChannelUI.js.map +1 -1
  248. package/cjs/OpenChannel/context.js +8 -9
  249. package/cjs/OpenChannel/context.js.map +1 -1
  250. package/cjs/OpenChannel.js +26 -25
  251. package/cjs/OpenChannel.js.map +1 -1
  252. package/cjs/OpenChannelList/components/OpenChannelListUI.js +14 -14
  253. package/cjs/OpenChannelList/components/OpenChannelListUI.js.map +1 -1
  254. package/cjs/OpenChannelList/components/OpenChannelPreview.js +4 -4
  255. package/cjs/OpenChannelList/context.js +3 -4
  256. package/cjs/OpenChannelList/context.js.map +1 -1
  257. package/cjs/OpenChannelList.js +13 -13
  258. package/cjs/{OpenChannelListProvider-aa38b9f3.js → OpenChannelListProvider-e49acf04.js} +4 -4
  259. package/cjs/OpenChannelListProvider-e49acf04.js.map +1 -0
  260. package/cjs/{OpenChannelProvider-689e3690.js → OpenChannelProvider-c018bfe2.js} +12 -12
  261. package/cjs/OpenChannelProvider-c018bfe2.js.map +1 -0
  262. package/cjs/OpenChannelSettings/components/EditDetailsModal.js +13 -14
  263. package/cjs/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
  264. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js +12 -13
  265. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
  266. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js +17 -18
  267. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
  268. package/cjs/OpenChannelSettings/components/OperatorUI.js +16 -17
  269. package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -1
  270. package/cjs/OpenChannelSettings/components/ParticipantUI.js +14 -15
  271. package/cjs/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
  272. package/cjs/OpenChannelSettings/context.js +3 -3
  273. package/cjs/OpenChannelSettings.js +17 -18
  274. package/cjs/OpenChannelSettings.js.map +1 -1
  275. package/cjs/{RemoveMessageModal-e454585a.js → RemoveMessageModal-6f481228.js} +3 -3
  276. package/cjs/{RemoveMessageModal-e454585a.js.map → RemoveMessageModal-6f481228.js.map} +1 -1
  277. package/cjs/SendbirdProvider.js +225 -245
  278. package/cjs/SendbirdProvider.js.map +1 -1
  279. package/cjs/Thread/components/ParentMessageInfo.js +26 -27
  280. package/cjs/Thread/components/ParentMessageInfo.js.map +1 -1
  281. package/cjs/Thread/components/ParentMessageInfoItem.js +15 -17
  282. package/cjs/Thread/components/ParentMessageInfoItem.js.map +1 -1
  283. package/cjs/Thread/components/ThreadHeader.js +6 -6
  284. package/cjs/Thread/components/ThreadList.js +28 -29
  285. package/cjs/Thread/components/ThreadList.js.map +1 -1
  286. package/cjs/Thread/components/ThreadListItem.js +28 -29
  287. package/cjs/Thread/components/ThreadListItem.js.map +1 -1
  288. package/cjs/Thread/components/ThreadMessageInput.js +25 -26
  289. package/cjs/Thread/components/ThreadMessageInput.js.map +1 -1
  290. package/cjs/Thread/components/ThreadUI.js +32 -33
  291. package/cjs/Thread/components/ThreadUI.js.map +1 -1
  292. package/cjs/Thread/context.js +8 -9
  293. package/cjs/Thread/context.js.map +1 -1
  294. package/cjs/Thread.js +32 -33
  295. package/cjs/Thread.js.map +1 -1
  296. package/cjs/{ThreadProvider-03fb5452.js → ThreadProvider-77682d98.js} +46 -29
  297. package/cjs/ThreadProvider-77682d98.js.map +1 -0
  298. package/cjs/{UserProfileContext-6b73c8c7.js → UserProfileContext-4c1cc9e7.js} +1 -1
  299. package/cjs/{UserProfileContext-6b73c8c7.js.map → UserProfileContext-4c1cc9e7.js.map} +1 -1
  300. package/cjs/{VoiceMessageInputWrapper-b00f09e0.js → VoiceMessageInputWrapper-bb085ef5.js} +12 -8
  301. package/cjs/VoiceMessageInputWrapper-bb085ef5.js.map +1 -0
  302. package/cjs/VoicePlayer/context.js +5 -3
  303. package/cjs/VoicePlayer/context.js.map +1 -1
  304. package/cjs/VoicePlayer/useVoicePlayer.js +5 -4
  305. package/cjs/VoicePlayer/useVoicePlayer.js.map +1 -1
  306. package/cjs/VoiceRecorder/context.js +2555 -8
  307. package/cjs/VoiceRecorder/context.js.map +1 -1
  308. package/cjs/VoiceRecorder/useVoiceRecorder.js +2 -3
  309. package/cjs/VoiceRecorder/useVoiceRecorder.js.map +1 -1
  310. package/cjs/{_rollupPluginBabelHelpers-6bd3ed3b.js → _rollupPluginBabelHelpers-6137a140.js} +1 -1
  311. package/cjs/_rollupPluginBabelHelpers-6137a140.js.map +1 -0
  312. package/cjs/{actionTypes-f0a152e4.js → actionTypes-e9702e2f.js} +1 -1
  313. package/cjs/{actionTypes-f0a152e4.js.map → actionTypes-e9702e2f.js.map} +1 -1
  314. package/cjs/{color-273e8911.js → color-6be2e9f3.js} +1 -1
  315. package/cjs/{color-273e8911.js.map → color-6be2e9f3.js.map} +1 -1
  316. package/cjs/{compareIds-cedb6c39.js → compareIds-83a57e5f.js} +1 -1
  317. package/cjs/{compareIds-cedb6c39.js.map → compareIds-83a57e5f.js.map} +1 -1
  318. package/cjs/{const-b8ef9240.js → const-743dfc24.js} +1 -3
  319. package/cjs/const-743dfc24.js.map +1 -0
  320. package/cjs/{const-5de4173e.js → const-eb0722bc.js} +1 -1
  321. package/cjs/{const-5de4173e.js.map → const-eb0722bc.js.map} +1 -1
  322. package/cjs/{consts-0e64ad01.js → consts-7df240d1.js} +8 -4
  323. package/cjs/consts-7df240d1.js.map +1 -0
  324. package/cjs/{consts-9d6ed0a6.js → consts-bb5e01e7.js} +1 -1
  325. package/cjs/{consts-9d6ed0a6.js.map → consts-bb5e01e7.js.map} +1 -1
  326. package/cjs/{context-e0a53b29.js → context-d22fc6e7.js} +2 -2
  327. package/cjs/{context-e0a53b29.js.map → context-d22fc6e7.js.map} +1 -1
  328. package/cjs/dist/index.css +55 -55
  329. package/cjs/dist/index.css.map +1 -1
  330. package/cjs/{index-31298927.js → index-1dd6b0e3.js} +2 -2
  331. package/cjs/{index-31298927.js.map → index-1dd6b0e3.js.map} +1 -1
  332. package/cjs/{index-75f8f2cd.js → index-244136d1.js} +2 -2
  333. package/cjs/{index-75f8f2cd.js.map → index-244136d1.js.map} +1 -1
  334. package/cjs/{index-36be8d44.js → index-30065b59.js} +4 -4
  335. package/cjs/{index-36be8d44.js.map → index-30065b59.js.map} +1 -1
  336. package/cjs/{index-aa5383c4.js → index-31bdfe4d.js} +5 -5
  337. package/cjs/{index-aa5383c4.js.map → index-31bdfe4d.js.map} +1 -1
  338. package/cjs/{index-7ba6befd.js → index-39a87513.js} +2 -2
  339. package/cjs/{index-7ba6befd.js.map → index-39a87513.js.map} +1 -1
  340. package/cjs/{index-197e3c5b.js → index-42d826d2.js} +2 -2
  341. package/cjs/{index-197e3c5b.js.map → index-42d826d2.js.map} +1 -1
  342. package/cjs/{index-25af7767.js → index-81bd0a0d.js} +7 -7
  343. package/cjs/{index-25af7767.js.map → index-81bd0a0d.js.map} +1 -1
  344. package/cjs/{index-f2e27f6a.js → index-9e4bf057.js} +21 -3
  345. package/cjs/index-9e4bf057.js.map +1 -0
  346. package/cjs/{index-f0d6f431.js → index-adcde1d2.js} +7 -7
  347. package/cjs/{index-f0d6f431.js.map → index-adcde1d2.js.map} +1 -1
  348. package/cjs/{index-6ed2df90.js → index-addd3be5.js} +4 -4
  349. package/cjs/{index-6ed2df90.js.map → index-addd3be5.js.map} +1 -1
  350. package/cjs/{index-8aa6d8c9.js → index-ba572c7a.js} +2 -2
  351. package/cjs/{index-8aa6d8c9.js.map → index-ba572c7a.js.map} +1 -1
  352. package/cjs/{index-3b0363a8.js → index-bef0eca0.js} +1 -1
  353. package/cjs/{index-3b0363a8.js.map → index-bef0eca0.js.map} +1 -1
  354. package/cjs/{index-684be350.js → index-c78778a6.js} +3 -3
  355. package/cjs/{index-684be350.js.map → index-c78778a6.js.map} +1 -1
  356. package/cjs/{index-c810e78c.js → index-f52eb778.js} +1 -1
  357. package/cjs/{index-c810e78c.js.map → index-f52eb778.js.map} +1 -1
  358. package/cjs/index.js +45 -46
  359. package/cjs/index.js.map +1 -1
  360. package/cjs/sendbirdSelectors.js +11 -11
  361. package/cjs/sendbirdSelectors.js.map +1 -1
  362. package/cjs/{stringSet-1e9a4bf2.js → stringSet-618eb438.js} +1 -1
  363. package/cjs/{stringSet-1e9a4bf2.js.map → stringSet-618eb438.js.map} +1 -1
  364. package/cjs/topics-a335cb1e.js +18 -0
  365. package/cjs/topics-a335cb1e.js.map +1 -0
  366. package/cjs/{tslib.es6-a674f4e5.js → tslib.es6-08359f50.js} +1 -1
  367. package/cjs/{tslib.es6-a674f4e5.js.map → tslib.es6-08359f50.js.map} +1 -1
  368. package/cjs/{types-ff787253.js → types-518abc78.js} +1 -1
  369. package/cjs/{types-ff787253.js.map → types-518abc78.js.map} +1 -1
  370. package/cjs/ui/Accordion.js +3 -3
  371. package/cjs/ui/AccordionGroup.js +2 -2
  372. package/cjs/ui/AdminMessage.js +3 -3
  373. package/cjs/ui/Avatar.js +2 -2
  374. package/cjs/ui/Badge.js +5 -5
  375. package/cjs/ui/BottomSheet.js +1 -1
  376. package/cjs/ui/Button.js +3 -3
  377. package/cjs/ui/ChannelAvatar.js +3 -3
  378. package/cjs/ui/ConnectionStatus.js +4 -4
  379. package/cjs/ui/ContextMenu.js +5 -5
  380. package/cjs/ui/DateSeparator.js +4 -4
  381. package/cjs/ui/EmojiReactions.js +7 -7
  382. package/cjs/ui/FileMessageItemBody.js +6 -6
  383. package/cjs/ui/FileViewer.js +8 -8
  384. package/cjs/ui/IconButton.js +1 -1
  385. package/cjs/ui/ImageRenderer.js +1 -1
  386. package/cjs/ui/Input.js +2 -2
  387. package/cjs/ui/Label.js +2 -2
  388. package/cjs/ui/LinkLabel.js +2 -2
  389. package/cjs/ui/Loader.js +1 -1
  390. package/cjs/ui/MentionLabel.js +10 -11
  391. package/cjs/ui/MentionLabel.js.map +1 -1
  392. package/cjs/ui/MentionUserLabel.js +1 -1
  393. package/cjs/ui/MessageContent.js +23 -24
  394. package/cjs/ui/MessageContent.js.map +1 -1
  395. package/cjs/ui/MessageInput.js +10 -10
  396. package/cjs/ui/MessageItemMenu.js +8 -8
  397. package/cjs/ui/MessageItemReactionMenu.js +5 -5
  398. package/cjs/ui/MessageSearchFileItem.js +10 -10
  399. package/cjs/ui/MessageSearchItem.js +9 -9
  400. package/cjs/ui/MessageStatus.js +10 -10
  401. package/cjs/ui/Modal.js +7 -7
  402. package/cjs/ui/OGMessageItemBody.js +10 -11
  403. package/cjs/ui/OGMessageItemBody.js.map +1 -1
  404. package/cjs/ui/OpenChannelAdminMessage.js +3 -3
  405. package/cjs/ui/OpenChannelAvatar.js +6 -6
  406. package/cjs/ui/OpenchannelConversationHeader.js +6 -6
  407. package/cjs/ui/OpenchannelFileMessage.js +16 -16
  408. package/cjs/ui/OpenchannelOGMessage.js +16 -16
  409. package/cjs/ui/OpenchannelThumbnailMessage.js +15 -15
  410. package/cjs/ui/OpenchannelUserMessage.js +16 -16
  411. package/cjs/ui/PlaceHolder.js +6 -6
  412. package/cjs/ui/PlaybackTime.js +2 -2
  413. package/cjs/ui/QuoteMessage.js +6 -6
  414. package/cjs/ui/QuoteMessageInput.js +6 -6
  415. package/cjs/ui/ReactionBadge.js +3 -3
  416. package/cjs/ui/ReactionButton.js +1 -1
  417. package/cjs/ui/SortByRow.js +2 -2
  418. package/cjs/ui/TextButton.js +2 -2
  419. package/cjs/ui/TextMessageItemBody.js +10 -11
  420. package/cjs/ui/TextMessageItemBody.js.map +1 -1
  421. package/cjs/ui/ThreadReplies.js +6 -6
  422. package/cjs/ui/ThumbnailMessageItemBody.js +2 -2
  423. package/cjs/ui/Tooltip.js +3 -3
  424. package/cjs/ui/TooltipWrapper.js +1 -1
  425. package/cjs/ui/UnknownMessageItemBody.js +6 -6
  426. package/cjs/ui/UserListItem.js +10 -11
  427. package/cjs/ui/UserListItem.js.map +1 -1
  428. package/cjs/ui/UserProfile.js +9 -10
  429. package/cjs/ui/UserProfile.js.map +1 -1
  430. package/cjs/ui/VoiceMessageItemBody.js +7 -6
  431. package/cjs/ui/VoiceMessageItemBody.js.map +1 -1
  432. package/cjs/ui/VoiceMessgeInput.js +8 -8
  433. package/cjs/ui/Word.js +10 -11
  434. package/cjs/ui/Word.js.map +1 -1
  435. package/cjs/{useLongPress-37c403d8.js → useLongPress-50b32689.js} +3 -3
  436. package/cjs/{useLongPress-37c403d8.js.map → useLongPress-50b32689.js.map} +1 -1
  437. package/cjs/useSendbirdStateContext.js +1 -1
  438. package/cjs/utils/message/isVoiceMessage.js +2 -2
  439. package/cjs/{utils-50ff8ad6.js → utils-60cddb64.js} +2 -2
  440. package/cjs/{utils-50ff8ad6.js.map → utils-60cddb64.js.map} +1 -1
  441. package/cjs/{utils-9df4cc6c.js → utils-66a05605.js} +1 -1
  442. package/cjs/{utils-9df4cc6c.js.map → utils-66a05605.js.map} +1 -1
  443. package/cjs/{utils-afdab4b0.js → utils-81f8670a.js} +1 -1
  444. package/cjs/{utils-afdab4b0.js.map → utils-81f8670a.js.map} +1 -1
  445. package/cjs/{utils-9fed7de8.js → utils-e669f1ee.js} +1 -1
  446. package/cjs/{utils-9fed7de8.js.map → utils-e669f1ee.js.map} +1 -1
  447. package/cjs/{uuid-f5d1a1fe.js → uuid-cd03215f.js} +1 -1
  448. package/cjs/{uuid-f5d1a1fe.js.map → uuid-cd03215f.js.map} +1 -1
  449. package/cjs/withSendbird.js +15 -13
  450. package/cjs/withSendbird.js.map +1 -1
  451. package/{color-a450612f.js → color-e4afd956.js} +1 -1
  452. package/{color-a450612f.js.map → color-e4afd956.js.map} +1 -1
  453. package/{compareIds-27ab0100.js → compareIds-90b5fdcc.js} +1 -1
  454. package/{compareIds-27ab0100.js.map → compareIds-90b5fdcc.js.map} +1 -1
  455. package/{const-2d43b497.js → const-2c43da6a.js} +2 -3
  456. package/const-2c43da6a.js.map +1 -0
  457. package/{const-de21a301.js → const-ed6c468d.js} +1 -1
  458. package/{const-de21a301.js.map → const-ed6c468d.js.map} +1 -1
  459. package/{consts-cedae35a.js → consts-4cdf8265.js} +8 -5
  460. package/consts-4cdf8265.js.map +1 -0
  461. package/{consts-9f2eecf3.js → consts-9c372f2e.js} +1 -1
  462. package/{consts-9f2eecf3.js.map → consts-9c372f2e.js.map} +1 -1
  463. package/{context-b7ccbd17.js → context-3da7becc.js} +2 -2
  464. package/{context-b7ccbd17.js.map → context-3da7becc.js.map} +1 -1
  465. package/dist/index.css +55 -55
  466. package/dist/index.css.map +1 -1
  467. package/{index-58b5008c.js → index-0a265c2c.js} +2 -2
  468. package/{index-58b5008c.js.map → index-0a265c2c.js.map} +1 -1
  469. package/{index-4729324a.js → index-2b6d5baa.js} +5 -5
  470. package/{index-4729324a.js.map → index-2b6d5baa.js.map} +1 -1
  471. package/{index-eba6c13e.js → index-3c6b00b6.js} +7 -7
  472. package/{index-eba6c13e.js.map → index-3c6b00b6.js.map} +1 -1
  473. package/{index-9f08118f.js → index-71682b33.js} +4 -4
  474. package/{index-9f08118f.js.map → index-71682b33.js.map} +1 -1
  475. package/{index-a245d213.js → index-7e7649f2.js} +2 -2
  476. package/{index-a245d213.js.map → index-7e7649f2.js.map} +1 -1
  477. package/{index-fb9f4d36.js → index-8e2d6bf1.js} +2 -2
  478. package/{index-fb9f4d36.js.map → index-8e2d6bf1.js.map} +1 -1
  479. package/{index-d69c6128.js → index-906f26f4.js} +3 -3
  480. package/{index-d69c6128.js.map → index-906f26f4.js.map} +1 -1
  481. package/{index-f3ba7696.js → index-9746b9e4.js} +1 -1
  482. package/{index-f3ba7696.js.map → index-9746b9e4.js.map} +1 -1
  483. package/{index-ba549e6a.js → index-99e3b057.js} +2 -2
  484. package/{index-ba549e6a.js.map → index-99e3b057.js.map} +1 -1
  485. package/{index-e8294858.js → index-b0c02bbc.js} +4 -4
  486. package/{index-e8294858.js.map → index-b0c02bbc.js.map} +1 -1
  487. package/{index-533dff7c.js → index-b498f4df.js} +7 -7
  488. package/{index-533dff7c.js.map → index-b498f4df.js.map} +1 -1
  489. package/{index-af6e4d1e.js → index-c24fc3d9.js} +1 -1
  490. package/{index-af6e4d1e.js.map → index-c24fc3d9.js.map} +1 -1
  491. package/{index-9ee89f7c.js → index-caabeae5.js} +2 -2
  492. package/{index-9ee89f7c.js.map → index-caabeae5.js.map} +1 -1
  493. package/{index-5e921f58.js → index-e21d4934.js} +21 -3
  494. package/index-e21d4934.js.map +1 -0
  495. package/index.d.ts +1 -2
  496. package/index.js +45 -46
  497. package/index.js.map +1 -1
  498. package/package.json +33 -33
  499. package/sendbirdSelectors.js +11 -11
  500. package/sendbirdSelectors.js.map +1 -1
  501. package/{stringSet-80381462.js → stringSet-8f776451.js} +1 -1
  502. package/{stringSet-80381462.js.map → stringSet-8f776451.js.map} +1 -1
  503. package/topics-e27c1d5d.js +16 -0
  504. package/topics-e27c1d5d.js.map +1 -0
  505. package/{tslib.es6-33004eb4.js → tslib.es6-c441d88b.js} +1 -1
  506. package/{tslib.es6-33004eb4.js.map → tslib.es6-c441d88b.js.map} +1 -1
  507. package/{types-79f3626f.js → types-9069552c.js} +1 -1
  508. package/{types-79f3626f.js.map → types-9069552c.js.map} +1 -1
  509. package/ui/Accordion.js +3 -3
  510. package/ui/AccordionGroup.js +2 -2
  511. package/ui/AdminMessage.js +3 -3
  512. package/ui/Avatar.js +2 -2
  513. package/ui/Badge.js +5 -5
  514. package/ui/BottomSheet.js +1 -1
  515. package/ui/Button.js +3 -3
  516. package/ui/ChannelAvatar.js +3 -3
  517. package/ui/ConnectionStatus.js +4 -4
  518. package/ui/ContextMenu.js +5 -5
  519. package/ui/DateSeparator.js +4 -4
  520. package/ui/EmojiReactions.js +7 -7
  521. package/ui/FileMessageItemBody.js +6 -6
  522. package/ui/FileViewer.js +8 -8
  523. package/ui/IconButton.js +1 -1
  524. package/ui/ImageRenderer.js +1 -1
  525. package/ui/Input.js +2 -2
  526. package/ui/Label.js +2 -2
  527. package/ui/LinkLabel.js +2 -2
  528. package/ui/Loader.js +1 -1
  529. package/ui/MentionLabel.js +10 -11
  530. package/ui/MentionLabel.js.map +1 -1
  531. package/ui/MentionUserLabel.js +1 -1
  532. package/ui/MessageContent.js +23 -24
  533. package/ui/MessageContent.js.map +1 -1
  534. package/ui/MessageInput.js +10 -10
  535. package/ui/MessageItemMenu.js +8 -8
  536. package/ui/MessageItemReactionMenu.js +5 -5
  537. package/ui/MessageSearchFileItem.js +10 -10
  538. package/ui/MessageSearchItem.js +9 -9
  539. package/ui/MessageStatus.js +10 -10
  540. package/ui/Modal.js +7 -7
  541. package/ui/OGMessageItemBody.js +10 -11
  542. package/ui/OGMessageItemBody.js.map +1 -1
  543. package/ui/OpenChannelAdminMessage.js +3 -3
  544. package/ui/OpenChannelAvatar.js +6 -6
  545. package/ui/OpenchannelConversationHeader.js +6 -6
  546. package/ui/OpenchannelFileMessage.js +16 -16
  547. package/ui/OpenchannelOGMessage.js +16 -16
  548. package/ui/OpenchannelThumbnailMessage.js +15 -15
  549. package/ui/OpenchannelUserMessage.js +16 -16
  550. package/ui/PlaceHolder.js +6 -6
  551. package/ui/PlaybackTime.js +2 -2
  552. package/ui/QuoteMessage.js +6 -6
  553. package/ui/QuoteMessageInput.js +6 -6
  554. package/ui/ReactionBadge.js +3 -3
  555. package/ui/ReactionButton.js +1 -1
  556. package/ui/SortByRow.js +2 -2
  557. package/ui/TextButton.js +2 -2
  558. package/ui/TextMessageItemBody.js +10 -11
  559. package/ui/TextMessageItemBody.js.map +1 -1
  560. package/ui/ThreadReplies.js +6 -6
  561. package/ui/ThumbnailMessageItemBody.js +2 -2
  562. package/ui/Tooltip.js +3 -3
  563. package/ui/TooltipWrapper.js +1 -1
  564. package/ui/UnknownMessageItemBody.js +6 -6
  565. package/ui/UserListItem.js +10 -11
  566. package/ui/UserListItem.js.map +1 -1
  567. package/ui/UserProfile.js +9 -10
  568. package/ui/UserProfile.js.map +1 -1
  569. package/ui/VoiceMessageItemBody.js +7 -6
  570. package/ui/VoiceMessageItemBody.js.map +1 -1
  571. package/ui/VoiceMessgeInput.js +8 -8
  572. package/ui/Word.js +10 -11
  573. package/ui/Word.js.map +1 -1
  574. package/{useLongPress-562f0826.js → useLongPress-c46971c4.js} +3 -3
  575. package/{useLongPress-562f0826.js.map → useLongPress-c46971c4.js.map} +1 -1
  576. package/useSendbirdStateContext.js +1 -1
  577. package/utils/message/isVoiceMessage.js +2 -2
  578. package/{utils-4e5389df.js → utils-0f335ebc.js} +1 -1
  579. package/{utils-4e5389df.js.map → utils-0f335ebc.js.map} +1 -1
  580. package/{utils-8fa2a634.js → utils-51f19122.js} +2 -2
  581. package/{utils-8fa2a634.js.map → utils-51f19122.js.map} +1 -1
  582. package/{utils-b84d9295.js → utils-cd7aab7a.js} +1 -1
  583. package/{utils-b84d9295.js.map → utils-cd7aab7a.js.map} +1 -1
  584. package/{utils-3eee4302.js → utils-ce528957.js} +1 -1
  585. package/{utils-3eee4302.js.map → utils-ce528957.js.map} +1 -1
  586. package/{uuid-7397f1ec.js → uuid-e3615ce2.js} +1 -1
  587. package/{uuid-7397f1ec.js.map → uuid-e3615ce2.js.map} +1 -1
  588. package/withSendbird.js +15 -13
  589. package/withSendbird.js.map +1 -1
  590. package/.size-snapshot.json +0 -9696
  591. package/ChannelListProvider-74d39ce5.js.map +0 -1
  592. package/ChannelProvider-7b83d4fd.js.map +0 -1
  593. package/OpenChannelListProvider-2685f3d5.js.map +0 -1
  594. package/OpenChannelProvider-9bd64275.js.map +0 -1
  595. package/ThreadProvider-daedc3df.js.map +0 -1
  596. package/VoiceMessageInputWrapper-f65cc3ae.js.map +0 -1
  597. package/_rollupPluginBabelHelpers-38fb8170.js.map +0 -1
  598. package/cjs/ChannelListProvider-4cf41348.js.map +0 -1
  599. package/cjs/ChannelProvider-af11f0e6.js.map +0 -1
  600. package/cjs/OpenChannelListProvider-aa38b9f3.js.map +0 -1
  601. package/cjs/OpenChannelProvider-689e3690.js.map +0 -1
  602. package/cjs/ThreadProvider-03fb5452.js.map +0 -1
  603. package/cjs/VoiceMessageInputWrapper-b00f09e0.js.map +0 -1
  604. package/cjs/_rollupPluginBabelHelpers-6bd3ed3b.js.map +0 -1
  605. package/cjs/const-b8ef9240.js.map +0 -1
  606. package/cjs/consts-0e64ad01.js.map +0 -1
  607. package/cjs/index-f2e27f6a.js.map +0 -1
  608. package/cjs/lame.all.js +0 -2541
  609. package/cjs/lame.all.js.map +0 -1
  610. package/cjs/topics-33dacb94.js +0 -22
  611. package/cjs/topics-33dacb94.js.map +0 -1
  612. package/const-2d43b497.js.map +0 -1
  613. package/consts-cedae35a.js.map +0 -1
  614. package/index-5e921f58.js.map +0 -1
  615. package/lame.all.js +0 -2537
  616. package/lame.all.js.map +0 -1
  617. package/topics-aa4d9dac.js +0 -13
  618. package/topics-aa4d9dac.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"ThreadUI.js","sources":["../../../src/smart-components/Thread/components/ThreadUI/useMemorizedHeader.tsx","../../../src/smart-components/Thread/components/ThreadUI/useMemorizedParentMessageInfo.tsx","../../../src/smart-components/Thread/components/ThreadUI/useMemorizedThreadList.tsx","../../../src/smart-components/Thread/components/ThreadUI/index.tsx"],"sourcesContent":["import React, { ReactElement, useMemo } from 'react';\n\nexport interface UseMemorizedHeaderProps {\n renderHeader?: () => React.ReactElement;\n}\n\nconst useMemorizedHeader = ({ renderHeader }: UseMemorizedHeaderProps): ReactElement => useMemo(() => {\n if (typeof renderHeader === 'function') {\n return renderHeader();\n }\n return null;\n}, [renderHeader]);\n\nexport default useMemorizedHeader;\n","import React, { ReactElement, useMemo } from 'react';\n\nimport { ParentMessageStateTypes } from '../../types';\nimport PlaceHolder, { PlaceHolderTypes } from '../../../../ui/PlaceHolder';\nimport { FileMessage, UserMessage } from '@sendbird/chat/message';\n\nexport interface UseMemorizedParentMessageInfoProps {\n parentMessage: UserMessage | FileMessage;\n parentMessageState: ParentMessageStateTypes;\n renderParentMessageInfo?: () => React.ReactElement;\n renderParentMessageInfoPlaceholder?: (type: ParentMessageStateTypes) => React.ReactElement;\n}\n\nconst useMemorizedParentMessageInfo = ({\n parentMessage,\n parentMessageState,\n renderParentMessageInfo,\n renderParentMessageInfoPlaceholder,\n}: UseMemorizedParentMessageInfoProps): ReactElement => useMemo(() => {\n if (parentMessageState === ParentMessageStateTypes.NIL\n || parentMessageState === ParentMessageStateTypes.LOADING\n || parentMessageState === ParentMessageStateTypes.INVALID\n ) {\n if (typeof renderParentMessageInfoPlaceholder === 'function') {\n return renderParentMessageInfoPlaceholder(parentMessageState);\n }\n switch (parentMessageState) {\n case ParentMessageStateTypes.NIL: {\n return (\n <PlaceHolder\n className=\"sendbird-thread-ui__parent-message-info placeholder-nil\"\n type={PlaceHolderTypes.NO_RESULTS}\n iconSize=\"64px\"\n />\n );\n }\n case ParentMessageStateTypes.LOADING: {\n return (\n <PlaceHolder\n className=\"sendbird-thread-ui__parent-message-info placeholder-loading\"\n type={PlaceHolderTypes.LOADING}\n iconSize=\"64px\"\n />\n );\n }\n case ParentMessageStateTypes.INVALID: {\n return (\n <PlaceHolder\n className=\"sendbird-thread-ui__parent-message-info placeholder-invalid\"\n type={PlaceHolderTypes.WRONG}\n iconSize=\"64px\"\n />\n );\n }\n default: {\n return null;\n }\n }\n } else if (parentMessageState === ParentMessageStateTypes.INITIALIZED) {\n if (typeof renderParentMessageInfo === 'function') {\n return renderParentMessageInfo();\n }\n }\n return null;\n}, [\n parentMessage,\n parentMessageState,\n renderParentMessageInfo,\n renderParentMessageInfoPlaceholder,\n]);\n\nexport default useMemorizedParentMessageInfo;\n","import React, { ReactElement, useMemo } from 'react';\nimport PlaceHolder, { PlaceHolderTypes } from '../../../../ui/PlaceHolder';\n\nimport { ThreadListStateTypes } from '../../types';\n\nexport interface UseMemorizedThreadListProps {\n threadListState: ThreadListStateTypes;\n renderThreadListPlaceHolder?: (tyep: ThreadListStateTypes) => React.ReactElement;\n}\n\nconst useMemorizedThreadList = ({\n threadListState,\n renderThreadListPlaceHolder,\n}: UseMemorizedThreadListProps): ReactElement => useMemo(() => {\n if (threadListState === ThreadListStateTypes.NIL\n || threadListState === ThreadListStateTypes.LOADING\n || threadListState === ThreadListStateTypes.INVALID\n ) {\n if (typeof renderThreadListPlaceHolder === 'function') {\n return renderThreadListPlaceHolder(threadListState);\n }\n switch (threadListState) {\n case ThreadListStateTypes.LOADING: {\n return (\n <PlaceHolder\n className=\"sendbird-thread-ui__thread-list placeholder-loading\"\n type={PlaceHolderTypes.LOADING}\n iconSize=\"64px\"\n />\n );\n }\n case ThreadListStateTypes.INVALID: {\n return (\n <PlaceHolder\n className=\"sendbird-thread-ui__thread-list placeholder-invalid\"\n type={PlaceHolderTypes.WRONG}\n iconSize=\"64px\"\n />\n );\n }\n case ThreadListStateTypes.NIL: {\n return <></>;\n }\n default: {\n return null;\n }\n }\n }\n return null;\n}, [\n threadListState,\n renderThreadListPlaceHolder,\n]);\n\nexport default useMemorizedThreadList;\n","import React, { useRef, useState } from 'react';\nimport { FileMessage, UserMessage } from '@sendbird/chat/message';\n\nimport './index.scss';\n\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport { useLocalization } from '../../../../lib/LocalizationContext';\nimport { getChannelTitle } from '../../../Channel/components/ChannelHeader/utils';\nimport { useThreadContext } from '../../context/ThreadProvider';\nimport { ParentMessageStateTypes, ThreadListStateTypes } from '../../types';\nimport ParentMessageInfo from '../ParentMessageInfo';\nimport ThreadHeader from '../ThreadHeader';\nimport ThreadList from '../ThreadList';\nimport ThreadMessageInput from '../ThreadMessageInput';\nimport useMemorizedHeader from './useMemorizedHeader';\nimport useMemorizedParentMessageInfo from './useMemorizedParentMessageInfo';\nimport useMemorizedThreadList from './useMemorizedThreadList';\nimport Label, { LabelTypography, LabelColors } from '../../../../ui/Label';\nimport { isAboutSame } from '../../context/utils';\n\nexport interface ThreadUIProps {\n renderHeader?: () => React.ReactElement;\n renderParentMessageInfo?: () => React.ReactElement;\n renderMessage?: (props: {\n message: UserMessage | FileMessage,\n chainTop: boolean,\n chainBottom: boolean,\n hasSeparator: boolean,\n }) => React.ReactElement;\n renderFileUploadIcon?: () => React.ReactElement;\n renderVoiceMessageIcon?: () => React.ReactElement;\n renderSendMessageIcon?: () => React.ReactElement;\n renderMessageInput?: () => React.ReactElement;\n renderCustomSeparator?: () => React.ReactElement;\n renderParentMessageInfoPlaceholder?: (type: ParentMessageStateTypes) => React.ReactElement;\n renderThreadListPlaceHolder?: (type: ThreadListStateTypes) => React.ReactElement;\n}\n\nconst ThreadUI: React.FC<ThreadUIProps> = ({\n renderHeader,\n renderParentMessageInfo,\n renderMessage,\n renderMessageInput,\n renderCustomSeparator,\n renderParentMessageInfoPlaceholder,\n renderThreadListPlaceHolder,\n renderFileUploadIcon,\n renderVoiceMessageIcon,\n renderSendMessageIcon,\n}: ThreadUIProps): React.ReactElement => {\n const {\n stores,\n } = useSendbirdStateContext();\n const currentUserId = stores?.sdkStore?.sdk?.currentUser?.userId;\n const {\n stringSet,\n } = useLocalization();\n const {\n currentChannel,\n allThreadMessages,\n parentMessage,\n parentMessageState,\n threadListState,\n hasMorePrev,\n hasMoreNext,\n fetchPrevThreads,\n fetchNextThreads,\n onHeaderActionClick,\n onMoveToParentMessage,\n } = useThreadContext();\n const replyCount = allThreadMessages.length;\n\n // Memoized custom components\n const MemorizedHeader = useMemorizedHeader({ renderHeader });\n const MemorizedParentMessageInfo = useMemorizedParentMessageInfo({\n parentMessage,\n parentMessageState,\n renderParentMessageInfo,\n renderParentMessageInfoPlaceholder, // nil, loading, invalid\n });\n const MemorizedThreadList = useMemorizedThreadList({\n threadListState,\n renderThreadListPlaceHolder,\n });\n\n // scroll\n const [scrollBottom, setScrollBottom] = useState(0);\n const scrollRef = useRef(null);\n const onScroll = (e) => {\n const element = e.target;\n const {\n scrollTop,\n clientHeight,\n scrollHeight,\n } = element;\n\n const threadItemNodes = scrollRef.current.querySelectorAll('.sendbird-thread-list-item');\n const firstNode = threadItemNodes?.[0];\n if (isAboutSame(scrollTop, 0, 10) && hasMorePrev) {\n fetchPrevThreads((messages) => {\n if (messages) {\n try {\n firstNode?.scrollIntoView?.({ block: 'start', inline: 'nearest' });\n } catch (error) {\n //\n }\n }\n });\n }\n\n if (isAboutSame(clientHeight + scrollTop, scrollHeight, 10) && hasMoreNext) {\n const scrollTop_ = scrollTop;\n fetchNextThreads((messages) => {\n if (messages) {\n try {\n element.scrollTop = scrollTop_;\n scrollRef.current.scrollTop = scrollTop_;\n } catch (error) {\n //\n }\n }\n });\n }\n\n // save the lastest scroll bottom value\n if (scrollRef?.current) {\n const current = scrollRef?.current;\n setScrollBottom(current.scrollHeight - current.scrollTop - current.offsetHeight)\n }\n };\n\n return (\n <div className='sendbird-thread-ui'>\n {\n MemorizedHeader || (\n <ThreadHeader\n className=\"sendbird-thread-ui__header\"\n channelName={getChannelTitle(currentChannel, currentUserId, stringSet)}\n onActionIconClick={onHeaderActionClick}\n onChannelNameClick={() => onMoveToParentMessage({ message: parentMessage, channel: currentChannel })}\n />\n )\n }\n <div\n className=\"sendbird-thread-ui--scroll\"\n ref={scrollRef}\n onScroll={onScroll}\n >\n {\n MemorizedParentMessageInfo || (\n <ParentMessageInfo\n className=\"sendbird-thread-ui__parent-message-info\"\n />\n )\n }\n {\n replyCount > 0 && (\n <div className=\"sendbird-thread-ui__reply-counts\">\n <Label\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_3}\n >\n {`${replyCount} ${replyCount > 1 ? stringSet.THREAD__THREAD_REPLIES : stringSet.THREAD__THREAD_REPLY}`}\n </Label>\n </div>\n )\n }\n {\n MemorizedThreadList || (\n <ThreadList\n className=\"sendbird-thread-ui__thread-list\"\n allThreadMessages={allThreadMessages}\n renderMessage={renderMessage}\n renderCustomSeparator={renderCustomSeparator}\n scrollRef={scrollRef}\n scrollBottom={scrollBottom}\n />\n )\n }\n </div>\n {/* MessageInput */}\n {\n renderMessageInput?.() || (\n <ThreadMessageInput\n className=\"sendbird-thread-ui__message-input\"\n renderFileUploadIcon={renderFileUploadIcon}\n renderVoiceMessageIcon={renderVoiceMessageIcon}\n renderSendMessageIcon={renderSendMessageIcon}\n />\n )\n }\n </div>\n );\n};\n\nexport default ThreadUI;\n"],"names":["useMemorizedHeader","_a","renderHeader","useMemo","useMemorizedParentMessageInfo","parentMessage","parentMessageState","renderParentMessageInfo","renderParentMessageInfoPlaceholder","ParentMessageStateTypes","NIL","LOADING","INVALID","React","PlaceHolderTypes","NO_RESULTS","WRONG","INITIALIZED","useMemorizedThreadList","threadListState","renderThreadListPlaceHolder","ThreadListStateTypes","ThreadUI","renderMessage","renderMessageInput","renderCustomSeparator","renderFileUploadIcon","renderVoiceMessageIcon","renderSendMessageIcon","stores","useSendbirdStateContext","currentUserId","_d","_b","sdkStore","sdk","currentUser","userId","stringSet","useLocalization","_e","useThreadContext","currentChannel","allThreadMessages","hasMorePrev","hasMoreNext","fetchPrevThreads","fetchNextThreads","onHeaderActionClick","onMoveToParentMessage","replyCount","length","MemorizedHeader","MemorizedParentMessageInfo","MemorizedThreadList","_f","useState","scrollBottom","setScrollBottom","scrollRef","useRef","onScroll","e","element","target","scrollTop","clientHeight","scrollHeight","threadItemNodes","current","querySelectorAll","firstNode","isAboutSame","messages","scrollIntoView","call","block","inline","error","scrollTop_1","offsetHeight","getChannelTitle","message","channel","LabelTypography","BODY_1","LabelColors","ONBACKGROUND_3","concat","THREAD__THREAD_REPLIES","THREAD__THREAD_REPLY"],"mappings":"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"}
1
+ {"version":3,"file":"ThreadUI.js","sources":["../../../src/smart-components/Thread/components/ThreadUI/useMemorizedHeader.tsx","../../../src/smart-components/Thread/components/ThreadUI/useMemorizedParentMessageInfo.tsx","../../../src/smart-components/Thread/components/ThreadUI/useMemorizedThreadList.tsx","../../../src/smart-components/Thread/components/ThreadUI/index.tsx"],"sourcesContent":["import React, { ReactElement, useMemo } from 'react';\n\nexport interface UseMemorizedHeaderProps {\n renderHeader?: () => React.ReactElement;\n}\n\nconst useMemorizedHeader = ({ renderHeader }: UseMemorizedHeaderProps): ReactElement => useMemo(() => {\n if (typeof renderHeader === 'function') {\n return renderHeader();\n }\n return null;\n}, [renderHeader]);\n\nexport default useMemorizedHeader;\n","import React, { ReactElement, useMemo } from 'react';\n\nimport { ParentMessageStateTypes } from '../../types';\nimport PlaceHolder, { PlaceHolderTypes } from '../../../../ui/PlaceHolder';\nimport { FileMessage, UserMessage } from '@sendbird/chat/message';\n\nexport interface UseMemorizedParentMessageInfoProps {\n parentMessage: UserMessage | FileMessage;\n parentMessageState: ParentMessageStateTypes;\n renderParentMessageInfo?: () => React.ReactElement;\n renderParentMessageInfoPlaceholder?: (type: ParentMessageStateTypes) => React.ReactElement;\n}\n\nconst useMemorizedParentMessageInfo = ({\n parentMessage,\n parentMessageState,\n renderParentMessageInfo,\n renderParentMessageInfoPlaceholder,\n}: UseMemorizedParentMessageInfoProps): ReactElement => useMemo(() => {\n if (parentMessageState === ParentMessageStateTypes.NIL\n || parentMessageState === ParentMessageStateTypes.LOADING\n || parentMessageState === ParentMessageStateTypes.INVALID\n ) {\n if (typeof renderParentMessageInfoPlaceholder === 'function') {\n return renderParentMessageInfoPlaceholder(parentMessageState);\n }\n switch (parentMessageState) {\n case ParentMessageStateTypes.NIL: {\n return (\n <PlaceHolder\n className=\"sendbird-thread-ui__parent-message-info placeholder-nil\"\n type={PlaceHolderTypes.NO_RESULTS}\n iconSize=\"64px\"\n />\n );\n }\n case ParentMessageStateTypes.LOADING: {\n return (\n <PlaceHolder\n className=\"sendbird-thread-ui__parent-message-info placeholder-loading\"\n type={PlaceHolderTypes.LOADING}\n iconSize=\"64px\"\n />\n );\n }\n case ParentMessageStateTypes.INVALID: {\n return (\n <PlaceHolder\n className=\"sendbird-thread-ui__parent-message-info placeholder-invalid\"\n type={PlaceHolderTypes.WRONG}\n iconSize=\"64px\"\n />\n );\n }\n default: {\n return null;\n }\n }\n } else if (parentMessageState === ParentMessageStateTypes.INITIALIZED) {\n if (typeof renderParentMessageInfo === 'function') {\n return renderParentMessageInfo();\n }\n }\n return null;\n}, [\n parentMessage,\n parentMessageState,\n renderParentMessageInfo,\n renderParentMessageInfoPlaceholder,\n]);\n\nexport default useMemorizedParentMessageInfo;\n","import React, { ReactElement, useMemo } from 'react';\nimport PlaceHolder, { PlaceHolderTypes } from '../../../../ui/PlaceHolder';\n\nimport { ThreadListStateTypes } from '../../types';\n\nexport interface UseMemorizedThreadListProps {\n threadListState: ThreadListStateTypes;\n renderThreadListPlaceHolder?: (tyep: ThreadListStateTypes) => React.ReactElement;\n}\n\nconst useMemorizedThreadList = ({\n threadListState,\n renderThreadListPlaceHolder,\n}: UseMemorizedThreadListProps): ReactElement => useMemo(() => {\n if (threadListState === ThreadListStateTypes.NIL\n || threadListState === ThreadListStateTypes.LOADING\n || threadListState === ThreadListStateTypes.INVALID\n ) {\n if (typeof renderThreadListPlaceHolder === 'function') {\n return renderThreadListPlaceHolder(threadListState);\n }\n switch (threadListState) {\n case ThreadListStateTypes.LOADING: {\n return (\n <PlaceHolder\n className=\"sendbird-thread-ui__thread-list placeholder-loading\"\n type={PlaceHolderTypes.LOADING}\n iconSize=\"64px\"\n />\n );\n }\n case ThreadListStateTypes.INVALID: {\n return (\n <PlaceHolder\n className=\"sendbird-thread-ui__thread-list placeholder-invalid\"\n type={PlaceHolderTypes.WRONG}\n iconSize=\"64px\"\n />\n );\n }\n case ThreadListStateTypes.NIL: {\n return <></>;\n }\n default: {\n return null;\n }\n }\n }\n return null;\n}, [\n threadListState,\n renderThreadListPlaceHolder,\n]);\n\nexport default useMemorizedThreadList;\n","import React, { useRef, useState } from 'react';\nimport { FileMessage, UserMessage } from '@sendbird/chat/message';\n\nimport './index.scss';\n\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport { useLocalization } from '../../../../lib/LocalizationContext';\nimport { getChannelTitle } from '../../../Channel/components/ChannelHeader/utils';\nimport { useThreadContext } from '../../context/ThreadProvider';\nimport { ParentMessageStateTypes, ThreadListStateTypes } from '../../types';\nimport ParentMessageInfo from '../ParentMessageInfo';\nimport ThreadHeader from '../ThreadHeader';\nimport ThreadList from '../ThreadList';\nimport ThreadMessageInput from '../ThreadMessageInput';\nimport useMemorizedHeader from './useMemorizedHeader';\nimport useMemorizedParentMessageInfo from './useMemorizedParentMessageInfo';\nimport useMemorizedThreadList from './useMemorizedThreadList';\nimport Label, { LabelTypography, LabelColors } from '../../../../ui/Label';\nimport { isAboutSame } from '../../context/utils';\n\nexport interface ThreadUIProps {\n renderHeader?: () => React.ReactElement;\n renderParentMessageInfo?: () => React.ReactElement;\n renderMessage?: (props: {\n message: UserMessage | FileMessage,\n chainTop: boolean,\n chainBottom: boolean,\n hasSeparator: boolean,\n }) => React.ReactElement;\n renderFileUploadIcon?: () => React.ReactElement;\n renderVoiceMessageIcon?: () => React.ReactElement;\n renderSendMessageIcon?: () => React.ReactElement;\n renderMessageInput?: () => React.ReactElement;\n renderCustomSeparator?: () => React.ReactElement;\n renderParentMessageInfoPlaceholder?: (type: ParentMessageStateTypes) => React.ReactElement;\n renderThreadListPlaceHolder?: (type: ThreadListStateTypes) => React.ReactElement;\n}\n\nconst ThreadUI: React.FC<ThreadUIProps> = ({\n renderHeader,\n renderParentMessageInfo,\n renderMessage,\n renderMessageInput,\n renderCustomSeparator,\n renderParentMessageInfoPlaceholder,\n renderThreadListPlaceHolder,\n renderFileUploadIcon,\n renderVoiceMessageIcon,\n renderSendMessageIcon,\n}: ThreadUIProps): React.ReactElement => {\n const {\n stores,\n } = useSendbirdStateContext();\n const currentUserId = stores?.sdkStore?.sdk?.currentUser?.userId;\n const {\n stringSet,\n } = useLocalization();\n const {\n currentChannel,\n allThreadMessages,\n parentMessage,\n parentMessageState,\n threadListState,\n hasMorePrev,\n hasMoreNext,\n fetchPrevThreads,\n fetchNextThreads,\n onHeaderActionClick,\n onMoveToParentMessage,\n } = useThreadContext();\n const replyCount = allThreadMessages.length;\n\n // Memoized custom components\n const MemorizedHeader = useMemorizedHeader({ renderHeader });\n const MemorizedParentMessageInfo = useMemorizedParentMessageInfo({\n parentMessage,\n parentMessageState,\n renderParentMessageInfo,\n renderParentMessageInfoPlaceholder, // nil, loading, invalid\n });\n const MemorizedThreadList = useMemorizedThreadList({\n threadListState,\n renderThreadListPlaceHolder,\n });\n\n // scroll\n const [scrollBottom, setScrollBottom] = useState(0);\n const scrollRef = useRef(null);\n const onScroll = (e) => {\n const element = e.target;\n const {\n scrollTop,\n clientHeight,\n scrollHeight,\n } = element;\n\n const threadItemNodes = scrollRef.current.querySelectorAll('.sendbird-thread-list-item');\n const firstNode = threadItemNodes?.[0];\n if (isAboutSame(scrollTop, 0, 10) && hasMorePrev) {\n fetchPrevThreads((messages) => {\n if (messages) {\n try {\n firstNode?.scrollIntoView?.({ block: 'start', inline: 'nearest' });\n } catch (error) {\n //\n }\n }\n });\n }\n\n if (isAboutSame(clientHeight + scrollTop, scrollHeight, 10) && hasMoreNext) {\n const scrollTop_ = scrollTop;\n fetchNextThreads((messages) => {\n if (messages) {\n try {\n element.scrollTop = scrollTop_;\n scrollRef.current.scrollTop = scrollTop_;\n } catch (error) {\n //\n }\n }\n });\n }\n\n // save the lastest scroll bottom value\n if (scrollRef?.current) {\n const current = scrollRef?.current;\n setScrollBottom(current.scrollHeight - current.scrollTop - current.offsetHeight)\n }\n };\n\n return (\n <div className='sendbird-thread-ui'>\n {\n MemorizedHeader || (\n <ThreadHeader\n className=\"sendbird-thread-ui__header\"\n channelName={getChannelTitle(currentChannel, currentUserId, stringSet)}\n onActionIconClick={onHeaderActionClick}\n onChannelNameClick={() => onMoveToParentMessage({ message: parentMessage, channel: currentChannel })}\n />\n )\n }\n <div\n className=\"sendbird-thread-ui--scroll\"\n ref={scrollRef}\n onScroll={onScroll}\n >\n {\n MemorizedParentMessageInfo || (\n <ParentMessageInfo\n className=\"sendbird-thread-ui__parent-message-info\"\n />\n )\n }\n {\n replyCount > 0 && (\n <div className=\"sendbird-thread-ui__reply-counts\">\n <Label\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_3}\n >\n {`${replyCount} ${replyCount > 1 ? stringSet.THREAD__THREAD_REPLIES : stringSet.THREAD__THREAD_REPLY}`}\n </Label>\n </div>\n )\n }\n {\n MemorizedThreadList || (\n <ThreadList\n className=\"sendbird-thread-ui__thread-list\"\n allThreadMessages={allThreadMessages}\n renderMessage={renderMessage}\n renderCustomSeparator={renderCustomSeparator}\n scrollRef={scrollRef}\n scrollBottom={scrollBottom}\n />\n )\n }\n </div>\n {/* MessageInput */}\n {\n renderMessageInput?.() || (\n <ThreadMessageInput\n className=\"sendbird-thread-ui__message-input\"\n renderFileUploadIcon={renderFileUploadIcon}\n renderVoiceMessageIcon={renderVoiceMessageIcon}\n renderSendMessageIcon={renderSendMessageIcon}\n />\n )\n }\n </div>\n );\n};\n\nexport default ThreadUI;\n"],"names":["useMemorizedHeader","_a","renderHeader","useMemo","useMemorizedParentMessageInfo","parentMessage","parentMessageState","renderParentMessageInfo","renderParentMessageInfoPlaceholder","ParentMessageStateTypes","NIL","LOADING","INVALID","React","PlaceHolderTypes","NO_RESULTS","WRONG","INITIALIZED","useMemorizedThreadList","threadListState","renderThreadListPlaceHolder","ThreadListStateTypes","ThreadUI","renderMessage","renderMessageInput","renderCustomSeparator","renderFileUploadIcon","renderVoiceMessageIcon","renderSendMessageIcon","stores","useSendbirdStateContext","currentUserId","_d","_b","sdkStore","sdk","currentUser","userId","stringSet","useLocalization","_e","useThreadContext","currentChannel","allThreadMessages","hasMorePrev","hasMoreNext","fetchPrevThreads","fetchNextThreads","onHeaderActionClick","onMoveToParentMessage","replyCount","length","MemorizedHeader","MemorizedParentMessageInfo","MemorizedThreadList","_f","useState","scrollBottom","setScrollBottom","scrollRef","useRef","onScroll","e","element","target","scrollTop","clientHeight","scrollHeight","threadItemNodes","current","querySelectorAll","firstNode","isAboutSame","messages","scrollIntoView","call","block","inline","error","scrollTop_1","offsetHeight","getChannelTitle","message","channel","LabelTypography","BODY_1","LabelColors","ONBACKGROUND_3","concat","THREAD__THREAD_REPLIES","THREAD__THREAD_REPLY"],"mappings":"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"}
package/Thread/context.js CHANGED
@@ -1,19 +1,18 @@
1
1
  import 'react';
2
- export { T as ThreadProvider, u as useThreadContext } from '../ThreadProvider-daedc3df.js';
3
- import '../UserProfileContext-2ea97dc1.js';
2
+ export { T as ThreadProvider, u as useThreadContext } from '../ThreadProvider-c3528b8f.js';
3
+ import '../UserProfileContext-b722645f.js';
4
4
  import '../useSendbirdStateContext.js';
5
- import '../index-9ee89f7c.js';
6
- import '../index-f3ba7696.js';
5
+ import '../index-caabeae5.js';
6
+ import '../index-9746b9e4.js';
7
7
  import '../utils/message/getOutgoingMessageState.js';
8
- import '../tslib.es6-33004eb4.js';
8
+ import '../tslib.es6-c441d88b.js';
9
9
  import './context/types.js';
10
10
  import '@sendbird/chat';
11
- import '../topics-aa4d9dac.js';
11
+ import '../topics-e27c1d5d.js';
12
12
  import '@sendbird/chat/groupChannel';
13
- import '../uuid-7397f1ec.js';
13
+ import '../uuid-e3615ce2.js';
14
14
  import '@sendbird/chat/message';
15
- import '../consts-cedae35a.js';
15
+ import '../consts-4cdf8265.js';
16
16
  import 'prop-types';
17
17
  import '../withSendbird.js';
18
- import '../_rollupPluginBabelHelpers-38fb8170.js';
19
18
  //# sourceMappingURL=context.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"context.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"context.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;"}
package/Thread.js CHANGED
@@ -1,37 +1,36 @@
1
1
  import React__default from 'react';
2
- import { T as ThreadProvider } from './ThreadProvider-daedc3df.js';
2
+ import { T as ThreadProvider } from './ThreadProvider-c3528b8f.js';
3
3
  import ThreadUI from './Thread/components/ThreadUI.js';
4
- import './index-9ee89f7c.js';
5
- import './index-f3ba7696.js';
4
+ import './index-caabeae5.js';
5
+ import './index-9746b9e4.js';
6
6
  import './utils/message/getOutgoingMessageState.js';
7
- import './UserProfileContext-2ea97dc1.js';
7
+ import './UserProfileContext-b722645f.js';
8
8
  import 'prop-types';
9
9
  import './useSendbirdStateContext.js';
10
10
  import './withSendbird.js';
11
- import './_rollupPluginBabelHelpers-38fb8170.js';
12
- import './tslib.es6-33004eb4.js';
11
+ import './tslib.es6-c441d88b.js';
13
12
  import './Thread/context/types.js';
14
13
  import '@sendbird/chat';
15
- import './topics-aa4d9dac.js';
14
+ import './topics-e27c1d5d.js';
16
15
  import '@sendbird/chat/groupChannel';
17
- import './uuid-7397f1ec.js';
16
+ import './uuid-e3615ce2.js';
18
17
  import '@sendbird/chat/message';
19
- import './consts-cedae35a.js';
20
- import './LocalizationContext-4b25e6bc.js';
21
- import './stringSet-80381462.js';
22
- import './utils-8fa2a634.js';
23
- import './index-ba549e6a.js';
18
+ import './consts-4cdf8265.js';
19
+ import './LocalizationContext-21c445a7.js';
20
+ import './stringSet-8f776451.js';
21
+ import './utils-51f19122.js';
22
+ import './index-99e3b057.js';
24
23
  import './Thread/components/ParentMessageInfo.js';
25
- import './RemoveMessageModal-0182446a.js';
24
+ import './RemoveMessageModal-99978eb5.js';
26
25
  import './ui/Modal.js';
27
26
  import 'react-dom';
28
- import './index-af6e4d1e.js';
27
+ import './index-c24fc3d9.js';
29
28
  import './ui/Button.js';
30
29
  import './ui/Icon.js';
31
30
  import './ui/IconButton.js';
32
- import './MediaQueryContext-29dcaddb.js';
31
+ import './MediaQueryContext-46321124.js';
33
32
  import './Thread/components/ParentMessageInfoItem.js';
34
- import './index-58b5008c.js';
33
+ import './index-0a265c2c.js';
35
34
  import './ui/Word.js';
36
35
  import './ui/LinkLabel.js';
37
36
  import './ui/MentionLabel.js';
@@ -39,11 +38,11 @@ import './ui/ContextMenu.js';
39
38
  import './ui/SortByRow.js';
40
39
  import './ui/UserProfile.js';
41
40
  import './sendbirdSelectors.js';
42
- import './utils-b84d9295.js';
41
+ import './utils-cd7aab7a.js';
43
42
  import './ui/Avatar.js';
44
43
  import './ui/ImageRenderer.js';
45
44
  import './ui/TextButton.js';
46
- import './color-a450612f.js';
45
+ import './color-e4afd956.js';
47
46
  import './ui/EmojiReactions.js';
48
47
  import './ui/Tooltip.js';
49
48
  import './ui/TooltipWrapper.js';
@@ -52,30 +51,30 @@ import './ui/ReactionButton.js';
52
51
  import './ui/VoiceMessageItemBody.js';
53
52
  import './ui/ProgressBar.js';
54
53
  import './VoicePlayer/useVoicePlayer.js';
55
- import './index-5e921f58.js';
54
+ import './index-e21d4934.js';
56
55
  import './VoiceRecorder/context.js';
57
- import './lame.all.js';
58
56
  import './ui/PlaybackTime.js';
59
57
  import './ui/Loader.js';
60
58
  import './Channel/components/SuggestedMentionList.js';
61
- import './ChannelProvider-7b83d4fd.js';
62
- import './compareIds-27ab0100.js';
63
- import './const-2d43b497.js';
64
- import './const-de21a301.js';
59
+ import './ChannelProvider-fcab0099.js';
60
+ import './_rollupPluginBabelHelpers-06a0d79e.js';
61
+ import './compareIds-90b5fdcc.js';
62
+ import './const-2c43da6a.js';
63
+ import './const-ed6c468d.js';
65
64
  import './ui/FileViewer.js';
66
65
  import './ui/MessageItemMenu.js';
67
- import './types-79f3626f.js';
66
+ import './types-9069552c.js';
68
67
  import './ui/MessageItemReactionMenu.js';
69
68
  import './ui/MessageInput.js';
70
69
  import 'dompurify';
71
- import './consts-9f2eecf3.js';
70
+ import './consts-9c372f2e.js';
72
71
  import './Thread/components/ThreadHeader.js';
73
72
  import './Thread/components/ThreadList.js';
74
73
  import './Thread/components/ThreadListItem.js';
75
74
  import './ui/DateSeparator.js';
76
- import './index-eba6c13e.js';
77
- import './index-d69c6128.js';
78
- import './index-fb9f4d36.js';
75
+ import './index-3c6b00b6.js';
76
+ import './index-906f26f4.js';
77
+ import './index-8e2d6bf1.js';
79
78
  import './ui/TextMessageItemBody.js';
80
79
  import './ui/OGMessageItemBody.js';
81
80
  import './ui/FileMessageItemBody.js';
@@ -83,10 +82,10 @@ import './ui/ThumbnailMessageItemBody.js';
83
82
  import './ui/UnknownMessageItemBody.js';
84
83
  import 'date-fns';
85
84
  import './Thread/components/ThreadMessageInput.js';
86
- import './VoiceMessageInputWrapper-f65cc3ae.js';
85
+ import './VoiceMessageInputWrapper-6bce7f18.js';
87
86
  import './VoiceRecorder/useVoiceRecorder.js';
88
- import './index-9f08118f.js';
89
- import './index-e8294858.js';
87
+ import './index-71682b33.js';
88
+ import './index-b0c02bbc.js';
90
89
 
91
90
  var Thread = function (props) {
92
91
  var // props
package/Thread.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"Thread.js","sources":["../src/smart-components/Thread/index.tsx"],"sourcesContent":["import React from 'react';\n\nimport {\n ThreadProvider,\n ThreadProviderProps,\n} from './context/ThreadProvider';\nimport ThreadUI, { ThreadUIProps } from './components/ThreadUI';\n\nexport interface ThreadProps extends ThreadProviderProps, ThreadUIProps {\n className?: string;\n}\n\nconst Thread: React.FC<ThreadProps> = (props: ThreadProps) => {\n const {\n // props\n className,\n // ThreadProviderProps\n channelUrl,\n message,\n onHeaderActionClick,\n onMoveToParentMessage,\n // ThreadUIProps\n renderHeader,\n renderParentMessageInfo,\n renderMessage,\n renderMessageInput,\n renderCustomSeparator,\n renderParentMessageInfoPlaceholder,\n renderThreadListPlaceHolder,\n renderFileUploadIcon,\n renderVoiceMessageIcon,\n renderSendMessageIcon,\n } = props;\n return (\n <div className={`sendbird-thread ${className}`}>\n <ThreadProvider\n channelUrl={channelUrl}\n message={message}\n onHeaderActionClick={onHeaderActionClick}\n onMoveToParentMessage={onMoveToParentMessage}\n >\n <ThreadUI\n renderHeader={renderHeader}\n renderParentMessageInfo={renderParentMessageInfo}\n renderMessage={renderMessage}\n renderMessageInput={renderMessageInput}\n renderCustomSeparator={renderCustomSeparator}\n renderParentMessageInfoPlaceholder={renderParentMessageInfoPlaceholder}\n renderThreadListPlaceHolder={renderThreadListPlaceHolder}\n renderFileUploadIcon={renderFileUploadIcon}\n renderVoiceMessageIcon={renderVoiceMessageIcon}\n renderSendMessageIcon={renderSendMessageIcon}\n />\n </ThreadProvider>\n </div>\n );\n};\n\nexport default Thread;\n"],"names":["Thread","props","className","channelUrl","message","onHeaderActionClick","onMoveToParentMessage","renderHeader","renderParentMessageInfo","renderMessage","renderMessageInput","renderCustomSeparator","renderParentMessageInfoPlaceholder","renderThreadListPlaceHolder","renderFileUploadIcon","renderVoiceMessageIcon","renderSendMessageIcon","React","concat"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAYA,IAAMA,MAAM,GAA0B,UAACC,KAAD,EAAmB;EAGrD;EAAAC,SAAS,GAiBPD,KAAK,CAjBEC,SAAT;;EAEAC,UAAU,GAeRF,KAAK,CAAAE,UAjBP;AAAA,MAGAC,OAAO,GAcLH,KAAK,CAAAG,OAjBP;AAAA,MAIAC,mBAAmB,GAajBJ,KAAK,CAAAI,mBAjBP;AAAA,MAKAC,qBAAqB,GAYnBL,KAAK,CAZcK,qBALrB;;EAOAC,YAAY,GAUVN,KAAK,CAVKM,YAPZ;AAAA,MAQAC,uBAAuB,GASrBP,KAAK,CATgBO,uBARvB;AAAA,MASAC,aAAa,GAQXR,KAAK,CARMQ,aATb;AAAA,MAUAC,kBAAkB,GAOhBT,KAAK,mBAjBP;AAAA,MAWAU,qBAAqB,GAMnBV,KAAK,CANcU,qBAXrB;AAAA,MAYAC,kCAAkC,GAKhCX,KAAK,mCAjBP;AAAA,MAaAY,2BAA2B,GAIzBZ,KAAK,CAAAY,2BAjBP;AAAA,MAcAC,oBAAoB,GAGlBb,KAAK,qBAjBP;AAAA,MAeAc,sBAAsB,GAEpBd,KAAK,CAAAc,sBAjBP;AAAA,MAgBAC,qBAAqB,GACnBf,KAAK,CAAAe,qBAjBP,CAAA;EAkBF,oBACEC,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAAK,IAAA,SAAS,EAAE,kBAAA,CAAmBC,MAAnB,CAAmBhB,SAAnB,CAAA;AAAhB,GAAA,eACEe,6BAAC,cAAD,EAAA;AACE,IAAA,UAAU,EAAEd,UADd;AAEE,IAAA,OAAO,EAAEC,OAFX;AAGE,IAAA,mBAAmB,EAAEC,mBAHvB;AAIE,IAAA,qBAAqB,EAAEC,qBAAAA;AAJzB,GAAA,eAMEW,6BAAC,QAAD,EAAA;AACE,IAAA,YAAY,EAAEV,YADhB;AAEE,IAAA,uBAAuB,EAAEC,uBAF3B;AAGE,IAAA,aAAa,EAAEC,aAHjB;AAIE,IAAA,kBAAkB,EAAEC,kBAJtB;AAKE,IAAA,qBAAqB,EAAEC,qBALzB;AAME,IAAA,kCAAkC,EAAEC,kCANtC;AAOE,IAAA,2BAA2B,EAAEC,2BAP/B;AAQE,IAAA,oBAAoB,EAAEC,oBARxB;AASE,IAAA,sBAAsB,EAAEC,sBAT1B;AAUE,IAAA,qBAAqB,EAAEC,qBAAAA;AAVzB,GAAA,CANF,CADF,CADF,CAAA;AAuBD;;;;"}
1
+ {"version":3,"file":"Thread.js","sources":["../src/smart-components/Thread/index.tsx"],"sourcesContent":["import React from 'react';\n\nimport {\n ThreadProvider,\n ThreadProviderProps,\n} from './context/ThreadProvider';\nimport ThreadUI, { ThreadUIProps } from './components/ThreadUI';\n\nexport interface ThreadProps extends ThreadProviderProps, ThreadUIProps {\n className?: string;\n}\n\nconst Thread: React.FC<ThreadProps> = (props: ThreadProps) => {\n const {\n // props\n className,\n // ThreadProviderProps\n channelUrl,\n message,\n onHeaderActionClick,\n onMoveToParentMessage,\n // ThreadUIProps\n renderHeader,\n renderParentMessageInfo,\n renderMessage,\n renderMessageInput,\n renderCustomSeparator,\n renderParentMessageInfoPlaceholder,\n renderThreadListPlaceHolder,\n renderFileUploadIcon,\n renderVoiceMessageIcon,\n renderSendMessageIcon,\n } = props;\n return (\n <div className={`sendbird-thread ${className}`}>\n <ThreadProvider\n channelUrl={channelUrl}\n message={message}\n onHeaderActionClick={onHeaderActionClick}\n onMoveToParentMessage={onMoveToParentMessage}\n >\n <ThreadUI\n renderHeader={renderHeader}\n renderParentMessageInfo={renderParentMessageInfo}\n renderMessage={renderMessage}\n renderMessageInput={renderMessageInput}\n renderCustomSeparator={renderCustomSeparator}\n renderParentMessageInfoPlaceholder={renderParentMessageInfoPlaceholder}\n renderThreadListPlaceHolder={renderThreadListPlaceHolder}\n renderFileUploadIcon={renderFileUploadIcon}\n renderVoiceMessageIcon={renderVoiceMessageIcon}\n renderSendMessageIcon={renderSendMessageIcon}\n />\n </ThreadProvider>\n </div>\n );\n};\n\nexport default Thread;\n"],"names":["Thread","props","className","channelUrl","message","onHeaderActionClick","onMoveToParentMessage","renderHeader","renderParentMessageInfo","renderMessage","renderMessageInput","renderCustomSeparator","renderParentMessageInfoPlaceholder","renderThreadListPlaceHolder","renderFileUploadIcon","renderVoiceMessageIcon","renderSendMessageIcon","React","concat"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAYA,IAAMA,MAAM,GAA0B,UAACC,KAAD,EAAmB;EAGrD;EAAAC,SAAS,GAiBPD,KAAK,CAjBEC,SAAT;;EAEAC,UAAU,GAeRF,KAAK,CAAAE,UAjBP;AAAA,MAGAC,OAAO,GAcLH,KAAK,CAAAG,OAjBP;AAAA,MAIAC,mBAAmB,GAajBJ,KAAK,CAAAI,mBAjBP;AAAA,MAKAC,qBAAqB,GAYnBL,KAAK,CAZcK,qBALrB;;EAOAC,YAAY,GAUVN,KAAK,CAVKM,YAPZ;AAAA,MAQAC,uBAAuB,GASrBP,KAAK,CATgBO,uBARvB;AAAA,MASAC,aAAa,GAQXR,KAAK,CARMQ,aATb;AAAA,MAUAC,kBAAkB,GAOhBT,KAAK,mBAjBP;AAAA,MAWAU,qBAAqB,GAMnBV,KAAK,CANcU,qBAXrB;AAAA,MAYAC,kCAAkC,GAKhCX,KAAK,mCAjBP;AAAA,MAaAY,2BAA2B,GAIzBZ,KAAK,CAAAY,2BAjBP;AAAA,MAcAC,oBAAoB,GAGlBb,KAAK,qBAjBP;AAAA,MAeAc,sBAAsB,GAEpBd,KAAK,CAAAc,sBAjBP;AAAA,MAgBAC,qBAAqB,GACnBf,KAAK,CAAAe,qBAjBP,CAAA;EAkBF,oBACEC,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAAK,IAAA,SAAS,EAAE,kBAAA,CAAmBC,MAAnB,CAAmBhB,SAAnB,CAAA;AAAhB,GAAA,eACEe,6BAAC,cAAD,EAAA;AACE,IAAA,UAAU,EAAEd,UADd;AAEE,IAAA,OAAO,EAAEC,OAFX;AAGE,IAAA,mBAAmB,EAAEC,mBAHvB;AAIE,IAAA,qBAAqB,EAAEC,qBAAAA;AAJzB,GAAA,eAMEW,6BAAC,QAAD,EAAA;AACE,IAAA,YAAY,EAAEV,YADhB;AAEE,IAAA,uBAAuB,EAAEC,uBAF3B;AAGE,IAAA,aAAa,EAAEC,aAHjB;AAIE,IAAA,kBAAkB,EAAEC,kBAJtB;AAKE,IAAA,qBAAqB,EAAEC,qBALzB;AAME,IAAA,kCAAkC,EAAEC,kCANtC;AAOE,IAAA,2BAA2B,EAAEC,2BAP/B;AAQE,IAAA,oBAAoB,EAAEC,oBARxB;AASE,IAAA,sBAAsB,EAAEC,sBAT1B;AAUE,IAAA,qBAAqB,EAAEC,qBAAAA;AAVzB,GAAA,CANF,CADF,CADF,CAAA;AAuBD;;;;"}
@@ -1,16 +1,16 @@
1
1
  import React__default, { useEffect, useCallback, useReducer, useMemo } from 'react';
2
- import { f as format } from './index-9ee89f7c.js';
2
+ import { f as format } from './index-caabeae5.js';
3
3
  import { getOutgoingMessageState, OutgoingMessageStates } from './utils/message/getOutgoingMessageState.js';
4
- import { U as UserProfileProvider } from './UserProfileContext-2ea97dc1.js';
4
+ import { U as UserProfileProvider } from './UserProfileContext-b722645f.js';
5
5
  import useSendbirdStateContext from './useSendbirdStateContext.js';
6
- import { _ as __assign, a as __spreadArray, c as __awaiter, d as __generator } from './tslib.es6-33004eb4.js';
6
+ import { _ as __assign, a as __spreadArray, c as __awaiter, d as __generator } from './tslib.es6-c441d88b.js';
7
7
  import { ChannelStateTypes, ThreadListStateTypes, ParentMessageStateTypes } from './Thread/context/types.js';
8
8
  import { ChannelType } from '@sendbird/chat';
9
- import { a as SEND_USER_MESSAGE, b as SEND_FILE_MESSAGE, U as UPDATE_USER_MESSAGE, D as DELETE_MESSAGE } from './topics-aa4d9dac.js';
9
+ import { P as PUBSUB_TOPICS } from './topics-e27c1d5d.js';
10
10
  import { GroupChannelHandler } from '@sendbird/chat/groupChannel';
11
- import { u as uuidv4 } from './uuid-7397f1ec.js';
11
+ import { u as uuidv4 } from './uuid-e3615ce2.js';
12
12
  import { SendingStatus, MessageType, MessageMetaArray } from '@sendbird/chat/message';
13
- import { d as VOICE_MESSAGE_FILE_NAME, e as VOICE_MESSAGE_MIME_TYPE, M as META_ARRAY_VOICE_DURATION_KEY, h as META_ARRAY_MESSAGE_TYPE_KEY, i as META_ARRAY_MESSAGE_TYPE_VALUE__VOICE } from './consts-cedae35a.js';
13
+ import { b as VOICE_MESSAGE_FILE_NAME, c as VOICE_MESSAGE_MIME_TYPE, M as META_ARRAY_VOICE_DURATION_KEY, d as META_ARRAY_MESSAGE_TYPE_KEY, e as META_ARRAY_MESSAGE_TYPE_VALUE__VOICE } from './consts-4cdf8265.js';
14
14
 
15
15
  var getNicknamesMapFromMembers = function (members) {
16
16
  if (members === void 0) {
@@ -28,6 +28,23 @@ var getNicknamesMapFromMembers = function (members) {
28
28
 
29
29
  return nicknamesMap;
30
30
  };
31
+ var getParentMessageFrom = function (message) {
32
+ if (isParentMessage(message)) {
33
+ return message;
34
+ }
35
+
36
+ if (isThreadMessage(message)) {
37
+ return message === null || message === void 0 ? void 0 : message.parentMessage;
38
+ }
39
+
40
+ return null;
41
+ };
42
+ var isParentMessage = function (message) {
43
+ return (message === null || message === void 0 ? void 0 : message.parentMessage) === null && (message === null || message === void 0 ? void 0 : message.parentMessageId) === null && (message === null || message === void 0 ? void 0 : message.threadInfo) !== null;
44
+ };
45
+ var isThreadMessage = function (message) {
46
+ return (message === null || message === void 0 ? void 0 : message.parentMessage) !== null && (message === null || message === void 0 ? void 0 : message.parentMessageId) !== null && (message === null || message === void 0 ? void 0 : message.threadInfo) === null;
47
+ };
31
48
  var isAboutSame = function (a, b, px) {
32
49
  return Math.abs(a - b) <= px;
33
50
  };
@@ -662,7 +679,6 @@ function useGetParentMessage(_a, _b) {
662
679
  var _this = this;
663
680
 
664
681
  var channelUrl = _a.channelUrl,
665
- parentMessageId = _a.parentMessageId,
666
682
  sdkInit = _a.sdkInit,
667
683
  parentMessage = _a.parentMessage;
668
684
  var sdk = _b.sdk,
@@ -680,11 +696,10 @@ function useGetParentMessage(_a, _b) {
680
696
  var params_1 = {
681
697
  channelUrl: channelUrl,
682
698
  channelType: ChannelType.GROUP,
683
- messageId: parentMessageId,
699
+ messageId: parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.messageId,
684
700
  includeMetaArray: true,
685
701
  includeReactions: true,
686
702
  includeThreadInfo: true,
687
- includePollDetails: true,
688
703
  includeParentMessageInfo: true
689
704
  };
690
705
  logger.info('Thread | useGetParentMessage: Get parent message start.', params_1);
@@ -714,7 +729,7 @@ function useGetParentMessage(_a, _b) {
714
729
 
715
730
  fetchParentMessage().then(function (parentMsg) {
716
731
  logger.info('Thread | useGetParentMessage: Get parent message succeeded.', parentMessage);
717
- parentMsg.ogMetaData = parentMessage.ogMetaData; // ogMetaData is not included for now
732
+ parentMsg.ogMetaData = (parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.ogMetaData) || null; // ogMetaData is not included for now
718
733
 
719
734
  threadDispatcher({
720
735
  type: ThreadContextActionTypes.GET_PARENT_MESSAGE_SUCCESS,
@@ -730,7 +745,7 @@ function useGetParentMessage(_a, _b) {
730
745
  });
731
746
  });
732
747
  }
733
- }, [sdkInit, parentMessageId]);
748
+ }, [sdkInit, parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.messageId]);
734
749
  /**
735
750
  * We don't use channelUrl here,
736
751
  * because Thread must operate independently of the channel.
@@ -751,7 +766,7 @@ function useHandlePubsubEvents(_a, _b) {
751
766
  return subscriber;
752
767
  }
753
768
 
754
- subscriber.set(SEND_USER_MESSAGE, pubSub.subscribe(SEND_USER_MESSAGE, function (props) {
769
+ subscriber.set(PUBSUB_TOPICS.SEND_USER_MESSAGE, pubSub.subscribe(PUBSUB_TOPICS.SEND_USER_MESSAGE, function (props) {
755
770
  var channel = props.channel,
756
771
  message = props.message;
757
772
 
@@ -766,7 +781,7 @@ function useHandlePubsubEvents(_a, _b) {
766
781
 
767
782
  scrollIntoLast === null || scrollIntoLast === void 0 ? void 0 : scrollIntoLast();
768
783
  }));
769
- subscriber.set(SEND_FILE_MESSAGE, pubSub.subscribe(SEND_FILE_MESSAGE, function (props) {
784
+ subscriber.set(PUBSUB_TOPICS.SEND_FILE_MESSAGE, pubSub.subscribe(PUBSUB_TOPICS.SEND_FILE_MESSAGE, function (props) {
770
785
  var channel = props.channel,
771
786
  message = props.message;
772
787
 
@@ -781,7 +796,7 @@ function useHandlePubsubEvents(_a, _b) {
781
796
 
782
797
  scrollIntoLast === null || scrollIntoLast === void 0 ? void 0 : scrollIntoLast();
783
798
  }));
784
- subscriber.set(UPDATE_USER_MESSAGE, pubSub.subscribe(UPDATE_USER_MESSAGE, function (msg) {
799
+ subscriber.set(PUBSUB_TOPICS.UPDATE_USER_MESSAGE, pubSub.subscribe(PUBSUB_TOPICS.UPDATE_USER_MESSAGE, function (msg) {
785
800
  var channel = msg.channel,
786
801
  message = msg.message;
787
802
 
@@ -795,7 +810,7 @@ function useHandlePubsubEvents(_a, _b) {
795
810
  });
796
811
  }
797
812
  }));
798
- subscriber.set(DELETE_MESSAGE, pubSub.subscribe(DELETE_MESSAGE, function (msg) {
813
+ subscriber.set(PUBSUB_TOPICS.DELETE_MESSAGE, pubSub.subscribe(PUBSUB_TOPICS.DELETE_MESSAGE, function (msg) {
799
814
  var channel = msg.channel,
800
815
  messageId = msg.messageId;
801
816
 
@@ -1062,7 +1077,7 @@ function useSendFileMessageCallback(_a, _b) {
1062
1077
  });
1063
1078
  }).onSucceeded(function (message) {
1064
1079
  logger.info('Thread | useSendFileMessageCallback: Sending file message succeeded.', message);
1065
- pubSub.publish(SEND_FILE_MESSAGE, {
1080
+ pubSub.publish(PUBSUB_TOPICS.SEND_FILE_MESSAGE, {
1066
1081
  channel: currentChannel,
1067
1082
  message: message
1068
1083
  });
@@ -1113,7 +1128,7 @@ function useUpdateMessageCallback(_a, _b) {
1113
1128
  message: message
1114
1129
  }
1115
1130
  });
1116
- pubSub.publish(UPDATE_USER_MESSAGE, {
1131
+ pubSub.publish(PUBSUB_TOPICS.UPDATE_USER_MESSAGE, {
1117
1132
  fromSelector: true,
1118
1133
  channel: currentChannel,
1119
1134
  message: message
@@ -1346,7 +1361,7 @@ function useSendUserMessageCallback(_a, _b) {
1346
1361
  }
1347
1362
  }); // because Thread doesn't subscribe SEND_USER_MESSAGE
1348
1363
 
1349
- pubSub.publish(SEND_USER_MESSAGE, {
1364
+ pubSub.publish(PUBSUB_TOPICS.SEND_USER_MESSAGE, {
1350
1365
  channel: currentChannel,
1351
1366
  message: message
1352
1367
  });
@@ -1381,7 +1396,7 @@ function useResendMessageCallback(_a, _b) {
1381
1396
  message: message
1382
1397
  }
1383
1398
  });
1384
- pubSub.publish(SEND_USER_MESSAGE, {
1399
+ pubSub.publish(PUBSUB_TOPICS.SEND_USER_MESSAGE, {
1385
1400
  channel: currentChannel,
1386
1401
  message: message
1387
1402
  });
@@ -1413,7 +1428,7 @@ function useResendMessageCallback(_a, _b) {
1413
1428
  message: failedMessage
1414
1429
  }
1415
1430
  });
1416
- pubSub.publish(SEND_FILE_MESSAGE, {
1431
+ pubSub.publish(PUBSUB_TOPICS.SEND_FILE_MESSAGE, {
1417
1432
  channel: currentChannel,
1418
1433
  message: failedMessage
1419
1434
  });
@@ -1457,6 +1472,7 @@ var useSendVoiceMessageCallback = function (_a, _b) {
1457
1472
  messageParams.parentMessageId = quoteMessage.messageId;
1458
1473
  }
1459
1474
 
1475
+ logger.info('Thread | useSendVoiceMessageCallback: Start sending voice message', messageParams);
1460
1476
  currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.sendFileMessage(messageParams).onPending(function (pendingMessage) {
1461
1477
  threadDispatcher({
1462
1478
  type: ThreadContextActionTypes.SEND_MESSAGE_START,
@@ -1489,7 +1505,7 @@ var useSendVoiceMessageCallback = function (_a, _b) {
1489
1505
  });
1490
1506
  }).onSucceeded(function (message) {
1491
1507
  logger.info('Thread | useSendVoiceMessageCallback: Sending voice message succeeded.', message);
1492
- pubSub.publish(SEND_FILE_MESSAGE, {
1508
+ pubSub.publish(PUBSUB_TOPICS.SEND_FILE_MESSAGE, {
1493
1509
  channel: currentChannel,
1494
1510
  message: message
1495
1511
  });
@@ -1504,14 +1520,15 @@ var ThreadProvider = function (props) {
1504
1520
 
1505
1521
  var children = props.children,
1506
1522
  channelUrl = props.channelUrl,
1507
- message = props.message,
1508
1523
  onHeaderActionClick = props.onHeaderActionClick,
1509
1524
  onMoveToParentMessage = props.onMoveToParentMessage,
1510
1525
  onBeforeSendVoiceMessage = props.onBeforeSendVoiceMessage,
1511
1526
  // User Profile
1512
1527
  disableUserProfile = props.disableUserProfile,
1513
1528
  renderUserProfile = props.renderUserProfile,
1514
- onUserProfileMessage = props.onUserProfileMessage; // Context from SendbirdProvider
1529
+ onUserProfileMessage = props.onUserProfileMessage;
1530
+ var propsMessage = props === null || props === void 0 ? void 0 : props.message;
1531
+ var propsParentMessage = getParentMessageFrom(propsMessage); // Context from SendbirdProvider
1515
1532
 
1516
1533
  var globalStore = useSendbirdStateContext();
1517
1534
  var stores = globalStore.stores,
@@ -1555,7 +1572,7 @@ var ThreadProvider = function (props) {
1555
1572
  useGetChannel({
1556
1573
  channelUrl: channelUrl,
1557
1574
  sdkInit: sdkInit,
1558
- message: message
1575
+ message: propsMessage
1559
1576
  }, {
1560
1577
  sdk: sdk,
1561
1578
  logger: logger,
@@ -1564,8 +1581,7 @@ var ThreadProvider = function (props) {
1564
1581
  useGetParentMessage({
1565
1582
  channelUrl: channelUrl,
1566
1583
  sdkInit: sdkInit,
1567
- parentMessageId: message === null || message === void 0 ? void 0 : message.parentMessageId,
1568
- parentMessage: message === null || message === void 0 ? void 0 : message.parentMessage
1584
+ parentMessage: propsParentMessage
1569
1585
  }, {
1570
1586
  sdk: sdk,
1571
1587
  logger: logger,
@@ -1575,7 +1591,8 @@ var ThreadProvider = function (props) {
1575
1591
  sdkInit: sdkInit,
1576
1592
  parentMessage: parentMessage,
1577
1593
  isReactionEnabled: isReactionEnabled,
1578
- anchorMessage: (message === null || message === void 0 ? void 0 : message.messageId) ? message : null
1594
+ anchorMessage: (propsMessage === null || propsMessage === void 0 ? void 0 : propsMessage.messageId) !== (propsParentMessage === null || propsParentMessage === void 0 ? void 0 : propsParentMessage.messageId) ? propsMessage : null // anchorMessage should be null when parentMessage doesn't exist
1595
+
1579
1596
  }, {
1580
1597
  logger: logger,
1581
1598
  threadDispatcher: threadDispatcher
@@ -1681,7 +1698,7 @@ var ThreadProvider = function (props) {
1681
1698
  value: {
1682
1699
  // ThreadProviderProps
1683
1700
  channelUrl: channelUrl,
1684
- message: message,
1701
+ message: propsMessage,
1685
1702
  onHeaderActionClick: onHeaderActionClick,
1686
1703
  onMoveToParentMessage: onMoveToParentMessage,
1687
1704
  // ThreadContextInitialState
@@ -1721,4 +1738,4 @@ var useThreadContext = function () {
1721
1738
  };
1722
1739
 
1723
1740
  export { ThreadProvider as T, compareMessagesForGrouping as c, isAboutSame as i, useThreadContext as u };
1724
- //# sourceMappingURL=ThreadProvider-daedc3df.js.map
1741
+ //# sourceMappingURL=ThreadProvider-c3528b8f.js.map