@sendbird/uikit-react 3.0.0-beta.4 → 3.0.0-rc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (625) hide show
  1. package/App.js +316 -0
  2. package/App.js.map +1 -0
  3. package/CHANGELOG.md +43 -1
  4. package/Channel/components/ChannelHeader.js +121 -0
  5. package/Channel/components/ChannelHeader.js.map +1 -0
  6. package/Channel/components/ChannelUI.js +182 -0
  7. package/Channel/components/ChannelUI.js.map +1 -0
  8. package/Channel/components/FileViewer.js +153 -0
  9. package/Channel/components/FileViewer.js.map +1 -0
  10. package/Channel/components/FrozenNotification.js +20 -0
  11. package/Channel/components/FrozenNotification.js.map +1 -0
  12. package/Channel/components/Message.js +364 -0
  13. package/Channel/components/Message.js.map +1 -0
  14. package/Channel/components/MessageInput.js +214 -0
  15. package/Channel/components/MessageInput.js.map +1 -0
  16. package/Channel/components/MessageList.js +242 -0
  17. package/Channel/components/MessageList.js.map +1 -0
  18. package/Channel/components/RemoveMessageModal.js +55 -0
  19. package/Channel/components/RemoveMessageModal.js.map +1 -0
  20. package/Channel/components/SuggestedMentionList.js +306 -0
  21. package/Channel/components/SuggestedMentionList.js.map +1 -0
  22. package/Channel/components/TypingIndicator.js +102 -0
  23. package/Channel/components/TypingIndicator.js.map +1 -0
  24. package/Channel/components/UnreadCount.js +41 -0
  25. package/Channel/components/UnreadCount.js.map +1 -0
  26. package/Channel/context.js +26 -0
  27. package/Channel/context.js.map +1 -0
  28. package/Channel.js +109 -0
  29. package/Channel.js.map +1 -0
  30. package/ChannelList/components/AddChannel.js +70 -0
  31. package/ChannelList/components/AddChannel.js.map +1 -0
  32. package/ChannelList/components/ChannelListHeader.js +62 -0
  33. package/ChannelList/components/ChannelListHeader.js.map +1 -0
  34. package/ChannelList/components/ChannelListUI.js +235 -0
  35. package/ChannelList/components/ChannelListUI.js.map +1 -0
  36. package/ChannelList/components/ChannelPreview.js +216 -0
  37. package/ChannelList/components/ChannelPreview.js.map +1 -0
  38. package/ChannelList/components/ChannelPreviewAction.js +133 -0
  39. package/ChannelList/components/ChannelPreviewAction.js.map +1 -0
  40. package/ChannelList/context.js +15 -0
  41. package/ChannelList/context.js.map +1 -0
  42. package/ChannelList.js +91 -0
  43. package/ChannelList.js.map +1 -0
  44. package/ChannelListProvider-76b1ec23.js +944 -0
  45. package/ChannelListProvider-76b1ec23.js.map +1 -0
  46. package/ChannelProvider-c0ed5fae.js +2075 -0
  47. package/ChannelProvider-c0ed5fae.js.map +1 -0
  48. package/ChannelSettings/components/ChannelProfile.js +102 -0
  49. package/ChannelSettings/components/ChannelProfile.js.map +1 -0
  50. package/ChannelSettings/components/ChannelSettingsUI.js +152 -0
  51. package/ChannelSettings/components/ChannelSettingsUI.js.map +1 -0
  52. package/ChannelSettings/components/EditDetailsModal.js +158 -0
  53. package/ChannelSettings/components/EditDetailsModal.js.map +1 -0
  54. package/ChannelSettings/components/LeaveChannel.js +53 -0
  55. package/ChannelSettings/components/LeaveChannel.js.map +1 -0
  56. package/ChannelSettings/components/ModerationPanel.js +851 -0
  57. package/ChannelSettings/components/ModerationPanel.js.map +1 -0
  58. package/ChannelSettings/components/UserListItem.js +106 -0
  59. package/ChannelSettings/components/UserListItem.js.map +1 -0
  60. package/ChannelSettings/components/UserPanel.js +79 -0
  61. package/ChannelSettings/components/UserPanel.js.map +1 -0
  62. package/ChannelSettings/context.js +93 -0
  63. package/ChannelSettings/context.js.map +1 -0
  64. package/ChannelSettings.js +71 -0
  65. package/ChannelSettings.js.map +1 -0
  66. package/CreateChannel/components/CreateChannelUI.js +53 -0
  67. package/CreateChannel/components/CreateChannelUI.js.map +1 -0
  68. package/CreateChannel/components/InviteUsers.js +180 -0
  69. package/CreateChannel/components/InviteUsers.js.map +1 -0
  70. package/CreateChannel/components/SelectChannelType.js +131 -0
  71. package/CreateChannel/components/SelectChannelType.js.map +1 -0
  72. package/CreateChannel/context.js +9 -0
  73. package/CreateChannel/context.js.map +1 -0
  74. package/CreateChannel.js +53 -0
  75. package/CreateChannel.js.map +1 -0
  76. package/CreateChannelProvider-8c72aa06.js +53 -0
  77. package/CreateChannelProvider-8c72aa06.js.map +1 -0
  78. package/EditUserProfile/components/EditUserProfileUI.js +26 -0
  79. package/EditUserProfile/components/EditUserProfileUI.js.map +1 -0
  80. package/EditUserProfile/context.js +27 -0
  81. package/EditUserProfile/context.js.map +1 -0
  82. package/EditUserProfile.js +39 -0
  83. package/EditUserProfile.js.map +1 -0
  84. package/LocalizationContext-fb3dafcd.js +22 -0
  85. package/LocalizationContext-fb3dafcd.js.map +1 -0
  86. package/MemberList-01d3c8bf.js +404 -0
  87. package/MemberList-01d3c8bf.js.map +1 -0
  88. package/MessageSearch/components/MessageSearchUI.js +151 -0
  89. package/MessageSearch/components/MessageSearchUI.js.map +1 -0
  90. package/MessageSearch/context.js +387 -0
  91. package/MessageSearch/context.js.map +1 -0
  92. package/MessageSearch.js +146 -0
  93. package/MessageSearch.js.map +1 -0
  94. package/OpenChannel/components/FrozenChannelNotification.js +20 -0
  95. package/OpenChannel/components/FrozenChannelNotification.js.map +1 -0
  96. package/OpenChannel/components/OpenChannelHeader.js +80 -0
  97. package/OpenChannel/components/OpenChannelHeader.js.map +1 -0
  98. package/OpenChannel/components/OpenChannelInput.js +58 -0
  99. package/OpenChannel/components/OpenChannelInput.js.map +1 -0
  100. package/OpenChannel/components/OpenChannelMessage.js +287 -0
  101. package/OpenChannel/components/OpenChannelMessage.js.map +1 -0
  102. package/OpenChannel/components/OpenChannelMessageList.js +158 -0
  103. package/OpenChannel/components/OpenChannelMessageList.js.map +1 -0
  104. package/OpenChannel/components/OpenChannelUI.js +111 -0
  105. package/OpenChannel/components/OpenChannelUI.js.map +1 -0
  106. package/OpenChannel/context.js +16 -0
  107. package/OpenChannel/context.js.map +1 -0
  108. package/OpenChannel.js +82 -0
  109. package/OpenChannel.js.map +1 -0
  110. package/OpenChannelProvider-0fb27972.js +1946 -0
  111. package/OpenChannelProvider-0fb27972.js.map +1 -0
  112. package/OpenChannelSettings/components/EditDetailsModal.js +143 -0
  113. package/OpenChannelSettings/components/EditDetailsModal.js.map +1 -0
  114. package/OpenChannelSettings/components/OpenChannelProfile.js +81 -0
  115. package/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -0
  116. package/OpenChannelSettings/components/OpenChannelSettingsUI.js +120 -0
  117. package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -0
  118. package/OpenChannelSettings/components/OperatorUI.js +199 -0
  119. package/OpenChannelSettings/components/OperatorUI.js.map +1 -0
  120. package/OpenChannelSettings/components/ParticipantUI.js +145 -0
  121. package/OpenChannelSettings/components/ParticipantUI.js.map +1 -0
  122. package/OpenChannelSettings/context.js +64 -0
  123. package/OpenChannelSettings/context.js.map +1 -0
  124. package/OpenChannelSettings.js +64 -0
  125. package/OpenChannelSettings.js.map +1 -0
  126. package/README.md +0 -1
  127. package/SendbirdProvider.js +782 -0
  128. package/SendbirdProvider.js.map +1 -0
  129. package/UserProfileContext-6a387a08.js +38 -0
  130. package/UserProfileContext-6a387a08.js.map +1 -0
  131. package/__bundle-7dfccc8c-03df3ada.js +24 -0
  132. package/__bundle-7dfccc8c-03df3ada.js.map +1 -0
  133. package/_rollupPluginBabelHelpers-084fb589.js +233 -0
  134. package/_rollupPluginBabelHelpers-084fb589.js.map +1 -0
  135. package/actionTypes-302a2801.js +6 -0
  136. package/actionTypes-302a2801.js.map +1 -0
  137. package/cjs/App.js +323 -0
  138. package/cjs/App.js.map +1 -0
  139. package/cjs/Channel/components/ChannelHeader.js +127 -0
  140. package/cjs/Channel/components/ChannelHeader.js.map +1 -0
  141. package/cjs/Channel/components/ChannelUI.js +188 -0
  142. package/cjs/Channel/components/ChannelUI.js.map +1 -0
  143. package/cjs/Channel/components/FileViewer.js +162 -0
  144. package/cjs/Channel/components/FileViewer.js.map +1 -0
  145. package/cjs/Channel/components/FrozenNotification.js +26 -0
  146. package/cjs/Channel/components/FrozenNotification.js.map +1 -0
  147. package/cjs/Channel/components/Message.js +370 -0
  148. package/cjs/Channel/components/Message.js.map +1 -0
  149. package/cjs/Channel/components/MessageInput.js +220 -0
  150. package/cjs/Channel/components/MessageInput.js.map +1 -0
  151. package/cjs/Channel/components/MessageList.js +248 -0
  152. package/cjs/Channel/components/MessageList.js.map +1 -0
  153. package/cjs/Channel/components/RemoveMessageModal.js +61 -0
  154. package/cjs/Channel/components/RemoveMessageModal.js.map +1 -0
  155. package/cjs/Channel/components/SuggestedMentionList.js +312 -0
  156. package/cjs/Channel/components/SuggestedMentionList.js.map +1 -0
  157. package/cjs/Channel/components/TypingIndicator.js +111 -0
  158. package/cjs/Channel/components/TypingIndicator.js.map +1 -0
  159. package/cjs/Channel/components/UnreadCount.js +47 -0
  160. package/cjs/Channel/components/UnreadCount.js.map +1 -0
  161. package/cjs/Channel/context.js +35 -0
  162. package/cjs/Channel/context.js.map +1 -0
  163. package/cjs/Channel.js +115 -0
  164. package/cjs/Channel.js.map +1 -0
  165. package/cjs/ChannelList/components/AddChannel.js +79 -0
  166. package/cjs/ChannelList/components/AddChannel.js.map +1 -0
  167. package/cjs/ChannelList/components/ChannelListHeader.js +68 -0
  168. package/cjs/ChannelList/components/ChannelListHeader.js.map +1 -0
  169. package/cjs/ChannelList/components/ChannelListUI.js +241 -0
  170. package/cjs/ChannelList/components/ChannelListUI.js.map +1 -0
  171. package/cjs/ChannelList/components/ChannelPreview.js +222 -0
  172. package/cjs/ChannelList/components/ChannelPreview.js.map +1 -0
  173. package/cjs/ChannelList/components/ChannelPreviewAction.js +140 -0
  174. package/cjs/ChannelList/components/ChannelPreviewAction.js.map +1 -0
  175. package/cjs/ChannelList/context.js +24 -0
  176. package/cjs/ChannelList/context.js.map +1 -0
  177. package/cjs/ChannelList.js +97 -0
  178. package/cjs/ChannelList.js.map +1 -0
  179. package/cjs/ChannelListProvider-7d1c0466.js +956 -0
  180. package/cjs/ChannelListProvider-7d1c0466.js.map +1 -0
  181. package/cjs/ChannelProvider-a3ec5a56.js +2088 -0
  182. package/cjs/ChannelProvider-a3ec5a56.js.map +1 -0
  183. package/cjs/ChannelSettings/components/ChannelProfile.js +108 -0
  184. package/cjs/ChannelSettings/components/ChannelProfile.js.map +1 -0
  185. package/cjs/ChannelSettings/components/ChannelSettingsUI.js +158 -0
  186. package/cjs/ChannelSettings/components/ChannelSettingsUI.js.map +1 -0
  187. package/cjs/ChannelSettings/components/EditDetailsModal.js +164 -0
  188. package/cjs/ChannelSettings/components/EditDetailsModal.js.map +1 -0
  189. package/cjs/ChannelSettings/components/LeaveChannel.js +59 -0
  190. package/cjs/ChannelSettings/components/LeaveChannel.js.map +1 -0
  191. package/cjs/ChannelSettings/components/ModerationPanel.js +857 -0
  192. package/cjs/ChannelSettings/components/ModerationPanel.js.map +1 -0
  193. package/cjs/ChannelSettings/components/UserListItem.js +112 -0
  194. package/cjs/ChannelSettings/components/UserListItem.js.map +1 -0
  195. package/cjs/ChannelSettings/components/UserPanel.js +85 -0
  196. package/cjs/ChannelSettings/components/UserPanel.js.map +1 -0
  197. package/cjs/ChannelSettings/context.js +102 -0
  198. package/cjs/ChannelSettings/context.js.map +1 -0
  199. package/cjs/ChannelSettings.js +77 -0
  200. package/cjs/ChannelSettings.js.map +1 -0
  201. package/cjs/CreateChannel/components/CreateChannelUI.js +59 -0
  202. package/cjs/CreateChannel/components/CreateChannelUI.js.map +1 -0
  203. package/cjs/CreateChannel/components/InviteUsers.js +186 -0
  204. package/cjs/CreateChannel/components/InviteUsers.js.map +1 -0
  205. package/cjs/CreateChannel/components/SelectChannelType.js +137 -0
  206. package/cjs/CreateChannel/components/SelectChannelType.js.map +1 -0
  207. package/cjs/CreateChannel/context.js +18 -0
  208. package/cjs/CreateChannel/context.js.map +1 -0
  209. package/cjs/CreateChannel.js +59 -0
  210. package/cjs/CreateChannel.js.map +1 -0
  211. package/cjs/CreateChannelProvider-95fbfb06.js +60 -0
  212. package/cjs/CreateChannelProvider-95fbfb06.js.map +1 -0
  213. package/cjs/EditUserProfile/components/EditUserProfileUI.js +32 -0
  214. package/cjs/EditUserProfile/components/EditUserProfileUI.js.map +1 -0
  215. package/cjs/EditUserProfile/context.js +36 -0
  216. package/cjs/EditUserProfile/context.js.map +1 -0
  217. package/cjs/EditUserProfile.js +45 -0
  218. package/cjs/EditUserProfile.js.map +1 -0
  219. package/cjs/LocalizationContext-5a6a0f67.js +30 -0
  220. package/cjs/LocalizationContext-5a6a0f67.js.map +1 -0
  221. package/cjs/MemberList-bfecdd64.js +410 -0
  222. package/cjs/MemberList-bfecdd64.js.map +1 -0
  223. package/cjs/MessageSearch/components/MessageSearchUI.js +160 -0
  224. package/cjs/MessageSearch/components/MessageSearchUI.js.map +1 -0
  225. package/cjs/MessageSearch/context.js +396 -0
  226. package/cjs/MessageSearch/context.js.map +1 -0
  227. package/cjs/MessageSearch.js +152 -0
  228. package/cjs/MessageSearch.js.map +1 -0
  229. package/cjs/OpenChannel/components/FrozenChannelNotification.js +26 -0
  230. package/cjs/OpenChannel/components/FrozenChannelNotification.js.map +1 -0
  231. package/cjs/OpenChannel/components/OpenChannelHeader.js +86 -0
  232. package/cjs/OpenChannel/components/OpenChannelHeader.js.map +1 -0
  233. package/cjs/OpenChannel/components/OpenChannelInput.js +64 -0
  234. package/cjs/OpenChannel/components/OpenChannelInput.js.map +1 -0
  235. package/cjs/OpenChannel/components/OpenChannelMessage.js +293 -0
  236. package/cjs/OpenChannel/components/OpenChannelMessage.js.map +1 -0
  237. package/cjs/OpenChannel/components/OpenChannelMessageList.js +164 -0
  238. package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -0
  239. package/cjs/OpenChannel/components/OpenChannelUI.js +117 -0
  240. package/cjs/OpenChannel/components/OpenChannelUI.js.map +1 -0
  241. package/cjs/OpenChannel/context.js +25 -0
  242. package/cjs/OpenChannel/context.js.map +1 -0
  243. package/cjs/OpenChannel.js +88 -0
  244. package/cjs/OpenChannel.js.map +1 -0
  245. package/cjs/OpenChannelProvider-e8247193.js +1955 -0
  246. package/cjs/OpenChannelProvider-e8247193.js.map +1 -0
  247. package/cjs/OpenChannelSettings/components/EditDetailsModal.js +149 -0
  248. package/cjs/OpenChannelSettings/components/EditDetailsModal.js.map +1 -0
  249. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js +87 -0
  250. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -0
  251. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js +126 -0
  252. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -0
  253. package/cjs/OpenChannelSettings/components/OperatorUI.js +209 -0
  254. package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -0
  255. package/cjs/OpenChannelSettings/components/ParticipantUI.js +151 -0
  256. package/cjs/OpenChannelSettings/components/ParticipantUI.js.map +1 -0
  257. package/cjs/OpenChannelSettings/context.js +73 -0
  258. package/cjs/OpenChannelSettings/context.js.map +1 -0
  259. package/cjs/OpenChannelSettings.js +70 -0
  260. package/cjs/OpenChannelSettings.js.map +1 -0
  261. package/cjs/SendbirdProvider.js +790 -0
  262. package/cjs/SendbirdProvider.js.map +1 -0
  263. package/cjs/UserProfileContext-17c8f75c.js +46 -0
  264. package/cjs/UserProfileContext-17c8f75c.js.map +1 -0
  265. package/cjs/__bundle-7dfccc8c-c3c55861.js +151 -0
  266. package/cjs/__bundle-7dfccc8c-c3c55861.js.map +1 -0
  267. package/cjs/_rollupPluginBabelHelpers-d984e855.js +243 -0
  268. package/cjs/_rollupPluginBabelHelpers-d984e855.js.map +1 -0
  269. package/cjs/actionTypes-7a330bec.js +10 -0
  270. package/cjs/actionTypes-7a330bec.js.map +1 -0
  271. package/cjs/color-b30f84a2.js +42 -0
  272. package/cjs/color-b30f84a2.js.map +1 -0
  273. package/cjs/compareIds-d8053014.js +20 -0
  274. package/cjs/compareIds-d8053014.js.map +1 -0
  275. package/cjs/const-2623fae1.js +22 -0
  276. package/cjs/const-2623fae1.js.map +1 -0
  277. package/cjs/const-6aa26f9f.js +14 -0
  278. package/cjs/const-6aa26f9f.js.map +1 -0
  279. package/cjs/context-83ecdafd.js +19 -0
  280. package/cjs/context-83ecdafd.js.map +1 -0
  281. package/cjs/dist/index.css +4603 -0
  282. package/cjs/dist/index.css.map +1 -0
  283. package/cjs/groupChannel-e311e26a.js +9 -0
  284. package/cjs/groupChannel-e311e26a.js.map +1 -0
  285. package/cjs/index-1e14c5b9.js +130 -0
  286. package/cjs/index-1e14c5b9.js.map +1 -0
  287. package/cjs/index-2537cbc7.js +284 -0
  288. package/cjs/index-2537cbc7.js.map +1 -0
  289. package/cjs/index-40d245a3.js +729 -0
  290. package/cjs/index-40d245a3.js.map +1 -0
  291. package/cjs/index-5e7b82c2.js +178 -0
  292. package/cjs/index-5e7b82c2.js.map +1 -0
  293. package/cjs/index-72479c2a.js +514 -0
  294. package/cjs/index-72479c2a.js.map +1 -0
  295. package/cjs/index-ab5d906d.js +67 -0
  296. package/cjs/index-ab5d906d.js.map +1 -0
  297. package/cjs/index-cdcd27bc.js +1880 -0
  298. package/cjs/index-cdcd27bc.js.map +1 -0
  299. package/cjs/index-ce679d41.js +9 -0
  300. package/cjs/index-ce679d41.js.map +1 -0
  301. package/cjs/index-df05e765.js +142 -0
  302. package/cjs/index-df05e765.js.map +1 -0
  303. package/cjs/index-f9677913.js +97 -0
  304. package/cjs/index-f9677913.js.map +1 -0
  305. package/cjs/index.js +165 -0
  306. package/cjs/index.js.map +1 -0
  307. package/cjs/openChannel-e9f65946.js +13 -0
  308. package/cjs/openChannel-e9f65946.js.map +1 -0
  309. package/cjs/openChannelUtils-4b7d2697.js +97 -0
  310. package/cjs/openChannelUtils-4b7d2697.js.map +1 -0
  311. package/cjs/sendbirdSelectors.js +696 -0
  312. package/cjs/sendbirdSelectors.js.map +1 -0
  313. package/cjs/stringSet-2f3588b5.js +118 -0
  314. package/cjs/stringSet-2f3588b5.js.map +1 -0
  315. package/cjs/topics-582e38dc.js +18 -0
  316. package/cjs/topics-582e38dc.js.map +1 -0
  317. package/cjs/tslib.es6-d9c7aa8b.js +40 -0
  318. package/cjs/tslib.es6-d9c7aa8b.js.map +1 -0
  319. package/cjs/ui/Accordion.js +74 -0
  320. package/cjs/ui/Accordion.js.map +1 -0
  321. package/cjs/ui/AccordionGroup.js +32 -0
  322. package/cjs/ui/AccordionGroup.js.map +1 -0
  323. package/cjs/ui/AdminMessage.js +45 -0
  324. package/cjs/ui/AdminMessage.js.map +1 -0
  325. package/cjs/ui/Avatar.js +226 -0
  326. package/cjs/ui/Avatar.js.map +1 -0
  327. package/cjs/ui/Badge.js +45 -0
  328. package/cjs/ui/Badge.js.map +1 -0
  329. package/cjs/ui/Button.js +17 -0
  330. package/cjs/ui/Button.js.map +1 -0
  331. package/cjs/ui/ChannelAvatar.js +59 -0
  332. package/cjs/ui/ChannelAvatar.js.map +1 -0
  333. package/cjs/ui/ChannelPreview.js +208 -0
  334. package/cjs/ui/ChannelPreview.js.map +1 -0
  335. package/cjs/ui/ChatHeader.js +152 -0
  336. package/cjs/ui/ChatHeader.js.map +1 -0
  337. package/cjs/ui/Checkbox.js +49 -0
  338. package/cjs/ui/Checkbox.js.map +1 -0
  339. package/cjs/ui/ConnectionStatus.js +34 -0
  340. package/cjs/ui/ConnectionStatus.js.map +1 -0
  341. package/cjs/ui/ContextMenu.js +410 -0
  342. package/cjs/ui/ContextMenu.js.map +1 -0
  343. package/cjs/ui/DateSeparator.js +44 -0
  344. package/cjs/ui/DateSeparator.js.map +1 -0
  345. package/cjs/ui/Dropdown.js +107 -0
  346. package/cjs/ui/Dropdown.js.map +1 -0
  347. package/cjs/ui/EmojiReactions.js +127 -0
  348. package/cjs/ui/EmojiReactions.js.map +1 -0
  349. package/cjs/ui/FileMessageItemBody.js +57 -0
  350. package/cjs/ui/FileMessageItemBody.js.map +1 -0
  351. package/cjs/ui/FileViewer.js +174 -0
  352. package/cjs/ui/FileViewer.js.map +1 -0
  353. package/cjs/ui/Icon.js +1466 -0
  354. package/cjs/ui/Icon.js.map +1 -0
  355. package/cjs/ui/IconButton.js +83 -0
  356. package/cjs/ui/IconButton.js.map +1 -0
  357. package/cjs/ui/ImageRenderer.js +138 -0
  358. package/cjs/ui/ImageRenderer.js.map +1 -0
  359. package/cjs/ui/Input.js +74 -0
  360. package/cjs/ui/Input.js.map +1 -0
  361. package/cjs/ui/Label.js +17 -0
  362. package/cjs/ui/Label.js.map +1 -0
  363. package/cjs/ui/LinkLabel.js +51 -0
  364. package/cjs/ui/LinkLabel.js.map +1 -0
  365. package/cjs/ui/Loader.js +44 -0
  366. package/cjs/ui/Loader.js.map +1 -0
  367. package/cjs/ui/MentionLabel.js +100 -0
  368. package/cjs/ui/MentionLabel.js.map +1 -0
  369. package/cjs/ui/MentionUserLabel.js +25 -0
  370. package/cjs/ui/MentionUserLabel.js.map +1 -0
  371. package/cjs/ui/MessageContent.js +297 -0
  372. package/cjs/ui/MessageContent.js.map +1 -0
  373. package/cjs/ui/MessageInput.js +5052 -0
  374. package/cjs/ui/MessageInput.js.map +1 -0
  375. package/cjs/ui/MessageItemMenu.js +137 -0
  376. package/cjs/ui/MessageItemMenu.js.map +1 -0
  377. package/cjs/ui/MessageItemReactionMenu.js +112 -0
  378. package/cjs/ui/MessageItemReactionMenu.js.map +1 -0
  379. package/cjs/ui/MessageSearchFileItem.js +131 -0
  380. package/cjs/ui/MessageSearchFileItem.js.map +1 -0
  381. package/cjs/ui/MessageSearchItem.js +93 -0
  382. package/cjs/ui/MessageSearchItem.js.map +1 -0
  383. package/cjs/ui/MessageStatus.js +66 -0
  384. package/cjs/ui/MessageStatus.js.map +1 -0
  385. package/cjs/ui/Modal.js +140 -0
  386. package/cjs/ui/Modal.js.map +1 -0
  387. package/cjs/ui/MutedAvatarOverlay.js +40 -0
  388. package/cjs/ui/MutedAvatarOverlay.js.map +1 -0
  389. package/cjs/ui/OGMessageItemBody.js +119 -0
  390. package/cjs/ui/OGMessageItemBody.js.map +1 -0
  391. package/cjs/ui/OpenChannelAdminMessage.js +27 -0
  392. package/cjs/ui/OpenChannelAdminMessage.js.map +1 -0
  393. package/cjs/ui/OpenChannelAvatar.js +41 -0
  394. package/cjs/ui/OpenChannelAvatar.js.map +1 -0
  395. package/cjs/ui/OpenchannelConversationHeader.js +73 -0
  396. package/cjs/ui/OpenchannelConversationHeader.js.map +1 -0
  397. package/cjs/ui/OpenchannelFileMessage.js +231 -0
  398. package/cjs/ui/OpenchannelFileMessage.js.map +1 -0
  399. package/cjs/ui/OpenchannelOGMessage.js +346 -0
  400. package/cjs/ui/OpenchannelOGMessage.js.map +1 -0
  401. package/cjs/ui/OpenchannelThumbnailMessage.js +306 -0
  402. package/cjs/ui/OpenchannelThumbnailMessage.js.map +1 -0
  403. package/cjs/ui/OpenchannelUserMessage.js +265 -0
  404. package/cjs/ui/OpenchannelUserMessage.js.map +1 -0
  405. package/cjs/ui/PlaceHolder.js +20 -0
  406. package/cjs/ui/PlaceHolder.js.map +1 -0
  407. package/cjs/ui/QuoteMessage.js +131 -0
  408. package/cjs/ui/QuoteMessage.js.map +1 -0
  409. package/cjs/ui/QuoteMessageInput.js +97 -0
  410. package/cjs/ui/QuoteMessageInput.js.map +1 -0
  411. package/cjs/ui/ReactionBadge.js +68 -0
  412. package/cjs/ui/ReactionBadge.js.map +1 -0
  413. package/cjs/ui/ReactionButton.js +55 -0
  414. package/cjs/ui/ReactionButton.js.map +1 -0
  415. package/cjs/ui/SortByRow.js +57 -0
  416. package/cjs/ui/SortByRow.js.map +1 -0
  417. package/cjs/ui/TextButton.js +45 -0
  418. package/cjs/ui/TextButton.js.map +1 -0
  419. package/cjs/ui/TextMessageItemBody.js +76 -0
  420. package/cjs/ui/TextMessageItemBody.js.map +1 -0
  421. package/cjs/ui/ThumbnailMessageItemBody.js +82 -0
  422. package/cjs/ui/ThumbnailMessageItemBody.js.map +1 -0
  423. package/cjs/ui/Tooltip.js +35 -0
  424. package/cjs/ui/Tooltip.js.map +1 -0
  425. package/cjs/ui/TooltipWrapper.js +65 -0
  426. package/cjs/ui/TooltipWrapper.js.map +1 -0
  427. package/cjs/ui/UnknownMessageItemBody.js +41 -0
  428. package/cjs/ui/UnknownMessageItemBody.js.map +1 -0
  429. package/cjs/ui/UserListItem.js +159 -0
  430. package/cjs/ui/UserListItem.js.map +1 -0
  431. package/cjs/ui/UserProfile.js +88 -0
  432. package/cjs/ui/UserProfile.js.map +1 -0
  433. package/cjs/ui/Word.js +76 -0
  434. package/cjs/ui/Word.js.map +1 -0
  435. package/cjs/useSendbirdStateContext.js +22 -0
  436. package/cjs/useSendbirdStateContext.js.map +1 -0
  437. package/cjs/utils-031aba48.js +6 -0
  438. package/cjs/utils-031aba48.js.map +1 -0
  439. package/cjs/utils-510b93ac.js +38 -0
  440. package/cjs/utils-510b93ac.js.map +1 -0
  441. package/cjs/utils-689065e6.js +32 -0
  442. package/cjs/utils-689065e6.js.map +1 -0
  443. package/cjs/uuid-099485ae.js +19 -0
  444. package/cjs/uuid-099485ae.js.map +1 -0
  445. package/cjs/withSendBird.js +35 -0
  446. package/cjs/withSendBird.js.map +1 -0
  447. package/color-9bf8c922.js +39 -0
  448. package/color-9bf8c922.js.map +1 -0
  449. package/compareIds-b78d7cd6.js +18 -0
  450. package/compareIds-b78d7cd6.js.map +1 -0
  451. package/const-40b58d8b.js +18 -0
  452. package/const-40b58d8b.js.map +1 -0
  453. package/const-99800b8d.js +8 -0
  454. package/const-99800b8d.js.map +1 -0
  455. package/context-bedea43b.js +12 -0
  456. package/context-bedea43b.js.map +1 -0
  457. package/dist/index.css +292 -152
  458. package/dist/index.css.map +1 -1
  459. package/groupChannel-96502de7.js +6 -0
  460. package/groupChannel-96502de7.js.map +1 -0
  461. package/index-13729368.js +512 -0
  462. package/index-13729368.js.map +1 -0
  463. package/index-16bed610.js +64 -0
  464. package/index-16bed610.js.map +1 -0
  465. package/index-1d112ad4.js +7 -0
  466. package/index-1d112ad4.js.map +1 -0
  467. package/index-71ad343b.js +171 -0
  468. package/index-71ad343b.js.map +1 -0
  469. package/index-71e2bf26.js +131 -0
  470. package/index-71e2bf26.js.map +1 -0
  471. package/index-8e6a607b.js +688 -0
  472. package/index-8e6a607b.js.map +1 -0
  473. package/index-a5e8849a.js +280 -0
  474. package/index-a5e8849a.js.map +1 -0
  475. package/index-b574cc8e.js +87 -0
  476. package/index-b574cc8e.js.map +1 -0
  477. package/index-c95d2aab.js +121 -0
  478. package/index-c95d2aab.js.map +1 -0
  479. package/index-ccd99cfe.js +1873 -0
  480. package/index-ccd99cfe.js.map +1 -0
  481. package/index.d.ts +1965 -0
  482. package/index.d.ts_bkup +1883 -0
  483. package/index.js +146 -0
  484. package/index.js.map +1 -0
  485. package/openChannel-dd5c9246.js +8 -0
  486. package/openChannel-dd5c9246.js.map +1 -0
  487. package/openChannelUtils-211a679a.js +86 -0
  488. package/openChannelUtils-211a679a.js.map +1 -0
  489. package/package.json +11 -33
  490. package/sendbirdSelectors.js +671 -0
  491. package/sendbirdSelectors.js.map +1 -0
  492. package/stringSet-d3a8a2a0.js +116 -0
  493. package/stringSet-d3a8a2a0.js.map +1 -0
  494. package/topics-f941ba80.js +10 -0
  495. package/topics-f941ba80.js.map +1 -0
  496. package/tslib.es6-a7db0cc5.js +38 -0
  497. package/tslib.es6-a7db0cc5.js.map +1 -0
  498. package/ui/Accordion.js +65 -0
  499. package/ui/Accordion.js.map +1 -0
  500. package/ui/AccordionGroup.js +26 -0
  501. package/ui/AccordionGroup.js.map +1 -0
  502. package/ui/AdminMessage.js +38 -0
  503. package/ui/AdminMessage.js.map +1 -0
  504. package/ui/Avatar.js +217 -0
  505. package/ui/Avatar.js.map +1 -0
  506. package/ui/Badge.js +38 -0
  507. package/ui/Badge.js.map +1 -0
  508. package/ui/Button.js +7 -0
  509. package/ui/Button.js.map +1 -0
  510. package/ui/ChannelAvatar.js +53 -0
  511. package/ui/ChannelAvatar.js.map +1 -0
  512. package/ui/ChannelPreview.js +201 -0
  513. package/ui/ChannelPreview.js.map +1 -0
  514. package/ui/ChatHeader.js +145 -0
  515. package/ui/ChatHeader.js.map +1 -0
  516. package/ui/Checkbox.js +42 -0
  517. package/ui/Checkbox.js.map +1 -0
  518. package/ui/ConnectionStatus.js +28 -0
  519. package/ui/ConnectionStatus.js.map +1 -0
  520. package/ui/ContextMenu.js +396 -0
  521. package/ui/ContextMenu.js.map +1 -0
  522. package/ui/DateSeparator.js +37 -0
  523. package/ui/DateSeparator.js.map +1 -0
  524. package/ui/Dropdown.js +97 -0
  525. package/ui/Dropdown.js.map +1 -0
  526. package/ui/EmojiReactions.js +121 -0
  527. package/ui/EmojiReactions.js.map +1 -0
  528. package/ui/FileMessageItemBody.js +51 -0
  529. package/ui/FileMessageItemBody.js.map +1 -0
  530. package/ui/FileViewer.js +164 -0
  531. package/ui/FileViewer.js.map +1 -0
  532. package/ui/Icon.js +1436 -0
  533. package/ui/Icon.js.map +1 -0
  534. package/ui/IconButton.js +76 -0
  535. package/ui/IconButton.js.map +1 -0
  536. package/ui/ImageRenderer.js +131 -0
  537. package/ui/ImageRenderer.js.map +1 -0
  538. package/ui/Input.js +64 -0
  539. package/ui/Input.js.map +1 -0
  540. package/ui/Label.js +6 -0
  541. package/ui/Label.js.map +1 -0
  542. package/ui/LinkLabel.js +40 -0
  543. package/ui/LinkLabel.js.map +1 -0
  544. package/ui/Loader.js +37 -0
  545. package/ui/Loader.js.map +1 -0
  546. package/ui/MentionLabel.js +94 -0
  547. package/ui/MentionLabel.js.map +1 -0
  548. package/ui/MentionUserLabel.js +19 -0
  549. package/ui/MentionUserLabel.js.map +1 -0
  550. package/ui/MessageContent.js +291 -0
  551. package/ui/MessageContent.js.map +1 -0
  552. package/ui/MessageInput.js +5044 -0
  553. package/ui/MessageInput.js.map +1 -0
  554. package/ui/MessageItemMenu.js +131 -0
  555. package/ui/MessageItemMenu.js.map +1 -0
  556. package/ui/MessageItemReactionMenu.js +106 -0
  557. package/ui/MessageItemReactionMenu.js.map +1 -0
  558. package/ui/MessageSearchFileItem.js +125 -0
  559. package/ui/MessageSearchFileItem.js.map +1 -0
  560. package/ui/MessageSearchItem.js +87 -0
  561. package/ui/MessageSearchItem.js.map +1 -0
  562. package/ui/MessageStatus.js +57 -0
  563. package/ui/MessageStatus.js.map +1 -0
  564. package/ui/Modal.js +128 -0
  565. package/ui/Modal.js.map +1 -0
  566. package/ui/MutedAvatarOverlay.js +34 -0
  567. package/ui/MutedAvatarOverlay.js.map +1 -0
  568. package/ui/OGMessageItemBody.js +113 -0
  569. package/ui/OGMessageItemBody.js.map +1 -0
  570. package/ui/OpenChannelAdminMessage.js +21 -0
  571. package/ui/OpenChannelAdminMessage.js.map +1 -0
  572. package/ui/OpenChannelAvatar.js +35 -0
  573. package/ui/OpenChannelAvatar.js.map +1 -0
  574. package/ui/OpenchannelConversationHeader.js +67 -0
  575. package/ui/OpenchannelConversationHeader.js.map +1 -0
  576. package/ui/OpenchannelFileMessage.js +225 -0
  577. package/ui/OpenchannelFileMessage.js.map +1 -0
  578. package/ui/OpenchannelOGMessage.js +340 -0
  579. package/ui/OpenchannelOGMessage.js.map +1 -0
  580. package/ui/OpenchannelThumbnailMessage.js +300 -0
  581. package/ui/OpenchannelThumbnailMessage.js.map +1 -0
  582. package/ui/OpenchannelUserMessage.js +259 -0
  583. package/ui/OpenchannelUserMessage.js.map +1 -0
  584. package/ui/PlaceHolder.js +11 -0
  585. package/ui/PlaceHolder.js.map +1 -0
  586. package/ui/QuoteMessage.js +125 -0
  587. package/ui/QuoteMessage.js.map +1 -0
  588. package/ui/QuoteMessageInput.js +91 -0
  589. package/ui/QuoteMessageInput.js.map +1 -0
  590. package/ui/ReactionBadge.js +61 -0
  591. package/ui/ReactionBadge.js.map +1 -0
  592. package/ui/ReactionButton.js +48 -0
  593. package/ui/ReactionButton.js.map +1 -0
  594. package/ui/SortByRow.js +50 -0
  595. package/ui/SortByRow.js.map +1 -0
  596. package/ui/TextButton.js +38 -0
  597. package/ui/TextButton.js.map +1 -0
  598. package/ui/TextMessageItemBody.js +70 -0
  599. package/ui/TextMessageItemBody.js.map +1 -0
  600. package/ui/ThumbnailMessageItemBody.js +76 -0
  601. package/ui/ThumbnailMessageItemBody.js.map +1 -0
  602. package/ui/Tooltip.js +28 -0
  603. package/ui/Tooltip.js.map +1 -0
  604. package/ui/TooltipWrapper.js +58 -0
  605. package/ui/TooltipWrapper.js.map +1 -0
  606. package/ui/UnknownMessageItemBody.js +35 -0
  607. package/ui/UnknownMessageItemBody.js.map +1 -0
  608. package/ui/UserListItem.js +152 -0
  609. package/ui/UserListItem.js.map +1 -0
  610. package/ui/UserProfile.js +82 -0
  611. package/ui/UserProfile.js.map +1 -0
  612. package/ui/Word.js +70 -0
  613. package/ui/Word.js.map +1 -0
  614. package/useSendbirdStateContext.js +20 -0
  615. package/useSendbirdStateContext.js.map +1 -0
  616. package/utils-2e3623c0.js +30 -0
  617. package/utils-2e3623c0.js.map +1 -0
  618. package/utils-cadde06a.js +4 -0
  619. package/utils-cadde06a.js.map +1 -0
  620. package/utils-d9325ddf.js +34 -0
  621. package/utils-d9325ddf.js.map +1 -0
  622. package/uuid-748dae7a.js +17 -0
  623. package/uuid-748dae7a.js.map +1 -0
  624. package/withSendBird.js +26 -0
  625. package/withSendBird.js.map +1 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OpenchannelOGMessage.js","sources":["../../../src/ui/OpenchannelOGMessage/utils.ts","../../../src/ui/OpenchannelOGMessage/index.tsx"],"sourcesContent":["import type { UserMessage } from \"@sendbird/chat/message\";\n\nexport const URL_REG = /[-a-zA-Z0-9@:%._+~#=]{1,256}\\.[a-zA-Z0-9()]{1,6}\\b([-a-zA-Z0-9()@:%_+.~#?&//=]*)/;\nexport const createUrlTester = (regexp: RegExp) => (text: string): boolean => regexp.test(text);\nexport const checkOGIsEnalbed = (message: UserMessage): boolean => {\n const { ogMetaData } = message;\n if (!ogMetaData) {\n return false;\n }\n const { url } = ogMetaData;\n if (!url) {\n return false;\n }\n return true;\n};\n","import React, { useState, useContext, useMemo, useRef, useEffect } from 'react';\nimport { UserMessage } from '@sendbird/chat/message';\nimport format from 'date-fns/format';\nimport './index.scss';\n\nimport Avatar from '../Avatar';\nimport ContextMenu, { MenuItems, MenuItem } from '../ContextMenu';\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport IconButton from '../IconButton';\nimport ImageRenderer from '../ImageRenderer';\nimport LinkLabel from '../LinkLabel';\nimport Label, { LabelTypography, LabelColors } from '../Label';\nimport Loader from '../Loader';\nimport UserProfile from '../UserProfile';\nimport { UserProfileContext } from '../../lib/UserProfileContext';\n\nimport uuidv4 from '../../utils/uuid';\nimport { copyToClipboard } from '../OpenchannelUserMessage/utils';\nimport { useLocalization } from '../../lib/LocalizationContext';\nimport { checkOGIsEnalbed, createUrlTester, URL_REG } from './utils';\nimport {\n checkIsByMe,\n checkIsPending,\n checkIsFailed,\n isFineCopy,\n isFineEdit,\n isFineResend,\n isFineDelete,\n showMenuTrigger,\n} from '../../utils/openChannelUtils';\nimport { getSenderFromMessage } from '../../utils/openChannelUtils';\n\ninterface Props {\n message: UserMessage;\n className?: string | Array<string>;\n disabled?: boolean;\n showEdit(bool: boolean): void;\n showRemove(bool: boolean): void;\n resendMessage(message: UserMessage): void;\n chainTop?: boolean;\n chainBottom?: boolean;\n userId: string;\n}\n\nexport default function OpenchannelOGMessage({\n message,\n className,\n disabled,\n showEdit,\n showRemove,\n resendMessage,\n chainTop,\n userId,\n}: Props): JSX.Element {\n if (!message || message.messageType !== 'user') {\n return null;\n }\n\n const status = message?.sendingStatus;\n const { ogMetaData } = message;\n const { defaultImage } = ogMetaData;\n\n const { stringSet, dateLocale } = useLocalization();\n const { disableUserProfile, renderUserProfile } = useContext(UserProfileContext);\n const [contextStyle, setContextStyle] = useState({});\n const messageComponentRef = useRef(null);\n const contextMenuRef = useRef(null);\n const avatarRef = useRef(null);\n\n const isUrl = createUrlTester(URL_REG);\n const isByMe = checkIsByMe(message, userId);\n const isPending = checkIsPending(status);\n const isFailed = checkIsFailed(status);\n const sender = getSenderFromMessage(message);\n\n const MemoizedMessageText = useMemo(() => () => {\n const wordClassName = 'sendbird-openchannel-og-message--word';\n const splitMessage = message.message.split(' ');\n const matchedMessage = splitMessage\n .map((word) => (\n isUrl(word)\n ? (\n <LinkLabel\n key={uuidv4()}\n className={[\n wordClassName,\n 'sendbird-openchannel-og-message--word--link'\n ]}\n src={word}\n type={LabelTypography.BODY_1}\n color={LabelColors.PRIMARY}\n >\n {word}\n </LinkLabel>\n )\n : (\n <Label\n key={uuidv4()}\n className={wordClassName}\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_1}\n >\n {word}\n </Label>\n )\n ));\n\n if (message.updatedAt > 0) {\n matchedMessage.push(\n <Label\n key={uuidv4()}\n className={wordClassName}\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_2}\n >\n {stringSet.MESSAGE_EDITED}\n </Label>,\n );\n }\n\n return matchedMessage;\n }, [message, message.updatedAt]);\n\n const openLink = () => {\n if (checkOGIsEnalbed(message)) {\n const { url } = ogMetaData;\n window.open(url);\n }\n };\n\n // place conxt menu top depending clientHeight of message component\n useEffect(() => {\n if (messageComponentRef?.current?.clientHeight > 36) {\n setContextStyle({ top: '8px ' });\n } else {\n setContextStyle({ top: '2px' });\n }\n }, [window.innerWidth]);\n\n return (\n <div\n className={[\n ...(Array.isArray(className) ? className : [className]),\n 'sendbird-openchannel-og-message',\n ].join(' ')}\n ref={messageComponentRef}\n >\n <div\n className=\"sendbird-openchannel-og-message__top\"\n >\n <div className=\"sendbird-openchannel-og-message__top__left\">\n {\n !chainTop && (\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n <Avatar\n className=\"sendbird-openchannel-og-message__top__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-og-message__top__right\">\n {\n !chainTop && (\n <div className=\"sendbird-openchannel-og-message__top__right__title\">\n <Label\n className=\"sendbird-openchannel-og-message__top__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-og-message__top__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-og-message__top__right__description\">\n <Label\n className=\"sendbird-openchannel-og-message__top__right__description__message\"\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_1}\n >\n {MemoizedMessageText()}\n </Label>\n </div>\n </div>\n {\n <div\n className=\"sendbird-openchannel-og-message__top__context-menu\"\n ref={contextMenuRef}\n style={contextStyle}\n >\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n showMenuTrigger({ message: message, userId: userId, status: status }) && (\n <IconButton\n className=\"sendbird-openchannel-og-message__top__context-menu--icon\"\n width=\"32px\"\n height=\"32px\"\n onClick={() => {\n toggleDropdown();\n }}\n >\n <Icon\n type={IconTypes.MORE}\n fillColor={IconColors.CONTENT_INVERSE}\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 isFineCopy({ message, userId, status }) && (\n <MenuItem\n className=\"sendbird-openchannel-og-message__top__context-menu__copy\"\n onClick={() => {\n copyToClipboard(message.message);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__COPY}\n </MenuItem>\n )\n }\n {\n isFineEdit({ message, userId, status }) && (\n <MenuItem\n className=\"sendbird-openchannel-og-message__top__context-menu__edit\"\n onClick={() => {\n if (disabled) {\n return;\n }\n showEdit(true);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__EDIT}\n </MenuItem>\n )\n }\n {\n isFineResend({ message, userId, status }) && (\n <MenuItem\n className=\"sendbird-openchannel-og-message__top__context-menu__resend\"\n onClick={() => {\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 className=\"sendbird-openchannel-og-message__top__context-menu__delete\"\n onClick={() => {\n if (disabled) {\n return;\n }\n showRemove(true);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__DELETE}\n </MenuItem>\n )\n }\n </MenuItems>\n )}\n />\n </div>\n }\n </div>\n <div className=\"sendbird-openchannel-og-message__bottom\">\n <div className=\"sendbird-openchannel-og-message__bottom__og-tag\">\n {\n ogMetaData.url && (\n <Label\n className=\"sendbird-openchannel-og-message__bottom__og-tag__url\"\n type={LabelTypography.CAPTION_3}\n color={LabelColors.ONBACKGROUND_2}\n >\n {ogMetaData.url}\n </Label>\n )\n }\n {\n ogMetaData.title && (\n <LinkLabel\n className=\"sendbird-openchannel-og-message__bottom__og-tag__title\"\n src={ogMetaData.url}\n type={LabelTypography.SUBTITLE_2}\n color={LabelColors.PRIMARY}\n >\n {\n ogMetaData.title\n }\n </LinkLabel>\n )\n }\n {\n ogMetaData.description && (\n <Label\n className=\"sendbird-openchannel-og-message__bottom__og-tag__description\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_1}\n >\n {ogMetaData.description}\n </Label>\n )\n }\n {\n ogMetaData.url && (\n <div\n className=\"sendbird-openchannel-og-message__bottom__og-tag__thumbnail\"\n role=\"button\"\n onClick={openLink}\n onKeyDown={openLink}\n tabIndex={0}\n >\n {\n defaultImage && (\n <ImageRenderer\n className=\"sendbird-openchannel-og-message__bottom__og-tag__thumbnail__image\"\n url={defaultImage.url || ''}\n alt={defaultImage.alt || ''}\n height=\"189px\"\n defaultComponent={(\n <div className=\"sendbird-openchannel-og-message__bottom__og-tag__thumbnail__image--placeholder\">\n <Icon\n type={IconTypes.THUMBNAIL_NONE}\n width=\"56px\"\n height=\"56px\"\n />\n </div>\n )}\n />\n )\n }\n </div>\n )\n }\n </div>\n {\n (isPending || isFailed) && (\n <div className=\"sendbird-openchannel-og-message__top__right__tail\">\n {\n isPending && (\n <Loader\n width=\"16px\"\n height=\"16px\"\n >\n <Icon\n className=\"sendbird-openchannel-og-message__top__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-og-message__top__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 );\n}\n"],"names":["URL_REG","createUrlTester","regexp","text","test","checkOGIsEnalbed","message","ogMetaData","url","OpenchannelOGMessage","_a","className","disabled","showEdit","showRemove","resendMessage","chainTop","userId","messageType","status","sendingStatus","defaultImage","_b","useLocalization","stringSet","dateLocale","_c","useContext","UserProfileContext","disableUserProfile","renderUserProfile","_d","useState","contextStyle","setContextStyle","messageComponentRef","useRef","contextMenuRef","avatarRef","isUrl","isByMe","checkIsByMe","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","MemoizedMessageText","useMemo","wordClassName","splitMessage","split","matchedMessage","map","word","React","LinkLabel","uuidv4","LabelTypography","BODY_1","LabelColors","PRIMARY","Label","ONBACKGROUND_1","updatedAt","push","ONBACKGROUND_2","MESSAGE_EDITED","openLink","window","open","useEffect","current","clientHeight","top","innerWidth","__spreadArray","Array","isArray","join","ContextMenu","toggleDropdown","Avatar","profileUrl","closeDropdown","MenuItems","paddingTop","paddingBottom","user","close","UserProfile","CAPTION_2","SECONDARY_3","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","showMenuTrigger","IconButton","Icon","IconTypes","MORE","IconColors","CONTENT_INVERSE","isFineCopy","MenuItem","copyToClipboard","CONTEXT_MENU_DROPDOWN__COPY","isFineEdit","CONTEXT_MENU_DROPDOWN__EDIT","isFineResend","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE","title","SUBTITLE_2","description","BODY_2","ImageRenderer","alt","THUMBNAIL_NONE","Loader","SPINNER","ERROR"],"mappings":"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"}
