@sendbird/uikit-react 3.0.0-alpha.1 → 3.0.0-alpha.2

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 (585) hide show
  1. package/App.js +294 -0
  2. package/App.js.map +1 -0
  3. package/Channel/components/ChannelHeader.js +116 -0
  4. package/Channel/components/ChannelHeader.js.map +1 -0
  5. package/Channel/components/ChannelUI.js +172 -0
  6. package/Channel/components/ChannelUI.js.map +1 -0
  7. package/Channel/components/FileViewer.js +150 -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 +232 -0
  12. package/Channel/components/Message.js.map +1 -0
  13. package/Channel/components/MessageInput.js +87 -0
  14. package/Channel/components/MessageInput.js.map +1 -0
  15. package/Channel/components/MessageList.js +227 -0
  16. package/Channel/components/MessageList.js.map +1 -0
  17. package/Channel/components/RemoveMessageModal.js +52 -0
  18. package/Channel/components/RemoveMessageModal.js.map +1 -0
  19. package/Channel/components/TypingIndicator.js +97 -0
  20. package/Channel/components/TypingIndicator.js.map +1 -0
  21. package/Channel/components/UnreadCount.js +41 -0
  22. package/Channel/components/UnreadCount.js.map +1 -0
  23. package/Channel/context.js +23 -0
  24. package/Channel/context.js.map +1 -0
  25. package/Channel.js +99 -0
  26. package/Channel.js.map +1 -0
  27. package/ChannelList/components/AddChannel.js +70 -0
  28. package/ChannelList/components/AddChannel.js.map +1 -0
  29. package/ChannelList/components/ChannelListHeader.js +62 -0
  30. package/ChannelList/components/ChannelListHeader.js.map +1 -0
  31. package/ChannelList/components/ChannelListUI.js +213 -0
  32. package/ChannelList/components/ChannelListUI.js.map +1 -0
  33. package/ChannelList/components/ChannelPreview.js +177 -0
  34. package/ChannelList/components/ChannelPreview.js.map +1 -0
  35. package/ChannelList/components/ChannelPreviewAction.js +131 -0
  36. package/ChannelList/components/ChannelPreviewAction.js.map +1 -0
  37. package/ChannelList/context.js +13 -0
  38. package/ChannelList/context.js.map +1 -0
  39. package/ChannelList.js +80 -0
  40. package/ChannelList.js.map +1 -0
  41. package/ChannelListProvider-0b0c2c40.js +861 -0
  42. package/ChannelListProvider-0b0c2c40.js.map +1 -0
  43. package/ChannelProvider-459e463f.js +2083 -0
  44. package/ChannelProvider-459e463f.js.map +1 -0
  45. package/ChannelSettings/components/AdminPanel.js +905 -0
  46. package/ChannelSettings/components/AdminPanel.js.map +1 -0
  47. package/ChannelSettings/components/ChannelProfile.js +102 -0
  48. package/ChannelSettings/components/ChannelProfile.js.map +1 -0
  49. package/ChannelSettings/components/ChannelSettingsUI.js +152 -0
  50. package/ChannelSettings/components/ChannelSettingsUI.js.map +1 -0
  51. package/ChannelSettings/components/EditDetailsModal.js +154 -0
  52. package/ChannelSettings/components/EditDetailsModal.js.map +1 -0
  53. package/ChannelSettings/components/LeaveChannel.js +53 -0
  54. package/ChannelSettings/components/LeaveChannel.js.map +1 -0
  55. package/ChannelSettings/components/UserListItem.js +105 -0
  56. package/ChannelSettings/components/UserListItem.js.map +1 -0
  57. package/ChannelSettings/components/UserPanel.js +79 -0
  58. package/ChannelSettings/components/UserPanel.js.map +1 -0
  59. package/ChannelSettings/context.js +93 -0
  60. package/ChannelSettings/context.js.map +1 -0
  61. package/ChannelSettings.js +71 -0
  62. package/ChannelSettings.js.map +1 -0
  63. package/CreateChannel/components/CreateChannelUI.js +53 -0
  64. package/CreateChannel/components/CreateChannelUI.js.map +1 -0
  65. package/CreateChannel/components/InviteMembers.js +184 -0
  66. package/CreateChannel/components/InviteMembers.js.map +1 -0
  67. package/CreateChannel/components/SelectChannelType.js +131 -0
  68. package/CreateChannel/components/SelectChannelType.js.map +1 -0
  69. package/CreateChannel/context.js +8 -0
  70. package/CreateChannel/context.js.map +1 -0
  71. package/CreateChannel.js +53 -0
  72. package/CreateChannel.js.map +1 -0
  73. package/CreateChannelProvider-c617a1bb.js +53 -0
  74. package/CreateChannelProvider-c617a1bb.js.map +1 -0
  75. package/EditUserProfile/components/EditUserProfileUI.js +26 -0
  76. package/EditUserProfile/components/EditUserProfileUI.js.map +1 -0
  77. package/EditUserProfile/context.js +27 -0
  78. package/EditUserProfile/context.js.map +1 -0
  79. package/EditUserProfile.js +39 -0
  80. package/EditUserProfile.js.map +1 -0
  81. package/LocalizationContext-e4391013.js +22 -0
  82. package/LocalizationContext-e4391013.js.map +1 -0
  83. package/MemberList-6655cba0.js +425 -0
  84. package/MemberList-6655cba0.js.map +1 -0
  85. package/MessageSearch/components/MessageSearchUI.js +151 -0
  86. package/MessageSearch/components/MessageSearchUI.js.map +1 -0
  87. package/MessageSearch/context.js +392 -0
  88. package/MessageSearch/context.js.map +1 -0
  89. package/MessageSearch.js +146 -0
  90. package/MessageSearch.js.map +1 -0
  91. package/OpenChannel/components/FrozenChannelNotification.js +20 -0
  92. package/OpenChannel/components/FrozenChannelNotification.js.map +1 -0
  93. package/OpenChannel/components/OpenChannelHeader.js +78 -0
  94. package/OpenChannel/components/OpenChannelHeader.js.map +1 -0
  95. package/OpenChannel/components/OpenChannelInput.js +52 -0
  96. package/OpenChannel/components/OpenChannelInput.js.map +1 -0
  97. package/OpenChannel/components/OpenChannelMessage.js +278 -0
  98. package/OpenChannel/components/OpenChannelMessage.js.map +1 -0
  99. package/OpenChannel/components/OpenChannelMessageList.js +153 -0
  100. package/OpenChannel/components/OpenChannelMessageList.js.map +1 -0
  101. package/OpenChannel/components/OpenChannelUI.js +105 -0
  102. package/OpenChannel/components/OpenChannelUI.js.map +1 -0
  103. package/OpenChannel/context.js +14 -0
  104. package/OpenChannel/context.js.map +1 -0
  105. package/OpenChannel.js +76 -0
  106. package/OpenChannel.js.map +1 -0
  107. package/OpenChannelProvider-a7691eb4.js +2011 -0
  108. package/OpenChannelProvider-a7691eb4.js.map +1 -0
  109. package/OpenChannelSettings/components/EditDetailsModal.js +149 -0
  110. package/OpenChannelSettings/components/EditDetailsModal.js.map +1 -0
  111. package/OpenChannelSettings/components/OpenChannelProfile.js +81 -0
  112. package/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -0
  113. package/OpenChannelSettings/components/OpenChannelSettingsUI.js +104 -0
  114. package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -0
  115. package/OpenChannelSettings/components/OperatorUI.js +184 -0
  116. package/OpenChannelSettings/components/OperatorUI.js.map +1 -0
  117. package/OpenChannelSettings/components/ParticipantUI.js +172 -0
  118. package/OpenChannelSettings/components/ParticipantUI.js.map +1 -0
  119. package/OpenChannelSettings/context.js +64 -0
  120. package/OpenChannelSettings/context.js.map +1 -0
  121. package/OpenChannelSettings.js +64 -0
  122. package/OpenChannelSettings.js.map +1 -0
  123. package/SendbirdProvider.js +740 -0
  124. package/SendbirdProvider.js.map +1 -0
  125. package/UserProfileContext-865db5e6.js +38 -0
  126. package/UserProfileContext-865db5e6.js.map +1 -0
  127. package/_rollupPluginBabelHelpers-20904f21.js +233 -0
  128. package/_rollupPluginBabelHelpers-20904f21.js.map +1 -0
  129. package/actionTypes-1e3a4074.js +6 -0
  130. package/actionTypes-1e3a4074.js.map +1 -0
  131. package/cjs/App.js +301 -0
  132. package/cjs/App.js.map +1 -0
  133. package/cjs/Channel/components/ChannelHeader.js +122 -0
  134. package/cjs/Channel/components/ChannelHeader.js.map +1 -0
  135. package/cjs/Channel/components/ChannelUI.js +178 -0
  136. package/cjs/Channel/components/ChannelUI.js.map +1 -0
  137. package/cjs/Channel/components/FileViewer.js +159 -0
  138. package/cjs/Channel/components/FileViewer.js.map +1 -0
  139. package/cjs/Channel/components/FrozenNotification.js +26 -0
  140. package/cjs/Channel/components/FrozenNotification.js.map +1 -0
  141. package/cjs/Channel/components/Message.js +238 -0
  142. package/cjs/Channel/components/Message.js.map +1 -0
  143. package/cjs/Channel/components/MessageInput.js +93 -0
  144. package/cjs/Channel/components/MessageInput.js.map +1 -0
  145. package/cjs/Channel/components/MessageList.js +233 -0
  146. package/cjs/Channel/components/MessageList.js.map +1 -0
  147. package/cjs/Channel/components/RemoveMessageModal.js +58 -0
  148. package/cjs/Channel/components/RemoveMessageModal.js.map +1 -0
  149. package/cjs/Channel/components/TypingIndicator.js +103 -0
  150. package/cjs/Channel/components/TypingIndicator.js.map +1 -0
  151. package/cjs/Channel/components/UnreadCount.js +47 -0
  152. package/cjs/Channel/components/UnreadCount.js.map +1 -0
  153. package/cjs/Channel/context.js +32 -0
  154. package/cjs/Channel/context.js.map +1 -0
  155. package/cjs/Channel.js +105 -0
  156. package/cjs/Channel.js.map +1 -0
  157. package/cjs/ChannelList/components/AddChannel.js +79 -0
  158. package/cjs/ChannelList/components/AddChannel.js.map +1 -0
  159. package/cjs/ChannelList/components/ChannelListHeader.js +68 -0
  160. package/cjs/ChannelList/components/ChannelListHeader.js.map +1 -0
  161. package/cjs/ChannelList/components/ChannelListUI.js +219 -0
  162. package/cjs/ChannelList/components/ChannelListUI.js.map +1 -0
  163. package/cjs/ChannelList/components/ChannelPreview.js +183 -0
  164. package/cjs/ChannelList/components/ChannelPreview.js.map +1 -0
  165. package/cjs/ChannelList/components/ChannelPreviewAction.js +138 -0
  166. package/cjs/ChannelList/components/ChannelPreviewAction.js.map +1 -0
  167. package/cjs/ChannelList/context.js +22 -0
  168. package/cjs/ChannelList/context.js.map +1 -0
  169. package/cjs/ChannelList.js +86 -0
  170. package/cjs/ChannelList.js.map +1 -0
  171. package/cjs/ChannelListProvider-5a152618.js +873 -0
  172. package/cjs/ChannelListProvider-5a152618.js.map +1 -0
  173. package/cjs/ChannelProvider-f1fb0108.js +2096 -0
  174. package/cjs/ChannelProvider-f1fb0108.js.map +1 -0
  175. package/cjs/ChannelSettings/components/AdminPanel.js +911 -0
  176. package/cjs/ChannelSettings/components/AdminPanel.js.map +1 -0
  177. package/cjs/ChannelSettings/components/ChannelProfile.js +108 -0
  178. package/cjs/ChannelSettings/components/ChannelProfile.js.map +1 -0
  179. package/cjs/ChannelSettings/components/ChannelSettingsUI.js +158 -0
  180. package/cjs/ChannelSettings/components/ChannelSettingsUI.js.map +1 -0
  181. package/cjs/ChannelSettings/components/EditDetailsModal.js +160 -0
  182. package/cjs/ChannelSettings/components/EditDetailsModal.js.map +1 -0
  183. package/cjs/ChannelSettings/components/LeaveChannel.js +59 -0
  184. package/cjs/ChannelSettings/components/LeaveChannel.js.map +1 -0
  185. package/cjs/ChannelSettings/components/UserListItem.js +111 -0
  186. package/cjs/ChannelSettings/components/UserListItem.js.map +1 -0
  187. package/cjs/ChannelSettings/components/UserPanel.js +85 -0
  188. package/cjs/ChannelSettings/components/UserPanel.js.map +1 -0
  189. package/cjs/ChannelSettings/context.js +102 -0
  190. package/cjs/ChannelSettings/context.js.map +1 -0
  191. package/cjs/ChannelSettings.js +77 -0
  192. package/cjs/ChannelSettings.js.map +1 -0
  193. package/cjs/CreateChannel/components/CreateChannelUI.js +59 -0
  194. package/cjs/CreateChannel/components/CreateChannelUI.js.map +1 -0
  195. package/cjs/CreateChannel/components/InviteMembers.js +190 -0
  196. package/cjs/CreateChannel/components/InviteMembers.js.map +1 -0
  197. package/cjs/CreateChannel/components/SelectChannelType.js +137 -0
  198. package/cjs/CreateChannel/components/SelectChannelType.js.map +1 -0
  199. package/cjs/CreateChannel/context.js +17 -0
  200. package/cjs/CreateChannel/context.js.map +1 -0
  201. package/cjs/CreateChannel.js +59 -0
  202. package/cjs/CreateChannel.js.map +1 -0
  203. package/cjs/CreateChannelProvider-df42106f.js +60 -0
  204. package/cjs/CreateChannelProvider-df42106f.js.map +1 -0
  205. package/cjs/EditUserProfile/components/EditUserProfileUI.js +32 -0
  206. package/cjs/EditUserProfile/components/EditUserProfileUI.js.map +1 -0
  207. package/cjs/EditUserProfile/context.js +36 -0
  208. package/cjs/EditUserProfile/context.js.map +1 -0
  209. package/cjs/EditUserProfile.js +45 -0
  210. package/cjs/EditUserProfile.js.map +1 -0
  211. package/cjs/LocalizationContext-68e55e2a.js +30 -0
  212. package/cjs/LocalizationContext-68e55e2a.js.map +1 -0
  213. package/cjs/MemberList-dc84e303.js +431 -0
  214. package/cjs/MemberList-dc84e303.js.map +1 -0
  215. package/cjs/MessageSearch/components/MessageSearchUI.js +160 -0
  216. package/cjs/MessageSearch/components/MessageSearchUI.js.map +1 -0
  217. package/cjs/MessageSearch/context.js +401 -0
  218. package/cjs/MessageSearch/context.js.map +1 -0
  219. package/cjs/MessageSearch.js +152 -0
  220. package/cjs/MessageSearch.js.map +1 -0
  221. package/cjs/OpenChannel/components/FrozenChannelNotification.js +26 -0
  222. package/cjs/OpenChannel/components/FrozenChannelNotification.js.map +1 -0
  223. package/cjs/OpenChannel/components/OpenChannelHeader.js +84 -0
  224. package/cjs/OpenChannel/components/OpenChannelHeader.js.map +1 -0
  225. package/cjs/OpenChannel/components/OpenChannelInput.js +58 -0
  226. package/cjs/OpenChannel/components/OpenChannelInput.js.map +1 -0
  227. package/cjs/OpenChannel/components/OpenChannelMessage.js +284 -0
  228. package/cjs/OpenChannel/components/OpenChannelMessage.js.map +1 -0
  229. package/cjs/OpenChannel/components/OpenChannelMessageList.js +159 -0
  230. package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -0
  231. package/cjs/OpenChannel/components/OpenChannelUI.js +111 -0
  232. package/cjs/OpenChannel/components/OpenChannelUI.js.map +1 -0
  233. package/cjs/OpenChannel/context.js +23 -0
  234. package/cjs/OpenChannel/context.js.map +1 -0
  235. package/cjs/OpenChannel.js +82 -0
  236. package/cjs/OpenChannel.js.map +1 -0
  237. package/cjs/OpenChannelProvider-7a1a996f.js +2020 -0
  238. package/cjs/OpenChannelProvider-7a1a996f.js.map +1 -0
  239. package/cjs/OpenChannelSettings/components/EditDetailsModal.js +155 -0
  240. package/cjs/OpenChannelSettings/components/EditDetailsModal.js.map +1 -0
  241. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js +87 -0
  242. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -0
  243. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js +110 -0
  244. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -0
  245. package/cjs/OpenChannelSettings/components/OperatorUI.js +194 -0
  246. package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -0
  247. package/cjs/OpenChannelSettings/components/ParticipantUI.js +178 -0
  248. package/cjs/OpenChannelSettings/components/ParticipantUI.js.map +1 -0
  249. package/cjs/OpenChannelSettings/context.js +73 -0
  250. package/cjs/OpenChannelSettings/context.js.map +1 -0
  251. package/cjs/OpenChannelSettings.js +70 -0
  252. package/cjs/OpenChannelSettings.js.map +1 -0
  253. package/cjs/SendbirdProvider.js +749 -0
  254. package/cjs/SendbirdProvider.js.map +1 -0
  255. package/cjs/UserProfileContext-3533547d.js +46 -0
  256. package/cjs/UserProfileContext-3533547d.js.map +1 -0
  257. package/cjs/_rollupPluginBabelHelpers-fc14118c.js +243 -0
  258. package/cjs/_rollupPluginBabelHelpers-fc14118c.js.map +1 -0
  259. package/cjs/actionTypes-bc47f97a.js +10 -0
  260. package/cjs/actionTypes-bc47f97a.js.map +1 -0
  261. package/cjs/color-4afb15fb.js +42 -0
  262. package/cjs/color-4afb15fb.js.map +1 -0
  263. package/cjs/compareIds-01306377.js +20 -0
  264. package/cjs/compareIds-01306377.js.map +1 -0
  265. package/cjs/context-c1f9d650.js +19 -0
  266. package/cjs/context-c1f9d650.js.map +1 -0
  267. package/cjs/index-1044f1ed.js +97 -0
  268. package/cjs/index-1044f1ed.js.map +1 -0
  269. package/cjs/index-1468d245.js +142 -0
  270. package/cjs/index-1468d245.js.map +1 -0
  271. package/cjs/index-4987c8b2.js +175 -0
  272. package/cjs/index-4987c8b2.js.map +1 -0
  273. package/cjs/index-659c9ca5.js +130 -0
  274. package/cjs/index-659c9ca5.js.map +1 -0
  275. package/cjs/index-8becccd8.js +284 -0
  276. package/cjs/index-8becccd8.js.map +1 -0
  277. package/cjs/index-905331fa.js +1880 -0
  278. package/cjs/index-905331fa.js.map +1 -0
  279. package/cjs/index-9dc3863f.js +67 -0
  280. package/cjs/index-9dc3863f.js.map +1 -0
  281. package/cjs/index-aecc8d24.js +9 -0
  282. package/cjs/index-aecc8d24.js.map +1 -0
  283. package/cjs/index-d4880236.js +641 -0
  284. package/cjs/index-d4880236.js.map +1 -0
  285. package/cjs/index-e2bb862c.js +514 -0
  286. package/cjs/index-e2bb862c.js.map +1 -0
  287. package/cjs/index.css +4355 -0
  288. package/cjs/index.css.map +1 -0
  289. package/cjs/index.js +155 -0
  290. package/cjs/index.js.map +1 -0
  291. package/cjs/openChannelUtils-37919a36.js +92 -0
  292. package/cjs/openChannelUtils-37919a36.js.map +1 -0
  293. package/cjs/sendBirdSelectors.js +741 -0
  294. package/cjs/sendBirdSelectors.js.map +1 -0
  295. package/cjs/stringSet-aa544ce5.js +116 -0
  296. package/cjs/stringSet-aa544ce5.js.map +1 -0
  297. package/cjs/topics-8314d425.js +18 -0
  298. package/cjs/topics-8314d425.js.map +1 -0
  299. package/cjs/tslib.es6-4a281a05.js +40 -0
  300. package/cjs/tslib.es6-4a281a05.js.map +1 -0
  301. package/cjs/ui/Accordion.js +74 -0
  302. package/cjs/ui/Accordion.js.map +1 -0
  303. package/cjs/ui/AccordionGroup.js +32 -0
  304. package/cjs/ui/AccordionGroup.js.map +1 -0
  305. package/cjs/ui/AdminMessage.js +44 -0
  306. package/cjs/ui/AdminMessage.js.map +1 -0
  307. package/cjs/ui/Avatar.js +226 -0
  308. package/cjs/ui/Avatar.js.map +1 -0
  309. package/cjs/ui/Badge.js +45 -0
  310. package/cjs/ui/Badge.js.map +1 -0
  311. package/cjs/ui/Button.js +17 -0
  312. package/cjs/ui/Button.js.map +1 -0
  313. package/cjs/ui/ChannelAvatar.js +59 -0
  314. package/cjs/ui/ChannelAvatar.js.map +1 -0
  315. package/cjs/ui/ChannelPreview.js +201 -0
  316. package/cjs/ui/ChannelPreview.js.map +1 -0
  317. package/cjs/ui/ChatHeader.js +145 -0
  318. package/cjs/ui/ChatHeader.js.map +1 -0
  319. package/cjs/ui/Checkbox.js +49 -0
  320. package/cjs/ui/Checkbox.js.map +1 -0
  321. package/cjs/ui/ConnectionStatus.js +34 -0
  322. package/cjs/ui/ConnectionStatus.js.map +1 -0
  323. package/cjs/ui/ContextMenu.js +431 -0
  324. package/cjs/ui/ContextMenu.js.map +1 -0
  325. package/cjs/ui/DateSeparator.js +44 -0
  326. package/cjs/ui/DateSeparator.js.map +1 -0
  327. package/cjs/ui/Dropdown.js +107 -0
  328. package/cjs/ui/Dropdown.js.map +1 -0
  329. package/cjs/ui/EmojiReactions.js +127 -0
  330. package/cjs/ui/EmojiReactions.js.map +1 -0
  331. package/cjs/ui/FileMessageItemBody.js +57 -0
  332. package/cjs/ui/FileMessageItemBody.js.map +1 -0
  333. package/cjs/ui/FileViewer.js +174 -0
  334. package/cjs/ui/FileViewer.js.map +1 -0
  335. package/cjs/ui/Icon.js +1462 -0
  336. package/cjs/ui/Icon.js.map +1 -0
  337. package/cjs/ui/IconButton.js +83 -0
  338. package/cjs/ui/IconButton.js.map +1 -0
  339. package/cjs/ui/ImageRenderer.js +138 -0
  340. package/cjs/ui/ImageRenderer.js.map +1 -0
  341. package/cjs/ui/Input.js +74 -0
  342. package/cjs/ui/Input.js.map +1 -0
  343. package/cjs/ui/Label.js +17 -0
  344. package/cjs/ui/Label.js.map +1 -0
  345. package/cjs/ui/LinkLabel.js +51 -0
  346. package/cjs/ui/LinkLabel.js.map +1 -0
  347. package/cjs/ui/Loader.js +44 -0
  348. package/cjs/ui/Loader.js.map +1 -0
  349. package/cjs/ui/MessageContent.js +328 -0
  350. package/cjs/ui/MessageContent.js.map +1 -0
  351. package/cjs/ui/MessageInput.js +232 -0
  352. package/cjs/ui/MessageInput.js.map +1 -0
  353. package/cjs/ui/MessageItemMenu.js +141 -0
  354. package/cjs/ui/MessageItemMenu.js.map +1 -0
  355. package/cjs/ui/MessageItemReactionMenu.js +112 -0
  356. package/cjs/ui/MessageItemReactionMenu.js.map +1 -0
  357. package/cjs/ui/MessageSearchFileItem.js +130 -0
  358. package/cjs/ui/MessageSearchFileItem.js.map +1 -0
  359. package/cjs/ui/MessageSearchItem.js +93 -0
  360. package/cjs/ui/MessageSearchItem.js.map +1 -0
  361. package/cjs/ui/Modal.js +140 -0
  362. package/cjs/ui/Modal.js.map +1 -0
  363. package/cjs/ui/MutedAvatarOverlay.js +40 -0
  364. package/cjs/ui/MutedAvatarOverlay.js.map +1 -0
  365. package/cjs/ui/OGMessageItemBody.js +97 -0
  366. package/cjs/ui/OGMessageItemBody.js.map +1 -0
  367. package/cjs/ui/OpenChannelAdminMessage.js +27 -0
  368. package/cjs/ui/OpenChannelAdminMessage.js.map +1 -0
  369. package/cjs/ui/OpenChannelAvatar.js +41 -0
  370. package/cjs/ui/OpenChannelAvatar.js.map +1 -0
  371. package/cjs/ui/OpenChannelMessageContent.js +14 -0
  372. package/cjs/ui/OpenChannelMessageContent.js.map +1 -0
  373. package/cjs/ui/OpenchannelConversationHeader.js +73 -0
  374. package/cjs/ui/OpenchannelConversationHeader.js.map +1 -0
  375. package/cjs/ui/OpenchannelFileMessage.js +230 -0
  376. package/cjs/ui/OpenchannelFileMessage.js.map +1 -0
  377. package/cjs/ui/OpenchannelOGMessage.js +345 -0
  378. package/cjs/ui/OpenchannelOGMessage.js.map +1 -0
  379. package/cjs/ui/OpenchannelThumbnailMessage.js +305 -0
  380. package/cjs/ui/OpenchannelThumbnailMessage.js.map +1 -0
  381. package/cjs/ui/OpenchannelUserMessage.js +264 -0
  382. package/cjs/ui/OpenchannelUserMessage.js.map +1 -0
  383. package/cjs/ui/PlaceHolder.js +20 -0
  384. package/cjs/ui/PlaceHolder.js.map +1 -0
  385. package/cjs/ui/QuoteMessage.js +131 -0
  386. package/cjs/ui/QuoteMessage.js.map +1 -0
  387. package/cjs/ui/QuoteMessageInput.js +99 -0
  388. package/cjs/ui/QuoteMessageInput.js.map +1 -0
  389. package/cjs/ui/ReactionBadge.js +68 -0
  390. package/cjs/ui/ReactionBadge.js.map +1 -0
  391. package/cjs/ui/ReactionButton.js +55 -0
  392. package/cjs/ui/ReactionButton.js.map +1 -0
  393. package/cjs/ui/SortByRow.js +57 -0
  394. package/cjs/ui/SortByRow.js.map +1 -0
  395. package/cjs/ui/TextButton.js +45 -0
  396. package/cjs/ui/TextButton.js.map +1 -0
  397. package/cjs/ui/TextMessageItemBody.js +40 -0
  398. package/cjs/ui/TextMessageItemBody.js.map +1 -0
  399. package/cjs/ui/ThumbnailMessageItemBody.js +82 -0
  400. package/cjs/ui/ThumbnailMessageItemBody.js.map +1 -0
  401. package/cjs/ui/Tooltip.js +35 -0
  402. package/cjs/ui/Tooltip.js.map +1 -0
  403. package/cjs/ui/TooltipWrapper.js +65 -0
  404. package/cjs/ui/TooltipWrapper.js.map +1 -0
  405. package/cjs/ui/UnknownMessageItemBody.js +41 -0
  406. package/cjs/ui/UnknownMessageItemBody.js.map +1 -0
  407. package/cjs/ui/UserListItem.js +158 -0
  408. package/cjs/ui/UserListItem.js.map +1 -0
  409. package/cjs/ui/UserProfile.js +87 -0
  410. package/cjs/ui/UserProfile.js.map +1 -0
  411. package/cjs/useSendbirdStateContext.js +22 -0
  412. package/cjs/useSendbirdStateContext.js.map +1 -0
  413. package/cjs/utils-3b0815dc.js +6 -0
  414. package/cjs/utils-3b0815dc.js.map +1 -0
  415. package/cjs/utils-66b3f4ec.js +38 -0
  416. package/cjs/utils-66b3f4ec.js.map +1 -0
  417. package/cjs/utils-cbd3ed99.js +32 -0
  418. package/cjs/utils-cbd3ed99.js.map +1 -0
  419. package/cjs/uuid-1d5ec8b2.js +19 -0
  420. package/cjs/uuid-1d5ec8b2.js.map +1 -0
  421. package/cjs/withSendBird.js +35 -0
  422. package/cjs/withSendBird.js.map +1 -0
  423. package/color-ee3fc5ee.js +39 -0
  424. package/color-ee3fc5ee.js.map +1 -0
  425. package/compareIds-808956f2.js +18 -0
  426. package/compareIds-808956f2.js.map +1 -0
  427. package/context-98ce535c.js +12 -0
  428. package/context-98ce535c.js.map +1 -0
  429. package/index-1718324d.js +280 -0
  430. package/index-1718324d.js.map +1 -0
  431. package/index-5c2c81bc.js +168 -0
  432. package/index-5c2c81bc.js.map +1 -0
  433. package/index-6ebf7894.js +512 -0
  434. package/index-6ebf7894.js.map +1 -0
  435. package/index-770d7112.js +1873 -0
  436. package/index-770d7112.js.map +1 -0
  437. package/index-7a51bd16.js +131 -0
  438. package/index-7a51bd16.js.map +1 -0
  439. package/index-8c72a94a.js +602 -0
  440. package/index-8c72a94a.js.map +1 -0
  441. package/index-942c85a6.js +7 -0
  442. package/index-942c85a6.js.map +1 -0
  443. package/index-acebc2ff.js +87 -0
  444. package/index-acebc2ff.js.map +1 -0
  445. package/index-cd21929d.js +64 -0
  446. package/index-cd21929d.js.map +1 -0
  447. package/index-e818a8a3.js +121 -0
  448. package/index-e818a8a3.js.map +1 -0
  449. package/index.css +4355 -0
  450. package/index.css.map +1 -0
  451. package/index.d.ts +1801 -0
  452. package/index.js.map +1 -0
  453. package/openChannelUtils-56a372e7.js +81 -0
  454. package/openChannelUtils-56a372e7.js.map +1 -0
  455. package/package.json +1 -8
  456. package/sendBirdSelectors.js +713 -0
  457. package/sendBirdSelectors.js.map +1 -0
  458. package/stringSet-4f6eaa60.js +114 -0
  459. package/stringSet-4f6eaa60.js.map +1 -0
  460. package/topics-9442035c.js +10 -0
  461. package/topics-9442035c.js.map +1 -0
  462. package/tslib.es6-e3c44017.js +38 -0
  463. package/tslib.es6-e3c44017.js.map +1 -0
  464. package/ui/Accordion.js +65 -0
  465. package/ui/Accordion.js.map +1 -0
  466. package/ui/AccordionGroup.js +26 -0
  467. package/ui/AccordionGroup.js.map +1 -0
  468. package/ui/AdminMessage.js +37 -0
  469. package/ui/AdminMessage.js.map +1 -0
  470. package/ui/Avatar.js +217 -0
  471. package/ui/Avatar.js.map +1 -0
  472. package/ui/Badge.js +38 -0
  473. package/ui/Badge.js.map +1 -0
  474. package/ui/Button.js +7 -0
  475. package/ui/Button.js.map +1 -0
  476. package/ui/ChannelAvatar.js +53 -0
  477. package/ui/ChannelAvatar.js.map +1 -0
  478. package/ui/ChannelPreview.js +194 -0
  479. package/ui/ChannelPreview.js.map +1 -0
  480. package/ui/ChatHeader.js +138 -0
  481. package/ui/ChatHeader.js.map +1 -0
  482. package/ui/Checkbox.js +42 -0
  483. package/ui/Checkbox.js.map +1 -0
  484. package/ui/ConnectionStatus.js +28 -0
  485. package/ui/ConnectionStatus.js.map +1 -0
  486. package/ui/ContextMenu.js +417 -0
  487. package/ui/ContextMenu.js.map +1 -0
  488. package/ui/DateSeparator.js +37 -0
  489. package/ui/DateSeparator.js.map +1 -0
  490. package/ui/Dropdown.js +97 -0
  491. package/ui/Dropdown.js.map +1 -0
  492. package/ui/EmojiReactions.js +121 -0
  493. package/ui/EmojiReactions.js.map +1 -0
  494. package/ui/FileMessageItemBody.js +51 -0
  495. package/ui/FileMessageItemBody.js.map +1 -0
  496. package/ui/FileViewer.js +164 -0
  497. package/ui/FileViewer.js.map +1 -0
  498. package/ui/Icon.js +1432 -0
  499. package/ui/Icon.js.map +1 -0
  500. package/ui/IconButton.js +76 -0
  501. package/ui/IconButton.js.map +1 -0
  502. package/ui/ImageRenderer.js +131 -0
  503. package/ui/ImageRenderer.js.map +1 -0
  504. package/ui/Input.js +64 -0
  505. package/ui/Input.js.map +1 -0
  506. package/ui/Label.js +6 -0
  507. package/ui/Label.js.map +1 -0
  508. package/ui/LinkLabel.js +40 -0
  509. package/ui/LinkLabel.js.map +1 -0
  510. package/ui/Loader.js +37 -0
  511. package/ui/Loader.js.map +1 -0
  512. package/ui/MessageContent.js +322 -0
  513. package/ui/MessageContent.js.map +1 -0
  514. package/ui/MessageInput.js +225 -0
  515. package/ui/MessageInput.js.map +1 -0
  516. package/ui/MessageItemMenu.js +135 -0
  517. package/ui/MessageItemMenu.js.map +1 -0
  518. package/ui/MessageItemReactionMenu.js +106 -0
  519. package/ui/MessageItemReactionMenu.js.map +1 -0
  520. package/ui/MessageSearchFileItem.js +124 -0
  521. package/ui/MessageSearchFileItem.js.map +1 -0
  522. package/ui/MessageSearchItem.js +87 -0
  523. package/ui/MessageSearchItem.js.map +1 -0
  524. package/ui/Modal.js +128 -0
  525. package/ui/Modal.js.map +1 -0
  526. package/ui/MutedAvatarOverlay.js +34 -0
  527. package/ui/MutedAvatarOverlay.js.map +1 -0
  528. package/ui/OGMessageItemBody.js +91 -0
  529. package/ui/OGMessageItemBody.js.map +1 -0
  530. package/ui/OpenChannelAdminMessage.js +21 -0
  531. package/ui/OpenChannelAdminMessage.js.map +1 -0
  532. package/ui/OpenChannelAvatar.js +35 -0
  533. package/ui/OpenChannelAvatar.js.map +1 -0
  534. package/ui/OpenChannelMessageContent.js +8 -0
  535. package/ui/OpenChannelMessageContent.js.map +1 -0
  536. package/ui/OpenchannelConversationHeader.js +67 -0
  537. package/ui/OpenchannelConversationHeader.js.map +1 -0
  538. package/ui/OpenchannelFileMessage.js +224 -0
  539. package/ui/OpenchannelFileMessage.js.map +1 -0
  540. package/ui/OpenchannelOGMessage.js +339 -0
  541. package/ui/OpenchannelOGMessage.js.map +1 -0
  542. package/ui/OpenchannelThumbnailMessage.js +299 -0
  543. package/ui/OpenchannelThumbnailMessage.js.map +1 -0
  544. package/ui/OpenchannelUserMessage.js +258 -0
  545. package/ui/OpenchannelUserMessage.js.map +1 -0
  546. package/ui/PlaceHolder.js +11 -0
  547. package/ui/PlaceHolder.js.map +1 -0
  548. package/ui/QuoteMessage.js +125 -0
  549. package/ui/QuoteMessage.js.map +1 -0
  550. package/ui/QuoteMessageInput.js +93 -0
  551. package/ui/QuoteMessageInput.js.map +1 -0
  552. package/ui/ReactionBadge.js +61 -0
  553. package/ui/ReactionBadge.js.map +1 -0
  554. package/ui/ReactionButton.js +48 -0
  555. package/ui/ReactionButton.js.map +1 -0
  556. package/ui/SortByRow.js +50 -0
  557. package/ui/SortByRow.js.map +1 -0
  558. package/ui/TextButton.js +38 -0
  559. package/ui/TextButton.js.map +1 -0
  560. package/ui/TextMessageItemBody.js +34 -0
  561. package/ui/TextMessageItemBody.js.map +1 -0
  562. package/ui/ThumbnailMessageItemBody.js +76 -0
  563. package/ui/ThumbnailMessageItemBody.js.map +1 -0
  564. package/ui/Tooltip.js +28 -0
  565. package/ui/Tooltip.js.map +1 -0
  566. package/ui/TooltipWrapper.js +58 -0
  567. package/ui/TooltipWrapper.js.map +1 -0
  568. package/ui/UnknownMessageItemBody.js +35 -0
  569. package/ui/UnknownMessageItemBody.js.map +1 -0
  570. package/ui/UserListItem.js +151 -0
  571. package/ui/UserListItem.js.map +1 -0
  572. package/ui/UserProfile.js +81 -0
  573. package/ui/UserProfile.js.map +1 -0
  574. package/useSendbirdStateContext.js +20 -0
  575. package/useSendbirdStateContext.js.map +1 -0
  576. package/utils-08c4dbdc.js +34 -0
  577. package/utils-08c4dbdc.js.map +1 -0
  578. package/utils-af1b9829.js +30 -0
  579. package/utils-af1b9829.js.map +1 -0
  580. package/utils-c393e880.js +4 -0
  581. package/utils-c393e880.js.map +1 -0
  582. package/uuid-b0c93400.js +17 -0
  583. package/uuid-b0c93400.js.map +1 -0
  584. package/withSendBird.js +26 -0
  585. package/withSendBird.js.map +1 -0
