@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,224 @@
1
+ import { a as __spreadArray } from '../tslib.es6-e3c44017.js';
2
+ import React__default, { useRef, useContext } from 'react';
3
+ import { f as format } from '../index-770d7112.js';
4
+ import Avatar from './Avatar.js';
5
+ import ContextMenu, { MenuItems, MenuItem } from './ContextMenu.js';
6
+ import { L as Label, a as LabelTypography, b as LabelColors } from '../index-7a51bd16.js';
7
+ import Loader from './Loader.js';
8
+ import Icon, { IconTypes, IconColors } from './Icon.js';
9
+ import IconButton from './IconButton.js';
10
+ import TextButton from './TextButton.js';
11
+ import ConnectedUserProfile from './UserProfile.js';
12
+ import { a as UserProfileContext } from '../UserProfileContext-865db5e6.js';
13
+ import { u as useLocalization } from '../LocalizationContext-e4391013.js';
14
+ import { c as checkIsByMe, g as getSenderFromMessage, s as showMenuTrigger, b as isFineResend, d as isFineDelete, e as checkIsPending, f as checkIsFailed } from '../openChannelUtils-56a372e7.js';
15
+ import '../index-6ebf7894.js';
16
+ import './ImageRenderer.js';
17
+ import '../_rollupPluginBabelHelpers-20904f21.js';
18
+ import 'prop-types';
19
+ import '../uuid-b0c93400.js';
20
+ import '../index-8c72a94a.js';
21
+ import 'react-dom';
22
+ import './SortByRow.js';
23
+ import '../stringSet-4f6eaa60.js';
24
+ import '../color-ee3fc5ee.js';
25
+ import '../withSendBird.js';
26
+ import '../sendBirdSelectors.js';
27
+ import '../topics-9442035c.js';
28
+ import '../index-acebc2ff.js';
29
+
30
+ var checkFileType = function checkFileType(fileUrl) {
31
+ var audioFile = /(\.mp3)$/i;
32
+ var gifFile = /(\.gif)$/i;
33
+
34
+ if (audioFile.test(fileUrl)) {
35
+ return IconTypes.FILE_AUDIO;
36
+ }
37
+
38
+ if (gifFile.test(fileUrl)) {
39
+ return IconTypes.GIF;
40
+ }
41
+
42
+ return IconTypes.FILE_DOCUMENT;
43
+ };
44
+ var truncate = function truncate(fullStr, strLen) {
45
+ if (fullStr === null || fullStr === undefined) return '';
46
+ if (fullStr.length <= strLen) return fullStr;
47
+ var separator = '...';
48
+ var sepLen = separator.length;
49
+ var charsToShow = strLen - sepLen;
50
+ var frontChars = Math.ceil(charsToShow / 2);
51
+ var backChars = Math.floor(charsToShow / 2);
52
+ return fullStr.substr(0, frontChars) + separator + fullStr.substr(fullStr.length - backChars);
53
+ };
54
+
55
+ function OpenchannelFileMessage(_a) {
56
+ var className = _a.className,
57
+ message = _a.message,
58
+ userId = _a.userId,
59
+ disabled = _a.disabled,
60
+ chainTop = _a.chainTop,
61
+ showRemove = _a.showRemove,
62
+ resendMessage = _a.resendMessage;
63
+ var status = message === null || message === void 0 ? void 0 : message.sendingStatus;
64
+
65
+ var _b = useLocalization(),
66
+ dateLocale = _b.dateLocale,
67
+ stringSet = _b.stringSet;
68
+
69
+ var contextMenuRef = useRef(null);
70
+ var avatarRef = useRef(null);
71
+
72
+ var _c = useContext(UserProfileContext),
73
+ disableUserProfile = _c.disableUserProfile,
74
+ renderUserProfile = _c.renderUserProfile;
75
+
76
+ var openFileUrl = function openFileUrl() {
77
+ window.open(message.url);
78
+ };
79
+
80
+ var isByMe = checkIsByMe(message, userId);
81
+ var isPending = checkIsPending(status);
82
+ var isFailed = checkIsFailed(status);
83
+ var sender = getSenderFromMessage(message);
84
+ return /*#__PURE__*/React__default.createElement("div", {
85
+ className: __spreadArray(__spreadArray([], Array.isArray(className) ? className : [className], true), ['sendbird-openchannel-file-message'], false).join(' ')
86
+ }, /*#__PURE__*/React__default.createElement("div", {
87
+ className: "sendbird-openchannel-file-message__left"
88
+ }, !chainTop && /*#__PURE__*/React__default.createElement(ContextMenu, {
89
+ menuTrigger: function menuTrigger(toggleDropdown) {
90
+ return /*#__PURE__*/React__default.createElement(Avatar, {
91
+ className: "sendbird-openchannel-file-message__left__avatar",
92
+ src: sender.profileUrl || '',
93
+ ref: avatarRef,
94
+ width: "28px",
95
+ height: "28px",
96
+ onClick: function onClick() {
97
+ if (!disableUserProfile) {
98
+ toggleDropdown();
99
+ }
100
+ }
101
+ });
102
+ },
103
+ menuItems: function menuItems(closeDropdown) {
104
+ return /*#__PURE__*/React__default.createElement(MenuItems, {
105
+ parentRef: avatarRef,
106
+ parentContainRef: avatarRef,
107
+ closeDropdown: closeDropdown,
108
+ style: {
109
+ paddingTop: 0,
110
+ paddingBottom: 0
111
+ }
112
+ }, renderUserProfile ? renderUserProfile({
113
+ user: sender,
114
+ close: closeDropdown
115
+ }) : /*#__PURE__*/React__default.createElement(ConnectedUserProfile, {
116
+ user: sender,
117
+ onSuccess: closeDropdown,
118
+ disableMessaging: true
119
+ }));
120
+ }
121
+ })), /*#__PURE__*/React__default.createElement("div", {
122
+ className: "sendbird-openchannel-file-message__right"
123
+ }, !chainTop && /*#__PURE__*/React__default.createElement("div", {
124
+ className: "sendbird-openchannel-file-message__right__title"
125
+ }, /*#__PURE__*/React__default.createElement(Label, {
126
+ className: "sendbird-openchannel-file-message__right__title__sender-name",
127
+ type: LabelTypography.CAPTION_2,
128
+ color: isByMe ? LabelColors.SECONDARY_3 : LabelColors.ONBACKGROUND_2
129
+ }, sender && (sender.friendName || sender.nickname || sender.userId)), /*#__PURE__*/React__default.createElement(Label, {
130
+ className: "sendbird-openchannel-file-message__right__title__sent-at",
131
+ type: LabelTypography.CAPTION_3,
132
+ color: LabelColors.ONBACKGROUND_3
133
+ }, (message === null || message === void 0 ? void 0 : message.createdAt) && format(message.createdAt, 'p', {
134
+ locale: dateLocale
135
+ }))), /*#__PURE__*/React__default.createElement("div", {
136
+ className: "sendbird-openchannel-file-message__right__body"
137
+ }, checkFileType(message.url) && /*#__PURE__*/React__default.createElement(Icon, {
138
+ className: "sendbird-openchannel-file-message__right__body__icon",
139
+ type: checkFileType(message.url),
140
+ fillColor: IconColors.PRIMARY,
141
+ width: "48px",
142
+ height: "48px"
143
+ }), /*#__PURE__*/React__default.createElement(TextButton, {
144
+ className: "sendbird-openchannel-file-message__right__body__file-name",
145
+ onClick: openFileUrl
146
+ }, /*#__PURE__*/React__default.createElement(Label, {
147
+ type: LabelTypography.BODY_1,
148
+ color: LabelColors.ONBACKGROUND_1
149
+ }, truncate(message.name || message.url, 40)))), (isPending || isFailed) && /*#__PURE__*/React__default.createElement("div", {
150
+ className: "sendbird-openchannel-file-message__right__tail"
151
+ }, isPending && /*#__PURE__*/React__default.createElement(Loader, {
152
+ width: "16px",
153
+ height: "16px"
154
+ }, /*#__PURE__*/React__default.createElement(Icon, {
155
+ className: "sendbird-openchannel-file-message__right__tail__pending",
156
+ type: IconTypes.SPINNER,
157
+ fillColor: IconColors.PRIMARY,
158
+ width: "16px",
159
+ height: "16px"
160
+ })), isFailed && /*#__PURE__*/React__default.createElement(Icon, {
161
+ className: "sendbird-openchannel-file-message__right__tail__failed",
162
+ type: IconTypes.ERROR,
163
+ fillColor: IconColors.ERROR,
164
+ width: "16px",
165
+ height: "16px"
166
+ }))), /*#__PURE__*/React__default.createElement("div", {
167
+ className: "sendbird-openchannel-file-message__context-menu",
168
+ ref: contextMenuRef
169
+ }, /*#__PURE__*/React__default.createElement(ContextMenu, {
170
+ menuTrigger: function menuTrigger(toggleDropdown) {
171
+ return showMenuTrigger({
172
+ message: message,
173
+ userId: userId,
174
+ status: status
175
+ }) && /*#__PURE__*/React__default.createElement(IconButton, {
176
+ className: "sendbird-openchannel-file-message__context-menu__icon",
177
+ width: "32px",
178
+ height: "32px",
179
+ onClick: toggleDropdown
180
+ }, /*#__PURE__*/React__default.createElement(Icon, {
181
+ type: IconTypes.MORE,
182
+ width: "24px",
183
+ height: "24px"
184
+ }));
185
+ },
186
+ menuItems: function menuItems(closeDropdown) {
187
+ return /*#__PURE__*/React__default.createElement(MenuItems, {
188
+ parentRef: contextMenuRef,
189
+ parentContainRef: contextMenuRef,
190
+ closeDropdown: closeDropdown,
191
+ openLeft: true
192
+ }, isFineResend({
193
+ message: message,
194
+ userId: userId,
195
+ status: status
196
+ }) && /*#__PURE__*/React__default.createElement(MenuItem, {
197
+ onClick: function onClick() {
198
+ if (disabled) {
199
+ return;
200
+ }
201
+
202
+ resendMessage(message);
203
+ closeDropdown();
204
+ }
205
+ }, stringSet.CONTEXT_MENU_DROPDOWN__RESEND), isFineDelete({
206
+ message: message,
207
+ userId: userId,
208
+ status: status
209
+ }) && /*#__PURE__*/React__default.createElement(MenuItem, {
210
+ onClick: function onClick() {
211
+ if (disabled) {
212
+ return;
213
+ }
214
+
215
+ showRemove(true);
216
+ closeDropdown();
217
+ }
218
+ }, stringSet.CONTEXT_MENU_DROPDOWN__DELETE));
219
+ }
220
+ })));
221
+ }
222
+
223
+ export { OpenchannelFileMessage as default };
224
+ //# sourceMappingURL=OpenchannelFileMessage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OpenchannelFileMessage.js","sources":["../../src/ui/OpenchannelFileMessage/utils.ts","../../src/ui/OpenchannelFileMessage/index.tsx"],"sourcesContent":["import { IconTypes } from '../Icon';\n\nexport const checkFileType = (fileUrl: string): string => {\n const audioFile = /(\\.mp3)$/i;\n const gifFile = /(\\.gif)$/i;\n if (audioFile.test(fileUrl)) {\n return IconTypes.FILE_AUDIO;\n }\n if (gifFile.test(fileUrl)) {\n return IconTypes.GIF\n }\n return IconTypes.FILE_DOCUMENT;\n}\n\nexport const truncate = (fullStr:string, strLen: number): string => {\n if (fullStr === null || fullStr === undefined) return '';\n if (fullStr.length <= strLen) return fullStr;\n const separator = '...';\n const sepLen = separator.length;\n const charsToShow = strLen - sepLen;\n const frontChars = Math.ceil(charsToShow / 2);\n const backChars = Math.floor(charsToShow / 2);\n return fullStr.substr(0, frontChars) + separator + fullStr.substr(fullStr.length - backChars);\n};\n","import React, { useContext, useRef } from 'react';\nimport format from 'date-fns/format';\nimport './index.scss';\n\nimport Avatar from '../Avatar';\nimport ContextMenu, { MenuItems, MenuItem } from '../ContextMenu';\nimport Label, { LabelTypography, LabelColors } from '../Label';\nimport Loader from '../Loader';\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport IconButton from '../IconButton';\nimport TextButton from '../TextButton';\nimport UserProfile from '../UserProfile';\nimport { UserProfileContext } from '../../lib/UserProfileContext';\n\nimport { useLocalization } from '../../lib/LocalizationContext';\nimport { checkFileType, truncate } from './utils';\nimport { ClientFileMessage } from '../../index';\nimport {\n checkIsByMe,\n checkIsPending,\n checkIsFailed,\n isFineDelete,\n isFineResend,\n showMenuTrigger,\n} from '../../utils/openChannelUtils';\nimport { getSenderFromMessage } from '../../utils/openChannelUtils';\n\ninterface Props {\n className?: string | Array<string>;\n message: ClientFileMessage;\n userId: string;\n disabled?: boolean;\n chainTop?: boolean;\n chainBottom?: boolean;\n showRemove(bool: boolean): void;\n resendMessage(message: ClientFileMessage): void;\n}\n\nexport default function OpenchannelFileMessage({\n className,\n message,\n userId,\n disabled,\n chainTop,\n showRemove,\n resendMessage,\n}: Props): JSX.Element {\n const status = message?.sendingStatus;\n const { dateLocale, stringSet } = useLocalization();\n const contextMenuRef = useRef(null);\n const avatarRef = useRef(null);\n const { disableUserProfile, renderUserProfile } = useContext(UserProfileContext);\n\n const openFileUrl = () => { window.open(message.url); };\n\n const isByMe = checkIsByMe(message, userId);\n const isPending = checkIsPending(status);\n const isFailed = checkIsFailed(status);\n const sender = getSenderFromMessage(message);\n\n return (\n <div\n className={[\n ...(Array.isArray(className) ? className : [className]),\n 'sendbird-openchannel-file-message',\n ].join(' ')}\n >\n <div className=\"sendbird-openchannel-file-message__left\">\n {\n !chainTop && (\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n <Avatar\n className=\"sendbird-openchannel-file-message__left__avatar\"\n src={sender.profileUrl || ''}\n ref={avatarRef}\n width=\"28px\"\n height=\"28px\"\n onClick={() => {\n if (!disableUserProfile) {\n toggleDropdown();\n }\n }}\n />\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={avatarRef}\n parentContainRef={avatarRef}\n closeDropdown={closeDropdown}\n style={{ paddingTop: 0, paddingBottom: 0 }}\n >\n {\n renderUserProfile\n ? (\n renderUserProfile({\n user: sender,\n close: closeDropdown,\n })\n )\n : (\n <UserProfile\n user={sender}\n onSuccess={closeDropdown}\n disableMessaging\n />\n )\n }\n </MenuItems>\n )}\n />\n )\n }\n </div>\n <div className=\"sendbird-openchannel-file-message__right\">\n {\n !chainTop && (\n <div className=\"sendbird-openchannel-file-message__right__title\">\n <Label\n className=\"sendbird-openchannel-file-message__right__title__sender-name\"\n type={LabelTypography.CAPTION_2}\n color={isByMe ? LabelColors.SECONDARY_3 : LabelColors.ONBACKGROUND_2}\n >\n {\n sender && (\n sender.friendName\n || sender.nickname\n || sender.userId\n )\n }\n </Label>\n <Label\n className=\"sendbird-openchannel-file-message__right__title__sent-at\"\n type={LabelTypography.CAPTION_3}\n color={LabelColors.ONBACKGROUND_3}\n >\n {\n message?.createdAt && (\n format(message.createdAt, 'p', {\n locale: dateLocale,\n })\n )\n }\n </Label>\n </div>\n )\n }\n <div className=\"sendbird-openchannel-file-message__right__body\">\n {\n checkFileType(message.url) && (\n <Icon\n className=\"sendbird-openchannel-file-message__right__body__icon\"\n type={checkFileType(message.url)}\n fillColor={IconColors.PRIMARY}\n width=\"48px\"\n height=\"48px\"\n />\n )\n }\n <TextButton\n className=\"sendbird-openchannel-file-message__right__body__file-name\"\n onClick={openFileUrl}\n >\n <Label\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_1}\n >\n {truncate(message.name || message.url, 40)}\n </Label>\n </TextButton>\n </div>\n {\n (isPending || isFailed) && (\n <div className=\"sendbird-openchannel-file-message__right__tail\">\n {\n isPending && (\n <Loader\n width=\"16px\"\n height=\"16px\"\n >\n <Icon\n className=\"sendbird-openchannel-file-message__right__tail__pending\"\n type={IconTypes.SPINNER}\n fillColor={IconColors.PRIMARY}\n width=\"16px\"\n height=\"16px\"\n />\n </Loader>\n )\n }\n {\n isFailed && (\n <Icon\n className=\"sendbird-openchannel-file-message__right__tail__failed\"\n type={IconTypes.ERROR}\n fillColor={IconColors.ERROR}\n width=\"16px\"\n height=\"16px\"\n />\n )\n }\n </div>\n )\n }\n </div>\n <div\n className=\"sendbird-openchannel-file-message__context-menu\"\n ref={contextMenuRef}\n >\n {\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n showMenuTrigger({ message, userId, status }) && (\n <IconButton\n className=\"sendbird-openchannel-file-message__context-menu__icon\"\n width=\"32px\"\n height=\"32px\"\n onClick={toggleDropdown}\n >\n <Icon\n type={IconTypes.MORE}\n width=\"24px\"\n height=\"24px\"\n />\n </IconButton>\n )\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={contextMenuRef}\n parentContainRef={contextMenuRef}\n closeDropdown={closeDropdown}\n openLeft\n >\n {\n isFineResend({ message, userId, status }) && (\n <MenuItem\n onClick={() => {\n if (disabled) { return; }\n resendMessage(message);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__RESEND}\n </MenuItem>\n )\n }\n {\n isFineDelete({ message, userId, status }) && (\n <MenuItem\n onClick={() => {\n if (disabled) { return; }\n showRemove(true);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__DELETE}\n </MenuItem>\n )\n }\n </MenuItems>\n )}\n />\n }\n </div>\n </div>\n );\n}\n"],"names":["checkFileType","fileUrl","audioFile","gifFile","test","IconTypes","FILE_AUDIO","GIF","FILE_DOCUMENT","truncate","fullStr","strLen","undefined","length","separator","sepLen","charsToShow","frontChars","Math","ceil","backChars","floor","substr","OpenchannelFileMessage","_a","className","message","userId","disabled","chainTop","showRemove","resendMessage","status","sendingStatus","_b","useLocalization","dateLocale","stringSet","contextMenuRef","useRef","avatarRef","_c","useContext","UserProfileContext","disableUserProfile","renderUserProfile","openFileUrl","window","open","url","isByMe","checkIsByMe","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","React","__spreadArray","Array","isArray","join","toggleDropdown","profileUrl","closeDropdown","paddingTop","paddingBottom","user","close","UserProfile","LabelTypography","CAPTION_2","LabelColors","SECONDARY_3","ONBACKGROUND_2","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","IconColors","PRIMARY","BODY_1","ONBACKGROUND_1","name","SPINNER","ERROR","showMenuTrigger","MORE","isFineResend","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE"],"mappings":"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"}
@@ -0,0 +1,339 @@
1
+ import { a as __spreadArray } from '../tslib.es6-e3c44017.js';
2
+ import React__default, { useContext, useState, useRef, useMemo, useEffect } from 'react';
3
+ import { f as format } from '../index-770d7112.js';
4
+ import Avatar from './Avatar.js';
5
+ import ContextMenu, { MenuItems, MenuItem } from './ContextMenu.js';
6
+ import Icon, { IconTypes, IconColors } from './Icon.js';
7
+ import IconButton from './IconButton.js';
8
+ import ImageRenderer from './ImageRenderer.js';
9
+ import LinkLabel from './LinkLabel.js';
10
+ import { a as LabelTypography, b as LabelColors, L as Label } from '../index-7a51bd16.js';
11
+ import Loader from './Loader.js';
12
+ import ConnectedUserProfile from './UserProfile.js';
13
+ import { a as UserProfileContext } from '../UserProfileContext-865db5e6.js';
14
+ import { u as uuidv4 } from '../uuid-b0c93400.js';
15
+ import { c as copyToClipboard } from '../utils-af1b9829.js';
16
+ import { u as useLocalization } from '../LocalizationContext-e4391013.js';
17
+ import { c as checkIsByMe, g as getSenderFromMessage, s as showMenuTrigger, i as isFineCopy, a as isFineEdit, b as isFineResend, d as isFineDelete, e as checkIsPending, f as checkIsFailed } from '../openChannelUtils-56a372e7.js';
18
+ import '../index-6ebf7894.js';
19
+ import '../_rollupPluginBabelHelpers-20904f21.js';
20
+ import 'prop-types';
21
+ import '../index-8c72a94a.js';
22
+ import 'react-dom';
23
+ import './SortByRow.js';
24
+ import '../stringSet-4f6eaa60.js';
25
+ import '../withSendBird.js';
26
+ import '../sendBirdSelectors.js';
27
+ import '../topics-9442035c.js';
28
+ import '../index-acebc2ff.js';
29
+
30
+ var URL_REG = /[-a-zA-Z0-9@:%._+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_+.~#?&//=]*)/;
31
+ var createUrlTester = function createUrlTester(regexp) {
32
+ return function (text) {
33
+ return regexp.test(text);
34
+ };
35
+ };
36
+ var checkOGIsEnalbed = function checkOGIsEnalbed(message) {
37
+ var ogMetaData = message.ogMetaData;
38
+
39
+ if (!ogMetaData) {
40
+ return false;
41
+ }
42
+
43
+ var url = ogMetaData.url;
44
+
45
+ if (!url) {
46
+ return false;
47
+ }
48
+
49
+ return true;
50
+ };
51
+
52
+ function OpenchannelOGMessage(_a) {
53
+ var message = _a.message,
54
+ className = _a.className,
55
+ disabled = _a.disabled,
56
+ showEdit = _a.showEdit,
57
+ showRemove = _a.showRemove,
58
+ resendMessage = _a.resendMessage,
59
+ chainTop = _a.chainTop,
60
+ userId = _a.userId;
61
+
62
+ if (!message || message.messageType !== 'user') {
63
+ return null;
64
+ }
65
+
66
+ var status = message === null || message === void 0 ? void 0 : message.sendingStatus;
67
+ var ogMetaData = message.ogMetaData;
68
+ var defaultImage = ogMetaData.defaultImage;
69
+
70
+ var _b = useLocalization(),
71
+ stringSet = _b.stringSet,
72
+ dateLocale = _b.dateLocale;
73
+
74
+ var _c = useContext(UserProfileContext),
75
+ disableUserProfile = _c.disableUserProfile,
76
+ renderUserProfile = _c.renderUserProfile;
77
+
78
+ var _d = useState({}),
79
+ contextStyle = _d[0],
80
+ setContextStyle = _d[1];
81
+
82
+ var messageComponentRef = useRef(null);
83
+ var contextMenuRef = useRef(null);
84
+ var avatarRef = useRef(null);
85
+ var isUrl = createUrlTester(URL_REG);
86
+ var isByMe = checkIsByMe(message, userId);
87
+ var isPending = checkIsPending(status);
88
+ var isFailed = checkIsFailed(status);
89
+ var sender = getSenderFromMessage(message);
90
+ var MemoizedMessageText = useMemo(function () {
91
+ return function () {
92
+ var wordClassName = 'sendbird-openchannel-og-message--word';
93
+ var splitMessage = message.message.split(' ');
94
+ var matchedMessage = splitMessage.map(function (word) {
95
+ return isUrl(word) ? /*#__PURE__*/React__default.createElement(LinkLabel, {
96
+ key: uuidv4(),
97
+ className: [wordClassName, 'sendbird-openchannel-og-message--word--link'],
98
+ src: word,
99
+ type: LabelTypography.BODY_1,
100
+ color: LabelColors.PRIMARY
101
+ }, word) : /*#__PURE__*/React__default.createElement(Label, {
102
+ key: uuidv4(),
103
+ className: wordClassName,
104
+ type: LabelTypography.BODY_1,
105
+ color: LabelColors.ONBACKGROUND_1
106
+ }, word);
107
+ });
108
+
109
+ if (message.updatedAt > 0) {
110
+ matchedMessage.push( /*#__PURE__*/React__default.createElement(Label, {
111
+ key: uuidv4(),
112
+ className: wordClassName,
113
+ type: LabelTypography.BODY_1,
114
+ color: LabelColors.ONBACKGROUND_2
115
+ }, stringSet.MESSAGE_EDITED));
116
+ }
117
+
118
+ return matchedMessage;
119
+ };
120
+ }, [message, message.updatedAt]);
121
+
122
+ var openLink = function openLink() {
123
+ if (checkOGIsEnalbed(message)) {
124
+ var url = ogMetaData.url;
125
+ window.open(url);
126
+ }
127
+ }; // place conxt menu top depending clientHeight of message component
128
+
129
+
130
+ useEffect(function () {
131
+ var _a;
132
+
133
+ if (((_a = messageComponentRef === null || messageComponentRef === void 0 ? void 0 : messageComponentRef.current) === null || _a === void 0 ? void 0 : _a.clientHeight) > 36) {
134
+ setContextStyle({
135
+ top: '8px '
136
+ });
137
+ } else {
138
+ setContextStyle({
139
+ top: '2px'
140
+ });
141
+ }
142
+ }, [window.innerWidth]);
143
+ return /*#__PURE__*/React__default.createElement("div", {
144
+ className: __spreadArray(__spreadArray([], Array.isArray(className) ? className : [className], true), ['sendbird-openchannel-og-message'], false).join(' '),
145
+ ref: messageComponentRef
146
+ }, /*#__PURE__*/React__default.createElement("div", {
147
+ className: "sendbird-openchannel-og-message__top"
148
+ }, /*#__PURE__*/React__default.createElement("div", {
149
+ className: "sendbird-openchannel-og-message__top__left"
150
+ }, !chainTop && /*#__PURE__*/React__default.createElement(ContextMenu, {
151
+ menuTrigger: function menuTrigger(toggleDropdown) {
152
+ return /*#__PURE__*/React__default.createElement(Avatar, {
153
+ className: "sendbird-openchannel-og-message__top__left__avatar",
154
+ src: sender.profileUrl || '',
155
+ ref: avatarRef,
156
+ width: "28px",
157
+ height: "28px",
158
+ onClick: function onClick() {
159
+ if (!disableUserProfile) {
160
+ toggleDropdown();
161
+ }
162
+ }
163
+ });
164
+ },
165
+ menuItems: function menuItems(closeDropdown) {
166
+ return /*#__PURE__*/React__default.createElement(MenuItems, {
167
+ parentRef: avatarRef,
168
+ parentContainRef: avatarRef,
169
+ closeDropdown: closeDropdown,
170
+ style: {
171
+ paddingTop: 0,
172
+ paddingBottom: 0
173
+ }
174
+ }, renderUserProfile ? renderUserProfile({
175
+ user: sender,
176
+ close: closeDropdown
177
+ }) : /*#__PURE__*/React__default.createElement(ConnectedUserProfile, {
178
+ user: sender,
179
+ onSuccess: closeDropdown,
180
+ disableMessaging: true
181
+ }));
182
+ }
183
+ })), /*#__PURE__*/React__default.createElement("div", {
184
+ className: "sendbird-openchannel-og-message__top__right"
185
+ }, !chainTop && /*#__PURE__*/React__default.createElement("div", {
186
+ className: "sendbird-openchannel-og-message__top__right__title"
187
+ }, /*#__PURE__*/React__default.createElement(Label, {
188
+ className: "sendbird-openchannel-og-message__top__right__title__sender-name",
189
+ type: LabelTypography.CAPTION_2,
190
+ color: isByMe ? LabelColors.SECONDARY_3 : LabelColors.ONBACKGROUND_2
191
+ }, sender && (sender.friendName || sender.nickname || sender.userId)), /*#__PURE__*/React__default.createElement(Label, {
192
+ className: "sendbird-openchannel-og-message__top__right__title__sent-at",
193
+ type: LabelTypography.CAPTION_3,
194
+ color: LabelColors.ONBACKGROUND_3
195
+ }, (message === null || message === void 0 ? void 0 : message.createdAt) && format(message === null || message === void 0 ? void 0 : message.createdAt, 'p', {
196
+ locale: dateLocale
197
+ }))), /*#__PURE__*/React__default.createElement("div", {
198
+ className: "sendbird-openchannel-og-message__top__right__description"
199
+ }, /*#__PURE__*/React__default.createElement(Label, {
200
+ className: "sendbird-openchannel-og-message__top__right__description__message",
201
+ type: LabelTypography.BODY_1,
202
+ color: LabelColors.ONBACKGROUND_1
203
+ }, MemoizedMessageText()))), /*#__PURE__*/React__default.createElement("div", {
204
+ className: "sendbird-openchannel-og-message__top__context-menu",
205
+ ref: contextMenuRef,
206
+ style: contextStyle
207
+ }, /*#__PURE__*/React__default.createElement(ContextMenu, {
208
+ menuTrigger: function menuTrigger(toggleDropdown) {
209
+ return showMenuTrigger({
210
+ message: message,
211
+ userId: userId,
212
+ status: status
213
+ }) && /*#__PURE__*/React__default.createElement(IconButton, {
214
+ className: "sendbird-openchannel-og-message__top__context-menu--icon",
215
+ width: "32px",
216
+ height: "32px",
217
+ onClick: function onClick() {
218
+ toggleDropdown();
219
+ }
220
+ }, /*#__PURE__*/React__default.createElement(Icon, {
221
+ type: IconTypes.MORE,
222
+ fillColor: IconColors.CONTENT_INVERSE,
223
+ width: "24px",
224
+ height: "24px"
225
+ }));
226
+ },
227
+ menuItems: function menuItems(closeDropdown) {
228
+ return /*#__PURE__*/React__default.createElement(MenuItems, {
229
+ parentRef: contextMenuRef,
230
+ parentContainRef: contextMenuRef,
231
+ closeDropdown: closeDropdown,
232
+ openLeft: true
233
+ }, isFineCopy({
234
+ message: message,
235
+ userId: userId,
236
+ status: status
237
+ }) && /*#__PURE__*/React__default.createElement(MenuItem, {
238
+ className: "sendbird-openchannel-og-message__top__context-menu__copy",
239
+ onClick: function onClick() {
240
+ copyToClipboard(message.message);
241
+ closeDropdown();
242
+ }
243
+ }, stringSet.CONTEXT_MENU_DROPDOWN__COPY), isFineEdit({
244
+ message: message,
245
+ userId: userId,
246
+ status: status
247
+ }) && /*#__PURE__*/React__default.createElement(MenuItem, {
248
+ className: "sendbird-openchannel-og-message__top__context-menu__edit",
249
+ onClick: function onClick() {
250
+ if (disabled) {
251
+ return;
252
+ }
253
+
254
+ showEdit(true);
255
+ closeDropdown();
256
+ }
257
+ }, stringSet.CONTEXT_MENU_DROPDOWN__EDIT), isFineResend({
258
+ message: message,
259
+ userId: userId,
260
+ status: status
261
+ }) && /*#__PURE__*/React__default.createElement(MenuItem, {
262
+ className: "sendbird-openchannel-og-message__top__context-menu__resend",
263
+ onClick: function onClick() {
264
+ resendMessage(message);
265
+ closeDropdown();
266
+ }
267
+ }, stringSet.CONTEXT_MENU_DROPDOWN__RESEND), isFineDelete({
268
+ message: message,
269
+ userId: userId,
270
+ status: status
271
+ }) && /*#__PURE__*/React__default.createElement(MenuItem, {
272
+ className: "sendbird-openchannel-og-message__top__context-menu__delete",
273
+ onClick: function onClick() {
274
+ if (disabled) {
275
+ return;
276
+ }
277
+
278
+ showRemove(true);
279
+ closeDropdown();
280
+ }
281
+ }, stringSet.CONTEXT_MENU_DROPDOWN__DELETE));
282
+ }
283
+ }))), /*#__PURE__*/React__default.createElement("div", {
284
+ className: "sendbird-openchannel-og-message__bottom"
285
+ }, /*#__PURE__*/React__default.createElement("div", {
286
+ className: "sendbird-openchannel-og-message__bottom__og-tag"
287
+ }, ogMetaData.url && /*#__PURE__*/React__default.createElement(Label, {
288
+ className: "sendbird-openchannel-og-message__bottom__og-tag__url",
289
+ type: LabelTypography.CAPTION_3,
290
+ color: LabelColors.ONBACKGROUND_2
291
+ }, ogMetaData.url), ogMetaData.title && /*#__PURE__*/React__default.createElement(LinkLabel, {
292
+ className: "sendbird-openchannel-og-message__bottom__og-tag__title",
293
+ src: ogMetaData.url,
294
+ type: LabelTypography.SUBTITLE_2,
295
+ color: LabelColors.PRIMARY
296
+ }, ogMetaData.title), ogMetaData.description && /*#__PURE__*/React__default.createElement(Label, {
297
+ className: "sendbird-openchannel-og-message__bottom__og-tag__description",
298
+ type: LabelTypography.BODY_2,
299
+ color: LabelColors.ONBACKGROUND_1
300
+ }, ogMetaData.description), ogMetaData.url && /*#__PURE__*/React__default.createElement("div", {
301
+ className: "sendbird-openchannel-og-message__bottom__og-tag__thumbnail",
302
+ role: "button",
303
+ onClick: openLink,
304
+ onKeyDown: openLink,
305
+ tabIndex: 0
306
+ }, defaultImage && /*#__PURE__*/React__default.createElement(ImageRenderer, {
307
+ className: "sendbird-openchannel-og-message__bottom__og-tag__thumbnail__image",
308
+ url: defaultImage.url || '',
309
+ alt: defaultImage.alt || '',
310
+ height: "189px",
311
+ defaultComponent: /*#__PURE__*/React__default.createElement("div", {
312
+ className: "sendbird-openchannel-og-message__bottom__og-tag__thumbnail__image--placeholder"
313
+ }, /*#__PURE__*/React__default.createElement(Icon, {
314
+ type: IconTypes.THUMBNAIL_NONE,
315
+ width: "56px",
316
+ height: "56px"
317
+ }))
318
+ }))), (isPending || isFailed) && /*#__PURE__*/React__default.createElement("div", {
319
+ className: "sendbird-openchannel-og-message__top__right__tail"
320
+ }, isPending && /*#__PURE__*/React__default.createElement(Loader, {
321
+ width: "16px",
322
+ height: "16px"
323
+ }, /*#__PURE__*/React__default.createElement(Icon, {
324
+ className: "sendbird-openchannel-og-message__top__right__tail__pending",
325
+ type: IconTypes.SPINNER,
326
+ fillColor: IconColors.PRIMARY,
327
+ width: "16px",
328
+ height: "16px"
329
+ })), isFailed && /*#__PURE__*/React__default.createElement(Icon, {
330
+ className: "sendbird-openchannel-og-message__top__right__tail__failed",
331
+ type: IconTypes.ERROR,
332
+ fillColor: IconColors.ERROR,
333
+ width: "16px",
334
+ height: "16px"
335
+ }))));
336
+ }
337
+
338
+ export { OpenchannelOGMessage as default };
339
+ //# sourceMappingURL=OpenchannelOGMessage.js.map