@@ -0,0 +1,306 @@
1
+ 'use strict';
2
+
3
+ var tslib_es6 = require('../tslib.es6-d9c7aa8b.js');
4
+ var React = require('react');
5
+ var index = require('../index-cdcd27bc.js');
6
+ var LocalizationContext = require('../LocalizationContext-5a6a0f67.js');
7
+ var ui_Avatar = require('./Avatar.js');
8
+ var ui_ContextMenu = require('./ContextMenu.js');
9
+ var ui_Icon = require('./Icon.js');
10
+ var ui_IconButton = require('./IconButton.js');
11
+ var ui_ImageRenderer = require('./ImageRenderer.js');
12
+ var ui_Label = require('../index-df05e765.js');
13
+ var ui_Loader = require('./Loader.js');
14
+ var ui_UserProfile = require('./UserProfile.js');
15
+ var UserProfileContext = require('../UserProfileContext-17c8f75c.js');
16
+ var openChannelUtils = require('../openChannelUtils-4b7d2697.js');
17
+ require('../index-72479c2a.js');
18
+ require('../stringSet-2f3588b5.js');
19
+ require('../uuid-099485ae.js');
20
+ require('../_rollupPluginBabelHelpers-d984e855.js');
21
+ require('prop-types');
22
+ require('../index-40d245a3.js');
23
+ require('react-dom');
24
+ require('./SortByRow.js');
25
+ require('../withSendBird.js');
26
+ require('../sendbirdSelectors.js');
27
+ require('../topics-582e38dc.js');
28
+ require('../utils-031aba48.js');
29
+ require('../index-f9677913.js');
30
+
31
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
32
+
33
+ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
34
+
35
+ var SUPPORTING_TYPES = {
36
+ IMAGE: 'IMAGE',
37
+ VIDEO: 'VIDEO',
38
+ UNSUPPORTED: 'UNSUPPORTED'
39
+ };
40
+ var SUPPORTED_MIMES = {
41
+ IMAGE: ['image/jpeg', 'image/jpg', 'image/png', 'image/gif', 'image/webp'],
42
+ VIDEO: ['video/mpeg', 'video/ogg', 'video/webm', 'video/mp4']
43
+ };
44
+ var getSupportingFileType = function getSupportingFileType(type) {
45
+ if (SUPPORTED_MIMES.IMAGE.indexOf(type) >= 0) {
46
+ return SUPPORTING_TYPES.IMAGE;
47
+ }
48
+
49
+ if (SUPPORTED_MIMES.VIDEO.indexOf(type) >= 0) {
50
+ return SUPPORTING_TYPES.VIDEO;
51
+ }
52
+
53
+ return SUPPORTING_TYPES.UNSUPPORTED;
54
+ };
55
+
56
+ function OpenchannelThumbnailMessage(_a) {
57
+ var _b;
58
+
59
+ var className = _a.className,
60
+ message = _a.message,
61
+ disabled = _a.disabled,
62
+ userId = _a.userId,
63
+ chainTop = _a.chainTop,
64
+ _onClick = _a.onClick,
65
+ showRemove = _a.showRemove,
66
+ resendMessage = _a.resendMessage;
67
+ var type = message.type,
68
+ url = message.url,
69
+ thumbnails = message.thumbnails,
70
+ localUrl = message.localUrl;
71
+ var status = message === null || message === void 0 ? void 0 : message.sendingStatus;
72
+ var thumbnailUrl = thumbnails && thumbnails.length > 0 && thumbnails[0].url || null;
73
+
74
+ var _c = LocalizationContext.useLocalization(),
75
+ stringSet = _c.stringSet,
76
+ dateLocale = _c.dateLocale;
77
+
78
+ var _d = React.useContext(UserProfileContext.UserProfileContext),
79
+ disableUserProfile = _d.disableUserProfile,
80
+ renderUserProfile = _d.renderUserProfile;
81
+
82
+ var _e = React.useState(360),
83
+ messageWidth = _e[0],
84
+ setMessageWidth = _e[1];
85
+
86
+ var messageRef = React.useRef(null);
87
+ var contextMenuRef = React.useRef(null);
88
+ var avatarRef = React.useRef(null);
89
+ var memorizedThumbnailPlaceHolder = React.useMemo(function () {
90
+ return function (type) {
91
+ return function (_a) {
92
+ var style = _a.style;
93
+ return (
94
+ /*#__PURE__*/
95
+ // eslint-disable-line
96
+ React__default["default"].createElement("div", {
97
+ style: style
98
+ }, /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
99
+ type: type,
100
+ fillColor: ui_Icon.IconColors.ON_BACKGROUND_2,
101
+ width: "56px",
102
+ height: "56px"
103
+ }))
104
+ );
105
+ };
106
+ };
107
+ }, []);
108
+ var isByMe = openChannelUtils.checkIsByMe(message, userId);
109
+ var isMessageSent = openChannelUtils.checkIsSent(status);
110
+ var isPending = openChannelUtils.checkIsPending(status);
111
+ var isFailed = openChannelUtils.checkIsFailed(status);
112
+ var sender = openChannelUtils.getSenderFromMessage(message);
113
+ React.useEffect(function () {
114
+ var _a;
115
+
116
+ var thumbnailWidth = ((_a = messageRef === null || messageRef === void 0 ? void 0 : messageRef.current) === null || _a === void 0 ? void 0 : _a.clientWidth) - 80;
117
+ setMessageWidth(thumbnailWidth > 360 ? 360 : thumbnailWidth);
118
+ }, []);
119
+ return /*#__PURE__*/React__default["default"].createElement("div", {
120
+ className: tslib_es6.__spreadArray(tslib_es6.__spreadArray([], Array.isArray(className) ? className : [className], true), ['sendbird-openchannel-thumbnail-message'], false).join(' '),
121
+ ref: messageRef
122
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
123
+ className: "sendbird-openchannel-thumbnail-message__left"
124
+ }, !chainTop && /*#__PURE__*/React__default["default"].createElement(ui_ContextMenu["default"], {
125
+ menuTrigger: function menuTrigger(toggleDropdown) {
126
+ return /*#__PURE__*/React__default["default"].createElement(ui_Avatar["default"], {
127
+ className: "sendbird-openchannel-thumbnail-message__left__avatar",
128
+ src: sender.profileUrl || '',
129
+ ref: avatarRef,
130
+ width: "28px",
131
+ height: "28px",
132
+ onClick: function onClick() {
133
+ if (!disableUserProfile) {
134
+ toggleDropdown();
135
+ }
136
+ }
137
+ });
138
+ },
139
+ menuItems: function menuItems(closeDropdown) {
140
+ return /*#__PURE__*/React__default["default"].createElement(ui_ContextMenu.MenuItems, {
141
+ parentRef: avatarRef,
142
+ parentContainRef: avatarRef,
143
+ closeDropdown: closeDropdown,
144
+ style: {
145
+ paddingTop: 0,
146
+ paddingBottom: 0
147
+ }
148
+ }, renderUserProfile ? renderUserProfile({
149
+ user: sender,
150
+ close: closeDropdown
151
+ }) : /*#__PURE__*/React__default["default"].createElement(ui_UserProfile, {
152
+ user: sender,
153
+ onSuccess: closeDropdown,
154
+ disableMessaging: true
155
+ }));
156
+ }
157
+ })), /*#__PURE__*/React__default["default"].createElement("div", {
158
+ className: "sendbird-openchannel-thumbnail-message__right"
159
+ }, !chainTop && /*#__PURE__*/React__default["default"].createElement("div", {
160
+ className: "sendbird-openchannel-thumbnail-message__right__title"
161
+ }, /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
162
+ className: "sendbird-openchannel-thumbnail-message__right__title__sender-name",
163
+ type: ui_Label.LabelTypography.CAPTION_2,
164
+ color: isByMe ? ui_Label.LabelColors.SECONDARY_3 : ui_Label.LabelColors.ONBACKGROUND_2
165
+ }, sender && (sender.friendName || sender.nickname || sender.userId)), /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
166
+ className: "sendbird-openchannel-thumbnail-message__right__title__sent-at",
167
+ type: ui_Label.LabelTypography.CAPTION_3,
168
+ color: ui_Label.LabelColors.ONBACKGROUND_3
169
+ }, (message === null || message === void 0 ? void 0 : message.createdAt) && index.format(message.createdAt, 'p', {
170
+ locale: dateLocale
171
+ }))), /*#__PURE__*/React__default["default"].createElement("div", {
172
+ className: "sendbird-openchannel-thumbnail-message__right__body"
173
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
174
+ className: "sendbird-openchannel-thumbnail-message__right__body__wrap",
175
+ role: "button",
176
+ onClick: function onClick() {
177
+ if (isMessageSent) {
178
+ _onClick(true);
179
+ }
180
+ },
181
+ onKeyDown: function onKeyDown() {
182
+ if (isMessageSent) {
183
+ _onClick(true);
184
+ }
185
+ },
186
+ tabIndex: 0
187
+ }, /*#__PURE__*/React__default["default"].createElement("div", {
188
+ className: "sendbird-openchannel-thumbnail-message__right__body__wrap__overlay"
189
+ }), (_b = {}, _b[SUPPORTING_TYPES.VIDEO] = url || localUrl ? /*#__PURE__*/React__default["default"].createElement("div", {
190
+ className: "sendbird-openchannel-thumbnail-message__right__body__wrap__video"
191
+ }, thumbnailUrl ? /*#__PURE__*/React__default["default"].createElement(ui_ImageRenderer, {
192
+ className: "sendbird-openchannel-thumbnail-message__right__body__wrap__video",
193
+ url: thumbnailUrl,
194
+ width: messageWidth,
195
+ height: "270px",
196
+ alt: "image",
197
+ placeHolder: memorizedThumbnailPlaceHolder(ui_Icon.IconTypes.PLAY)
198
+ }) : /*#__PURE__*/React__default["default"].createElement("video", {
199
+ className: "sendbird-openchannel-thumbnail-message__right__body__wrap__video__video"
200
+ }, /*#__PURE__*/React__default["default"].createElement("source", {
201
+ src: url || localUrl,
202
+ type: type
203
+ })), /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
204
+ className: "sendbird-openchannel-thumbnail-message__right__body__wrap__video__icon",
205
+ type: ui_Icon.IconTypes.PLAY,
206
+ fillColor: ui_Icon.IconColors.ON_BACKGROUND_2,
207
+ width: "56px",
208
+ height: "56px"
209
+ })) : /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
210
+ className: "sendbird-openchannel-thumbnail-message__right__body__wrap__video--icon",
211
+ type: ui_Icon.IconTypes.PHOTO,
212
+ fillColor: ui_Icon.IconColors.ON_BACKGROUND_2,
213
+ width: "56px",
214
+ height: "56px"
215
+ }), _b[SUPPORTING_TYPES.IMAGE] = url || localUrl ? /*#__PURE__*/React__default["default"].createElement(ui_ImageRenderer, {
216
+ className: "sendbird-openchannel-thumbnail-message__right__body__wrap__image",
217
+ url: thumbnailUrl || url || localUrl,
218
+ alt: "image",
219
+ width: messageWidth,
220
+ height: "270px",
221
+ placeHolder: memorizedThumbnailPlaceHolder(ui_Icon.IconTypes.PHOTO)
222
+ }) : /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
223
+ className: "sendbird-openchannel-thumbnail-message__right__body__wrap__image--icon",
224
+ type: ui_Icon.IconTypes.PHOTO,
225
+ fillColor: ui_Icon.IconColors.ON_BACKGROUND_2,
226
+ width: "56px",
227
+ height: "56px"
228
+ }), _b[SUPPORTING_TYPES.UNSUPPORTED] = /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
229
+ className: "sendbird-openchannel-thumbnail-message__right__body__wrap__unknown",
230
+ type: ui_Icon.IconTypes.PHOTO,
231
+ fillColor: ui_Icon.IconColors.ON_BACKGROUND_2,
232
+ width: "56px",
233
+ height: "56px"
234
+ }), _b)[getSupportingFileType(type)])), (isPending || isFailed) && /*#__PURE__*/React__default["default"].createElement("div", {
235
+ className: "sendbird-openchannel-thumbnail-message__right__tail"
236
+ }, isPending && /*#__PURE__*/React__default["default"].createElement(ui_Loader, {
237
+ width: "16px",
238
+ height: "16px"
239
+ }, /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
240
+ className: "sendbird-openchannel-thumbnail-message__right__tail__pending",
241
+ type: ui_Icon.IconTypes.SPINNER,
242
+ fillColor: ui_Icon.IconColors.PRIMARY,
243
+ width: "16px",
244
+ height: "16px"
245
+ })), isFailed && /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
246
+ className: "sendbird-openchannel-thumbnail-message__right__tail__failed",
247
+ type: ui_Icon.IconTypes.ERROR,
248
+ fillColor: ui_Icon.IconColors.ERROR,
249
+ width: "16px",
250
+ height: "16px"
251
+ }))), /*#__PURE__*/React__default["default"].createElement("div", {
252
+ className: "sendbird-openchannel-thumbnail-message__context-menu",
253
+ ref: contextMenuRef
254
+ }, /*#__PURE__*/React__default["default"].createElement(ui_ContextMenu["default"], {
255
+ menuTrigger: function menuTrigger(toggleDropdown) {
256
+ return openChannelUtils.showMenuTrigger({
257
+ message: message,
258
+ userId: userId,
259
+ status: status
260
+ }) && /*#__PURE__*/React__default["default"].createElement(ui_IconButton, {
261
+ className: "sendbird-openchannel-thumbnail-message__context-menu--icon",
262
+ width: "32px",
263
+ height: "32px",
264
+ onClick: toggleDropdown
265
+ }, /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
266
+ type: ui_Icon.IconTypes.MORE,
267
+ fillColor: ui_Icon.IconColors.CONTENT_INVERSE,
268
+ width: "24px",
269
+ height: "24px"
270
+ }));
271
+ },
272
+ menuItems: function menuItems(closeDropdown) {
273
+ return /*#__PURE__*/React__default["default"].createElement(ui_ContextMenu.MenuItems, {
274
+ parentRef: contextMenuRef,
275
+ parentContainRef: contextMenuRef,
276
+ closeDropdown: closeDropdown,
277
+ openLeft: true
278
+ }, openChannelUtils.isFineResend({
279
+ message: message,
280
+ userId: userId,
281
+ status: status
282
+ }) && /*#__PURE__*/React__default["default"].createElement(ui_ContextMenu.MenuItem, {
283
+ onClick: function onClick() {
284
+ resendMessage(message);
285
+ closeDropdown();
286
+ }
287
+ }, stringSet.CONTEXT_MENU_DROPDOWN__RESEND), openChannelUtils.isFineDelete({
288
+ message: message,
289
+ userId: userId,
290
+ status: status
291
+ }) && /*#__PURE__*/React__default["default"].createElement(ui_ContextMenu.MenuItem, {
292
+ onClick: function onClick() {
293
+ if (disabled) {
294
+ return;
295
+ }
296
+
297
+ showRemove(true);
298
+ closeDropdown();
299
+ }
300
+ }, stringSet.CONTEXT_MENU_DROPDOWN__DELETE));
301
+ }
302
+ })));
303
+ }
304
+
305
+ module.exports = OpenchannelThumbnailMessage;
306
+ //# sourceMappingURL=OpenchannelThumbnailMessage.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"OpenchannelThumbnailMessage.js","sources":["../../../src/ui/OpenchannelThumbnailMessage/utils.ts","../../../src/ui/OpenchannelThumbnailMessage/index.tsx"],"sourcesContent":["export const SUPPORTING_TYPES = {\n IMAGE: 'IMAGE',\n VIDEO: 'VIDEO',\n UNSUPPORTED: 'UNSUPPORTED',\n};\n\nconst SUPPORTED_MIMES = {\n IMAGE: [\n 'image/jpeg',\n 'image/jpg',\n 'image/png',\n 'image/gif',\n 'image/webp',\n ],\n VIDEO: [\n 'video/mpeg',\n 'video/ogg',\n 'video/webm',\n 'video/mp4',\n ],\n};\n\nexport const getSupportingFileType = (type: string): string => {\n if (SUPPORTED_MIMES.IMAGE.indexOf(type) >= 0) {\n return SUPPORTING_TYPES.IMAGE;\n }\n if (SUPPORTED_MIMES.VIDEO.indexOf(type) >= 0) {\n return SUPPORTING_TYPES.VIDEO;\n }\n return SUPPORTING_TYPES.UNSUPPORTED;\n}\n","import React, {\n useRef,\n useMemo,\n useState,\n useEffect,\n useContext,\n} from 'react';\nimport { FileMessage } from '@sendbird/chat/message';\nimport format from 'date-fns/format';\nimport './index.scss';\nimport { SUPPORTING_TYPES, getSupportingFileType } from './utils';\nimport { useLocalization } from '../../lib/LocalizationContext';\n\nimport Avatar from '../Avatar';\nimport ContextMenu, { MenuItems, MenuItem } from '../ContextMenu';\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport IconButton from '../IconButton';\nimport ImageRenderer from '../ImageRenderer';\nimport Label, { LabelTypography, LabelColors } from '../Label';\nimport Loader from '../Loader';\nimport UserProfile from '../UserProfile';\nimport { UserProfileContext } from '../../lib/UserProfileContext';\nimport {\n checkIsByMe,\n checkIsSent,\n checkIsPending,\n checkIsFailed,\n isFineResend,\n isFineDelete,\n showMenuTrigger,\n} from '../../utils/openChannelUtils';\nimport { getSenderFromMessage } from '../../utils/openChannelUtils';\n\ninterface LocalUrl {\n localUrl?: string;\n}\ninterface Props {\n className?: string | Array<string>;\n message: FileMessage;\n disabled: boolean;\n userId: string;\n chainTop: boolean;\n chainBottom: boolean;\n onClick(bool: boolean): void,\n showRemove(bool: boolean): void,\n resendMessage(message: FileMessage): void;\n}\n\nexport default function OpenchannelThumbnailMessage({\n className,\n message,\n disabled,\n userId,\n chainTop,\n onClick,\n showRemove,\n resendMessage,\n}: Props): JSX.Element {\n const {\n type,\n url,\n thumbnails,\n localUrl,\n }: FileMessage & LocalUrl = message;\n const status = message?.sendingStatus;\n const thumbnailUrl = (thumbnails && thumbnails.length > 0 && thumbnails[0].url) || null;\n const { stringSet, dateLocale } = useLocalization();\n const { disableUserProfile, renderUserProfile } = useContext(UserProfileContext);\n const [messageWidth, setMessageWidth] = useState(360);\n const messageRef = useRef(null);\n const contextMenuRef = useRef(null);\n const avatarRef = useRef(null);\n\n const memorizedThumbnailPlaceHolder = useMemo(() => (type) => ({ style }) => ( // eslint-disable-line\n <div style={style}>\n <Icon\n type={type}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n </div>\n ), []);\n\n const isByMe = checkIsByMe(message, userId);\n const isMessageSent = checkIsSent(status);\n const isPending = checkIsPending(status);\n const isFailed = checkIsFailed(status);\n const sender = getSenderFromMessage(message);\n\n useEffect(() => {\n const thumbnailWidth = messageRef?.current?.clientWidth - 80;\n setMessageWidth(thumbnailWidth > 360 ? 360 : thumbnailWidth);\n }, []);\n\n return (\n <div\n className={[\n ...(Array.isArray(className) ? className : [className]),\n 'sendbird-openchannel-thumbnail-message',\n ].join(' ')}\n ref={messageRef}\n >\n <div className=\"sendbird-openchannel-thumbnail-message__left\">\n {\n !chainTop && (\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n <Avatar\n className=\"sendbird-openchannel-thumbnail-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-thumbnail-message__right\">\n {\n !chainTop && (\n <div className=\"sendbird-openchannel-thumbnail-message__right__title\">\n <Label\n className=\"sendbird-openchannel-thumbnail-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-thumbnail-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-thumbnail-message__right__body\">\n <div\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap\"\n role=\"button\"\n onClick={() => {\n if (isMessageSent) {\n onClick(true);\n }\n }}\n onKeyDown={() => {\n if (isMessageSent) {\n onClick(true);\n }\n }}\n tabIndex={0}\n >\n <div className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__overlay\" />\n {\n {\n [SUPPORTING_TYPES.VIDEO]: (\n (url || localUrl)\n ? (\n <div className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video\" >\n {\n (thumbnailUrl)\n ? (\n <ImageRenderer\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video\"\n url={thumbnailUrl}\n width={messageWidth}\n height=\"270px\"\n alt=\"image\"\n placeHolder={memorizedThumbnailPlaceHolder(IconTypes.PLAY)}\n />\n )\n : (\n <video className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video__video\">\n <source src={url || localUrl} type={type} />\n </video>\n )\n }\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video__icon\"\n type={IconTypes.PLAY}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n </div>\n )\n : (\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video--icon\"\n type={IconTypes.PHOTO}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n )\n ),\n [SUPPORTING_TYPES.IMAGE]: (\n (url || localUrl)\n ? (\n <ImageRenderer\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__image\"\n url={thumbnailUrl || url || localUrl}\n alt=\"image\"\n width={messageWidth}\n height=\"270px\"\n placeHolder={memorizedThumbnailPlaceHolder(IconTypes.PHOTO)}\n />\n )\n : (\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__image--icon\"\n type={IconTypes.PHOTO}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n )\n ),\n [SUPPORTING_TYPES.UNSUPPORTED]: (\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__unknown\"\n type={IconTypes.PHOTO}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n ),\n }[getSupportingFileType(type)]\n }\n </div>\n </div>\n {\n (isPending || isFailed) && (\n <div className=\"sendbird-openchannel-thumbnail-message__right__tail\">\n {\n isPending && (\n <Loader\n width=\"16px\"\n height=\"16px\"\n >\n <Icon\n className=\"sendbird-openchannel-thumbnail-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-thumbnail-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-thumbnail-message__context-menu\"\n ref={contextMenuRef}\n >\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n showMenuTrigger({ message, userId, status }) && (\n <IconButton\n className=\"sendbird-openchannel-thumbnail-message__context-menu--icon\"\n width=\"32px\"\n height=\"32px\"\n onClick={toggleDropdown}\n >\n <Icon\n type={IconTypes.MORE}\n fillColor={IconColors.CONTENT_INVERSE}\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 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) {\n return;\n }\n showRemove(true);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__DELETE}\n </MenuItem>\n )\n }\n </MenuItems>\n )}\n />\n </div>\n </div>\n );\n}\n"],"names":["SUPPORTING_TYPES","IMAGE","VIDEO","UNSUPPORTED","SUPPORTED_MIMES","getSupportingFileType","type","indexOf","OpenchannelThumbnailMessage","_a","className","message","disabled","userId","chainTop","onClick","showRemove","resendMessage","url","thumbnails","localUrl","status","sendingStatus","thumbnailUrl","length","_c","useLocalization","stringSet","dateLocale","_d","useContext","UserProfileContext","disableUserProfile","renderUserProfile","_e","useState","messageWidth","setMessageWidth","messageRef","useRef","contextMenuRef","avatarRef","memorizedThumbnailPlaceHolder","useMemo","style","React","Icon","IconColors","ON_BACKGROUND_2","isByMe","checkIsByMe","isMessageSent","checkIsSent","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","useEffect","thumbnailWidth","current","clientWidth","__spreadArray","Array","isArray","join","ContextMenu","toggleDropdown","Avatar","profileUrl","closeDropdown","MenuItems","paddingTop","paddingBottom","user","close","UserProfile","Label","LabelTypography","CAPTION_2","LabelColors","SECONDARY_3","ONBACKGROUND_2","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","_b","ImageRenderer","IconTypes","PLAY","PHOTO","Loader","SPINNER","PRIMARY","ERROR","showMenuTrigger","IconButton","MORE","CONTENT_INVERSE","isFineResend","MenuItem","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE"],"mappings":"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"}