@sendbird/uikit-react 3.0.0-beta.4 → 3.0.0-beta.5

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 (610) hide show
  1. package/App.js +313 -0
  2. package/App.js.map +1 -0
  3. package/Channel/components/ChannelHeader.js +117 -0
  4. package/Channel/components/ChannelHeader.js.map +1 -0
  5. package/Channel/components/ChannelUI.js +179 -0
  6. package/Channel/components/ChannelUI.js.map +1 -0
  7. package/Channel/components/FileViewer.js +151 -0
  8. package/Channel/components/FileViewer.js.map +1 -0
  9. package/Channel/components/FrozenNotification.js +20 -0
  10. package/Channel/components/FrozenNotification.js.map +1 -0
  11. package/Channel/components/Message.js +355 -0
  12. package/Channel/components/Message.js.map +1 -0
  13. package/Channel/components/MessageInput.js +202 -0
  14. package/Channel/components/MessageInput.js.map +1 -0
  15. package/Channel/components/MessageList.js +239 -0
  16. package/Channel/components/MessageList.js.map +1 -0
  17. package/Channel/components/RemoveMessageModal.js +53 -0
  18. package/Channel/components/RemoveMessageModal.js.map +1 -0
  19. package/Channel/components/SuggestedMentionList.js +250 -0
  20. package/Channel/components/SuggestedMentionList.js.map +1 -0
  21. package/Channel/components/TypingIndicator.js +98 -0
  22. package/Channel/components/TypingIndicator.js.map +1 -0
  23. package/Channel/components/UnreadCount.js +41 -0
  24. package/Channel/components/UnreadCount.js.map +1 -0
  25. package/Channel/context.js +24 -0
  26. package/Channel/context.js.map +1 -0
  27. package/Channel.js +106 -0
  28. package/Channel.js.map +1 -0
  29. package/ChannelList/components/AddChannel.js +70 -0
  30. package/ChannelList/components/AddChannel.js.map +1 -0
  31. package/ChannelList/components/ChannelListHeader.js +62 -0
  32. package/ChannelList/components/ChannelListHeader.js.map +1 -0
  33. package/ChannelList/components/ChannelListUI.js +236 -0
  34. package/ChannelList/components/ChannelListUI.js.map +1 -0
  35. package/ChannelList/components/ChannelPreview.js +211 -0
  36. package/ChannelList/components/ChannelPreview.js.map +1 -0
  37. package/ChannelList/components/ChannelPreviewAction.js +131 -0
  38. package/ChannelList/components/ChannelPreviewAction.js.map +1 -0
  39. package/ChannelList/context.js +13 -0
  40. package/ChannelList/context.js.map +1 -0
  41. package/ChannelList.js +89 -0
  42. package/ChannelList.js.map +1 -0
  43. package/ChannelListProvider-a7bdd63a.js +923 -0
  44. package/ChannelListProvider-a7bdd63a.js.map +1 -0
  45. package/ChannelProvider-923b58df.js +2114 -0
  46. package/ChannelProvider-923b58df.js.map +1 -0
  47. package/ChannelSettings/components/AdminPanel.js +905 -0
  48. package/ChannelSettings/components/AdminPanel.js.map +1 -0
  49. package/ChannelSettings/components/ChannelProfile.js +102 -0
  50. package/ChannelSettings/components/ChannelProfile.js.map +1 -0
  51. package/ChannelSettings/components/ChannelSettingsUI.js +152 -0
  52. package/ChannelSettings/components/ChannelSettingsUI.js.map +1 -0
  53. package/ChannelSettings/components/EditDetailsModal.js +154 -0
  54. package/ChannelSettings/components/EditDetailsModal.js.map +1 -0
  55. package/ChannelSettings/components/LeaveChannel.js +53 -0
  56. package/ChannelSettings/components/LeaveChannel.js.map +1 -0
  57. package/ChannelSettings/components/UserListItem.js +105 -0
  58. package/ChannelSettings/components/UserListItem.js.map +1 -0
  59. package/ChannelSettings/components/UserPanel.js +79 -0
  60. package/ChannelSettings/components/UserPanel.js.map +1 -0
  61. package/ChannelSettings/context.js +93 -0
  62. package/ChannelSettings/context.js.map +1 -0
  63. package/ChannelSettings.js +71 -0
  64. package/ChannelSettings.js.map +1 -0
  65. package/CreateChannel/components/CreateChannelUI.js +53 -0
  66. package/CreateChannel/components/CreateChannelUI.js.map +1 -0
  67. package/CreateChannel/components/InviteMembers.js +184 -0
  68. package/CreateChannel/components/InviteMembers.js.map +1 -0
  69. package/CreateChannel/components/SelectChannelType.js +131 -0
  70. package/CreateChannel/components/SelectChannelType.js.map +1 -0
  71. package/CreateChannel/context.js +8 -0
  72. package/CreateChannel/context.js.map +1 -0
  73. package/CreateChannel.js +53 -0
  74. package/CreateChannel.js.map +1 -0
  75. package/CreateChannelProvider-e491613f.js +53 -0
  76. package/CreateChannelProvider-e491613f.js.map +1 -0
  77. package/EditUserProfile/components/EditUserProfileUI.js +26 -0
  78. package/EditUserProfile/components/EditUserProfileUI.js.map +1 -0
  79. package/EditUserProfile/context.js +27 -0
  80. package/EditUserProfile/context.js.map +1 -0
  81. package/EditUserProfile.js +39 -0
  82. package/EditUserProfile.js.map +1 -0
  83. package/LocalizationContext-0e05ddca.js +22 -0
  84. package/LocalizationContext-0e05ddca.js.map +1 -0
  85. package/MemberList-ed7da941.js +425 -0
  86. package/MemberList-ed7da941.js.map +1 -0
  87. package/MessageSearch/components/MessageSearchUI.js +151 -0
  88. package/MessageSearch/components/MessageSearchUI.js.map +1 -0
  89. package/MessageSearch/context.js +392 -0
  90. package/MessageSearch/context.js.map +1 -0
  91. package/MessageSearch.js +146 -0
  92. package/MessageSearch.js.map +1 -0
  93. package/OpenChannel/components/FrozenChannelNotification.js +20 -0
  94. package/OpenChannel/components/FrozenChannelNotification.js.map +1 -0
  95. package/OpenChannel/components/OpenChannelHeader.js +78 -0
  96. package/OpenChannel/components/OpenChannelHeader.js.map +1 -0
  97. package/OpenChannel/components/OpenChannelInput.js +56 -0
  98. package/OpenChannel/components/OpenChannelInput.js.map +1 -0
  99. package/OpenChannel/components/OpenChannelMessage.js +282 -0
  100. package/OpenChannel/components/OpenChannelMessage.js.map +1 -0
  101. package/OpenChannel/components/OpenChannelMessageList.js +157 -0
  102. package/OpenChannel/components/OpenChannelMessageList.js.map +1 -0
  103. package/OpenChannel/components/OpenChannelUI.js +109 -0
  104. package/OpenChannel/components/OpenChannelUI.js.map +1 -0
  105. package/OpenChannel/context.js +14 -0
  106. package/OpenChannel/context.js.map +1 -0
  107. package/OpenChannel.js +80 -0
  108. package/OpenChannel.js.map +1 -0
  109. package/OpenChannelProvider-45a848a3.js +2011 -0
  110. package/OpenChannelProvider-45a848a3.js.map +1 -0
  111. package/OpenChannelSettings/components/EditDetailsModal.js +149 -0
  112. package/OpenChannelSettings/components/EditDetailsModal.js.map +1 -0
  113. package/OpenChannelSettings/components/OpenChannelProfile.js +81 -0
  114. package/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -0
  115. package/OpenChannelSettings/components/OpenChannelSettingsUI.js +104 -0
  116. package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -0
  117. package/OpenChannelSettings/components/OperatorUI.js +184 -0
  118. package/OpenChannelSettings/components/OperatorUI.js.map +1 -0
  119. package/OpenChannelSettings/components/ParticipantUI.js +172 -0
  120. package/OpenChannelSettings/components/ParticipantUI.js.map +1 -0
  121. package/OpenChannelSettings/context.js +64 -0
  122. package/OpenChannelSettings/context.js.map +1 -0
  123. package/OpenChannelSettings.js +64 -0
  124. package/OpenChannelSettings.js.map +1 -0
  125. package/SendbirdProvider.js +762 -0
  126. package/SendbirdProvider.js.map +1 -0
  127. package/UserProfileContext-90704c73.js +38 -0
  128. package/UserProfileContext-90704c73.js.map +1 -0
  129. package/_rollupPluginBabelHelpers-c7eeba03.js +233 -0
  130. package/_rollupPluginBabelHelpers-c7eeba03.js.map +1 -0
  131. package/actionTypes-e0f4e19c.js +6 -0
  132. package/actionTypes-e0f4e19c.js.map +1 -0
  133. package/cjs/App.js +320 -0
  134. package/cjs/App.js.map +1 -0
  135. package/cjs/Channel/components/ChannelHeader.js +123 -0
  136. package/cjs/Channel/components/ChannelHeader.js.map +1 -0
  137. package/cjs/Channel/components/ChannelUI.js +185 -0
  138. package/cjs/Channel/components/ChannelUI.js.map +1 -0
  139. package/cjs/Channel/components/FileViewer.js +160 -0
  140. package/cjs/Channel/components/FileViewer.js.map +1 -0
  141. package/cjs/Channel/components/FrozenNotification.js +26 -0
  142. package/cjs/Channel/components/FrozenNotification.js.map +1 -0
  143. package/cjs/Channel/components/Message.js +361 -0
  144. package/cjs/Channel/components/Message.js.map +1 -0
  145. package/cjs/Channel/components/MessageInput.js +208 -0
  146. package/cjs/Channel/components/MessageInput.js.map +1 -0
  147. package/cjs/Channel/components/MessageList.js +245 -0
  148. package/cjs/Channel/components/MessageList.js.map +1 -0
  149. package/cjs/Channel/components/RemoveMessageModal.js +59 -0
  150. package/cjs/Channel/components/RemoveMessageModal.js.map +1 -0
  151. package/cjs/Channel/components/SuggestedMentionList.js +256 -0
  152. package/cjs/Channel/components/SuggestedMentionList.js.map +1 -0
  153. package/cjs/Channel/components/TypingIndicator.js +107 -0
  154. package/cjs/Channel/components/TypingIndicator.js.map +1 -0
  155. package/cjs/Channel/components/UnreadCount.js +47 -0
  156. package/cjs/Channel/components/UnreadCount.js.map +1 -0
  157. package/cjs/Channel/context.js +33 -0
  158. package/cjs/Channel/context.js.map +1 -0
  159. package/cjs/Channel.js +112 -0
  160. package/cjs/Channel.js.map +1 -0
  161. package/cjs/ChannelList/components/AddChannel.js +79 -0
  162. package/cjs/ChannelList/components/AddChannel.js.map +1 -0
  163. package/cjs/ChannelList/components/ChannelListHeader.js +68 -0
  164. package/cjs/ChannelList/components/ChannelListHeader.js.map +1 -0
  165. package/cjs/ChannelList/components/ChannelListUI.js +242 -0
  166. package/cjs/ChannelList/components/ChannelListUI.js.map +1 -0
  167. package/cjs/ChannelList/components/ChannelPreview.js +217 -0
  168. package/cjs/ChannelList/components/ChannelPreview.js.map +1 -0
  169. package/cjs/ChannelList/components/ChannelPreviewAction.js +138 -0
  170. package/cjs/ChannelList/components/ChannelPreviewAction.js.map +1 -0
  171. package/cjs/ChannelList/context.js +23 -0
  172. package/cjs/ChannelList/context.js.map +1 -0
  173. package/cjs/ChannelList.js +95 -0
  174. package/cjs/ChannelList.js.map +1 -0
  175. package/cjs/ChannelListProvider-01864e22.js +936 -0
  176. package/cjs/ChannelListProvider-01864e22.js.map +1 -0
  177. package/cjs/ChannelProvider-3ef2a755.js +2127 -0
  178. package/cjs/ChannelProvider-3ef2a755.js.map +1 -0
  179. package/cjs/ChannelSettings/components/AdminPanel.js +911 -0
  180. package/cjs/ChannelSettings/components/AdminPanel.js.map +1 -0
  181. package/cjs/ChannelSettings/components/ChannelProfile.js +108 -0
  182. package/cjs/ChannelSettings/components/ChannelProfile.js.map +1 -0
  183. package/cjs/ChannelSettings/components/ChannelSettingsUI.js +158 -0
  184. package/cjs/ChannelSettings/components/ChannelSettingsUI.js.map +1 -0
  185. package/cjs/ChannelSettings/components/EditDetailsModal.js +160 -0
  186. package/cjs/ChannelSettings/components/EditDetailsModal.js.map +1 -0
  187. package/cjs/ChannelSettings/components/LeaveChannel.js +59 -0
  188. package/cjs/ChannelSettings/components/LeaveChannel.js.map +1 -0
  189. package/cjs/ChannelSettings/components/UserListItem.js +111 -0
  190. package/cjs/ChannelSettings/components/UserListItem.js.map +1 -0
  191. package/cjs/ChannelSettings/components/UserPanel.js +85 -0
  192. package/cjs/ChannelSettings/components/UserPanel.js.map +1 -0
  193. package/cjs/ChannelSettings/context.js +102 -0
  194. package/cjs/ChannelSettings/context.js.map +1 -0
  195. package/cjs/ChannelSettings.js +77 -0
  196. package/cjs/ChannelSettings.js.map +1 -0
  197. package/cjs/CreateChannel/components/CreateChannelUI.js +59 -0
  198. package/cjs/CreateChannel/components/CreateChannelUI.js.map +1 -0
  199. package/cjs/CreateChannel/components/InviteMembers.js +190 -0
  200. package/cjs/CreateChannel/components/InviteMembers.js.map +1 -0
  201. package/cjs/CreateChannel/components/SelectChannelType.js +137 -0
  202. package/cjs/CreateChannel/components/SelectChannelType.js.map +1 -0
  203. package/cjs/CreateChannel/context.js +17 -0
  204. package/cjs/CreateChannel/context.js.map +1 -0
  205. package/cjs/CreateChannel.js +59 -0
  206. package/cjs/CreateChannel.js.map +1 -0
  207. package/cjs/CreateChannelProvider-0d01dcbf.js +60 -0
  208. package/cjs/CreateChannelProvider-0d01dcbf.js.map +1 -0
  209. package/cjs/EditUserProfile/components/EditUserProfileUI.js +32 -0
  210. package/cjs/EditUserProfile/components/EditUserProfileUI.js.map +1 -0
  211. package/cjs/EditUserProfile/context.js +36 -0
  212. package/cjs/EditUserProfile/context.js.map +1 -0
  213. package/cjs/EditUserProfile.js +45 -0
  214. package/cjs/EditUserProfile.js.map +1 -0
  215. package/cjs/LocalizationContext-4c0a4a70.js +30 -0
  216. package/cjs/LocalizationContext-4c0a4a70.js.map +1 -0
  217. package/cjs/MemberList-b917d2b8.js +431 -0
  218. package/cjs/MemberList-b917d2b8.js.map +1 -0
  219. package/cjs/MessageSearch/components/MessageSearchUI.js +160 -0
  220. package/cjs/MessageSearch/components/MessageSearchUI.js.map +1 -0
  221. package/cjs/MessageSearch/context.js +401 -0
  222. package/cjs/MessageSearch/context.js.map +1 -0
  223. package/cjs/MessageSearch.js +152 -0
  224. package/cjs/MessageSearch.js.map +1 -0
  225. package/cjs/OpenChannel/components/FrozenChannelNotification.js +26 -0
  226. package/cjs/OpenChannel/components/FrozenChannelNotification.js.map +1 -0
  227. package/cjs/OpenChannel/components/OpenChannelHeader.js +84 -0
  228. package/cjs/OpenChannel/components/OpenChannelHeader.js.map +1 -0
  229. package/cjs/OpenChannel/components/OpenChannelInput.js +62 -0
  230. package/cjs/OpenChannel/components/OpenChannelInput.js.map +1 -0
  231. package/cjs/OpenChannel/components/OpenChannelMessage.js +288 -0
  232. package/cjs/OpenChannel/components/OpenChannelMessage.js.map +1 -0
  233. package/cjs/OpenChannel/components/OpenChannelMessageList.js +163 -0
  234. package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -0
  235. package/cjs/OpenChannel/components/OpenChannelUI.js +115 -0
  236. package/cjs/OpenChannel/components/OpenChannelUI.js.map +1 -0
  237. package/cjs/OpenChannel/context.js +23 -0
  238. package/cjs/OpenChannel/context.js.map +1 -0
  239. package/cjs/OpenChannel.js +86 -0
  240. package/cjs/OpenChannel.js.map +1 -0
  241. package/cjs/OpenChannelProvider-862a55ec.js +2020 -0
  242. package/cjs/OpenChannelProvider-862a55ec.js.map +1 -0
  243. package/cjs/OpenChannelSettings/components/EditDetailsModal.js +155 -0
  244. package/cjs/OpenChannelSettings/components/EditDetailsModal.js.map +1 -0
  245. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js +87 -0
  246. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -0
  247. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js +110 -0
  248. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -0
  249. package/cjs/OpenChannelSettings/components/OperatorUI.js +194 -0
  250. package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -0
  251. package/cjs/OpenChannelSettings/components/ParticipantUI.js +178 -0
  252. package/cjs/OpenChannelSettings/components/ParticipantUI.js.map +1 -0
  253. package/cjs/OpenChannelSettings/context.js +73 -0
  254. package/cjs/OpenChannelSettings/context.js.map +1 -0
  255. package/cjs/OpenChannelSettings.js +70 -0
  256. package/cjs/OpenChannelSettings.js.map +1 -0
  257. package/cjs/SendbirdProvider.js +771 -0
  258. package/cjs/SendbirdProvider.js.map +1 -0
  259. package/cjs/UserProfileContext-0081d7b2.js +46 -0
  260. package/cjs/UserProfileContext-0081d7b2.js.map +1 -0
  261. package/cjs/_rollupPluginBabelHelpers-08d1d0ec.js +243 -0
  262. package/cjs/_rollupPluginBabelHelpers-08d1d0ec.js.map +1 -0
  263. package/cjs/actionTypes-03bdd863.js +10 -0
  264. package/cjs/actionTypes-03bdd863.js.map +1 -0
  265. package/cjs/color-37edcf95.js +42 -0
  266. package/cjs/color-37edcf95.js.map +1 -0
  267. package/cjs/compareIds-1cb14940.js +20 -0
  268. package/cjs/compareIds-1cb14940.js.map +1 -0
  269. package/cjs/const-21636adb.js +22 -0
  270. package/cjs/const-21636adb.js.map +1 -0
  271. package/cjs/const-64185108.js +14 -0
  272. package/cjs/const-64185108.js.map +1 -0
  273. package/cjs/context-8f183eb3.js +19 -0
  274. package/cjs/context-8f183eb3.js.map +1 -0
  275. package/cjs/index-1a6c1893.js +9 -0
  276. package/cjs/index-1a6c1893.js.map +1 -0
  277. package/cjs/index-23c51d89.js +67 -0
  278. package/cjs/index-23c51d89.js.map +1 -0
  279. package/cjs/index-30e8e785.js +142 -0
  280. package/cjs/index-30e8e785.js.map +1 -0
  281. package/cjs/index-4e4d7494.js +514 -0
  282. package/cjs/index-4e4d7494.js.map +1 -0
  283. package/cjs/index-630f8d1b.js +97 -0
  284. package/cjs/index-630f8d1b.js.map +1 -0
  285. package/cjs/index-6d82098c.js +130 -0
  286. package/cjs/index-6d82098c.js.map +1 -0
  287. package/cjs/index-7532e1ca.js +284 -0
  288. package/cjs/index-7532e1ca.js.map +1 -0
  289. package/cjs/index-8479199c.js +175 -0
  290. package/cjs/index-8479199c.js.map +1 -0
  291. package/cjs/index-94e8cf13.js +54 -0
  292. package/cjs/index-94e8cf13.js.map +1 -0
  293. package/cjs/index-a40d57a5.js +722 -0
  294. package/cjs/index-a40d57a5.js.map +1 -0
  295. package/cjs/index-dcd38046.js +1880 -0
  296. package/cjs/index-dcd38046.js.map +1 -0
  297. package/cjs/index.css +4463 -0
  298. package/cjs/index.css.map +1 -0
  299. package/cjs/index.js +162 -0
  300. package/cjs/index.js.map +1 -0
  301. package/cjs/openChannelUtils-46a3a403.js +92 -0
  302. package/cjs/openChannelUtils-46a3a403.js.map +1 -0
  303. package/cjs/sendBirdSelectors.js +741 -0
  304. package/cjs/sendBirdSelectors.js.map +1 -0
  305. package/cjs/stringSet-d9121aa6.js +118 -0
  306. package/cjs/stringSet-d9121aa6.js.map +1 -0
  307. package/cjs/topics-4fc933cb.js +18 -0
  308. package/cjs/topics-4fc933cb.js.map +1 -0
  309. package/cjs/tslib.es6-571bbfc9.js +40 -0
  310. package/cjs/tslib.es6-571bbfc9.js.map +1 -0
  311. package/cjs/ui/Accordion.js +74 -0
  312. package/cjs/ui/Accordion.js.map +1 -0
  313. package/cjs/ui/AccordionGroup.js +32 -0
  314. package/cjs/ui/AccordionGroup.js.map +1 -0
  315. package/cjs/ui/AdminMessage.js +44 -0
  316. package/cjs/ui/AdminMessage.js.map +1 -0
  317. package/cjs/ui/Avatar.js +226 -0
  318. package/cjs/ui/Avatar.js.map +1 -0
  319. package/cjs/ui/Badge.js +45 -0
  320. package/cjs/ui/Badge.js.map +1 -0
  321. package/cjs/ui/Button.js +17 -0
  322. package/cjs/ui/Button.js.map +1 -0
  323. package/cjs/ui/ChannelAvatar.js +59 -0
  324. package/cjs/ui/ChannelAvatar.js.map +1 -0
  325. package/cjs/ui/ChannelPreview.js +201 -0
  326. package/cjs/ui/ChannelPreview.js.map +1 -0
  327. package/cjs/ui/ChatHeader.js +145 -0
  328. package/cjs/ui/ChatHeader.js.map +1 -0
  329. package/cjs/ui/Checkbox.js +49 -0
  330. package/cjs/ui/Checkbox.js.map +1 -0
  331. package/cjs/ui/ConnectionStatus.js +34 -0
  332. package/cjs/ui/ConnectionStatus.js.map +1 -0
  333. package/cjs/ui/ContextMenu.js +431 -0
  334. package/cjs/ui/ContextMenu.js.map +1 -0
  335. package/cjs/ui/DateSeparator.js +44 -0
  336. package/cjs/ui/DateSeparator.js.map +1 -0
  337. package/cjs/ui/Dropdown.js +107 -0
  338. package/cjs/ui/Dropdown.js.map +1 -0
  339. package/cjs/ui/EmojiReactions.js +127 -0
  340. package/cjs/ui/EmojiReactions.js.map +1 -0
  341. package/cjs/ui/FileMessageItemBody.js +57 -0
  342. package/cjs/ui/FileMessageItemBody.js.map +1 -0
  343. package/cjs/ui/FileViewer.js +174 -0
  344. package/cjs/ui/FileViewer.js.map +1 -0
  345. package/cjs/ui/Icon.js +1462 -0
  346. package/cjs/ui/Icon.js.map +1 -0
  347. package/cjs/ui/IconButton.js +83 -0
  348. package/cjs/ui/IconButton.js.map +1 -0
  349. package/cjs/ui/ImageRenderer.js +138 -0
  350. package/cjs/ui/ImageRenderer.js.map +1 -0
  351. package/cjs/ui/Input.js +74 -0
  352. package/cjs/ui/Input.js.map +1 -0
  353. package/cjs/ui/Label.js +17 -0
  354. package/cjs/ui/Label.js.map +1 -0
  355. package/cjs/ui/LinkLabel.js +51 -0
  356. package/cjs/ui/LinkLabel.js.map +1 -0
  357. package/cjs/ui/Loader.js +44 -0
  358. package/cjs/ui/Loader.js.map +1 -0
  359. package/cjs/ui/MentionUserLabel.js +25 -0
  360. package/cjs/ui/MentionUserLabel.js.map +1 -0
  361. package/cjs/ui/MessageContent.js +291 -0
  362. package/cjs/ui/MessageContent.js.map +1 -0
  363. package/cjs/ui/MessageInput.js +5048 -0
  364. package/cjs/ui/MessageInput.js.map +1 -0
  365. package/cjs/ui/MessageItemMenu.js +141 -0
  366. package/cjs/ui/MessageItemMenu.js.map +1 -0
  367. package/cjs/ui/MessageItemReactionMenu.js +112 -0
  368. package/cjs/ui/MessageItemReactionMenu.js.map +1 -0
  369. package/cjs/ui/MessageSearchFileItem.js +130 -0
  370. package/cjs/ui/MessageSearchFileItem.js.map +1 -0
  371. package/cjs/ui/MessageSearchItem.js +93 -0
  372. package/cjs/ui/MessageSearchItem.js.map +1 -0
  373. package/cjs/ui/MessageStatus.js +66 -0
  374. package/cjs/ui/MessageStatus.js.map +1 -0
  375. package/cjs/ui/Modal.js +140 -0
  376. package/cjs/ui/Modal.js.map +1 -0
  377. package/cjs/ui/MutedAvatarOverlay.js +40 -0
  378. package/cjs/ui/MutedAvatarOverlay.js.map +1 -0
  379. package/cjs/ui/OGMessageItemBody.js +107 -0
  380. package/cjs/ui/OGMessageItemBody.js.map +1 -0
  381. package/cjs/ui/OpenChannelAdminMessage.js +27 -0
  382. package/cjs/ui/OpenChannelAdminMessage.js.map +1 -0
  383. package/cjs/ui/OpenChannelAvatar.js +41 -0
  384. package/cjs/ui/OpenChannelAvatar.js.map +1 -0
  385. package/cjs/ui/OpenChannelMessageContent.js +14 -0
  386. package/cjs/ui/OpenChannelMessageContent.js.map +1 -0
  387. package/cjs/ui/OpenchannelConversationHeader.js +73 -0
  388. package/cjs/ui/OpenchannelConversationHeader.js.map +1 -0
  389. package/cjs/ui/OpenchannelFileMessage.js +230 -0
  390. package/cjs/ui/OpenchannelFileMessage.js.map +1 -0
  391. package/cjs/ui/OpenchannelOGMessage.js +345 -0
  392. package/cjs/ui/OpenchannelOGMessage.js.map +1 -0
  393. package/cjs/ui/OpenchannelThumbnailMessage.js +305 -0
  394. package/cjs/ui/OpenchannelThumbnailMessage.js.map +1 -0
  395. package/cjs/ui/OpenchannelUserMessage.js +264 -0
  396. package/cjs/ui/OpenchannelUserMessage.js.map +1 -0
  397. package/cjs/ui/PlaceHolder.js +20 -0
  398. package/cjs/ui/PlaceHolder.js.map +1 -0
  399. package/cjs/ui/QuoteMessage.js +131 -0
  400. package/cjs/ui/QuoteMessage.js.map +1 -0
  401. package/cjs/ui/QuoteMessageInput.js +99 -0
  402. package/cjs/ui/QuoteMessageInput.js.map +1 -0
  403. package/cjs/ui/ReactionBadge.js +68 -0
  404. package/cjs/ui/ReactionBadge.js.map +1 -0
  405. package/cjs/ui/ReactionButton.js +55 -0
  406. package/cjs/ui/ReactionButton.js.map +1 -0
  407. package/cjs/ui/SortByRow.js +57 -0
  408. package/cjs/ui/SortByRow.js.map +1 -0
  409. package/cjs/ui/TextButton.js +45 -0
  410. package/cjs/ui/TextButton.js.map +1 -0
  411. package/cjs/ui/TextMessageItemBody.js +62 -0
  412. package/cjs/ui/TextMessageItemBody.js.map +1 -0
  413. package/cjs/ui/ThumbnailMessageItemBody.js +82 -0
  414. package/cjs/ui/ThumbnailMessageItemBody.js.map +1 -0
  415. package/cjs/ui/Tooltip.js +35 -0
  416. package/cjs/ui/Tooltip.js.map +1 -0
  417. package/cjs/ui/TooltipWrapper.js +65 -0
  418. package/cjs/ui/TooltipWrapper.js.map +1 -0
  419. package/cjs/ui/UnknownMessageItemBody.js +41 -0
  420. package/cjs/ui/UnknownMessageItemBody.js.map +1 -0
  421. package/cjs/ui/UserListItem.js +158 -0
  422. package/cjs/ui/UserListItem.js.map +1 -0
  423. package/cjs/ui/UserProfile.js +87 -0
  424. package/cjs/ui/UserProfile.js.map +1 -0
  425. package/cjs/useSendbirdStateContext.js +22 -0
  426. package/cjs/useSendbirdStateContext.js.map +1 -0
  427. package/cjs/utils-63225dc9.js +32 -0
  428. package/cjs/utils-63225dc9.js.map +1 -0
  429. package/cjs/utils-b88eb3e0.js +6 -0
  430. package/cjs/utils-b88eb3e0.js.map +1 -0
  431. package/cjs/utils-f734965d.js +38 -0
  432. package/cjs/utils-f734965d.js.map +1 -0
  433. package/cjs/uuid-086f0c34.js +19 -0
  434. package/cjs/uuid-086f0c34.js.map +1 -0
  435. package/cjs/withSendBird.js +35 -0
  436. package/cjs/withSendBird.js.map +1 -0
  437. package/color-a3d3742c.js +39 -0
  438. package/color-a3d3742c.js.map +1 -0
  439. package/compareIds-2bfd667a.js +18 -0
  440. package/compareIds-2bfd667a.js.map +1 -0
  441. package/const-9f83647a.js +18 -0
  442. package/const-9f83647a.js.map +1 -0
  443. package/const-a8df15de.js +8 -0
  444. package/const-a8df15de.js.map +1 -0
  445. package/context-ae164d45.js +12 -0
  446. package/context-ae164d45.js.map +1 -0
  447. package/index-03baba6a.js +682 -0
  448. package/index-03baba6a.js.map +1 -0
  449. package/index-13eb0f5e.js +48 -0
  450. package/index-13eb0f5e.js.map +1 -0
  451. package/index-29563598.js +64 -0
  452. package/index-29563598.js.map +1 -0
  453. package/index-2c56786f.js +1873 -0
  454. package/index-2c56786f.js.map +1 -0
  455. package/index-80e330a9.js +7 -0
  456. package/index-80e330a9.js.map +1 -0
  457. package/index-89f5a4ba.js +168 -0
  458. package/index-89f5a4ba.js.map +1 -0
  459. package/index-d7840fad.js +280 -0
  460. package/index-d7840fad.js.map +1 -0
  461. package/index-df459121.js +121 -0
  462. package/index-df459121.js.map +1 -0
  463. package/index-e1b93b3a.js +131 -0
  464. package/index-e1b93b3a.js.map +1 -0
  465. package/index-e7c0bc26.js +512 -0
  466. package/index-e7c0bc26.js.map +1 -0
  467. package/index-f78ebc31.js +87 -0
  468. package/index-f78ebc31.js.map +1 -0
  469. package/index.css +4463 -0
  470. package/index.css.map +1 -0
  471. package/index.d.ts +1830 -0
  472. package/index.js +143 -0
  473. package/index.js.map +1 -0
  474. package/openChannelUtils-ae1d6038.js +81 -0
  475. package/openChannelUtils-ae1d6038.js.map +1 -0
  476. package/package.json +7 -29
  477. package/sendBirdSelectors.js +713 -0
  478. package/sendBirdSelectors.js.map +1 -0
  479. package/stringSet-6c9c68ae.js +116 -0
  480. package/stringSet-6c9c68ae.js.map +1 -0
  481. package/topics-d347c996.js +10 -0
  482. package/topics-d347c996.js.map +1 -0
  483. package/tslib.es6-61821688.js +38 -0
  484. package/tslib.es6-61821688.js.map +1 -0
  485. package/ui/Accordion.js +65 -0
  486. package/ui/Accordion.js.map +1 -0
  487. package/ui/AccordionGroup.js +26 -0
  488. package/ui/AccordionGroup.js.map +1 -0
  489. package/ui/AdminMessage.js +37 -0
  490. package/ui/AdminMessage.js.map +1 -0
  491. package/ui/Avatar.js +217 -0
  492. package/ui/Avatar.js.map +1 -0
  493. package/ui/Badge.js +38 -0
  494. package/ui/Badge.js.map +1 -0
  495. package/ui/Button.js +7 -0
  496. package/ui/Button.js.map +1 -0
  497. package/ui/ChannelAvatar.js +53 -0
  498. package/ui/ChannelAvatar.js.map +1 -0
  499. package/ui/ChannelPreview.js +194 -0
  500. package/ui/ChannelPreview.js.map +1 -0
  501. package/ui/ChatHeader.js +138 -0
  502. package/ui/ChatHeader.js.map +1 -0
  503. package/ui/Checkbox.js +42 -0
  504. package/ui/Checkbox.js.map +1 -0
  505. package/ui/ConnectionStatus.js +28 -0
  506. package/ui/ConnectionStatus.js.map +1 -0
  507. package/ui/ContextMenu.js +417 -0
  508. package/ui/ContextMenu.js.map +1 -0
  509. package/ui/DateSeparator.js +37 -0
  510. package/ui/DateSeparator.js.map +1 -0
  511. package/ui/Dropdown.js +97 -0
  512. package/ui/Dropdown.js.map +1 -0
  513. package/ui/EmojiReactions.js +121 -0
  514. package/ui/EmojiReactions.js.map +1 -0
  515. package/ui/FileMessageItemBody.js +51 -0
  516. package/ui/FileMessageItemBody.js.map +1 -0
  517. package/ui/FileViewer.js +164 -0
  518. package/ui/FileViewer.js.map +1 -0
  519. package/ui/Icon.js +1432 -0
  520. package/ui/Icon.js.map +1 -0
  521. package/ui/IconButton.js +76 -0
  522. package/ui/IconButton.js.map +1 -0
  523. package/ui/ImageRenderer.js +131 -0
  524. package/ui/ImageRenderer.js.map +1 -0
  525. package/ui/Input.js +64 -0
  526. package/ui/Input.js.map +1 -0
  527. package/ui/Label.js +6 -0
  528. package/ui/Label.js.map +1 -0
  529. package/ui/LinkLabel.js +40 -0
  530. package/ui/LinkLabel.js.map +1 -0
  531. package/ui/Loader.js +37 -0
  532. package/ui/Loader.js.map +1 -0
  533. package/ui/MentionUserLabel.js +19 -0
  534. package/ui/MentionUserLabel.js.map +1 -0
  535. package/ui/MessageContent.js +285 -0
  536. package/ui/MessageContent.js.map +1 -0
  537. package/ui/MessageInput.js +5040 -0
  538. package/ui/MessageInput.js.map +1 -0
  539. package/ui/MessageItemMenu.js +135 -0
  540. package/ui/MessageItemMenu.js.map +1 -0
  541. package/ui/MessageItemReactionMenu.js +106 -0
  542. package/ui/MessageItemReactionMenu.js.map +1 -0
  543. package/ui/MessageSearchFileItem.js +124 -0
  544. package/ui/MessageSearchFileItem.js.map +1 -0
  545. package/ui/MessageSearchItem.js +87 -0
  546. package/ui/MessageSearchItem.js.map +1 -0
  547. package/ui/MessageStatus.js +57 -0
  548. package/ui/MessageStatus.js.map +1 -0
  549. package/ui/Modal.js +128 -0
  550. package/ui/Modal.js.map +1 -0
  551. package/ui/MutedAvatarOverlay.js +34 -0
  552. package/ui/MutedAvatarOverlay.js.map +1 -0
  553. package/ui/OGMessageItemBody.js +101 -0
  554. package/ui/OGMessageItemBody.js.map +1 -0
  555. package/ui/OpenChannelAdminMessage.js +21 -0
  556. package/ui/OpenChannelAdminMessage.js.map +1 -0
  557. package/ui/OpenChannelAvatar.js +35 -0
  558. package/ui/OpenChannelAvatar.js.map +1 -0
  559. package/ui/OpenChannelMessageContent.js +8 -0
  560. package/ui/OpenChannelMessageContent.js.map +1 -0
  561. package/ui/OpenchannelConversationHeader.js +67 -0
  562. package/ui/OpenchannelConversationHeader.js.map +1 -0
  563. package/ui/OpenchannelFileMessage.js +224 -0
  564. package/ui/OpenchannelFileMessage.js.map +1 -0
  565. package/ui/OpenchannelOGMessage.js +339 -0
  566. package/ui/OpenchannelOGMessage.js.map +1 -0
  567. package/ui/OpenchannelThumbnailMessage.js +299 -0
  568. package/ui/OpenchannelThumbnailMessage.js.map +1 -0
  569. package/ui/OpenchannelUserMessage.js +258 -0
  570. package/ui/OpenchannelUserMessage.js.map +1 -0
  571. package/ui/PlaceHolder.js +11 -0
  572. package/ui/PlaceHolder.js.map +1 -0
  573. package/ui/QuoteMessage.js +125 -0
  574. package/ui/QuoteMessage.js.map +1 -0
  575. package/ui/QuoteMessageInput.js +93 -0
  576. package/ui/QuoteMessageInput.js.map +1 -0
  577. package/ui/ReactionBadge.js +61 -0
  578. package/ui/ReactionBadge.js.map +1 -0
  579. package/ui/ReactionButton.js +48 -0
  580. package/ui/ReactionButton.js.map +1 -0
  581. package/ui/SortByRow.js +50 -0
  582. package/ui/SortByRow.js.map +1 -0
  583. package/ui/TextButton.js +38 -0
  584. package/ui/TextButton.js.map +1 -0
  585. package/ui/TextMessageItemBody.js +56 -0
  586. package/ui/TextMessageItemBody.js.map +1 -0
  587. package/ui/ThumbnailMessageItemBody.js +76 -0
  588. package/ui/ThumbnailMessageItemBody.js.map +1 -0
  589. package/ui/Tooltip.js +28 -0
  590. package/ui/Tooltip.js.map +1 -0
  591. package/ui/TooltipWrapper.js +58 -0
  592. package/ui/TooltipWrapper.js.map +1 -0
  593. package/ui/UnknownMessageItemBody.js +35 -0
  594. package/ui/UnknownMessageItemBody.js.map +1 -0
  595. package/ui/UserListItem.js +151 -0
  596. package/ui/UserListItem.js.map +1 -0
  597. package/ui/UserProfile.js +81 -0
  598. package/ui/UserProfile.js.map +1 -0
  599. package/useSendbirdStateContext.js +20 -0
  600. package/useSendbirdStateContext.js.map +1 -0
  601. package/utils-4e85584a.js +4 -0
  602. package/utils-4e85584a.js.map +1 -0
  603. package/utils-5e25aca3.js +34 -0
  604. package/utils-5e25aca3.js.map +1 -0
  605. package/utils-aed86fb8.js +30 -0
  606. package/utils-aed86fb8.js.map +1 -0
  607. package/uuid-6e6389e2.js +17 -0
  608. package/uuid-6e6389e2.js.map +1 -0
  609. package/withSendBird.js +26 -0
  610. package/withSendBird.js.map +1 -0