@@ -0,0 +1,70 @@
1
+ import React__default, { useState } from 'react';
2
+ import IconButton from '../../ui/IconButton.js';
3
+ import Icon, { IconTypes, IconColors } from '../../ui/Icon.js';
4
+ import CreateChannel from '../../CreateChannel.js';
5
+ import useSendbirdStateContext from '../../useSendbirdStateContext.js';
6
+ import '../../_rollupPluginBabelHelpers-20904f21.js';
7
+ import 'prop-types';
8
+ import '../../CreateChannel/components/CreateChannelUI.js';
9
+ import '../../CreateChannelProvider-c617a1bb.js';
10
+ import '../../sendBirdSelectors.js';
11
+ import '../../topics-9442035c.js';
12
+ import '../../CreateChannel/components/InviteMembers.js';
13
+ import '../../tslib.es6-e3c44017.js';
14
+ import '../../LocalizationContext-e4391013.js';
15
+ import '../../stringSet-4f6eaa60.js';
16
+ import '../../index-6ebf7894.js';
17
+ import '../../ui/Modal.js';
18
+ import 'react-dom';
19
+ import '../../index-942c85a6.js';
20
+ import '../../index-acebc2ff.js';
21
+ import '../../index-7a51bd16.js';
22
+ import '../../utils-c393e880.js';
23
+ import '../../ui/UserListItem.js';
24
+ import '../../UserProfileContext-865db5e6.js';
25
+ import '../../ui/Avatar.js';
26
+ import '../../ui/ImageRenderer.js';
27
+ import '../../uuid-b0c93400.js';
28
+ import '../../ui/MutedAvatarOverlay.js';
29
+ import '../../ui/Checkbox.js';
30
+ import '../../ui/UserProfile.js';
31
+ import '../../withSendBird.js';
32
+ import '../../ui/ContextMenu.js';
33
+ import '../../index-8c72a94a.js';
34
+ import '../../ui/SortByRow.js';
35
+ import '../../CreateChannel/components/SelectChannelType.js';
36
+
37
+ var AddChannel = function AddChannel() {
38
+ var _a;
39
+
40
+ var _b = useState(false),
41
+ showModal = _b[0],
42
+ setShowModal = _b[1];
43
+
44
+ var state = useSendbirdStateContext();
45
+ var isOnline = (_a = state === null || state === void 0 ? void 0 : state.config) === null || _a === void 0 ? void 0 : _a.isOnline;
46
+ var disabled = !isOnline;
47
+ return /*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement(IconButton, {
48
+ height: "32px",
49
+ width: "32px",
50
+ onClick: function onClick() {
51
+ setShowModal(true);
52
+ },
53
+ disabled: disabled
54
+ }, /*#__PURE__*/React__default.createElement(Icon, {
55
+ type: IconTypes.CREATE,
56
+ fillColor: IconColors.PRIMARY,
57
+ width: "24px",
58
+ height: "24px"
59
+ })), showModal && /*#__PURE__*/React__default.createElement(CreateChannel, {
60
+ onCancel: function onCancel() {
61
+ setShowModal(false);
62
+ },
63
+ onCreateChannel: function onCreateChannel() {
64
+ setShowModal(false);
65
+ }
66
+ }));
67
+ };
68
+
69
+ export { AddChannel, AddChannel as default };
70
+ //# sourceMappingURL=AddChannel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AddChannel.js","sources":["../../../src/smart-components/ChannelList/components/AddChannel/index.tsx"],"sourcesContent":["import './add-channel.scss';\n\nimport React, { useState } from 'react';\n\nimport IconButton from '../../../../ui/IconButton';\nimport Icon, { IconTypes, IconColors } from '../../../../ui/Icon';\n\nimport CreateChannel from '../../../CreateChannel';\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\n\nexport const AddChannel: React.VoidFunctionComponent = () => {\n const [showModal, setShowModal] = useState(false);\n const state = useSendbirdStateContext();\n const isOnline = state?.config?.isOnline;\n const disabled = !isOnline;\n\n return (\n <>\n <IconButton\n height=\"32px\"\n width=\"32px\"\n onClick={() => {\n setShowModal(true);\n }}\n disabled={disabled}\n >\n <Icon\n type={IconTypes.CREATE}\n fillColor={IconColors.PRIMARY}\n width=\"24px\"\n height=\"24px\"\n />\n </IconButton>\n {\n showModal && (\n <CreateChannel\n onCancel={() => {\n setShowModal(false);\n }}\n onCreateChannel={() => {\n setShowModal(false);\n }}\n />\n )\n }\n </>\n );\n}\n\nexport default AddChannel;\n"],"names":["AddChannel","_b","useState","showModal","setShowModal","state","useSendbirdStateContext","isOnline","config","disabled","React","IconTypes","CREATE","IconColors","PRIMARY"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAUaA,UAAU,GAAgC,SAA1CA,UAA0C;;;AAC/C,MAAAC,KAA4BC,QAAQ,CAAC,KAAD,CAApC;AAAA,MAACC,SAAS,QAAV;AAAA,MAAYC,YAAY,QAAxB;;AACN,MAAMC,KAAK,GAAGC,uBAAuB,EAArC;AACA,MAAMC,QAAQ,GAAG,MAAAF,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEG,MAAP,UAAA,iBAAA,SAAA,MAAeD,QAAhC;AACA,MAAME,QAAQ,GAAG,CAACF,QAAlB;AAEA,sBACEG,yEACEA,6BAAC,UAAD;AACE,IAAA,MAAM,EAAC,MADT;AAEE,IAAA,KAAK,EAAC,MAFR;AAGE,IAAA,OAAO,EAAE;AACPN,MAAAA,YAAY,CAAC,IAAD,CAAZ;AACD,KALH;AAME,IAAA,QAAQ,EAAEK;AANZ,kBAQEC,6BAAC,IAAD;AACE,IAAA,IAAI,EAAEC,SAAS,CAACC,MADlB;AAEE,IAAA,SAAS,EAAEC,UAAU,CAACC,OAFxB;AAGE,IAAA,KAAK,EAAC,MAHR;AAIE,IAAA,MAAM,EAAC;AAJT,IARF,CADF,EAiBIX,SAAS,iBACPO,6BAAC,aAAD;AACE,IAAA,QAAQ,EAAE;AACRN,MAAAA,YAAY,CAAC,KAAD,CAAZ;AACD,KAHH;AAIE,IAAA,eAAe,EAAE;AACfA,MAAAA,YAAY,CAAC,KAAD,CAAZ;AACD;AANH,IAlBN,CADF;AA+BD;;;;"}
@@ -0,0 +1,62 @@
1
+ import React__default, { useContext } from 'react';
2
+ import { a as LocalizationContext } from '../../LocalizationContext-e4391013.js';
3
+ import useSendbirdStateContext from '../../useSendbirdStateContext.js';
4
+ import { L as Label, a as LabelTypography, b as LabelColors } from '../../index-7a51bd16.js';
5
+ import IconButton from '../../ui/IconButton.js';
6
+ import Avatar from '../../ui/Avatar.js';
7
+ import '../../stringSet-4f6eaa60.js';
8
+ import '../../index-6ebf7894.js';
9
+ import '../../withSendBird.js';
10
+ import '../../_rollupPluginBabelHelpers-20904f21.js';
11
+ import 'prop-types';
12
+ import '../../tslib.es6-e3c44017.js';
13
+ import '../../ui/ImageRenderer.js';
14
+ import '../../ui/Icon.js';
15
+ import '../../uuid-b0c93400.js';
16
+
17
+ var ChannelListHeader = function ChannelListHeader(_a) {
18
+ var _b;
19
+
20
+ var renderHeader = _a.renderHeader,
21
+ renderIconButton = _a.renderIconButton,
22
+ onEdit = _a.onEdit,
23
+ allowProfileEdit = _a.allowProfileEdit;
24
+ var sbState = useSendbirdStateContext();
25
+ var user = ((_b = sbState === null || sbState === void 0 ? void 0 : sbState.stores) === null || _b === void 0 ? void 0 : _b.userStore).user;
26
+ var stringSet = useContext(LocalizationContext).stringSet;
27
+ return /*#__PURE__*/React__default.createElement("div", {
28
+ className: ['sendbird-channel-header', allowProfileEdit ? 'sendbird-channel-header--allow-edit' : ''].join(' ')
29
+ }, renderHeader ? renderHeader() : /*#__PURE__*/React__default.createElement("div", {
30
+ className: "sendbird-channel-header__title",
31
+ role: "button",
32
+ onClick: function onClick() {
33
+ onEdit();
34
+ },
35
+ onKeyDown: function onKeyDown() {
36
+ onEdit();
37
+ },
38
+ tabIndex: 0
39
+ }, /*#__PURE__*/React__default.createElement("div", {
40
+ className: "sendbird-channel-header__title__left"
41
+ }, /*#__PURE__*/React__default.createElement(Avatar, {
42
+ width: "32px",
43
+ height: "32px",
44
+ src: user.profileUrl,
45
+ alt: user.nickname
46
+ })), /*#__PURE__*/React__default.createElement("div", {
47
+ className: "sendbird-channel-header__title__right"
48
+ }, /*#__PURE__*/React__default.createElement(Label, {
49
+ className: "sendbird-channel-header__title__right__name",
50
+ type: LabelTypography.SUBTITLE_2,
51
+ color: LabelColors.ONBACKGROUND_1
52
+ }, user.nickname || stringSet.NO_NAME), /*#__PURE__*/React__default.createElement(Label, {
53
+ className: "sendbird-channel-header__title__right__user-id",
54
+ type: LabelTypography.BODY_2,
55
+ color: LabelColors.ONBACKGROUND_2
56
+ }, user.userId))), /*#__PURE__*/React__default.createElement("div", {
57
+ className: "sendbird-channel-header__right-icon"
58
+ }, renderIconButton() || /*#__PURE__*/React__default.createElement(IconButton, null)));
59
+ };
60
+
61
+ export { ChannelListHeader as default };
62
+ //# sourceMappingURL=ChannelListHeader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ChannelListHeader.js","sources":["../../../src/smart-components/ChannelList/components/ChannelListHeader/index.tsx"],"sourcesContent":["import React, { useContext } from 'react';\n\nimport { LocalizationContext } from '../../../../lib/LocalizationContext';\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport Label, { LabelTypography, LabelColors } from '../../../../ui/Label';\nimport IconButton from '../../../../ui/IconButton';\n\nimport './index.scss';\nimport Avatar from '../../../../ui/Avatar';\n\ninterface ChannelListHeaderInterface {\n renderHeader?: (props: void) => React.ReactNode;\n renderIconButton?: (props: void) => React.ReactNode;\n onEdit?: (props: void) => void;\n allowProfileEdit?: boolean;\n}\n\nconst ChannelListHeader : React.FC<ChannelListHeaderInterface> = ({\n renderHeader,\n renderIconButton,\n onEdit,\n allowProfileEdit,\n}: ChannelListHeaderInterface) => {\n const sbState = useSendbirdStateContext();\n const { user } = sbState?.stores?.userStore;\n\n const { stringSet } = useContext(LocalizationContext);\n return (\n <div\n className={[\n 'sendbird-channel-header',\n allowProfileEdit ? 'sendbird-channel-header--allow-edit' : '',\n ].join(' ')}\n >\n {\n renderHeader\n ? renderHeader()\n : (\n <div\n className=\"sendbird-channel-header__title\"\n role=\"button\"\n onClick={() => { onEdit() }}\n onKeyDown={() => { onEdit() }}\n tabIndex={0}\n >\n <div className=\"sendbird-channel-header__title__left\">\n <Avatar\n width=\"32px\"\n height=\"32px\"\n src={user.profileUrl}\n alt={user.nickname}\n />\n </div>\n <div className=\"sendbird-channel-header__title__right\">\n <Label\n className=\"sendbird-channel-header__title__right__name\"\n type={LabelTypography.SUBTITLE_2}\n color={LabelColors.ONBACKGROUND_1}\n >\n {user.nickname || stringSet.NO_NAME}\n </Label>\n <Label\n className=\"sendbird-channel-header__title__right__user-id\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_2}\n >\n {user.userId}\n </Label>\n </div>\n </div>\n )\n }\n <div className=\"sendbird-channel-header__right-icon\">\n {renderIconButton() || <IconButton />}\n </div>\n </div>\n );\n}\n\nexport default ChannelListHeader;\n"],"names":["ChannelListHeader","_a","renderHeader","renderIconButton","onEdit","allowProfileEdit","sbState","useSendbirdStateContext","user","stores","userStore","stringSet","useContext","LocalizationContext","React","join","profileUrl","nickname","LabelTypography","SUBTITLE_2","LabelColors","ONBACKGROUND_1","NO_NAME","BODY_2","ONBACKGROUND_2","userId"],"mappings":";;;;;;;;;;;;;;;;IAiBMA,iBAAiB,GAA0C,SAA3DA,iBAA2D,CAACC,EAAD;;;MAC/DC,YAAY;MACZC,gBAAgB;MAChBC,MAAM;MACNC,gBAAgB;AAEhB,MAAMC,OAAO,GAAGC,uBAAuB,EAAvC;AACQ,MAAAC,IAAI,GAAK,CAAA,MAAAF,OAAO,SAAP,IAAAA,OAAO,WAAP,SAAA,GAAAA,OAAO,CAAEG,MAAT,UAAA,iBAAA,SAAA,MAAiBC,SAAjB,MAAT;AAEA,MAAAC,SAAS,GAAKC,UAAU,CAACC,mBAAD,CAAV,UAAd;AACR,sBACEC;AACE,IAAA,SAAS,EAAE,CACT,yBADS,EAETT,gBAAgB,GAAG,qCAAH,GAA2C,EAFlD,EAGTU,IAHS,CAGJ,GAHI;AADb,KAOIb,YAAY,GACRA,YAAY,EADJ,gBAGRY;AACE,IAAA,SAAS,EAAC,gCADZ;AAEE,IAAA,IAAI,EAAC,QAFP;AAGE,IAAA,OAAO,EAAE;AAAQV,MAAAA,MAAM;AAAI,KAH7B;AAIE,IAAA,SAAS,EAAE;AAAQA,MAAAA,MAAM;AAAI,KAJ/B;AAKE,IAAA,QAAQ,EAAE;AALZ,kBAOEU;AAAK,IAAA,SAAS,EAAC;AAAf,kBACEA,6BAAC,MAAD;AACE,IAAA,KAAK,EAAC,MADR;AAEE,IAAA,MAAM,EAAC,MAFT;AAGE,IAAA,GAAG,EAAEN,IAAI,CAACQ,UAHZ;AAIE,IAAA,GAAG,EAAER,IAAI,CAACS;AAJZ,IADF,CAPF,eAeEH;AAAK,IAAA,SAAS,EAAC;AAAf,kBACEA,6BAAC,KAAD;AACE,IAAA,SAAS,EAAC,6CADZ;AAEE,IAAA,IAAI,EAAEI,eAAe,CAACC,UAFxB;AAGE,IAAA,KAAK,EAAEC,WAAW,CAACC;AAHrB,KAKGb,IAAI,CAACS,QAAL,IAAiBN,SAAS,CAACW,OAL9B,CADF,eAQER,6BAAC,KAAD;AACE,IAAA,SAAS,EAAC,gDADZ;AAEE,IAAA,IAAI,EAAEI,eAAe,CAACK,MAFxB;AAGE,IAAA,KAAK,EAAEH,WAAW,CAACI;AAHrB,KAKGhB,IAAI,CAACiB,MALR,CARF,CAfF,CAVR,eA4CEX;AAAK,IAAA,SAAS,EAAC;AAAf,KACGX,gBAAgB,mBAAMW,6BAAC,UAAD,OADzB,CA5CF,CADF;AAkDD;;;;"}
@@ -0,0 +1,213 @@
1
+ import React__default, { useState } from 'react';
2
+ import ChannelListHeader from './ChannelListHeader.js';
3
+ import { AddChannel } from './AddChannel.js';
4
+ import ChannelPreview from './ChannelPreview.js';
5
+ import ChannelPreviewAction from './ChannelPreviewAction.js';
6
+ import { u as useChannelListContext, F as FETCH_CHANNELS_START, a as FETCH_CHANNELS_FAILURE, b as FETCH_CHANNELS_SUCCESS, L as LEAVE_CHANNEL_SUCCESS, S as SET_CURRENT_CHANNEL } from '../../ChannelListProvider-0b0c2c40.js';
7
+ import useSendbirdStateContext from '../../useSendbirdStateContext.js';
8
+ import EditProfile from '../../EditUserProfile.js';
9
+ import { P as PlaceHolder, a as PlaceHolderTypes } from '../../index-e818a8a3.js';
10
+ import '../../LocalizationContext-e4391013.js';
11
+ import '../../stringSet-4f6eaa60.js';
12
+ import '../../index-6ebf7894.js';
13
+ import '../../index-7a51bd16.js';
14
+ import '../../_rollupPluginBabelHelpers-20904f21.js';
15
+ import 'prop-types';
16
+ import '../../ui/IconButton.js';
17
+ import '../../ui/Avatar.js';
18
+ import '../../tslib.es6-e3c44017.js';
19
+ import '../../ui/ImageRenderer.js';
20
+ import '../../ui/Icon.js';
21
+ import '../../uuid-b0c93400.js';
22
+ import '../../CreateChannel.js';
23
+ import '../../CreateChannel/components/CreateChannelUI.js';
24
+ import '../../CreateChannelProvider-c617a1bb.js';
25
+ import '../../sendBirdSelectors.js';
26
+ import '../../topics-9442035c.js';
27
+ import '../../CreateChannel/components/InviteMembers.js';
28
+ import '../../ui/Modal.js';
29
+ import 'react-dom';
30
+ import '../../index-942c85a6.js';
31
+ import '../../index-acebc2ff.js';
32
+ import '../../utils-c393e880.js';
33
+ import '../../ui/UserListItem.js';
34
+ import '../../UserProfileContext-865db5e6.js';
35
+ import '../../ui/MutedAvatarOverlay.js';
36
+ import '../../ui/Checkbox.js';
37
+ import '../../ui/UserProfile.js';
38
+ import '../../withSendBird.js';
39
+ import '../../ui/ContextMenu.js';
40
+ import '../../index-8c72a94a.js';
41
+ import '../../ui/SortByRow.js';
42
+ import '../../CreateChannel/components/SelectChannelType.js';
43
+ import '../../ui/ChannelAvatar.js';
44
+ import '../../utils-08c4dbdc.js';
45
+ import '../../ui/Badge.js';
46
+ import '../../index-1718324d.js';
47
+ import '../../index-cd21929d.js';
48
+ import '../../index-770d7112.js';
49
+ import '../../index-5c2c81bc.js';
50
+ import '../../ui/Input.js';
51
+ import '../../ui/TextButton.js';
52
+ import '../../color-ee3fc5ee.js';
53
+ import '../../actionTypes-1e3a4074.js';
54
+ import '../../ui/Loader.js';
55
+
56
+ var ChannelListUI = function ChannelListUI(props) {
57
+ var _a, _b;
58
+
59
+ var renderHeader = props.renderHeader,
60
+ renderChannelPreview = props.renderChannelPreview,
61
+ renderPlaceHolderError = props.renderPlaceHolderError,
62
+ renderPlaceHolderLoading = props.renderPlaceHolderLoading,
63
+ renderPlaceHolderEmptyList = props.renderPlaceHolderEmptyList;
64
+
65
+ var _c = useState(false),
66
+ showProfileEdit = _c[0],
67
+ setShowProfileEdit = _c[1];
68
+
69
+ var _d = useChannelListContext(),
70
+ onThemeChange = _d.onThemeChange,
71
+ allowProfileEdit = _d.allowProfileEdit,
72
+ allChannels = _d.allChannels,
73
+ loading = _d.loading,
74
+ currentChannel = _d.currentChannel,
75
+ channelListDispatcher = _d.channelListDispatcher,
76
+ channelSource = _d.channelSource;
77
+
78
+ var state = useSendbirdStateContext();
79
+ var sdkStore = (_a = state === null || state === void 0 ? void 0 : state.stores) === null || _a === void 0 ? void 0 : _a.sdkStore;
80
+ var config = state === null || state === void 0 ? void 0 : state.config;
81
+ var isOnline = (_b = state === null || state === void 0 ? void 0 : state.config) === null || _b === void 0 ? void 0 : _b.isOnline;
82
+ var logger = config === null || config === void 0 ? void 0 : config.logger;
83
+ var sdk = sdkStore === null || sdkStore === void 0 ? void 0 : sdkStore.sdk;
84
+ var sdkError = sdkStore === null || sdkStore === void 0 ? void 0 : sdkStore.error;
85
+ var sdkIntialized = (sdkStore === null || sdkStore === void 0 ? void 0 : sdkStore.initialized) || false;
86
+ return /*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement("div", {
87
+ className: "sendbird-channel-list__header"
88
+ }, /*#__PURE__*/React__default.createElement(ChannelListHeader, {
89
+ renderHeader: renderHeader,
90
+ onEdit: function onEdit() {
91
+ if (allowProfileEdit) {
92
+ setShowProfileEdit(true);
93
+ }
94
+ },
95
+ allowProfileEdit: allowProfileEdit,
96
+ renderIconButton: function renderIconButton() {
97
+ return /*#__PURE__*/React__default.createElement(AddChannel, null);
98
+ }
99
+ })), showProfileEdit && /*#__PURE__*/React__default.createElement(EditProfile, {
100
+ onThemeChange: onThemeChange,
101
+ onCancel: function onCancel() {
102
+ setShowProfileEdit(false);
103
+ },
104
+ onEditProfile: function onEditProfile() {
105
+ setShowProfileEdit(false);
106
+ }
107
+ }), /*#__PURE__*/React__default.createElement("div", {
108
+ className: "sendbird-channel-list__body",
109
+ onScroll: function onScroll(e) {
110
+ var target = e === null || e === void 0 ? void 0 : e.target;
111
+ var fetchMore = target.clientHeight + target.scrollTop === target.scrollHeight;
112
+
113
+ if (fetchMore && (channelSource === null || channelSource === void 0 ? void 0 : channelSource.hasNext)) {
114
+ logger.info('ChannelList: Fetching more channels');
115
+ channelListDispatcher({
116
+ type: FETCH_CHANNELS_START,
117
+ payload: null
118
+ });
119
+ channelSource === null || channelSource === void 0 ? void 0 : channelSource.next(function (channelList, err) {
120
+ if (err) {
121
+ logger.info('ChannelList: Fetching channels failed', err);
122
+ channelListDispatcher({
123
+ type: FETCH_CHANNELS_FAILURE,
124
+ payload: channelList
125
+ });
126
+ return;
127
+ }
128
+
129
+ logger.info('ChannelList: Fetching channels successful', channelList);
130
+ channelListDispatcher({
131
+ type: FETCH_CHANNELS_SUCCESS,
132
+ payload: channelList
133
+ });
134
+
135
+ if (channelList && typeof channelList.forEach === 'function') {
136
+ logger.info('ChannelList: Marking all channels as read');
137
+ channelList.forEach(function (c) {
138
+ sdk.markAsDelivered(c.url);
139
+ });
140
+ }
141
+ });
142
+ }
143
+ }
144
+ }, sdkError && (renderPlaceHolderError && typeof renderPlaceHolderError === 'function' ? renderPlaceHolderError === null || renderPlaceHolderError === void 0 ? void 0 : renderPlaceHolderError() : /*#__PURE__*/React__default.createElement(PlaceHolder, {
145
+ type: PlaceHolderTypes.WRONG
146
+ })), /*#__PURE__*/React__default.createElement("div", null, allChannels && allChannels.map(function (channel, idx) {
147
+ var _onLeaveChannel = function onLeaveChannel(c, cb) {
148
+ logger.info('ChannelList: Leaving channel', c);
149
+ c.leave().then(function (res) {
150
+ logger.info('ChannelList: Leaving channel success', res);
151
+
152
+ if (cb && typeof cb === 'function') {
153
+ cb(res, null);
154
+ }
155
+
156
+ channelListDispatcher({
157
+ type: LEAVE_CHANNEL_SUCCESS,
158
+ payload: channel.url
159
+ });
160
+ }).catch(function (err) {
161
+ logger.error('ChannelList: Leaving channel failed', err);
162
+
163
+ if (cb && typeof cb === 'function') {
164
+ cb(null, err);
165
+ }
166
+ });
167
+ };
168
+
169
+ var onClick = function onClick() {
170
+ if (!isOnline) {
171
+ return;
172
+ }
173
+
174
+ logger.info('ChannelList: Clicked on channel:', channel);
175
+ channelListDispatcher({
176
+ type: SET_CURRENT_CHANNEL,
177
+ payload: channel
178
+ });
179
+ };
180
+
181
+ return renderChannelPreview ?
182
+ /*#__PURE__*/
183
+ // eslint-disable-next-line
184
+ React__default.createElement("div", {
185
+ key: channel.url,
186
+ onClick: onClick
187
+ }, renderChannelPreview({
188
+ channel: channel,
189
+ onLeaveChannel: _onLeaveChannel
190
+ })) : /*#__PURE__*/React__default.createElement(ChannelPreview, {
191
+ key: channel.url,
192
+ tabIndex: idx,
193
+ onClick: onClick,
194
+ channel: channel,
195
+ isActive: channel.url === (currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.url),
196
+ renderChannelAction: function renderChannelAction() {
197
+ return /*#__PURE__*/React__default.createElement(ChannelPreviewAction, {
198
+ disabled: !isOnline,
199
+ onLeaveChannel: function onLeaveChannel() {
200
+ return _onLeaveChannel(channel, null);
201
+ }
202
+ });
203
+ }
204
+ });
205
+ })), (!sdkIntialized || loading) && (renderPlaceHolderLoading && typeof renderPlaceHolderLoading === 'function' ? renderPlaceHolderLoading === null || renderPlaceHolderLoading === void 0 ? void 0 : renderPlaceHolderLoading() : /*#__PURE__*/React__default.createElement(PlaceHolder, {
206
+ type: PlaceHolderTypes.LOADING
207
+ })), (!allChannels || allChannels.length === 0) && (renderPlaceHolderEmptyList && typeof renderPlaceHolderEmptyList === 'function' ? renderPlaceHolderEmptyList === null || renderPlaceHolderEmptyList === void 0 ? void 0 : renderPlaceHolderEmptyList() : /*#__PURE__*/React__default.createElement(PlaceHolder, {
208
+ type: PlaceHolderTypes.NO_CHANNELS
209
+ }))));
210
+ };
211
+
212
+ export { ChannelListUI as default };
213
+ //# sourceMappingURL=ChannelListUI.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ChannelListUI.js","sources":["../../../src/smart-components/ChannelList/components/ChannelListUI/index.tsx"],"sourcesContent":["import './channel-list-ui.scss';\n\nimport React, { useState } from 'react';\n\nimport SendBird from 'sendbird';\n\nimport ChannelListHeader from '../ChannelListHeader';\nimport AddChannel from '../AddChannel';\nimport ChannelPreview from '../ChannelPreview';\nimport ChannelPreviewAction from '../ChannelPreviewAction';\nimport { useChannelListContext } from '../../context/ChannelListProvider';\nimport * as channelListActions from '../../dux/actionTypes';\n\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport EditUserProfile from '../../../EditUserProfile';\nimport PlaceHolder, { PlaceHolderTypes } from '../../../../ui/PlaceHolder';\n\ninterface RenderChannelPreviewProps {\n channel: SendBird.GroupChannel;\n onLeaveChannel(\n channel: SendBird.GroupChannel,\n onLeaveChannelCb?: (c: SendBird.GroupChannel) => void,\n );\n}\n\ninterface RenderUserProfileProps {\n user: SendBird.Member | SendBird.User;\n currentUserId: string;\n close(): void;\n}\n\nexport interface ChannelListUIProps {\n renderChannelPreview?: (props: RenderChannelPreviewProps) => React.ReactNode;\n renderUserProfile?: (props: RenderUserProfileProps) => React.ReactNode;\n renderHeader?: (props: void) => React.ReactNode;\n renderPlaceHolderError?: (props: void) => React.ReactNode;\n renderPlaceHolderLoading?: (props: void) => React.ReactNode;\n renderPlaceHolderEmptyList?: (props: void) => React.ReactNode;\n}\n\nconst ChannelListUI: React.FC<ChannelListUIProps> = (props: ChannelListUIProps) => {\n const {\n renderHeader,\n renderChannelPreview,\n renderPlaceHolderError,\n renderPlaceHolderLoading,\n renderPlaceHolderEmptyList,\n } = props;\n\n const [showProfileEdit, setShowProfileEdit] = useState(false);\n\n const {\n onThemeChange,\n allowProfileEdit,\n allChannels,\n loading,\n currentChannel,\n channelListDispatcher,\n channelSource,\n } = useChannelListContext();\n\n const state = useSendbirdStateContext();\n\n const sdkStore = state?.stores?.sdkStore;\n const config = state?.config;\n\n const isOnline = state?.config?.isOnline;\n const logger = config?.logger;\n\n const sdk = sdkStore?.sdk;\n const sdkError = sdkStore?.error;\n const sdkIntialized = sdkStore?.initialized || false;\n\n return (\n <>\n <div className=\"sendbird-channel-list__header\">\n <ChannelListHeader\n renderHeader={renderHeader}\n onEdit={() => {\n if (allowProfileEdit) {\n setShowProfileEdit(true);\n }\n }}\n allowProfileEdit={allowProfileEdit}\n renderIconButton={() => (\n <AddChannel />\n )}\n />\n </div>\n {\n showProfileEdit && (\n <EditUserProfile\n onThemeChange={onThemeChange}\n onCancel={() => { setShowProfileEdit(false); }}\n onEditProfile={() => {\n setShowProfileEdit(false);\n }}\n />\n )\n }\n <div\n className=\"sendbird-channel-list__body\"\n onScroll={(e) => {\n const target = e?.target as HTMLDivElement;\n const fetchMore = target.clientHeight + target.scrollTop === target.scrollHeight;\n if (fetchMore && channelSource?.hasNext) {\n logger.info('ChannelList: Fetching more channels');\n channelListDispatcher({\n type: channelListActions.FETCH_CHANNELS_START,\n payload: null,\n });\n channelSource?.next((channelList, err) => {\n if (err) {\n logger.info('ChannelList: Fetching channels failed', err);\n channelListDispatcher({\n type: channelListActions.FETCH_CHANNELS_FAILURE,\n payload: channelList,\n });\n return;\n }\n logger.info('ChannelList: Fetching channels successful', channelList);\n channelListDispatcher({\n type: channelListActions.FETCH_CHANNELS_SUCCESS,\n payload: channelList,\n });\n if (channelList && typeof channelList.forEach === 'function') {\n logger.info('ChannelList: Marking all channels as read');\n channelList.forEach((c) => { sdk.markAsDelivered(c.url) });\n }\n });\n }\n }}\n >\n {\n (sdkError) && (\n (renderPlaceHolderError && typeof renderPlaceHolderError === 'function') ? (\n renderPlaceHolderError?.()\n ): (\n <PlaceHolder type={PlaceHolderTypes.WRONG} />\n )\n )\n }\n {/*\n To do: Implement windowing\n Implement windowing if you are dealing with large number of messages/channels\n https://github.com/bvaughn/react-window -> recommendation\n We hesitate to bring one more dependency to our library,\n we are planning to implement it inside the library\n */}\n <div>\n {\n allChannels && allChannels.map((channel, idx) => {\n const onLeaveChannel = (c, cb) => {\n logger.info('ChannelList: Leaving channel', c);\n c.leave()\n .then((res) => {\n logger.info('ChannelList: Leaving channel success', res);\n if (cb && typeof cb === 'function') {\n cb(res, null);\n }\n channelListDispatcher({\n type: channelListActions.LEAVE_CHANNEL_SUCCESS,\n payload: channel.url,\n });\n })\n .catch((err) => {\n logger.error('ChannelList: Leaving channel failed', err);\n if (cb && typeof cb === 'function') {\n cb(null, err);\n }\n });\n };\n\n const onClick = () => {\n if (!isOnline) { return; }\n logger.info('ChannelList: Clicked on channel:', channel);\n channelListDispatcher({\n type: channelListActions.SET_CURRENT_CHANNEL,\n payload: channel,\n });\n };\n\n return (\n (renderChannelPreview)\n ? (\n // eslint-disable-next-line\n <div key={channel.url} onClick={onClick}>\n {renderChannelPreview({ channel, onLeaveChannel })}\n </div>\n )\n : (\n <ChannelPreview\n key={channel.url}\n tabIndex={idx}\n onClick={onClick}\n channel={channel}\n isActive={channel.url === currentChannel?.url}\n renderChannelAction={(() => (\n <ChannelPreviewAction\n disabled={!isOnline}\n onLeaveChannel={() => onLeaveChannel(channel, null)}\n />\n ))}\n />\n )\n );\n })\n }\n </div>\n {\n (!sdkIntialized || loading) && (\n (renderPlaceHolderLoading && typeof renderPlaceHolderLoading === 'function') ? (\n renderPlaceHolderLoading?.()\n ): (\n <PlaceHolder type={PlaceHolderTypes.LOADING} />\n )\n )\n }\n {\n (!allChannels || allChannels.length === 0) && (\n (renderPlaceHolderEmptyList && typeof renderPlaceHolderEmptyList === 'function') ? (\n renderPlaceHolderEmptyList?.()\n ): (\n <PlaceHolder type={PlaceHolderTypes.NO_CHANNELS} />\n )\n )\n }\n </div>\n </>\n );\n}\n\nexport default ChannelListUI;\n"],"names":["ChannelListUI","props","renderHeader","renderChannelPreview","renderPlaceHolderError","renderPlaceHolderLoading","renderPlaceHolderEmptyList","_c","useState","showProfileEdit","setShowProfileEdit","_d","useChannelListContext","onThemeChange","allowProfileEdit","allChannels","loading","currentChannel","channelListDispatcher","channelSource","state","useSendbirdStateContext","sdkStore","stores","config","isOnline","logger","sdk","sdkError","error","sdkIntialized","initialized","React","EditUserProfile","e","target","fetchMore","clientHeight","scrollTop","scrollHeight","hasNext","info","type","channelListActions","payload","next","channelList","err","forEach","c","markAsDelivered","url","PlaceHolderTypes","WRONG","map","channel","idx","onLeaveChannel","cb","leave","then","res","catch","onClick","LOADING","length","NO_CHANNELS"],"mappings":"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"}
@@ -0,0 +1,177 @@
1
+ import React__default from 'react';
2
+ import ChannelAvatar from '../../ui/ChannelAvatar.js';
3
+ import Badge from '../../ui/Badge.js';
4
+ import Icon, { IconTypes, IconColors } from '../../ui/Icon.js';
5
+ import { c as LabelStringSet, L as Label, a as LabelTypography, b as LabelColors } from '../../index-7a51bd16.js';
6
+ import { i as isToday, a as isYesterday, f as formatRelative } from '../../index-1718324d.js';
7
+ import { f as format } from '../../index-770d7112.js';
8
+ import { t as truncateString } from '../../index-8c72a94a.js';
9
+ import useSendbirdStateContext from '../../useSendbirdStateContext.js';
10
+ import { u as useLocalization } from '../../LocalizationContext-e4391013.js';
11
+ import '../../ui/Avatar.js';
12
+ import '../../tslib.es6-e3c44017.js';
13
+ import '../../ui/ImageRenderer.js';
14
+ import '../../_rollupPluginBabelHelpers-20904f21.js';
15
+ import 'prop-types';
16
+ import '../../uuid-b0c93400.js';
17
+ import '../../utils-08c4dbdc.js';
18
+ import '../../stringSet-4f6eaa60.js';
19
+ import '../../index-cd21929d.js';
20
+ import '../../index-6ebf7894.js';
21
+ import '../../withSendBird.js';
22
+
23
+ var getChannelTitle = function getChannelTitle() {
24
+ var channel = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
25
+ var currentUserId = arguments.length > 1 ? arguments[1] : undefined;
26
+ var stringSet = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : LabelStringSet;
27
+
28
+ if (!channel || !channel.name && !channel.members) {
29
+ return stringSet.NO_TITLE;
30
+ }
31
+
32
+ if (channel.name && channel.name !== 'Group Channel') {
33
+ return channel.name;
34
+ }
35
+
36
+ if (channel.members.length === 1) {
37
+ return stringSet.NO_MEMBERS;
38
+ }
39
+
40
+ return channel.members.filter(function (_ref) {
41
+ var userId = _ref.userId;
42
+ return userId !== currentUserId;
43
+ }).map(function (_ref2) {
44
+ var nickname = _ref2.nickname;
45
+ return nickname || stringSet.NO_NAME;
46
+ }).join(', ');
47
+ };
48
+ var getLastMessageCreatedAt = function getLastMessageCreatedAt(channel, locale) {
49
+ var _channel$lastMessage;
50
+
51
+ var createdAt = channel === null || channel === void 0 ? void 0 : (_channel$lastMessage = channel.lastMessage) === null || _channel$lastMessage === void 0 ? void 0 : _channel$lastMessage.createdAt;
52
+ var optionalParam = locale ? {
53
+ locale: locale
54
+ } : null;
55
+
56
+ if (!createdAt) {
57
+ return '';
58
+ }
59
+
60
+ if (isToday(createdAt)) {
61
+ return format(createdAt, 'p', optionalParam);
62
+ }
63
+
64
+ if (isYesterday(createdAt)) {
65
+ return formatRelative(createdAt, new Date(), optionalParam);
66
+ }
67
+
68
+ return format(createdAt, 'MMM dd', optionalParam);
69
+ };
70
+ var getTotalMembers = function getTotalMembers(channel) {
71
+ return channel && channel.memberCount ? channel.memberCount : 0;
72
+ };
73
+
74
+ var getPrettyLastMessage = function getPrettyLastMessage() {
75
+ var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
76
+ var MAXLEN = 30;
77
+ var messageType = message.messageType,
78
+ name = message.name;
79
+
80
+ if (messageType === 'file') {
81
+ return truncateString(name, MAXLEN);
82
+ }
83
+
84
+ return message.message;
85
+ };
86
+
87
+ var getLastMessage = function getLastMessage(channel) {
88
+ return channel && channel.lastMessage ? getPrettyLastMessage(channel.lastMessage) : '';
89
+ };
90
+ var getChannelUnreadMessageCount = function getChannelUnreadMessageCount(channel) {
91
+ return channel && channel.unreadMessageCount ? channel.unreadMessageCount : 0;
92
+ };
93
+
94
+ var ChannelPreview = function ChannelPreview(_a) {
95
+ var _b, _c, _d, _e;
96
+
97
+ var channel = _a.channel,
98
+ _f = _a.isActive,
99
+ isActive = _f === void 0 ? false : _f,
100
+ renderChannelAction = _a.renderChannelAction,
101
+ onClick = _a.onClick,
102
+ tabIndex = _a.tabIndex;
103
+ var sbState = useSendbirdStateContext();
104
+
105
+ var _g = useLocalization(),
106
+ dateLocale = _g.dateLocale,
107
+ stringSet = _g.stringSet;
108
+
109
+ var userId = (_d = (_c = (_b = sbState === null || sbState === void 0 ? void 0 : sbState.stores) === null || _b === void 0 ? void 0 : _b.userStore) === null || _c === void 0 ? void 0 : _c.user) === null || _d === void 0 ? void 0 : _d.userId;
110
+ var theme = (_e = sbState === null || sbState === void 0 ? void 0 : sbState.config) === null || _e === void 0 ? void 0 : _e.theme;
111
+ var isBroadcast = channel.isBroadcast,
112
+ isFrozen = channel.isFrozen;
113
+ return /*#__PURE__*/React__default.createElement("div", {
114
+ className: ['sendbird-channel-preview', isActive ? 'sendbird-channel-preview--active' : ''].join(' '),
115
+ role: "link",
116
+ onClick: onClick,
117
+ onKeyPress: onClick,
118
+ tabIndex: tabIndex
119
+ }, /*#__PURE__*/React__default.createElement("div", {
120
+ className: "sendbird-channel-preview__avatar"
121
+ }, /*#__PURE__*/React__default.createElement(ChannelAvatar, {
122
+ channel: channel,
123
+ userId: userId,
124
+ theme: theme
125
+ })), /*#__PURE__*/React__default.createElement("div", {
126
+ className: "sendbird-channel-preview__content"
127
+ }, /*#__PURE__*/React__default.createElement("div", {
128
+ className: "sendbird-channel-preview__content__upper"
129
+ }, /*#__PURE__*/React__default.createElement("div", {
130
+ className: "sendbird-channel-preview__content__upper__header"
131
+ }, isBroadcast && /*#__PURE__*/React__default.createElement("div", {
132
+ className: "sendbird-channel-preview__content__upper__header__broadcast-icon"
133
+ }, /*#__PURE__*/React__default.createElement(Icon, {
134
+ type: IconTypes.BROADCAST,
135
+ fillColor: IconColors.SECONDARY,
136
+ height: "16px",
137
+ width: "16px"
138
+ })), /*#__PURE__*/React__default.createElement(Label, {
139
+ className: "sendbird-channel-preview__content__upper__header__channel-name",
140
+ type: LabelTypography.SUBTITLE_2,
141
+ color: LabelColors.ONBACKGROUND_1
142
+ }, getChannelTitle(channel, userId, stringSet)), /*#__PURE__*/React__default.createElement(Label, {
143
+ className: "sendbird-channel-preview__content__upper__header__total-members",
144
+ type: LabelTypography.CAPTION_2,
145
+ color: LabelColors.ONBACKGROUND_2
146
+ }, getTotalMembers(channel)), isFrozen && /*#__PURE__*/React__default.createElement("div", {
147
+ title: "Frozen",
148
+ className: "sendbird-channel-preview__content__upper__header__frozen-icon"
149
+ }, /*#__PURE__*/React__default.createElement(Icon, {
150
+ type: IconTypes.FREEZE,
151
+ fillColor: IconColors.PRIMARY,
152
+ height: 12,
153
+ width: 12
154
+ }))), /*#__PURE__*/React__default.createElement(Label, {
155
+ className: "sendbird-channel-preview__content__upper__last-message-at",
156
+ type: LabelTypography.CAPTION_3,
157
+ color: LabelColors.ONBACKGROUND_2
158
+ }, getLastMessageCreatedAt(channel, dateLocale))), /*#__PURE__*/React__default.createElement("div", {
159
+ className: "sendbird-channel-preview__content__lower"
160
+ }, /*#__PURE__*/React__default.createElement(Label, {
161
+ className: "sendbird-channel-preview__content__lower__last-message",
162
+ type: LabelTypography.BODY_2,
163
+ color: LabelColors.ONBACKGROUND_3
164
+ }, getLastMessage(channel)), /*#__PURE__*/React__default.createElement("div", {
165
+ className: "sendbird-channel-preview__content__lower__unread-message-count"
166
+ }, getChannelUnreadMessageCount(channel) // return number
167
+ ? /*#__PURE__*/React__default.createElement(Badge, {
168
+ count: getChannelUnreadMessageCount(channel)
169
+ }) : null))), /*#__PURE__*/React__default.createElement("div", {
170
+ className: "sendbird-channel-preview__action"
171
+ }, renderChannelAction({
172
+ channel: channel
173
+ })));
174
+ };
175
+
176
+ export { ChannelPreview as default };
177
+ //# sourceMappingURL=ChannelPreview.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ChannelPreview.js","sources":["../../../src/smart-components/ChannelList/components/ChannelPreview/utils.js","../../../src/smart-components/ChannelList/components/ChannelPreview/index.tsx"],"sourcesContent":["import isToday from 'date-fns/isToday';\nimport format from 'date-fns/format';\nimport formatRelative from 'date-fns/formatRelative';\nimport isYesterday from 'date-fns/isYesterday';\n\nimport { truncateString } from '../../../../utils';\nimport { LabelStringSet } from '../../../../ui/Label';\n\nexport const getChannelTitle = (channel = {}, currentUserId, stringSet = LabelStringSet) => {\n if (!channel || (!channel.name && !channel.members)) {\n return stringSet.NO_TITLE;\n }\n if (channel.name && channel.name !== 'Group Channel') {\n return channel.name;\n }\n if (channel.members.length === 1) {\n return stringSet.NO_MEMBERS;\n }\n\n return channel.members\n .filter(({ userId }) => userId !== currentUserId)\n .map(({ nickname }) => (nickname || stringSet.NO_NAME))\n .join(', ');\n};\n\nexport const getLastMessageCreatedAt = (channel, locale) => {\n const createdAt = channel?.lastMessage?.createdAt;\n const optionalParam = locale ? { locale } : null;\n if (!createdAt) {\n return '';\n }\n if (isToday(createdAt)) {\n return format(createdAt, 'p', optionalParam);\n }\n if (isYesterday(createdAt)) {\n return formatRelative(createdAt, new Date(), optionalParam);\n }\n return format(createdAt, 'MMM dd', optionalParam);\n};\n\nexport const getTotalMembers = (channel) => (\n channel && channel.memberCount\n ? channel.memberCount\n : 0\n);\n\nconst getPrettyLastMessage = (message = {}) => {\n const MAXLEN = 30;\n const { messageType, name } = message;\n if (messageType === 'file') {\n return truncateString(name, MAXLEN);\n }\n return message.message;\n};\n\nexport const getLastMessage = (channel) => (\n channel && channel.lastMessage\n ? getPrettyLastMessage(channel.lastMessage)\n : ''\n);\n\nexport const getChannelUnreadMessageCount = (channel) => (\n (channel && channel.unreadMessageCount)\n ? channel.unreadMessageCount\n : 0\n);\n","import React from 'react';\nimport SendBird from 'sendbird';\n\nimport './channel-preview.scss';\n\nimport ChannelAvatar from '../../../../ui/ChannelAvatar';\nimport Badge from '../../../../ui/Badge';\nimport Icon, { IconColors, IconTypes } from '../../../../ui/Icon';\nimport Label, { LabelTypography, LabelColors } from '../../../../ui/Label';\n\nimport * as utils from './utils';\n\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport { useLocalization } from '../../../../lib/LocalizationContext';\n\ninterface ChannelPreviewInterface {\n channel: SendBird.GroupChannel;\n isActive?: boolean;\n onClick: () => void;\n renderChannelAction: (props: { channel: SendBird.GroupChannel }) => React.ReactNode;\n tabIndex: number;\n}\n\nconst ChannelPreview: React.FC<ChannelPreviewInterface> = ({\n channel,\n isActive = false,\n renderChannelAction,\n onClick,\n tabIndex,\n}: ChannelPreviewInterface) => {\n const sbState = useSendbirdStateContext();\n const { dateLocale, stringSet } = useLocalization();\n const userId = sbState?.stores?.userStore?.user?.userId;\n const theme = sbState?.config?.theme;\n const { isBroadcast, isFrozen } = channel;\n return (\n <div\n className={[\n 'sendbird-channel-preview',\n isActive ? 'sendbird-channel-preview--active' : '',\n ].join(' ')}\n role=\"link\"\n onClick={onClick}\n onKeyPress={onClick}\n tabIndex={tabIndex}\n >\n <div\n className=\"sendbird-channel-preview__avatar\"\n >\n <ChannelAvatar\n channel={channel}\n userId={userId}\n theme={theme}\n />\n </div>\n <div className=\"sendbird-channel-preview__content\">\n <div className=\"sendbird-channel-preview__content__upper\">\n <div className=\"sendbird-channel-preview__content__upper__header\">\n {\n isBroadcast\n && (\n <div className=\"sendbird-channel-preview__content__upper__header__broadcast-icon\">\n <Icon\n type={IconTypes.BROADCAST}\n fillColor={IconColors.SECONDARY}\n height=\"16px\"\n width=\"16px\"\n />\n </div>\n )\n }\n <Label\n className=\"sendbird-channel-preview__content__upper__header__channel-name\"\n type={LabelTypography.SUBTITLE_2}\n color={LabelColors.ONBACKGROUND_1}\n >\n {utils.getChannelTitle(channel, userId, stringSet)}\n </Label>\n <Label\n className=\"sendbird-channel-preview__content__upper__header__total-members\"\n type={LabelTypography.CAPTION_2}\n color={LabelColors.ONBACKGROUND_2}\n >\n {utils.getTotalMembers(channel)}\n </Label>\n {\n isFrozen\n && (\n <div title=\"Frozen\" className=\"sendbird-channel-preview__content__upper__header__frozen-icon\">\n <Icon\n type={IconTypes.FREEZE}\n fillColor={IconColors.PRIMARY}\n height={12}\n width={12}\n />\n </div>\n )\n }\n </div>\n <Label\n className=\"sendbird-channel-preview__content__upper__last-message-at\"\n type={LabelTypography.CAPTION_3}\n color={LabelColors.ONBACKGROUND_2}\n >\n {utils.getLastMessageCreatedAt(channel, dateLocale)}\n </Label>\n </div>\n <div className=\"sendbird-channel-preview__content__lower\">\n <Label\n className=\"sendbird-channel-preview__content__lower__last-message\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_3}\n >\n {utils.getLastMessage(channel)}\n </Label>\n <div className=\"sendbird-channel-preview__content__lower__unread-message-count\">\n {\n utils.getChannelUnreadMessageCount(channel) // return number\n ? <Badge count={utils.getChannelUnreadMessageCount(channel)} />\n : null\n }\n </div>\n </div>\n </div>\n <div\n className=\"sendbird-channel-preview__action\"\n >\n { renderChannelAction({ channel }) }\n </div>\n </div>\n );\n}\n\nexport default ChannelPreview;\n"],"names":["getChannelTitle","channel","currentUserId","stringSet","LabelStringSet","name","members","NO_TITLE","length","NO_MEMBERS","filter","userId","map","nickname","NO_NAME","join","getLastMessageCreatedAt","locale","createdAt","lastMessage","optionalParam","isToday","format","isYesterday","formatRelative","Date","getTotalMembers","memberCount","getPrettyLastMessage","message","MAXLEN","messageType","truncateString","getLastMessage","getChannelUnreadMessageCount","unreadMessageCount","ChannelPreview","_a","_f","isActive","renderChannelAction","onClick","tabIndex","sbState","useSendbirdStateContext","_g","useLocalization","dateLocale","stores","userStore","user","theme","config","isBroadcast","isFrozen","React","IconTypes","BROADCAST","IconColors","SECONDARY","LabelTypography","SUBTITLE_2","LabelColors","ONBACKGROUND_1","utils","CAPTION_2","ONBACKGROUND_2","FREEZE","PRIMARY","CAPTION_3","BODY_2","ONBACKGROUND_3"],"mappings":"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"}