@@ -0,0 +1,361 @@
1
+ 'use strict';
2
+
3
+ var tslib_es6 = require('../../tslib.es6-571bbfc9.js');
4
+ var React = require('react');
5
+ var index$1 = require('../../index-dcd38046.js');
6
+ var Channel_components_SuggestedMentionList = require('./SuggestedMentionList.js');
7
+ var useSendbirdStateContext = require('../../useSendbirdStateContext.js');
8
+ var Channel_context = require('../../ChannelProvider-3ef2a755.js');
9
+ var index = require('../../index-a40d57a5.js');
10
+ var _const = require('../../const-64185108.js');
11
+ var ui_DateSeparator = require('../../ui/DateSeparator.js');
12
+ var ui_Label = require('../../index-30e8e785.js');
13
+ var ui_MessageInput = require('../../ui/MessageInput.js');
14
+ var ui_MessageContent = require('../../ui/MessageContent.js');
15
+ var Channel_components_FileViewer = require('./FileViewer.js');
16
+ var Channel_components_RemoveMessageModal = require('./RemoveMessageModal.js');
17
+ var _const$1 = require('../../const-21636adb.js');
18
+ var LocalizationContext = require('../../LocalizationContext-4c0a4a70.js');
19
+ require('../../index-4e4d7494.js');
20
+ require('../../ui/Icon.js');
21
+ require('../../_rollupPluginBabelHelpers-08d1d0ec.js');
22
+ require('prop-types');
23
+ require('../../ui/Avatar.js');
24
+ require('../../ui/ImageRenderer.js');
25
+ require('../../uuid-086f0c34.js');
26
+ require('../../withSendBird.js');
27
+ require('../../UserProfileContext-0081d7b2.js');
28
+ require('../../topics-4fc933cb.js');
29
+ require('../../compareIds-1cb14940.js');
30
+ require('../../ui/ContextMenu.js');
31
+ require('react-dom');
32
+ require('../../ui/SortByRow.js');
33
+ require('../../stringSet-d9121aa6.js');
34
+ require('../../ui/ReactionButton.js');
35
+ require('../../color-37edcf95.js');
36
+ require('stream');
37
+ require('../../ui/IconButton.js');
38
+ require('../../index-630f8d1b.js');
39
+ require('../../ui/MentionUserLabel.js');
40
+ require('../../ui/UserProfile.js');
41
+ require('../../sendBirdSelectors.js');
42
+ require('../../ui/MessageStatus.js');
43
+ require('../../ui/Loader.js');
44
+ require('../../ui/MessageItemMenu.js');
45
+ require('../../ui/MessageItemReactionMenu.js');
46
+ require('../../ui/EmojiReactions.js');
47
+ require('../../ui/Tooltip.js');
48
+ require('../../ui/TooltipWrapper.js');
49
+ require('../../ui/ReactionBadge.js');
50
+ require('../../ui/AdminMessage.js');
51
+ require('../../ui/TextMessageItemBody.js');
52
+ require('../../index-94e8cf13.js');
53
+ require('../../ui/LinkLabel.js');
54
+ require('../../ui/FileMessageItemBody.js');
55
+ require('../../ui/TextButton.js');
56
+ require('../../ui/ThumbnailMessageItemBody.js');
57
+ require('../../ui/OGMessageItemBody.js');
58
+ require('../../ui/UnknownMessageItemBody.js');
59
+ require('../../ui/QuoteMessage.js');
60
+ require('../../index-1a6c1893.js');
61
+ require('../../ui/Modal.js');
62
+ require('../../utils-b88eb3e0.js');
63
+
64
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
65
+
66
+ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
67
+
68
+ var Message = function Message(props) {
69
+ var _a;
70
+
71
+ var message = props.message,
72
+ hasSeparator = props.hasSeparator,
73
+ chainTop = props.chainTop,
74
+ chainBottom = props.chainBottom,
75
+ handleScroll = props.handleScroll,
76
+ renderCustomSeparator = props.renderCustomSeparator,
77
+ renderEditInput = props.renderEditInput,
78
+ renderMessage = props.renderMessage,
79
+ renderMessageContent = props.renderMessageContent;
80
+ var dateLocale = LocalizationContext.useLocalization().dateLocale;
81
+ var globalStore = useSendbirdStateContext();
82
+
83
+ var _b = globalStore === null || globalStore === void 0 ? void 0 : globalStore.config,
84
+ userId = _b.userId,
85
+ isOnline = _b.isOnline,
86
+ isMentionEnabled = _b.isMentionEnabled,
87
+ userMention = _b.userMention;
88
+
89
+ var maxUserMentionCount = (userMention === null || userMention === void 0 ? void 0 : userMention.maxMentionCount) || _const.MAX_USER_MENTION_COUNT;
90
+ var maxUserSuggestionCount = (userMention === null || userMention === void 0 ? void 0 : userMention.maxSuggestionCount) || _const.MAX_USER_SUGGESTION_COUNT;
91
+
92
+ var _c = Channel_context.useChannel(),
93
+ currentGroupChannel = _c.currentGroupChannel,
94
+ highLightedMessageId = _c.highLightedMessageId,
95
+ setHighLightedMessageId = _c.setHighLightedMessageId,
96
+ animatedMessageId = _c.animatedMessageId,
97
+ setAnimatedMessageId = _c.setAnimatedMessageId,
98
+ updateMessage = _c.updateMessage,
99
+ scrollToMessage = _c.scrollToMessage,
100
+ replyType = _c.replyType,
101
+ useReaction = _c.useReaction,
102
+ toggleReaction = _c.toggleReaction,
103
+ emojiContainer = _c.emojiContainer,
104
+ nicknamesMap = _c.nicknamesMap,
105
+ setQuoteMessage = _c.setQuoteMessage,
106
+ resendMessage = _c.resendMessage,
107
+ renderUserMentionItem = _c.renderUserMentionItem;
108
+
109
+ var _d = React.useState(false),
110
+ showEdit = _d[0],
111
+ setShowEdit = _d[1];
112
+
113
+ var _e = React.useState(false),
114
+ showRemove = _e[0],
115
+ setShowRemove = _e[1];
116
+
117
+ var _f = React.useState(false),
118
+ showFileViewer = _f[0],
119
+ setShowFileViewer = _f[1];
120
+
121
+ var _g = React.useState(false),
122
+ isAnimated = _g[0],
123
+ setIsAnimated = _g[1];
124
+
125
+ var _h = React.useState(false),
126
+ isHighlighted = _h[0],
127
+ setIsHighlighted = _h[1];
128
+
129
+ var _j = React.useState(''),
130
+ mentionNickname = _j[0],
131
+ setMentionNickname = _j[1];
132
+
133
+ var _k = React.useState([]),
134
+ mentionedUsers = _k[0],
135
+ setMentionedUsers = _k[1];
136
+
137
+ var _l = React.useState([]),
138
+ mentionedUserIds = _l[0],
139
+ setMentionedUserIds = _l[1];
140
+
141
+ var _m = React.useState(null),
142
+ messageInputEvent = _m[0],
143
+ setMessageInputEvent = _m[1];
144
+
145
+ var _o = React.useState(null),
146
+ selectedUser = _o[0],
147
+ setSelectedUser = _o[1];
148
+
149
+ var _p = React.useState([]),
150
+ mentionSuggestedUsers = _p[0],
151
+ setMentionSuggestedUsers = _p[1];
152
+
153
+ var _q = React.useState(true),
154
+ ableMention = _q[0],
155
+ setAbleMention = _q[1];
156
+
157
+ var editMessageInputRef = React.useRef(null);
158
+ var useMessageScrollRef = React.useRef(null);
159
+ var displaySuggestedMentionList = isMentionEnabled && mentionNickname.length > 0;
160
+ React.useEffect(function () {
161
+ if ((mentionedUsers === null || mentionedUsers === void 0 ? void 0 : mentionedUsers.length) >= maxUserMentionCount) {
162
+ setAbleMention(false);
163
+ } else {
164
+ setAbleMention(true);
165
+ }
166
+ }, [mentionedUsers]);
167
+ React.useEffect(function () {
168
+ setMentionedUsers(mentionedUsers.filter(function (_a) {
169
+ var userId = _a.userId;
170
+ var i = mentionedUserIds.indexOf(userId);
171
+
172
+ if (i < 0) {
173
+ return false;
174
+ } else {
175
+ mentionedUserIds.splice(i, 1);
176
+ return true;
177
+ }
178
+ }));
179
+ }, [mentionedUserIds]);
180
+ React.useLayoutEffect(function () {
181
+ handleScroll === null || handleScroll === void 0 ? void 0 : handleScroll();
182
+ }, [showEdit, (_a = message === null || message === void 0 ? void 0 : message.reactions) === null || _a === void 0 ? void 0 : _a.length]);
183
+ React.useLayoutEffect(function () {
184
+ if (highLightedMessageId === message.messageId) {
185
+ if (useMessageScrollRef && useMessageScrollRef.current) {
186
+ useMessageScrollRef.current.scrollIntoView({
187
+ block: 'center',
188
+ inline: 'center'
189
+ });
190
+ setIsAnimated(false);
191
+ setTimeout(function () {
192
+ setIsHighlighted(true);
193
+ }, 500);
194
+ setTimeout(function () {
195
+ setHighLightedMessageId(0);
196
+ }, 1600);
197
+ }
198
+ } else {
199
+ setIsHighlighted(false);
200
+ }
201
+ }, [highLightedMessageId, useMessageScrollRef.current, message.messageId]);
202
+ React.useLayoutEffect(function () {
203
+ if (animatedMessageId === message.messageId) {
204
+ if (useMessageScrollRef && useMessageScrollRef.current) {
205
+ useMessageScrollRef.current.scrollIntoView({
206
+ block: 'center',
207
+ inline: 'center'
208
+ });
209
+ setIsHighlighted(false);
210
+ setTimeout(function () {
211
+ setIsAnimated(true);
212
+ }, 500);
213
+ setTimeout(function () {
214
+ setAnimatedMessageId(0);
215
+ }, 1600);
216
+ }
217
+ } else {
218
+ setIsAnimated(false);
219
+ }
220
+ }, [animatedMessageId, useMessageScrollRef.current, message.messageId]);
221
+ var renderedMessage = React.useMemo(function () {
222
+ return renderMessage === null || renderMessage === void 0 ? void 0 : renderMessage({
223
+ message: message,
224
+ chainTop: chainTop,
225
+ chainBottom: chainBottom
226
+ });
227
+ }, [message, renderMessage]);
228
+ var renderedCustomSeparator = React.useMemo(function () {
229
+ if (renderCustomSeparator) {
230
+ return renderCustomSeparator === null || renderCustomSeparator === void 0 ? void 0 : renderCustomSeparator();
231
+ }
232
+
233
+ return null;
234
+ }, [message, renderCustomSeparator]);
235
+
236
+ if (renderedMessage) {
237
+ return /*#__PURE__*/React__default["default"].createElement("div", {
238
+ ref: useMessageScrollRef,
239
+ className: index.getClassName(['sendbird-msg-hoc sendbird-msg--scroll-ref', isAnimated ? 'sendbird-msg-hoc__animated' : '', isHighlighted ? 'sendbird-msg-hoc__highlighted' : ''])
240
+ }, // TODO: Add message instance as a function parameter
241
+ hasSeparator && (renderedCustomSeparator || /*#__PURE__*/React__default["default"].createElement(ui_DateSeparator, null, /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
242
+ type: ui_Label.LabelTypography.CAPTION_2,
243
+ color: ui_Label.LabelColors.ONBACKGROUND_2
244
+ }, index$1.format(message.createdAt, 'MMMM dd, yyyy', {
245
+ locale: dateLocale
246
+ })))), renderedMessage);
247
+ }
248
+
249
+ if (showEdit && message.isUserMessage()) {
250
+ return (renderEditInput === null || renderEditInput === void 0 ? void 0 : renderEditInput()) || /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, displaySuggestedMentionList && /*#__PURE__*/React__default["default"].createElement(Channel_components_SuggestedMentionList, {
251
+ targetNickname: mentionNickname,
252
+ inputEvent: messageInputEvent,
253
+ renderUserMentionItem: renderUserMentionItem,
254
+ onUserItemClick: function onUserItemClick(user) {
255
+ if (user) {
256
+ setMentionedUsers(tslib_es6.__spreadArray(tslib_es6.__spreadArray([], mentionedUsers, true), [user], false));
257
+ }
258
+
259
+ setMentionNickname('');
260
+ setSelectedUser(user);
261
+ setMessageInputEvent(null);
262
+ },
263
+ onFocusItemChange: function onFocusItemChange() {
264
+ setMessageInputEvent(null);
265
+ },
266
+ onFetchUsers: function onFetchUsers(users) {
267
+ setMentionSuggestedUsers(users);
268
+ },
269
+ ableAddMention: ableMention,
270
+ maxMentionCount: maxUserMentionCount,
271
+ maxSuggestionCount: maxUserSuggestionCount
272
+ }), /*#__PURE__*/React__default["default"].createElement(ui_MessageInput, {
273
+ isEdit: true,
274
+ disabled: Channel_context.isDisabledBecauseFrozen(currentGroupChannel),
275
+ ref: editMessageInputRef,
276
+ mentionSelectedUser: selectedUser,
277
+ isMentionEnabled: isMentionEnabled,
278
+ message: message,
279
+ onUpdateMessage: function onUpdateMessage(_a) {
280
+ var messageId = _a.messageId,
281
+ message = _a.message,
282
+ mentionTemplate = _a.mentionTemplate;
283
+ updateMessage({
284
+ messageId: messageId,
285
+ message: message,
286
+ mentionedUsers: mentionedUsers,
287
+ mentionTemplate: mentionTemplate
288
+ });
289
+ setShowEdit(false);
290
+ },
291
+ onCancelEdit: function onCancelEdit() {
292
+ setShowEdit(false);
293
+ },
294
+ onUserMentioned: function onUserMentioned(user) {
295
+ if ((selectedUser === null || selectedUser === void 0 ? void 0 : selectedUser.userId) === (user === null || user === void 0 ? void 0 : user.userId)) {
296
+ setSelectedUser(null);
297
+ setMentionNickname('');
298
+ }
299
+ },
300
+ onMentionStringChange: function onMentionStringChange(mentionText) {
301
+ setMentionNickname(mentionText);
302
+ },
303
+ onMentionedUserIdsUpdated: function onMentionedUserIdsUpdated(userIds) {
304
+ setMentionedUserIds(userIds);
305
+ },
306
+ onKeyDown: function onKeyDown(e) {
307
+ if (displaySuggestedMentionList && (mentionSuggestedUsers === null || mentionSuggestedUsers === void 0 ? void 0 : mentionSuggestedUsers.length) > 0 && (e.key === _const$1.MessageInputKeys.Enter && ableMention || e.key === _const$1.MessageInputKeys.ArrowUp || e.key === _const$1.MessageInputKeys.ArrowDown)) {
308
+ setMessageInputEvent(e);
309
+ return true;
310
+ }
311
+
312
+ return false;
313
+ }
314
+ }));
315
+ }
316
+
317
+ return /*#__PURE__*/React__default["default"].createElement("div", {
318
+ className: index.getClassName(['sendbird-msg-hoc sendbird-msg--scroll-ref', isAnimated ? 'sendbird-msg-hoc__animated' : '', isHighlighted ? 'sendbird-msg-hoc__highlighted' : '']),
319
+ style: {
320
+ marginBottom: '2px'
321
+ },
322
+ ref: useMessageScrollRef
323
+ }, hasSeparator && (renderedCustomSeparator || /*#__PURE__*/React__default["default"].createElement(ui_DateSeparator, null, /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
324
+ type: ui_Label.LabelTypography.CAPTION_2,
325
+ color: ui_Label.LabelColors.ONBACKGROUND_2
326
+ }, index$1.format(message.createdAt, 'MMMM dd, yyyy', {
327
+ locale: dateLocale
328
+ })))), (renderMessageContent === null || renderMessageContent === void 0 ? void 0 : renderMessageContent()) || /*#__PURE__*/React__default["default"].createElement(ui_MessageContent, {
329
+ className: "sendbird-message-hoc__message-content",
330
+ userId: userId,
331
+ scrollToMessage: scrollToMessage,
332
+ channel: currentGroupChannel,
333
+ message: message,
334
+ disabled: !isOnline,
335
+ chainTop: chainTop,
336
+ chainBottom: chainBottom,
337
+ useReaction: useReaction,
338
+ replyType: replyType,
339
+ nicknamesMap: nicknamesMap,
340
+ emojiContainer: emojiContainer,
341
+ showEdit: setShowEdit,
342
+ showRemove: setShowRemove,
343
+ showFileViewer: setShowFileViewer,
344
+ resendMessage: resendMessage,
345
+ toggleReaction: toggleReaction,
346
+ setQuoteMessage: setQuoteMessage
347
+ }), showRemove && /*#__PURE__*/React__default["default"].createElement(Channel_components_RemoveMessageModal, {
348
+ message: message,
349
+ onCancel: function onCancel() {
350
+ return setShowRemove(false);
351
+ }
352
+ }), showFileViewer && /*#__PURE__*/React__default["default"].createElement(Channel_components_FileViewer["default"], {
353
+ message: message,
354
+ onCancel: function onCancel() {
355
+ return setShowFileViewer(false);
356
+ }
357
+ }));
358
+ };
359
+
360
+ module.exports = Message;
361
+ //# sourceMappingURL=Message.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Message.js","sources":["../../../../src/smart-components/Channel/components/Message/index.tsx"],"sourcesContent":["import React, {\n useState,\n useEffect,\n useRef,\n useLayoutEffect,\n useMemo,\n} from 'react';\nimport format from 'date-fns/format';\n\nimport SuggestedMentionList from '../SuggestedMentionList';\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport { useChannel } from '../../context/ChannelProvider';\nimport { getClassName } from '../../../../utils';\nimport { isDisabledBecauseFrozen } from '../../context/utils';\nimport { MAX_USER_MENTION_COUNT, MAX_USER_SUGGESTION_COUNT } from '../../context/const';\n\nimport DateSeparator from '../../../../ui/DateSeparator';\nimport Label, { LabelTypography, LabelColors } from '../../../../ui/Label';\nimport MessageInput from '../../../../ui/MessageInput';\nimport MessageContent from '../../../../ui/MessageContent';\nimport FileViewer from '../FileViewer';\nimport RemoveMessageModal from '../RemoveMessageModal';\nimport { MessageInputKeys } from '../../../../ui/MessageInput/const';\nimport { EveryMessage, RenderMessageProps } from '../../../../types';\nimport { useLocalization } from '../../../../lib/LocalizationContext';\n\ntype MessageUIProps = {\n message: EveryMessage;\n hasSeparator?: boolean;\n chainTop?: boolean;\n chainBottom?: boolean;\n handleScroll: () => void;\n // for extending\n renderMessage?: (props: RenderMessageProps) => React.ReactNode;\n renderCustomSeparator?: () => React.ReactNode;\n renderEditInput?: () => React.ReactNode;\n renderMessageContent?: () => React.ReactNode;\n};\n\nconst Message: React.FC<MessageUIProps> = (props: MessageUIProps) => {\n const {\n message,\n hasSeparator,\n chainTop,\n chainBottom,\n handleScroll,\n renderCustomSeparator,\n renderEditInput,\n renderMessage,\n renderMessageContent,\n } = props;\n\n const { dateLocale } = useLocalization();\n const globalStore = useSendbirdStateContext();\n const {\n userId,\n isOnline,\n isMentionEnabled,\n userMention,\n } = globalStore?.config;\n const maxUserMentionCount = userMention?.maxMentionCount || MAX_USER_MENTION_COUNT;\n const maxUserSuggestionCount = userMention?.maxSuggestionCount || MAX_USER_SUGGESTION_COUNT;\n\n const {\n currentGroupChannel,\n highLightedMessageId,\n setHighLightedMessageId,\n animatedMessageId,\n setAnimatedMessageId,\n updateMessage,\n scrollToMessage,\n replyType,\n useReaction,\n toggleReaction,\n emojiContainer,\n nicknamesMap,\n setQuoteMessage,\n resendMessage,\n renderUserMentionItem,\n } = useChannel();\n\n const [showEdit, setShowEdit] = useState(false);\n const [showRemove, setShowRemove] = useState(false);\n const [showFileViewer, setShowFileViewer] = useState(false);\n const [isAnimated, setIsAnimated] = useState(false);\n const [isHighlighted, setIsHighlighted] = useState(false);\n const [mentionNickname, setMentionNickname] = useState('');\n const [mentionedUsers, setMentionedUsers] = useState([]);\n const [mentionedUserIds, setMentionedUserIds] = useState([]);\n const [messageInputEvent, setMessageInputEvent] = useState(null);\n const [selectedUser, setSelectedUser] = useState(null);\n const [mentionSuggestedUsers, setMentionSuggestedUsers] = useState([]);\n const [ableMention, setAbleMention] = useState(true);\n const editMessageInputRef = useRef(null);\n const useMessageScrollRef = useRef(null);\n\n const displaySuggestedMentionList = (isMentionEnabled && mentionNickname.length > 0);\n\n useEffect(() => {\n if (mentionedUsers?.length >= maxUserMentionCount) {\n setAbleMention(false);\n } else {\n setAbleMention(true);\n }\n }, [mentionedUsers]);\n\n useEffect(() => {\n setMentionedUsers(mentionedUsers.filter(({ userId }) => {\n const i = mentionedUserIds.indexOf(userId);\n if (i < 0) {\n return false;\n } else {\n mentionedUserIds.splice(i, 1);\n return true;\n }\n }));\n }, [mentionedUserIds]);\n\n useLayoutEffect(() => {\n handleScroll?.();\n }, [showEdit, message?.reactions?.length]);\n\n useLayoutEffect(() => {\n if (highLightedMessageId === message.messageId) {\n if (useMessageScrollRef && useMessageScrollRef.current) {\n useMessageScrollRef.current.scrollIntoView({ block: 'center', inline: 'center' });\n setIsAnimated(false);\n setTimeout(() => {\n setIsHighlighted(true);\n }, 500);\n setTimeout(() => {\n setHighLightedMessageId(0);\n }, 1600);\n }\n } else {\n setIsHighlighted(false);\n }\n }, [highLightedMessageId, useMessageScrollRef.current, message.messageId]);\n\n useLayoutEffect(() => {\n if (animatedMessageId === message.messageId) {\n if (useMessageScrollRef && useMessageScrollRef.current) {\n useMessageScrollRef.current.scrollIntoView({ block: 'center', inline: 'center' });\n setIsHighlighted(false);\n setTimeout(() => {\n setIsAnimated(true);\n }, 500);\n setTimeout(() => {\n setAnimatedMessageId(0);\n }, 1600);\n }\n } else {\n setIsAnimated(false);\n }\n }, [animatedMessageId, useMessageScrollRef.current, message.messageId]);\n const renderedMessage = useMemo(() => {\n return renderMessage?.({\n message,\n chainTop,\n chainBottom,\n });\n }, [message, renderMessage]);\n const renderedCustomSeparator = useMemo(() => {\n if (renderCustomSeparator) {\n return renderCustomSeparator?.();\n }\n return null;\n }, [message, renderCustomSeparator]);\n\n if (renderedMessage) {\n return (\n <div\n ref={useMessageScrollRef}\n className={getClassName([\n 'sendbird-msg-hoc sendbird-msg--scroll-ref',\n isAnimated ? 'sendbird-msg-hoc__animated' : '',\n isHighlighted ? 'sendbird-msg-hoc__highlighted' : '',\n ])}\n >\n {/* date-separator */}\n {\n // TODO: Add message instance as a function parameter\n hasSeparator && (renderedCustomSeparator || (\n <DateSeparator>\n <Label type={LabelTypography.CAPTION_2} color={LabelColors.ONBACKGROUND_2}>\n {format(message.createdAt, 'MMMM dd, yyyy', {\n locale: dateLocale,\n })}\n </Label>\n </DateSeparator>\n ))\n }\n {renderedMessage}\n </div>\n );\n }\n\n if (showEdit && message.isUserMessage()) {\n return renderEditInput?.() || (\n <>\n {\n displaySuggestedMentionList && (\n <SuggestedMentionList\n targetNickname={mentionNickname}\n inputEvent={messageInputEvent}\n renderUserMentionItem={renderUserMentionItem}\n onUserItemClick={(user) => {\n if (user) {\n setMentionedUsers([...mentionedUsers, user]);\n }\n setMentionNickname('');\n setSelectedUser(user);\n setMessageInputEvent(null);\n }}\n onFocusItemChange={() => {\n setMessageInputEvent(null);\n }}\n onFetchUsers={(users) => {\n setMentionSuggestedUsers(users);\n }}\n ableAddMention={ableMention}\n maxMentionCount={maxUserMentionCount}\n maxSuggestionCount={maxUserSuggestionCount}\n />\n )\n }\n <MessageInput\n isEdit\n disabled={isDisabledBecauseFrozen(currentGroupChannel)}\n ref={editMessageInputRef}\n mentionSelectedUser={selectedUser}\n isMentionEnabled={isMentionEnabled}\n message={message}\n onUpdateMessage={({ messageId, message, mentionTemplate }) => {\n updateMessage({\n messageId,\n message,\n mentionedUsers,\n mentionTemplate,\n });\n setShowEdit(false);\n }}\n onCancelEdit={() => { setShowEdit(false); }}\n onUserMentioned={(user) => {\n if (selectedUser?.userId === user?.userId) {\n setSelectedUser(null);\n setMentionNickname('');\n }\n }}\n onMentionStringChange={(mentionText) => {\n setMentionNickname(mentionText);\n }}\n onMentionedUserIdsUpdated={(userIds) => {\n setMentionedUserIds(userIds);\n }}\n onKeyDown={(e) => {\n if (displaySuggestedMentionList && mentionSuggestedUsers?.length > 0\n && ((e.key === MessageInputKeys.Enter && ableMention) || e.key === MessageInputKeys.ArrowUp || e.key === MessageInputKeys.ArrowDown)\n ) {\n setMessageInputEvent(e);\n return true;\n }\n return false;\n }}\n />\n </>\n );\n }\n\n return (\n <div\n className={getClassName([\n 'sendbird-msg-hoc sendbird-msg--scroll-ref',\n isAnimated ? 'sendbird-msg-hoc__animated' : '',\n isHighlighted ? 'sendbird-msg-hoc__highlighted' : '',\n ])}\n style={{ marginBottom: '2px' }}\n ref={useMessageScrollRef}\n >\n {/* date-separator */}\n {\n hasSeparator && (renderedCustomSeparator || (\n <DateSeparator>\n <Label type={LabelTypography.CAPTION_2} color={LabelColors.ONBACKGROUND_2}>\n {format(message.createdAt, 'MMMM dd, yyyy', {\n locale: dateLocale,\n })}\n </Label>\n </DateSeparator>\n ))\n }\n {/* Message */}\n {\n renderMessageContent?.() || (\n <MessageContent\n className=\"sendbird-message-hoc__message-content\"\n userId={userId}\n scrollToMessage={scrollToMessage}\n channel={currentGroupChannel}\n message={message}\n disabled={!isOnline}\n chainTop={chainTop}\n chainBottom={chainBottom}\n useReaction={useReaction}\n replyType={replyType}\n nicknamesMap={nicknamesMap}\n emojiContainer={emojiContainer}\n showEdit={setShowEdit}\n showRemove={setShowRemove}\n showFileViewer={setShowFileViewer}\n resendMessage={resendMessage}\n toggleReaction={toggleReaction}\n setQuoteMessage={setQuoteMessage}\n />\n )\n }\n {/* Modal */}\n {\n showRemove && (\n <RemoveMessageModal\n message={message}\n onCancel={() => setShowRemove(false)}\n />\n )\n }\n {\n showFileViewer && (\n <FileViewer\n message={message as SendbirdUIKit.ClientFileMessage}\n onCancel={() => setShowFileViewer(false)}\n />\n )\n }\n </div>\n );\n};\n\nexport default Message;\n"],"names":["Message","props","message","hasSeparator","chainTop","chainBottom","handleScroll","renderCustomSeparator","renderEditInput","renderMessage","renderMessageContent","dateLocale","useLocalization","globalStore","useSendbirdStateContext","_b","config","userId","isOnline","isMentionEnabled","userMention","maxUserMentionCount","maxMentionCount","MAX_USER_MENTION_COUNT","maxUserSuggestionCount","maxSuggestionCount","MAX_USER_SUGGESTION_COUNT","_c","useChannel","currentGroupChannel","highLightedMessageId","setHighLightedMessageId","animatedMessageId","setAnimatedMessageId","updateMessage","scrollToMessage","replyType","useReaction","toggleReaction","emojiContainer","nicknamesMap","setQuoteMessage","resendMessage","renderUserMentionItem","_d","useState","showEdit","setShowEdit","_e","showRemove","setShowRemove","_f","showFileViewer","setShowFileViewer","_g","isAnimated","setIsAnimated","_h","isHighlighted","setIsHighlighted","_j","mentionNickname","setMentionNickname","_k","mentionedUsers","setMentionedUsers","_l","mentionedUserIds","setMentionedUserIds","_m","messageInputEvent","setMessageInputEvent","_o","selectedUser","setSelectedUser","_p","mentionSuggestedUsers","setMentionSuggestedUsers","_q","ableMention","setAbleMention","editMessageInputRef","useRef","useMessageScrollRef","displaySuggestedMentionList","length","useEffect","filter","_a","i","indexOf","splice","useLayoutEffect","reactions","messageId","current","scrollIntoView","block","inline","setTimeout","renderedMessage","useMemo","renderedCustomSeparator","React","getClassName","DateSeparator","Label","LabelTypography","CAPTION_2","LabelColors","ONBACKGROUND_2","format","createdAt","locale","isUserMessage","SuggestedMentionList","user","users","MessageInput","isDisabledBecauseFrozen","mentionTemplate","mentionText","userIds","e","key","MessageInputKeys","Enter","ArrowUp","ArrowDown","marginBottom","MessageContent","RemoveMessageModal","FileViewer"],"mappings":"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"}
@@ -0,0 +1,208 @@
1
+ 'use strict';
2
+
3
+ var tslib_es6 = require('../../tslib.es6-571bbfc9.js');
4
+ var React = require('react');
5
+ var Channel_context = require('../../ChannelProvider-3ef2a755.js');
6
+ var ui_MessageInput = require('../../ui/MessageInput.js');
7
+ var ui_QuoteMessageInput = require('../../ui/QuoteMessageInput.js');
8
+ var LocalizationContext = require('../../LocalizationContext-4c0a4a70.js');
9
+ var useSendbirdStateContext = require('../../useSendbirdStateContext.js');
10
+ var Channel_components_SuggestedMentionList = require('./SuggestedMentionList.js');
11
+ var _const = require('../../const-21636adb.js');
12
+ require('../../UserProfileContext-0081d7b2.js');
13
+ require('prop-types');
14
+ require('../../_rollupPluginBabelHelpers-08d1d0ec.js');
15
+ require('../../index-dcd38046.js');
16
+ require('../../index-4e4d7494.js');
17
+ require('../../topics-4fc933cb.js');
18
+ require('../../index-a40d57a5.js');
19
+ require('../../compareIds-1cb14940.js');
20
+ require('../../const-64185108.js');
21
+ require('../../uuid-086f0c34.js');
22
+ require('../../ui/ContextMenu.js');
23
+ require('../../index-30e8e785.js');
24
+ require('../../stringSet-d9121aa6.js');
25
+ require('react-dom');
26
+ require('../../ui/SortByRow.js');
27
+ require('../../ui/ReactionButton.js');
28
+ require('../../ui/ImageRenderer.js');
29
+ require('../../ui/Icon.js');
30
+ require('stream');
31
+ require('../../ui/IconButton.js');
32
+ require('../../index-630f8d1b.js');
33
+ require('../../ui/MentionUserLabel.js');
34
+ require('../../withSendBird.js');
35
+ require('../../ui/Avatar.js');
36
+
37
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
38
+
39
+ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
40
+
41
+ var MessageInputWrapper = function MessageInputWrapper() {
42
+ var _a = Channel_context.useChannel(),
43
+ currentGroupChannel = _a.currentGroupChannel,
44
+ initialized = _a.initialized,
45
+ quoteMessage = _a.quoteMessage,
46
+ sendMessage = _a.sendMessage,
47
+ sendFileMessage = _a.sendFileMessage,
48
+ setQuoteMessage = _a.setQuoteMessage,
49
+ messageInputRef = _a.messageInputRef,
50
+ renderUserMentionItem = _a.renderUserMentionItem;
51
+
52
+ var globalStore = useSendbirdStateContext();
53
+ var channel = currentGroupChannel;
54
+
55
+ var _b = globalStore === null || globalStore === void 0 ? void 0 : globalStore.config,
56
+ isOnline = _b.isOnline,
57
+ isMentionEnabled = _b.isMentionEnabled,
58
+ userMention = _b.userMention;
59
+
60
+ var maxUserMentionCount = (userMention === null || userMention === void 0 ? void 0 : userMention.maxMentionCount) || 10;
61
+ var maxUserSuggestionCount = (userMention === null || userMention === void 0 ? void 0 : userMention.maxSuggestionCount) || 15;
62
+ var stringSet = React.useContext(LocalizationContext.LocalizationContext).stringSet;
63
+
64
+ var _c = React.useState(''),
65
+ mentionNickname = _c[0],
66
+ setMentionNickname = _c[1];
67
+
68
+ var _d = React.useState([]),
69
+ mentionedUsers = _d[0],
70
+ setMentionedUsers = _d[1];
71
+
72
+ var _e = React.useState([]),
73
+ mentionedUserIds = _e[0],
74
+ setMentionedUserIds = _e[1];
75
+
76
+ var _f = React.useState(null),
77
+ selectedUser = _f[0],
78
+ setSelectedUser = _f[1];
79
+
80
+ var _g = React.useState([]),
81
+ mentionSuggestedUsers = _g[0],
82
+ setMentionSuggestedUsers = _g[1];
83
+
84
+ var _h = React.useState(true),
85
+ ableMention = _h[0],
86
+ setAbleMention = _h[1];
87
+
88
+ var _j = React.useState(null),
89
+ messageInputEvent = _j[0],
90
+ setMessageInputEvent = _j[1];
91
+
92
+ var disabled = !initialized || Channel_context.isDisabledBecauseFrozen(channel) || Channel_context.isDisabledBecauseMuted(channel) || !isOnline;
93
+ var isOperator = Channel_context.isOperator(channel);
94
+ var isBroadcast = channel.isBroadcast;
95
+ var displaySuggestedMentionList = isMentionEnabled && mentionNickname.length > 0;
96
+ React.useEffect(function () {
97
+ if ((mentionedUsers === null || mentionedUsers === void 0 ? void 0 : mentionedUsers.length) >= maxUserMentionCount) {
98
+ setAbleMention(false);
99
+ } else {
100
+ setAbleMention(true);
101
+ }
102
+ }, [mentionedUsers]);
103
+ React.useEffect(function () {
104
+ setMentionedUsers(mentionedUsers.filter(function (_a) {
105
+ var userId = _a.userId;
106
+ var i = mentionedUserIds.indexOf(userId);
107
+
108
+ if (i < 0) {
109
+ return false;
110
+ } else {
111
+ mentionedUserIds.splice(i, 1);
112
+ return true;
113
+ }
114
+ }));
115
+ }, [mentionedUserIds]); // broadcast channel + not operator
116
+
117
+ if (isBroadcast && !isOperator) {
118
+ return null;
119
+ } // other conditions
120
+
121
+
122
+ return /*#__PURE__*/React__default["default"].createElement("div", {
123
+ className: "sendbird-message-input-wrapper"
124
+ }, displaySuggestedMentionList && /*#__PURE__*/React__default["default"].createElement(Channel_components_SuggestedMentionList, {
125
+ targetNickname: mentionNickname,
126
+ inputEvent: messageInputEvent,
127
+ renderUserMentionItem: renderUserMentionItem,
128
+ onUserItemClick: function onUserItemClick(user) {
129
+ if (user) {
130
+ setMentionedUsers(tslib_es6.__spreadArray(tslib_es6.__spreadArray([], mentionedUsers, true), [user], false));
131
+ }
132
+
133
+ setMentionNickname('');
134
+ setSelectedUser(user);
135
+ setMessageInputEvent(null);
136
+ },
137
+ onFocusItemChange: function onFocusItemChange() {
138
+ setMessageInputEvent(null);
139
+ },
140
+ onFetchUsers: function onFetchUsers(users) {
141
+ setMentionSuggestedUsers(users);
142
+ },
143
+ ableAddMention: ableMention,
144
+ maxMentionCount: maxUserMentionCount,
145
+ maxSuggestionCount: maxUserSuggestionCount
146
+ }), quoteMessage && /*#__PURE__*/React__default["default"].createElement("div", {
147
+ className: "sendbird-message-input-wrapper__quote-message-input"
148
+ }, /*#__PURE__*/React__default["default"].createElement(ui_QuoteMessageInput, {
149
+ replyingMessage: quoteMessage,
150
+ onClose: function onClose() {
151
+ return setQuoteMessage(null);
152
+ }
153
+ })), /*#__PURE__*/React__default["default"].createElement(ui_MessageInput, {
154
+ className: "sendbird-message-input-wrapper__message-input",
155
+ channelUrl: channel === null || channel === void 0 ? void 0 : channel.url,
156
+ mentionSelectedUser: selectedUser,
157
+ isMentionEnabled: isMentionEnabled,
158
+ placeholder: quoteMessage && stringSet.MESSAGE_INPUT__QUOTE_REPLY__PLACE_HOLDER || Channel_context.isDisabledBecauseFrozen(channel) && stringSet.MESSAGE_INPUT__PLACE_HOLDER__DISABLED || Channel_context.isDisabledBecauseMuted(channel) && stringSet.MESSAGE_INPUT__PLACE_HOLDER__MUTED,
159
+ ref: messageInputRef,
160
+ disabled: disabled,
161
+ onStartTyping: function onStartTyping() {
162
+ channel === null || channel === void 0 ? void 0 : channel.startTyping();
163
+ },
164
+ onSendMessage: function onSendMessage(_a) {
165
+ var message = _a.message,
166
+ mentionTemplate = _a.mentionTemplate;
167
+ sendMessage({
168
+ message: message,
169
+ quoteMessage: quoteMessage,
170
+ mentionedUsers: mentionedUsers,
171
+ mentionTemplate: mentionTemplate
172
+ });
173
+ setMentionNickname('');
174
+ setMentionedUsers([]);
175
+ setQuoteMessage(null);
176
+ channel === null || channel === void 0 ? void 0 : channel.endTyping();
177
+ },
178
+ onFileUpload: function onFileUpload(file) {
179
+ sendFileMessage(file, quoteMessage);
180
+ setQuoteMessage(null);
181
+ },
182
+ onUserMentioned: function onUserMentioned(user) {
183
+ if ((selectedUser === null || selectedUser === void 0 ? void 0 : selectedUser.userId) === (user === null || user === void 0 ? void 0 : user.userId)) {
184
+ setSelectedUser(null);
185
+ setMentionNickname('');
186
+ }
187
+ },
188
+ onMentionStringChange: function onMentionStringChange(mentionText) {
189
+ setMentionNickname(mentionText);
190
+ },
191
+ onMentionedUserIdsUpdated: function onMentionedUserIdsUpdated(userIds) {
192
+ setMentionedUserIds(userIds);
193
+ },
194
+ onKeyDown: function onKeyDown(e) {
195
+ if (displaySuggestedMentionList && (mentionSuggestedUsers === null || mentionSuggestedUsers === void 0 ? void 0 : mentionSuggestedUsers.length) > 0 && (e.key === _const.MessageInputKeys.Enter && ableMention || e.key === _const.MessageInputKeys.ArrowUp || e.key === _const.MessageInputKeys.ArrowDown)) {
196
+ setMessageInputEvent(e);
197
+ return true;
198
+ }
199
+
200
+ return false;
201
+ }
202
+ }));
203
+ };
204
+
205
+ var MessageInputWrapper$1 = /*#__PURE__*/React__default["default"].forwardRef(MessageInputWrapper);
206
+
207
+ module.exports = MessageInputWrapper$1;
208
+ //# sourceMappingURL=MessageInput.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MessageInput.js","sources":["../../../../src/smart-components/Channel/components/MessageInput/index.tsx"],"sourcesContent":["import React, { useState, useContext, useEffect } from 'react';\n\nimport './message-input.scss';\nimport * as utils from '../../context/utils';\n\nimport MessageInput from '../../../../ui/MessageInput';\nimport QuoteMessageInput from '../../../../ui/QuoteMessageInput';\nimport { LocalizationContext } from '../../../../lib/LocalizationContext';\nimport { useChannel } from '../../context/ChannelProvider';\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport SuggestedMentionList from '../SuggestedMentionList';\nimport { MessageInputKeys } from '../../../../ui/MessageInput/const';\n\nconst MessageInputWrapper = (): JSX.Element => {\n const {\n currentGroupChannel,\n initialized,\n quoteMessage,\n sendMessage,\n sendFileMessage,\n setQuoteMessage,\n messageInputRef,\n renderUserMentionItem,\n } = useChannel();\n const globalStore = useSendbirdStateContext();\n const channel = currentGroupChannel;\n\n const { isOnline, isMentionEnabled, userMention } = globalStore?.config;\n const maxUserMentionCount = userMention?.maxMentionCount || 10;\n const maxUserSuggestionCount = userMention?.maxSuggestionCount || 15;\n\n const { stringSet } = useContext(LocalizationContext);\n const [mentionNickname, setMentionNickname] = useState('');\n const [mentionedUsers, setMentionedUsers] = useState([]);\n const [mentionedUserIds, setMentionedUserIds] = useState([]);\n const [selectedUser, setSelectedUser] = useState(null);\n const [mentionSuggestedUsers, setMentionSuggestedUsers] = useState([]);\n const [ableMention, setAbleMention] = useState(true);\n const [messageInputEvent, setMessageInputEvent] = useState(null);\n const disabled = !initialized\n || utils.isDisabledBecauseFrozen(channel)\n || utils.isDisabledBecauseMuted(channel)\n || !isOnline;\n const isOperator = utils.isOperator(channel);\n const { isBroadcast } = channel;\n\n const displaySuggestedMentionList = (isMentionEnabled && mentionNickname.length > 0);\n\n useEffect(() => {\n if (mentionedUsers?.length >= maxUserMentionCount) {\n setAbleMention(false);\n } else {\n setAbleMention(true);\n }\n }, [mentionedUsers]);\n\n useEffect(() => {\n setMentionedUsers(mentionedUsers.filter(({ userId }) => {\n const i = mentionedUserIds.indexOf(userId);\n if (i < 0) {\n return false;\n } else {\n mentionedUserIds.splice(i, 1);\n return true;\n }\n }));\n }, [mentionedUserIds]);\n\n // broadcast channel + not operator\n if (isBroadcast && !isOperator) {\n return null;\n }\n // other conditions\n return (\n <div className=\"sendbird-message-input-wrapper\">\n {\n displaySuggestedMentionList && (\n <SuggestedMentionList\n targetNickname={mentionNickname}\n inputEvent={messageInputEvent}\n renderUserMentionItem={renderUserMentionItem}\n onUserItemClick={(user) => {\n if (user) {\n setMentionedUsers([...mentionedUsers, user]);\n }\n setMentionNickname('');\n setSelectedUser(user);\n setMessageInputEvent(null);\n }}\n onFocusItemChange={() => {\n setMessageInputEvent(null);\n }}\n onFetchUsers={(users) => {\n setMentionSuggestedUsers(users);\n }}\n ableAddMention={ableMention}\n maxMentionCount={maxUserMentionCount}\n maxSuggestionCount={maxUserSuggestionCount}\n />\n )\n }\n {quoteMessage && (\n <div className=\"sendbird-message-input-wrapper__quote-message-input\">\n <QuoteMessageInput\n replyingMessage={quoteMessage}\n onClose={() => setQuoteMessage(null)}\n />\n </div>\n )}\n <MessageInput\n className=\"sendbird-message-input-wrapper__message-input\"\n channelUrl={channel?.url}\n mentionSelectedUser={selectedUser}\n isMentionEnabled={isMentionEnabled}\n placeholder={\n (quoteMessage && stringSet.MESSAGE_INPUT__QUOTE_REPLY__PLACE_HOLDER)\n || (utils.isDisabledBecauseFrozen(channel) && stringSet.MESSAGE_INPUT__PLACE_HOLDER__DISABLED)\n || (utils.isDisabledBecauseMuted(channel) && stringSet.MESSAGE_INPUT__PLACE_HOLDER__MUTED)\n }\n ref={messageInputRef}\n disabled={disabled}\n onStartTyping={() => {\n channel?.startTyping();\n }}\n onSendMessage={({ message, mentionTemplate }) => {\n sendMessage({\n message,\n quoteMessage,\n mentionedUsers,\n mentionTemplate,\n });\n setMentionNickname('');\n setMentionedUsers([]);\n setQuoteMessage(null);\n channel?.endTyping();\n }}\n onFileUpload={(file) => {\n sendFileMessage(file, quoteMessage);\n setQuoteMessage(null);\n }}\n onUserMentioned={(user) => {\n if (selectedUser?.userId === user?.userId) {\n setSelectedUser(null);\n setMentionNickname('');\n }\n }}\n onMentionStringChange={(mentionText) => {\n setMentionNickname(mentionText);\n }}\n onMentionedUserIdsUpdated={(userIds) => {\n setMentionedUserIds(userIds);\n }}\n onKeyDown={(e) => {\n if (displaySuggestedMentionList && mentionSuggestedUsers?.length > 0\n && ((e.key === MessageInputKeys.Enter && ableMention) || e.key === MessageInputKeys.ArrowUp || e.key === MessageInputKeys.ArrowDown)\n ) {\n setMessageInputEvent(e);\n return true;\n }\n return false;\n }}\n />\n </div>\n );\n}\n\nexport default React.forwardRef(MessageInputWrapper);\n"],"names":["MessageInputWrapper","_a","useChannel","currentGroupChannel","initialized","quoteMessage","sendMessage","sendFileMessage","setQuoteMessage","messageInputRef","renderUserMentionItem","globalStore","useSendbirdStateContext","channel","_b","config","isOnline","isMentionEnabled","userMention","maxUserMentionCount","maxMentionCount","maxUserSuggestionCount","maxSuggestionCount","stringSet","useContext","LocalizationContext","_c","useState","mentionNickname","setMentionNickname","_d","mentionedUsers","setMentionedUsers","_e","mentionedUserIds","setMentionedUserIds","_f","selectedUser","setSelectedUser","_g","mentionSuggestedUsers","setMentionSuggestedUsers","_h","ableMention","setAbleMention","_j","messageInputEvent","setMessageInputEvent","disabled","utils","isOperator","isBroadcast","displaySuggestedMentionList","length","useEffect","filter","userId","i","indexOf","splice","React","SuggestedMentionList","user","users","QuoteMessageInput","MessageInput","url","MESSAGE_INPUT__QUOTE_REPLY__PLACE_HOLDER","MESSAGE_INPUT__PLACE_HOLDER__DISABLED","MESSAGE_INPUT__PLACE_HOLDER__MUTED","startTyping","message","mentionTemplate","endTyping","file","mentionText","userIds","e","key","MessageInputKeys","Enter","ArrowUp","ArrowDown","forwardRef"],"mappings":"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"}