@sendbird/uikit-react 3.0.0-beta.6 → 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 (594) hide show
  1. package/App.js +46 -44
  2. package/App.js.map +1 -1
  3. package/CHANGELOG.md +107 -0
  4. package/Channel/components/ChannelHeader.js +24 -20
  5. package/Channel/components/ChannelHeader.js.map +1 -1
  6. package/Channel/components/ChannelUI.js +28 -26
  7. package/Channel/components/ChannelUI.js.map +1 -1
  8. package/Channel/components/FileViewer.js +17 -15
  9. package/Channel/components/FileViewer.js.map +1 -1
  10. package/Channel/components/FrozenNotification.js +5 -5
  11. package/Channel/components/Message.js +30 -26
  12. package/Channel/components/Message.js.map +1 -1
  13. package/Channel/components/MessageInput.js +20 -18
  14. package/Channel/components/MessageInput.js.map +1 -1
  15. package/Channel/components/MessageList.js +30 -28
  16. package/Channel/components/MessageList.js.map +1 -1
  17. package/Channel/components/RemoveMessageModal.js +20 -18
  18. package/Channel/components/RemoveMessageModal.js.map +1 -1
  19. package/Channel/components/SuggestedMentionList.js +42 -37
  20. package/Channel/components/SuggestedMentionList.js.map +1 -1
  21. package/Channel/components/TypingIndicator.js +36 -32
  22. package/Channel/components/TypingIndicator.js.map +1 -1
  23. package/Channel/components/UnreadCount.js +6 -6
  24. package/Channel/components/UnreadCount.js.map +1 -1
  25. package/Channel/context.js +15 -13
  26. package/Channel/context.js.map +1 -1
  27. package/Channel.js +28 -26
  28. package/Channel.js.map +1 -1
  29. package/ChannelList/components/AddChannel.js +16 -16
  30. package/ChannelList/components/ChannelListHeader.js +7 -7
  31. package/ChannelList/components/ChannelListUI.js +43 -44
  32. package/ChannelList/components/ChannelListUI.js.map +1 -1
  33. package/ChannelList/components/ChannelPreview.js +35 -31
  34. package/ChannelList/components/ChannelPreview.js.map +1 -1
  35. package/ChannelList/components/ChannelPreviewAction.js +17 -15
  36. package/ChannelList/components/ChannelPreviewAction.js.map +1 -1
  37. package/ChannelList/context.js +10 -8
  38. package/ChannelList/context.js.map +1 -1
  39. package/ChannelList.js +30 -28
  40. package/ChannelList.js.map +1 -1
  41. package/{ChannelListProvider-737ee36f.js → ChannelListProvider-76b1ec23.js} +219 -198
  42. package/ChannelListProvider-76b1ec23.js.map +1 -0
  43. package/{ChannelProvider-34834493.js → ChannelProvider-c0ed5fae.js} +380 -419
  44. package/ChannelProvider-c0ed5fae.js.map +1 -0
  45. package/ChannelSettings/components/ChannelProfile.js +16 -16
  46. package/ChannelSettings/components/ChannelProfile.js.map +1 -1
  47. package/ChannelSettings/components/ChannelSettingsUI.js +23 -23
  48. package/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
  49. package/ChannelSettings/components/EditDetailsModal.js +22 -18
  50. package/ChannelSettings/components/EditDetailsModal.js.map +1 -1
  51. package/ChannelSettings/components/LeaveChannel.js +13 -13
  52. package/ChannelSettings/components/LeaveChannel.js.map +1 -1
  53. package/ChannelSettings/components/{AdminPanel.js → ModerationPanel.js} +87 -141
  54. package/ChannelSettings/components/ModerationPanel.js.map +1 -0
  55. package/ChannelSettings/components/UserListItem.js +18 -17
  56. package/ChannelSettings/components/UserListItem.js.map +1 -1
  57. package/ChannelSettings/components/UserPanel.js +19 -19
  58. package/ChannelSettings/components/UserPanel.js.map +1 -1
  59. package/ChannelSettings/context.js +10 -10
  60. package/ChannelSettings/context.js.map +1 -1
  61. package/ChannelSettings.js +20 -20
  62. package/CreateChannel/components/CreateChannelUI.js +17 -17
  63. package/CreateChannel/components/CreateChannelUI.js.map +1 -1
  64. package/CreateChannel/components/{InviteMembers.js → InviteUsers.js} +23 -27
  65. package/CreateChannel/components/InviteUsers.js.map +1 -0
  66. package/CreateChannel/components/SelectChannelType.js +12 -12
  67. package/CreateChannel/components/SelectChannelType.js.map +1 -1
  68. package/CreateChannel/context.js +5 -4
  69. package/CreateChannel/context.js.map +1 -1
  70. package/CreateChannel.js +16 -16
  71. package/{CreateChannelProvider-3d3e4a7c.js → CreateChannelProvider-8c72aa06.js} +3 -3
  72. package/CreateChannelProvider-8c72aa06.js.map +1 -0
  73. package/EditUserProfile/components/EditUserProfileUI.js +13 -13
  74. package/EditUserProfile/context.js +2 -2
  75. package/EditUserProfile/context.js.map +1 -1
  76. package/EditUserProfile.js +13 -13
  77. package/{LocalizationContext-5b0a9339.js → LocalizationContext-fb3dafcd.js} +3 -3
  78. package/{LocalizationContext-5b0a9339.js.map → LocalizationContext-fb3dafcd.js.map} +1 -1
  79. package/{MemberList-6e33a562.js → MemberList-01d3c8bf.js} +47 -68
  80. package/MemberList-01d3c8bf.js.map +1 -0
  81. package/MessageSearch/components/MessageSearchUI.js +15 -15
  82. package/MessageSearch/components/MessageSearchUI.js.map +1 -1
  83. package/MessageSearch/context.js +55 -60
  84. package/MessageSearch/context.js.map +1 -1
  85. package/MessageSearch.js +21 -21
  86. package/MessageSearch.js.map +1 -1
  87. package/OpenChannel/components/FrozenChannelNotification.js +5 -5
  88. package/OpenChannel/components/OpenChannelHeader.js +16 -14
  89. package/OpenChannel/components/OpenChannelHeader.js.map +1 -1
  90. package/OpenChannel/components/OpenChannelInput.js +19 -17
  91. package/OpenChannel/components/OpenChannelInput.js.map +1 -1
  92. package/OpenChannel/components/OpenChannelMessage.js +43 -38
  93. package/OpenChannel/components/OpenChannelMessage.js.map +1 -1
  94. package/OpenChannel/components/OpenChannelMessageList.js +37 -36
  95. package/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
  96. package/OpenChannel/components/OpenChannelUI.js +27 -25
  97. package/OpenChannel/components/OpenChannelUI.js.map +1 -1
  98. package/OpenChannel/context.js +11 -9
  99. package/OpenChannel/context.js.map +1 -1
  100. package/OpenChannel.js +27 -25
  101. package/OpenChannel.js.map +1 -1
  102. package/{OpenChannelProvider-9ef0d52a.js → OpenChannelProvider-0fb27972.js} +629 -694
  103. package/OpenChannelProvider-0fb27972.js.map +1 -0
  104. package/OpenChannelSettings/components/EditDetailsModal.js +29 -35
  105. package/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
  106. package/OpenChannelSettings/components/OpenChannelProfile.js +15 -15
  107. package/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
  108. package/OpenChannelSettings/components/OpenChannelSettingsUI.js +38 -22
  109. package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
  110. package/OpenChannelSettings/components/OperatorUI.js +45 -30
  111. package/OpenChannelSettings/components/OperatorUI.js.map +1 -1
  112. package/OpenChannelSettings/components/ParticipantUI.js +29 -56
  113. package/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
  114. package/OpenChannelSettings/context.js +15 -15
  115. package/OpenChannelSettings/context.js.map +1 -1
  116. package/OpenChannelSettings.js +18 -18
  117. package/README.md +128 -0
  118. package/SendbirdProvider.js +42 -37
  119. package/SendbirdProvider.js.map +1 -1
  120. package/{UserProfileContext-b6d89d0d.js → UserProfileContext-6a387a08.js} +1 -1
  121. package/{UserProfileContext-b6d89d0d.js.map → UserProfileContext-6a387a08.js.map} +1 -1
  122. package/__bundle-7dfccc8c-03df3ada.js +24 -0
  123. package/__bundle-7dfccc8c-03df3ada.js.map +1 -0
  124. package/{_rollupPluginBabelHelpers-d10f91b9.js → _rollupPluginBabelHelpers-084fb589.js} +1 -1
  125. package/{_rollupPluginBabelHelpers-d10f91b9.js.map → _rollupPluginBabelHelpers-084fb589.js.map} +1 -1
  126. package/{actionTypes-17920f59.js → actionTypes-302a2801.js} +1 -1
  127. package/{actionTypes-17920f59.js.map → actionTypes-302a2801.js.map} +1 -1
  128. package/cjs/App.js +46 -44
  129. package/cjs/App.js.map +1 -1
  130. package/cjs/Channel/components/ChannelHeader.js +24 -20
  131. package/cjs/Channel/components/ChannelHeader.js.map +1 -1
  132. package/cjs/Channel/components/ChannelUI.js +28 -26
  133. package/cjs/Channel/components/ChannelUI.js.map +1 -1
  134. package/cjs/Channel/components/FileViewer.js +17 -15
  135. package/cjs/Channel/components/FileViewer.js.map +1 -1
  136. package/cjs/Channel/components/FrozenNotification.js +5 -5
  137. package/cjs/Channel/components/Message.js +30 -26
  138. package/cjs/Channel/components/Message.js.map +1 -1
  139. package/cjs/Channel/components/MessageInput.js +20 -18
  140. package/cjs/Channel/components/MessageInput.js.map +1 -1
  141. package/cjs/Channel/components/MessageList.js +30 -28
  142. package/cjs/Channel/components/MessageList.js.map +1 -1
  143. package/cjs/Channel/components/RemoveMessageModal.js +20 -18
  144. package/cjs/Channel/components/RemoveMessageModal.js.map +1 -1
  145. package/cjs/Channel/components/SuggestedMentionList.js +42 -37
  146. package/cjs/Channel/components/SuggestedMentionList.js.map +1 -1
  147. package/cjs/Channel/components/TypingIndicator.js +36 -32
  148. package/cjs/Channel/components/TypingIndicator.js.map +1 -1
  149. package/cjs/Channel/components/UnreadCount.js +6 -6
  150. package/cjs/Channel/components/UnreadCount.js.map +1 -1
  151. package/cjs/Channel/context.js +16 -14
  152. package/cjs/Channel/context.js.map +1 -1
  153. package/cjs/Channel.js +28 -26
  154. package/cjs/Channel.js.map +1 -1
  155. package/cjs/ChannelList/components/AddChannel.js +16 -16
  156. package/cjs/ChannelList/components/ChannelListHeader.js +7 -7
  157. package/cjs/ChannelList/components/ChannelListUI.js +43 -44
  158. package/cjs/ChannelList/components/ChannelListUI.js.map +1 -1
  159. package/cjs/ChannelList/components/ChannelPreview.js +35 -31
  160. package/cjs/ChannelList/components/ChannelPreview.js.map +1 -1
  161. package/cjs/ChannelList/components/ChannelPreviewAction.js +17 -15
  162. package/cjs/ChannelList/components/ChannelPreviewAction.js.map +1 -1
  163. package/cjs/ChannelList/context.js +10 -9
  164. package/cjs/ChannelList/context.js.map +1 -1
  165. package/cjs/ChannelList.js +30 -28
  166. package/cjs/ChannelList.js.map +1 -1
  167. package/cjs/{ChannelListProvider-f910e236.js → ChannelListProvider-7d1c0466.js} +218 -198
  168. package/cjs/ChannelListProvider-7d1c0466.js.map +1 -0
  169. package/cjs/{ChannelProvider-86e2e68c.js → ChannelProvider-a3ec5a56.js} +380 -419
  170. package/cjs/ChannelProvider-a3ec5a56.js.map +1 -0
  171. package/cjs/ChannelSettings/components/ChannelProfile.js +15 -15
  172. package/cjs/ChannelSettings/components/ChannelProfile.js.map +1 -1
  173. package/cjs/ChannelSettings/components/ChannelSettingsUI.js +22 -22
  174. package/cjs/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
  175. package/cjs/ChannelSettings/components/EditDetailsModal.js +21 -17
  176. package/cjs/ChannelSettings/components/EditDetailsModal.js.map +1 -1
  177. package/cjs/ChannelSettings/components/LeaveChannel.js +12 -12
  178. package/cjs/ChannelSettings/components/LeaveChannel.js.map +1 -1
  179. package/cjs/ChannelSettings/components/{AdminPanel.js → ModerationPanel.js} +86 -140
  180. package/cjs/ChannelSettings/components/ModerationPanel.js.map +1 -0
  181. package/cjs/ChannelSettings/components/UserListItem.js +18 -17
  182. package/cjs/ChannelSettings/components/UserListItem.js.map +1 -1
  183. package/cjs/ChannelSettings/components/UserPanel.js +18 -18
  184. package/cjs/ChannelSettings/components/UserPanel.js.map +1 -1
  185. package/cjs/ChannelSettings/context.js +10 -10
  186. package/cjs/ChannelSettings/context.js.map +1 -1
  187. package/cjs/ChannelSettings.js +20 -20
  188. package/cjs/CreateChannel/components/CreateChannelUI.js +17 -17
  189. package/cjs/CreateChannel/components/CreateChannelUI.js.map +1 -1
  190. package/cjs/CreateChannel/components/{InviteMembers.js → InviteUsers.js} +23 -27
  191. package/cjs/CreateChannel/components/InviteUsers.js.map +1 -0
  192. package/cjs/CreateChannel/components/SelectChannelType.js +12 -12
  193. package/cjs/CreateChannel/components/SelectChannelType.js.map +1 -1
  194. package/cjs/CreateChannel/context.js +5 -4
  195. package/cjs/CreateChannel/context.js.map +1 -1
  196. package/cjs/CreateChannel.js +16 -16
  197. package/cjs/{CreateChannelProvider-07992a6d.js → CreateChannelProvider-95fbfb06.js} +3 -3
  198. package/cjs/CreateChannelProvider-95fbfb06.js.map +1 -0
  199. package/cjs/EditUserProfile/components/EditUserProfileUI.js +13 -13
  200. package/cjs/EditUserProfile/context.js +2 -2
  201. package/cjs/EditUserProfile/context.js.map +1 -1
  202. package/cjs/EditUserProfile.js +13 -13
  203. package/cjs/{LocalizationContext-79514649.js → LocalizationContext-5a6a0f67.js} +3 -3
  204. package/cjs/{LocalizationContext-79514649.js.map → LocalizationContext-5a6a0f67.js.map} +1 -1
  205. package/cjs/{MemberList-015c1075.js → MemberList-bfecdd64.js} +46 -67
  206. package/cjs/MemberList-bfecdd64.js.map +1 -0
  207. package/cjs/MessageSearch/components/MessageSearchUI.js +14 -14
  208. package/cjs/MessageSearch/components/MessageSearchUI.js.map +1 -1
  209. package/cjs/MessageSearch/context.js +55 -60
  210. package/cjs/MessageSearch/context.js.map +1 -1
  211. package/cjs/MessageSearch.js +21 -21
  212. package/cjs/MessageSearch.js.map +1 -1
  213. package/cjs/OpenChannel/components/FrozenChannelNotification.js +5 -5
  214. package/cjs/OpenChannel/components/OpenChannelHeader.js +16 -14
  215. package/cjs/OpenChannel/components/OpenChannelHeader.js.map +1 -1
  216. package/cjs/OpenChannel/components/OpenChannelInput.js +19 -17
  217. package/cjs/OpenChannel/components/OpenChannelInput.js.map +1 -1
  218. package/cjs/OpenChannel/components/OpenChannelMessage.js +43 -38
  219. package/cjs/OpenChannel/components/OpenChannelMessage.js.map +1 -1
  220. package/cjs/OpenChannel/components/OpenChannelMessageList.js +37 -36
  221. package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
  222. package/cjs/OpenChannel/components/OpenChannelUI.js +27 -25
  223. package/cjs/OpenChannel/components/OpenChannelUI.js.map +1 -1
  224. package/cjs/OpenChannel/context.js +12 -10
  225. package/cjs/OpenChannel/context.js.map +1 -1
  226. package/cjs/OpenChannel.js +27 -25
  227. package/cjs/OpenChannel.js.map +1 -1
  228. package/cjs/{OpenChannelProvider-445f214c.js → OpenChannelProvider-e8247193.js} +629 -694
  229. package/cjs/OpenChannelProvider-e8247193.js.map +1 -0
  230. package/cjs/OpenChannelSettings/components/EditDetailsModal.js +28 -34
  231. package/cjs/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
  232. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js +14 -14
  233. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
  234. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js +37 -21
  235. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
  236. package/cjs/OpenChannelSettings/components/OperatorUI.js +42 -27
  237. package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -1
  238. package/cjs/OpenChannelSettings/components/ParticipantUI.js +28 -55
  239. package/cjs/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
  240. package/cjs/OpenChannelSettings/context.js +15 -15
  241. package/cjs/OpenChannelSettings/context.js.map +1 -1
  242. package/cjs/OpenChannelSettings.js +18 -18
  243. package/cjs/SendbirdProvider.js +42 -38
  244. package/cjs/SendbirdProvider.js.map +1 -1
  245. package/cjs/{UserProfileContext-12cfee31.js → UserProfileContext-17c8f75c.js} +1 -1
  246. package/cjs/{UserProfileContext-12cfee31.js.map → UserProfileContext-17c8f75c.js.map} +1 -1
  247. package/cjs/__bundle-7dfccc8c-c3c55861.js +151 -0
  248. package/cjs/__bundle-7dfccc8c-c3c55861.js.map +1 -0
  249. package/cjs/{_rollupPluginBabelHelpers-f802e0e8.js → _rollupPluginBabelHelpers-d984e855.js} +1 -1
  250. package/cjs/{_rollupPluginBabelHelpers-f802e0e8.js.map → _rollupPluginBabelHelpers-d984e855.js.map} +1 -1
  251. package/cjs/{actionTypes-93161807.js → actionTypes-7a330bec.js} +1 -1
  252. package/cjs/{actionTypes-93161807.js.map → actionTypes-7a330bec.js.map} +1 -1
  253. package/cjs/{color-c53ac792.js → color-b30f84a2.js} +1 -1
  254. package/cjs/{color-c53ac792.js.map → color-b30f84a2.js.map} +1 -1
  255. package/cjs/{compareIds-37e8380c.js → compareIds-d8053014.js} +1 -1
  256. package/cjs/{compareIds-37e8380c.js.map → compareIds-d8053014.js.map} +1 -1
  257. package/cjs/{const-3024c719.js → const-2623fae1.js} +1 -1
  258. package/cjs/{const-3024c719.js.map → const-2623fae1.js.map} +1 -1
  259. package/cjs/{const-489c46b6.js → const-6aa26f9f.js} +1 -1
  260. package/cjs/{const-489c46b6.js.map → const-6aa26f9f.js.map} +1 -1
  261. package/cjs/{context-961d5b11.js → context-83ecdafd.js} +2 -2
  262. package/cjs/{context-961d5b11.js.map → context-83ecdafd.js.map} +1 -1
  263. package/cjs/dist/index.css +218 -96
  264. package/cjs/dist/index.css.map +1 -1
  265. package/cjs/groupChannel-e311e26a.js +9 -0
  266. package/cjs/groupChannel-e311e26a.js.map +1 -0
  267. package/cjs/{index-d25a7cbf.js → index-1e14c5b9.js} +4 -4
  268. package/cjs/{index-d25a7cbf.js.map → index-1e14c5b9.js.map} +1 -1
  269. package/cjs/{index-5615eab4.js → index-2537cbc7.js} +4 -4
  270. package/cjs/{index-5615eab4.js.map → index-2537cbc7.js.map} +1 -1
  271. package/cjs/{index-bc563d47.js → index-40d245a3.js} +32 -29
  272. package/cjs/index-40d245a3.js.map +1 -0
  273. package/cjs/{index-5eaebc66.js → index-5e7b82c2.js} +12 -9
  274. package/cjs/index-5e7b82c2.js.map +1 -0
  275. package/cjs/{index-0b2e2c2a.js → index-72479c2a.js} +1 -1
  276. package/cjs/{index-0b2e2c2a.js.map → index-72479c2a.js.map} +1 -1
  277. package/cjs/{index-07623c8b.js → index-ab5d906d.js} +2 -2
  278. package/cjs/{index-07623c8b.js.map → index-ab5d906d.js.map} +1 -1
  279. package/cjs/{index-cb53adf5.js → index-cdcd27bc.js} +2 -2
  280. package/cjs/{index-cb53adf5.js.map → index-cdcd27bc.js.map} +1 -1
  281. package/cjs/{index-d70ac86e.js → index-ce679d41.js} +1 -1
  282. package/cjs/{index-d70ac86e.js.map → index-ce679d41.js.map} +1 -1
  283. package/cjs/{index-a20b40c4.js → index-df05e765.js} +5 -5
  284. package/cjs/index-df05e765.js.map +1 -0
  285. package/cjs/{index-2180f74f.js → index-f9677913.js} +5 -5
  286. package/cjs/index-f9677913.js.map +1 -0
  287. package/cjs/index.js +40 -38
  288. package/cjs/index.js.map +1 -1
  289. package/cjs/openChannel-e9f65946.js +13 -0
  290. package/cjs/openChannel-e9f65946.js.map +1 -0
  291. package/cjs/{openChannelUtils-7fb1abc6.js → openChannelUtils-4b7d2697.js} +10 -5
  292. package/cjs/openChannelUtils-4b7d2697.js.map +1 -0
  293. package/cjs/sendbirdSelectors.js +696 -0
  294. package/cjs/sendbirdSelectors.js.map +1 -0
  295. package/cjs/{stringSet-ae448472.js → stringSet-2f3588b5.js} +1 -1
  296. package/cjs/{stringSet-ae448472.js.map → stringSet-2f3588b5.js.map} +1 -1
  297. package/cjs/{topics-bdbff23e.js → topics-582e38dc.js} +1 -1
  298. package/cjs/{topics-bdbff23e.js.map → topics-582e38dc.js.map} +1 -1
  299. package/cjs/{tslib.es6-a7af7bb8.js → tslib.es6-d9c7aa8b.js} +1 -1
  300. package/cjs/{tslib.es6-a7af7bb8.js.map → tslib.es6-d9c7aa8b.js.map} +1 -1
  301. package/cjs/ui/Accordion.js +4 -4
  302. package/cjs/ui/AccordionGroup.js +2 -2
  303. package/cjs/ui/AccordionGroup.js.map +1 -1
  304. package/cjs/ui/AdminMessage.js +4 -3
  305. package/cjs/ui/AdminMessage.js.map +1 -1
  306. package/cjs/ui/Avatar.js +3 -3
  307. package/cjs/ui/Badge.js +5 -5
  308. package/cjs/ui/Button.js +4 -4
  309. package/cjs/ui/ChannelAvatar.js +8 -8
  310. package/cjs/ui/ChannelAvatar.js.map +1 -1
  311. package/cjs/ui/ChannelPreview.js +28 -21
  312. package/cjs/ui/ChannelPreview.js.map +1 -1
  313. package/cjs/ui/ChatHeader.js +19 -12
  314. package/cjs/ui/ChatHeader.js.map +1 -1
  315. package/cjs/ui/Checkbox.js +1 -1
  316. package/cjs/ui/ConnectionStatus.js +5 -5
  317. package/cjs/ui/ContextMenu.js +9 -30
  318. package/cjs/ui/ContextMenu.js.map +1 -1
  319. package/cjs/ui/DateSeparator.js +5 -5
  320. package/cjs/ui/DateSeparator.js.map +1 -1
  321. package/cjs/ui/Dropdown.js +3 -3
  322. package/cjs/ui/EmojiReactions.js +10 -10
  323. package/cjs/ui/EmojiReactions.js.map +1 -1
  324. package/cjs/ui/FileMessageItemBody.js +6 -6
  325. package/cjs/ui/FileMessageItemBody.js.map +1 -1
  326. package/cjs/ui/FileViewer.js +7 -7
  327. package/cjs/ui/Icon.js +5 -1
  328. package/cjs/ui/Icon.js.map +1 -1
  329. package/cjs/ui/IconButton.js +1 -1
  330. package/cjs/ui/ImageRenderer.js +1 -1
  331. package/cjs/ui/Input.js +3 -3
  332. package/cjs/ui/Label.js +3 -3
  333. package/cjs/ui/LinkLabel.js +3 -3
  334. package/cjs/ui/Loader.js +1 -1
  335. package/cjs/ui/MentionLabel.js +19 -17
  336. package/cjs/ui/MentionLabel.js.map +1 -1
  337. package/cjs/ui/MentionUserLabel.js +1 -1
  338. package/cjs/ui/MentionUserLabel.js.map +1 -1
  339. package/cjs/ui/MessageContent.js +52 -47
  340. package/cjs/ui/MessageContent.js.map +1 -1
  341. package/cjs/ui/MessageInput.js +10 -10
  342. package/cjs/ui/MessageItemMenu.js +14 -18
  343. package/cjs/ui/MessageItemMenu.js.map +1 -1
  344. package/cjs/ui/MessageItemReactionMenu.js +5 -5
  345. package/cjs/ui/MessageItemReactionMenu.js.map +1 -1
  346. package/cjs/ui/MessageSearchFileItem.js +12 -11
  347. package/cjs/ui/MessageSearchFileItem.js.map +1 -1
  348. package/cjs/ui/MessageSearchItem.js +10 -10
  349. package/cjs/ui/MessageSearchItem.js.map +1 -1
  350. package/cjs/ui/MessageStatus.js +11 -11
  351. package/cjs/ui/MessageStatus.js.map +1 -1
  352. package/cjs/ui/Modal.js +8 -8
  353. package/cjs/ui/MutedAvatarOverlay.js +7 -7
  354. package/cjs/ui/MutedAvatarOverlay.js.map +1 -1
  355. package/cjs/ui/OGMessageItemBody.js +17 -16
  356. package/cjs/ui/OGMessageItemBody.js.map +1 -1
  357. package/cjs/ui/OpenChannelAdminMessage.js +4 -4
  358. package/cjs/ui/OpenChannelAdminMessage.js.map +1 -1
  359. package/cjs/ui/OpenChannelAvatar.js +11 -11
  360. package/cjs/ui/OpenChannelAvatar.js.map +1 -1
  361. package/cjs/ui/OpenchannelConversationHeader.js +7 -7
  362. package/cjs/ui/OpenchannelFileMessage.js +16 -15
  363. package/cjs/ui/OpenchannelFileMessage.js.map +1 -1
  364. package/cjs/ui/OpenchannelOGMessage.js +16 -15
  365. package/cjs/ui/OpenchannelOGMessage.js.map +1 -1
  366. package/cjs/ui/OpenchannelThumbnailMessage.js +17 -16
  367. package/cjs/ui/OpenchannelThumbnailMessage.js.map +1 -1
  368. package/cjs/ui/OpenchannelUserMessage.js +17 -16
  369. package/cjs/ui/OpenchannelUserMessage.js.map +1 -1
  370. package/cjs/ui/PlaceHolder.js +6 -6
  371. package/cjs/ui/QuoteMessage.js +24 -24
  372. package/cjs/ui/QuoteMessage.js.map +1 -1
  373. package/cjs/ui/QuoteMessageInput.js +11 -13
  374. package/cjs/ui/QuoteMessageInput.js.map +1 -1
  375. package/cjs/ui/ReactionBadge.js +3 -3
  376. package/cjs/ui/ReactionButton.js +1 -1
  377. package/cjs/ui/SortByRow.js +1 -1
  378. package/cjs/ui/TextButton.js +2 -2
  379. package/cjs/ui/TextMessageItemBody.js +16 -15
  380. package/cjs/ui/TextMessageItemBody.js.map +1 -1
  381. package/cjs/ui/ThumbnailMessageItemBody.js +3 -3
  382. package/cjs/ui/ThumbnailMessageItemBody.js.map +1 -1
  383. package/cjs/ui/Tooltip.js +3 -3
  384. package/cjs/ui/TooltipWrapper.js +1 -1
  385. package/cjs/ui/UnknownMessageItemBody.js +7 -7
  386. package/cjs/ui/UnknownMessageItemBody.js.map +1 -1
  387. package/cjs/ui/UserListItem.js +13 -12
  388. package/cjs/ui/UserListItem.js.map +1 -1
  389. package/cjs/ui/UserProfile.js +17 -16
  390. package/cjs/ui/UserProfile.js.map +1 -1
  391. package/cjs/{index-4e8b61f7.js → ui/Word.js} +31 -10
  392. package/cjs/ui/Word.js.map +1 -0
  393. package/cjs/useSendbirdStateContext.js +1 -1
  394. package/cjs/useSendbirdStateContext.js.map +1 -1
  395. package/cjs/{utils-0d5ecf05.js → utils-031aba48.js} +1 -1
  396. package/cjs/{utils-0d5ecf05.js.map → utils-031aba48.js.map} +1 -1
  397. package/cjs/{utils-03155980.js → utils-510b93ac.js} +8 -8
  398. package/cjs/utils-510b93ac.js.map +1 -0
  399. package/cjs/{utils-139469a5.js → utils-689065e6.js} +1 -1
  400. package/cjs/{utils-139469a5.js.map → utils-689065e6.js.map} +1 -1
  401. package/cjs/{uuid-03009a31.js → uuid-099485ae.js} +1 -1
  402. package/cjs/{uuid-03009a31.js.map → uuid-099485ae.js.map} +1 -1
  403. package/cjs/withSendBird.js +1 -1
  404. package/{color-6b259e40.js → color-9bf8c922.js} +1 -1
  405. package/{color-6b259e40.js.map → color-9bf8c922.js.map} +1 -1
  406. package/{compareIds-982972e8.js → compareIds-b78d7cd6.js} +1 -1
  407. package/{compareIds-982972e8.js.map → compareIds-b78d7cd6.js.map} +1 -1
  408. package/{const-da3968a5.js → const-40b58d8b.js} +1 -1
  409. package/{const-da3968a5.js.map → const-40b58d8b.js.map} +1 -1
  410. package/{const-e3d1e0ec.js → const-99800b8d.js} +1 -1
  411. package/{const-e3d1e0ec.js.map → const-99800b8d.js.map} +1 -1
  412. package/{context-3d5505d0.js → context-bedea43b.js} +2 -2
  413. package/{context-3d5505d0.js.map → context-bedea43b.js.map} +1 -1
  414. package/dist/index.css +218 -96
  415. package/dist/index.css.map +1 -1
  416. package/groupChannel-96502de7.js +6 -0
  417. package/groupChannel-96502de7.js.map +1 -0
  418. package/{index-94489c17.js → index-13729368.js} +1 -1
  419. package/{index-94489c17.js.map → index-13729368.js.map} +1 -1
  420. package/{index-95677caf.js → index-16bed610.js} +2 -2
  421. package/{index-95677caf.js.map → index-16bed610.js.map} +1 -1
  422. package/{index-db6a4860.js → index-1d112ad4.js} +1 -1
  423. package/{index-db6a4860.js.map → index-1d112ad4.js.map} +1 -1
  424. package/{index-065ef420.js → index-71ad343b.js} +12 -9
  425. package/index-71ad343b.js.map +1 -0
  426. package/{index-17cf7808.js → index-71e2bf26.js} +5 -5
  427. package/index-71e2bf26.js.map +1 -0
  428. package/{index-902c2068.js → index-8e6a607b.js} +33 -30
  429. package/index-8e6a607b.js.map +1 -0
  430. package/{index-a755675d.js → index-a5e8849a.js} +4 -4
  431. package/{index-a755675d.js.map → index-a5e8849a.js.map} +1 -1
  432. package/{index-9deb1389.js → index-b574cc8e.js} +5 -5
  433. package/index-b574cc8e.js.map +1 -0
  434. package/{index-691dc8da.js → index-c95d2aab.js} +4 -4
  435. package/{index-691dc8da.js.map → index-c95d2aab.js.map} +1 -1
  436. package/{index-92160328.js → index-ccd99cfe.js} +2 -2
  437. package/{index-92160328.js.map → index-ccd99cfe.js.map} +1 -1
  438. package/index.d.ts +1021 -897
  439. package/index.d.ts_bkup +1883 -0
  440. package/index.js +39 -37
  441. package/index.js.map +1 -1
  442. package/openChannel-dd5c9246.js +8 -0
  443. package/openChannel-dd5c9246.js.map +1 -0
  444. package/{openChannelUtils-2cd370a7.js → openChannelUtils-211a679a.js} +10 -5
  445. package/openChannelUtils-211a679a.js.map +1 -0
  446. package/package.json +5 -5
  447. package/sendbirdSelectors.js +671 -0
  448. package/sendbirdSelectors.js.map +1 -0
  449. package/{stringSet-5a85ff4b.js → stringSet-d3a8a2a0.js} +1 -1
  450. package/{stringSet-5a85ff4b.js.map → stringSet-d3a8a2a0.js.map} +1 -1
  451. package/{topics-24a660ee.js → topics-f941ba80.js} +2 -2
  452. package/{topics-24a660ee.js.map → topics-f941ba80.js.map} +1 -1
  453. package/{tslib.es6-2c4d01e9.js → tslib.es6-a7db0cc5.js} +1 -1
  454. package/{tslib.es6-2c4d01e9.js.map → tslib.es6-a7db0cc5.js.map} +1 -1
  455. package/ui/Accordion.js +4 -4
  456. package/ui/AccordionGroup.js +2 -2
  457. package/ui/AccordionGroup.js.map +1 -1
  458. package/ui/AdminMessage.js +4 -3
  459. package/ui/AdminMessage.js.map +1 -1
  460. package/ui/Avatar.js +3 -3
  461. package/ui/Badge.js +5 -5
  462. package/ui/Button.js +4 -4
  463. package/ui/ChannelAvatar.js +8 -8
  464. package/ui/ChannelAvatar.js.map +1 -1
  465. package/ui/ChannelPreview.js +28 -21
  466. package/ui/ChannelPreview.js.map +1 -1
  467. package/ui/ChatHeader.js +19 -12
  468. package/ui/ChatHeader.js.map +1 -1
  469. package/ui/Checkbox.js +1 -1
  470. package/ui/ConnectionStatus.js +5 -5
  471. package/ui/ContextMenu.js +9 -30
  472. package/ui/ContextMenu.js.map +1 -1
  473. package/ui/DateSeparator.js +5 -5
  474. package/ui/DateSeparator.js.map +1 -1
  475. package/ui/Dropdown.js +3 -3
  476. package/ui/EmojiReactions.js +10 -10
  477. package/ui/EmojiReactions.js.map +1 -1
  478. package/ui/FileMessageItemBody.js +6 -6
  479. package/ui/FileMessageItemBody.js.map +1 -1
  480. package/ui/FileViewer.js +7 -7
  481. package/ui/Icon.js +5 -1
  482. package/ui/Icon.js.map +1 -1
  483. package/ui/IconButton.js +1 -1
  484. package/ui/ImageRenderer.js +1 -1
  485. package/ui/Input.js +3 -3
  486. package/ui/Label.js +3 -3
  487. package/ui/LinkLabel.js +3 -3
  488. package/ui/Loader.js +1 -1
  489. package/ui/MentionLabel.js +19 -17
  490. package/ui/MentionLabel.js.map +1 -1
  491. package/ui/MentionUserLabel.js +1 -1
  492. package/ui/MentionUserLabel.js.map +1 -1
  493. package/ui/MessageContent.js +54 -49
  494. package/ui/MessageContent.js.map +1 -1
  495. package/ui/MessageInput.js +10 -10
  496. package/ui/MessageItemMenu.js +14 -18
  497. package/ui/MessageItemMenu.js.map +1 -1
  498. package/ui/MessageItemReactionMenu.js +5 -5
  499. package/ui/MessageItemReactionMenu.js.map +1 -1
  500. package/ui/MessageSearchFileItem.js +12 -11
  501. package/ui/MessageSearchFileItem.js.map +1 -1
  502. package/ui/MessageSearchItem.js +10 -10
  503. package/ui/MessageSearchItem.js.map +1 -1
  504. package/ui/MessageStatus.js +11 -11
  505. package/ui/MessageStatus.js.map +1 -1
  506. package/ui/Modal.js +8 -8
  507. package/ui/MutedAvatarOverlay.js +7 -7
  508. package/ui/MutedAvatarOverlay.js.map +1 -1
  509. package/ui/OGMessageItemBody.js +15 -14
  510. package/ui/OGMessageItemBody.js.map +1 -1
  511. package/ui/OpenChannelAdminMessage.js +4 -4
  512. package/ui/OpenChannelAdminMessage.js.map +1 -1
  513. package/ui/OpenChannelAvatar.js +11 -11
  514. package/ui/OpenChannelAvatar.js.map +1 -1
  515. package/ui/OpenchannelConversationHeader.js +7 -7
  516. package/ui/OpenchannelFileMessage.js +16 -15
  517. package/ui/OpenchannelFileMessage.js.map +1 -1
  518. package/ui/OpenchannelOGMessage.js +16 -15
  519. package/ui/OpenchannelOGMessage.js.map +1 -1
  520. package/ui/OpenchannelThumbnailMessage.js +17 -16
  521. package/ui/OpenchannelThumbnailMessage.js.map +1 -1
  522. package/ui/OpenchannelUserMessage.js +17 -16
  523. package/ui/OpenchannelUserMessage.js.map +1 -1
  524. package/ui/PlaceHolder.js +6 -6
  525. package/ui/QuoteMessage.js +24 -24
  526. package/ui/QuoteMessage.js.map +1 -1
  527. package/ui/QuoteMessageInput.js +11 -13
  528. package/ui/QuoteMessageInput.js.map +1 -1
  529. package/ui/ReactionBadge.js +3 -3
  530. package/ui/ReactionButton.js +1 -1
  531. package/ui/SortByRow.js +1 -1
  532. package/ui/TextButton.js +2 -2
  533. package/ui/TextMessageItemBody.js +15 -14
  534. package/ui/TextMessageItemBody.js.map +1 -1
  535. package/ui/ThumbnailMessageItemBody.js +3 -3
  536. package/ui/ThumbnailMessageItemBody.js.map +1 -1
  537. package/ui/Tooltip.js +3 -3
  538. package/ui/TooltipWrapper.js +1 -1
  539. package/ui/UnknownMessageItemBody.js +7 -7
  540. package/ui/UnknownMessageItemBody.js.map +1 -1
  541. package/ui/UserListItem.js +13 -12
  542. package/ui/UserListItem.js.map +1 -1
  543. package/ui/UserProfile.js +16 -15
  544. package/ui/UserProfile.js.map +1 -1
  545. package/ui/Word.js +70 -0
  546. package/ui/Word.js.map +1 -0
  547. package/useSendbirdStateContext.js +1 -1
  548. package/useSendbirdStateContext.js.map +1 -1
  549. package/{utils-57c79308.js → utils-2e3623c0.js} +1 -1
  550. package/{utils-57c79308.js.map → utils-2e3623c0.js.map} +1 -1
  551. package/{utils-85d3d94c.js → utils-cadde06a.js} +1 -1
  552. package/{utils-85d3d94c.js.map → utils-cadde06a.js.map} +1 -1
  553. package/{utils-b3b6f503.js → utils-d9325ddf.js} +8 -8
  554. package/utils-d9325ddf.js.map +1 -0
  555. package/{uuid-0ab81e67.js → uuid-748dae7a.js} +1 -1
  556. package/{uuid-0ab81e67.js.map → uuid-748dae7a.js.map} +1 -1
  557. package/withSendBird.js +1 -1
  558. package/ChannelListProvider-737ee36f.js.map +0 -1
  559. package/ChannelProvider-34834493.js.map +0 -1
  560. package/ChannelSettings/components/AdminPanel.js.map +0 -1
  561. package/CreateChannel/components/InviteMembers.js.map +0 -1
  562. package/CreateChannelProvider-3d3e4a7c.js.map +0 -1
  563. package/MemberList-6e33a562.js.map +0 -1
  564. package/OpenChannelProvider-9ef0d52a.js.map +0 -1
  565. package/cjs/ChannelListProvider-f910e236.js.map +0 -1
  566. package/cjs/ChannelProvider-86e2e68c.js.map +0 -1
  567. package/cjs/ChannelSettings/components/AdminPanel.js.map +0 -1
  568. package/cjs/CreateChannel/components/InviteMembers.js.map +0 -1
  569. package/cjs/CreateChannelProvider-07992a6d.js.map +0 -1
  570. package/cjs/MemberList-015c1075.js.map +0 -1
  571. package/cjs/OpenChannelProvider-445f214c.js.map +0 -1
  572. package/cjs/index-2180f74f.js.map +0 -1
  573. package/cjs/index-4e8b61f7.js.map +0 -1
  574. package/cjs/index-5eaebc66.js.map +0 -1
  575. package/cjs/index-a20b40c4.js.map +0 -1
  576. package/cjs/index-bc563d47.js.map +0 -1
  577. package/cjs/openChannelUtils-7fb1abc6.js.map +0 -1
  578. package/cjs/sendBirdSelectors.js +0 -741
  579. package/cjs/sendBirdSelectors.js.map +0 -1
  580. package/cjs/ui/OpenChannelMessageContent.js +0 -14
  581. package/cjs/ui/OpenChannelMessageContent.js.map +0 -1
  582. package/cjs/utils-03155980.js.map +0 -1
  583. package/index-065ef420.js.map +0 -1
  584. package/index-17cf7808.js.map +0 -1
  585. package/index-81a93b05.js +0 -49
  586. package/index-81a93b05.js.map +0 -1
  587. package/index-902c2068.js.map +0 -1
  588. package/index-9deb1389.js.map +0 -1
  589. package/openChannelUtils-2cd370a7.js.map +0 -1
  590. package/sendBirdSelectors.js +0 -713
  591. package/sendBirdSelectors.js.map +0 -1
  592. package/ui/OpenChannelMessageContent.js +0 -8
  593. package/ui/OpenChannelMessageContent.js.map +0 -1
  594. package/utils-b3b6f503.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"OpenchannelOGMessage.js","sources":["../../src/ui/OpenchannelOGMessage/utils.ts","../../src/ui/OpenchannelOGMessage/index.tsx"],"sourcesContent":["import Sendbird from 'sendbird';\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: Sendbird.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 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 { ClientUserMessage } from '../../index';\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: ClientUserMessage;\n className?: string | Array<string>;\n disabled?: boolean;\n showEdit(bool: boolean): void;\n showRemove(bool: boolean): void;\n resendMessage(message: ClientUserMessage): 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","uuidv4","LabelTypography","BODY_1","LabelColors","PRIMARY","ONBACKGROUND_1","updatedAt","push","ONBACKGROUND_2","MESSAGE_EDITED","openLink","window","open","useEffect","current","clientHeight","top","innerWidth","__spreadArray","Array","isArray","join","toggleDropdown","profileUrl","closeDropdown","paddingTop","paddingBottom","user","close","UserProfile","CAPTION_2","SECONDARY_3","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","showMenuTrigger","IconTypes","MORE","IconColors","CONTENT_INVERSE","isFineCopy","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","alt","THUMBNAIL_NONE","SPINNER","ERROR"],"mappings":"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"}
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","uuidv4","LabelTypography","BODY_1","LabelColors","PRIMARY","ONBACKGROUND_1","updatedAt","push","ONBACKGROUND_2","MESSAGE_EDITED","openLink","window","open","useEffect","current","clientHeight","top","innerWidth","__spreadArray","Array","isArray","join","toggleDropdown","profileUrl","closeDropdown","paddingTop","paddingBottom","user","close","UserProfile","CAPTION_2","SECONDARY_3","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","showMenuTrigger","IconTypes","MORE","IconColors","CONTENT_INVERSE","isFineCopy","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","alt","THUMBNAIL_NONE","SPINNER","ERROR"],"mappings":"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"}
@@ -1,29 +1,30 @@
1
- import { a as __spreadArray } from '../tslib.es6-2c4d01e9.js';
1
+ import { a as __spreadArray } from '../tslib.es6-a7db0cc5.js';
2
2
  import React__default, { useContext, useState, useRef, useMemo, useEffect } from 'react';
3
- import { f as format } from '../index-92160328.js';
4
- import { u as useLocalization } from '../LocalizationContext-5b0a9339.js';
3
+ import { f as format } from '../index-ccd99cfe.js';
4
+ import { u as useLocalization } from '../LocalizationContext-fb3dafcd.js';
5
5
  import Avatar from './Avatar.js';
6
6
  import ContextMenu, { MenuItems, MenuItem } from './ContextMenu.js';
7
7
  import Icon, { IconColors, IconTypes } from './Icon.js';
8
8
  import IconButton from './IconButton.js';
9
9
  import ImageRenderer from './ImageRenderer.js';
10
- import { L as Label, a as LabelTypography, b as LabelColors } from '../index-17cf7808.js';
10
+ import { L as Label, a as LabelTypography, b as LabelColors } from '../index-71e2bf26.js';
11
11
  import Loader from './Loader.js';
12
12
  import ConnectedUserProfile from './UserProfile.js';
13
- import { a as UserProfileContext } from '../UserProfileContext-b6d89d0d.js';
14
- import { c as checkIsByMe, g as getSenderFromMessage, s as showMenuTrigger, b as isFineResend, d as isFineDelete, h as checkIsSent, e as checkIsPending, f as checkIsFailed } from '../openChannelUtils-2cd370a7.js';
15
- import '../index-94489c17.js';
16
- import '../stringSet-5a85ff4b.js';
17
- import '../uuid-0ab81e67.js';
18
- import '../_rollupPluginBabelHelpers-d10f91b9.js';
13
+ import { a as UserProfileContext } from '../UserProfileContext-6a387a08.js';
14
+ import { c as checkIsByMe, g as getSenderFromMessage, s as showMenuTrigger, b as isFineResend, d as isFineDelete, h as checkIsSent, e as checkIsPending, f as checkIsFailed } from '../openChannelUtils-211a679a.js';
15
+ import '../index-13729368.js';
16
+ import '../stringSet-d3a8a2a0.js';
17
+ import '../uuid-748dae7a.js';
18
+ import '../_rollupPluginBabelHelpers-084fb589.js';
19
19
  import 'prop-types';
20
- import '../index-902c2068.js';
20
+ import '../index-8e6a607b.js';
21
21
  import 'react-dom';
22
22
  import './SortByRow.js';
23
23
  import '../withSendBird.js';
24
- import '../sendBirdSelectors.js';
25
- import '../topics-24a660ee.js';
26
- import '../index-9deb1389.js';
24
+ import '../sendbirdSelectors.js';
25
+ import '../topics-f941ba80.js';
26
+ import '../utils-cadde06a.js';
27
+ import '../index-b574cc8e.js';
27
28
 
28
29
  var SUPPORTING_TYPES = {
29
30
  IMAGE: 'IMAGE',
@@ -59,8 +60,8 @@ function OpenchannelThumbnailMessage(_a) {
59
60
  resendMessage = _a.resendMessage;
60
61
  var type = message.type,
61
62
  url = message.url,
62
- localUrl = message.localUrl,
63
- thumbnails = message.thumbnails;
63
+ thumbnails = message.thumbnails,
64
+ localUrl = message.localUrl;
64
65
  var status = message === null || message === void 0 ? void 0 : message.sendingStatus;
65
66
  var thumbnailUrl = thumbnails && thumbnails.length > 0 && thumbnails[0].url || null;
66
67
 
@@ -1 +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 format from 'date-fns/format';\nimport './index.scss';\nimport { SUPPORTING_TYPES, getSupportingFileType } from './utils';\nimport { ClientFileMessage } from '../../index';\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 Props {\n className?: string | Array<string>;\n message: ClientFileMessage;\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: ClientFileMessage): 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 localUrl,\n thumbnails,\n } = 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","localUrl","thumbnails","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","IconColors","ON_BACKGROUND_2","isByMe","checkIsByMe","isMessageSent","checkIsSent","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","useEffect","thumbnailWidth","current","clientWidth","__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","_b","IconTypes","PLAY","PHOTO","SPINNER","PRIMARY","ERROR","showMenuTrigger","MORE","CONTENT_INVERSE","isFineResend","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE"],"mappings":"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"}
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","IconColors","ON_BACKGROUND_2","isByMe","checkIsByMe","isMessageSent","checkIsSent","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","useEffect","thumbnailWidth","current","clientWidth","__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","_b","IconTypes","PLAY","PHOTO","SPINNER","PRIMARY","ERROR","showMenuTrigger","MORE","CONTENT_INVERSE","isFineResend","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE"],"mappings":"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"}
@@ -1,30 +1,31 @@
1
- import { a as __spreadArray } from '../tslib.es6-2c4d01e9.js';
1
+ import { a as __spreadArray } from '../tslib.es6-a7db0cc5.js';
2
2
  import React__default, { useContext, useRef, useState, useMemo, useEffect } from 'react';
3
- import { f as format } from '../index-92160328.js';
3
+ import { f as format } from '../index-ccd99cfe.js';
4
4
  import Avatar from './Avatar.js';
5
5
  import ContextMenu, { MenuItems, MenuItem } from './ContextMenu.js';
6
6
  import Icon, { IconTypes, IconColors } from './Icon.js';
7
7
  import IconButton from './IconButton.js';
8
- import { L as Label, a as LabelTypography, b as LabelColors } from '../index-17cf7808.js';
8
+ import { L as Label, a as LabelTypography, b as LabelColors } from '../index-71e2bf26.js';
9
9
  import Loader from './Loader.js';
10
10
  import ConnectedUserProfile from './UserProfile.js';
11
- import { a as UserProfileContext } from '../UserProfileContext-b6d89d0d.js';
12
- import { u as useLocalization } from '../LocalizationContext-5b0a9339.js';
13
- import { c as copyToClipboard } from '../utils-57c79308.js';
14
- import { u as uuidv4 } from '../uuid-0ab81e67.js';
15
- 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-2cd370a7.js';
16
- import '../index-94489c17.js';
11
+ import { a as UserProfileContext } from '../UserProfileContext-6a387a08.js';
12
+ import { u as useLocalization } from '../LocalizationContext-fb3dafcd.js';
13
+ import { c as copyToClipboard } from '../utils-2e3623c0.js';
14
+ import { u as uuidv4 } from '../uuid-748dae7a.js';
15
+ 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-211a679a.js';
16
+ import '../index-13729368.js';
17
17
  import './ImageRenderer.js';
18
- import '../_rollupPluginBabelHelpers-d10f91b9.js';
18
+ import '../_rollupPluginBabelHelpers-084fb589.js';
19
19
  import 'prop-types';
20
- import '../index-902c2068.js';
20
+ import '../index-8e6a607b.js';
21
21
  import 'react-dom';
22
22
  import './SortByRow.js';
23
- import '../stringSet-5a85ff4b.js';
23
+ import '../stringSet-d3a8a2a0.js';
24
24
  import '../withSendBird.js';
25
- import '../sendBirdSelectors.js';
26
- import '../topics-24a660ee.js';
27
- import '../index-9deb1389.js';
25
+ import '../sendbirdSelectors.js';
26
+ import '../topics-f941ba80.js';
27
+ import '../utils-cadde06a.js';
28
+ import '../index-b574cc8e.js';
28
29
 
29
30
  function OpenchannelUserMessage(_a) {
30
31
  var className = _a.className,
@@ -76,7 +77,7 @@ function OpenchannelUserMessage(_a) {
76
77
  type: LabelTypography.BODY_1,
77
78
  color: LabelColors.ONBACKGROUND_2,
78
79
  calssName: "sendbird-openchannel-user-message-word"
79
- }, " " + stringSet.MESSAGE_EDITED + " "));
80
+ }, " ".concat(stringSet.MESSAGE_EDITED, " ")));
80
81
  }
81
82
 
82
83
  return matchedMessage;
@@ -1 +1 @@
1
- {"version":3,"file":"OpenchannelUserMessage.js","sources":["../../src/ui/OpenchannelUserMessage/index.tsx"],"sourcesContent":["import React, {\n useMemo,\n useContext,\n useRef,\n useState,\n ReactElement,\n useEffect,\n} from 'react';\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 Label, { LabelTypography, LabelColors } from '../Label';\nimport Loader from '../Loader';\nimport UserProfile from '../UserProfile';\nimport { UserProfileContext } from '../../lib/UserProfileContext';\n\nimport { useLocalization } from '../../lib/LocalizationContext';\nimport { copyToClipboard } from './utils';\nimport uuidv4 from '../../utils/uuid';\nimport { ClientUserMessage } from '../../index';\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 className?: string | Array<string>;\n message: ClientUserMessage;\n userId: string;\n disabled?: boolean;\n showEdit(bool: boolean): void;\n showRemove(bool: boolean): void;\n resendMessage(message: ClientUserMessage): void;\n chainTop?: boolean;\n chainBottom?: boolean;\n}\n\nexport default function OpenchannelUserMessage({\n className,\n message,\n userId,\n resendMessage,\n disabled,\n showEdit,\n showRemove,\n chainTop,\n}: Props): ReactElement {\n if (!message || message.messageType !== 'user') {\n return null;\n }\n\n // hooks\n const { stringSet, dateLocale } = useLocalization();\n const { disableUserProfile, renderUserProfile } = useContext(UserProfileContext);\n const messageRef = useRef(null);\n const avatarRef = useRef(null);\n const contextMenuRef = useRef(null);\n const [contextStyle, setContextStyle] = useState({});\n\n // consts\n const status = message?.sendingStatus;\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 splitMessage = message.message.split(/\\r/);\n const matchedMessage = splitMessage.map((word) => (word !== '' ? word : <br />));\n if (message.updatedAt > 0) {\n matchedMessage.push(\n <Label\n key={uuidv4()}\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_2}\n calssName=\"sendbird-openchannel-user-message-word\"\n >\n {` ${stringSet.MESSAGE_EDITED} `}\n </Label>,\n );\n }\n return matchedMessage;\n }, [message, message.updatedAt]);\n\n // place context menu top depending clientHeight of message component\n useEffect(() => {\n if (messageRef?.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-user-message',\n ].join(' ')}\n ref={messageRef}\n >\n <div className=\"sendbird-openchannel-user-message__left\">\n {\n !chainTop && (\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n <Avatar\n className=\"sendbird-openchannel-user-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-user-message__right\">\n {\n !chainTop && (\n <div className=\"sendbird-openchannel-user-message__right__top\">\n <Label\n className=\"sendbird-openchannel-user-message__right__top__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-user-message__right__top__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-user-message__right__bottom\">\n <Label\n className=\"sendbird-openchannel-user-message__right__bottom__message\"\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_1}\n >\n {MemoizedMessageText()}\n </Label>\n </div>\n {\n (isPending || isFailed) && (\n <div className=\"sendbird-openchannel-user-message__right__tail\">\n {\n isPending && (\n <Loader\n width=\"16px\"\n height=\"16px\"\n >\n <Icon\n className=\"sendbird-openchannel-user-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-user-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 {\n <div\n className=\"sendbird-openchannel-user-message__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-user-message__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: message, userId: userId, status: status }) && (\n <MenuItem\n className=\"sendbird-openchannel-user-message__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: message, userId: userId, status: status }) && (\n <MenuItem\n className=\"sendbird-openchannel-user-message__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: message, userId: userId, status: status }) && (\n <MenuItem\n className=\"sendbird-openchannel-user-message__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: message, userId: userId, status: status }) && (\n <MenuItem\n className=\"sendbird-openchannel-user-message__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 );\n}\n"],"names":["OpenchannelUserMessage","_a","className","message","userId","resendMessage","disabled","showEdit","showRemove","chainTop","messageType","_b","useLocalization","stringSet","dateLocale","_c","useContext","UserProfileContext","disableUserProfile","renderUserProfile","messageRef","useRef","avatarRef","contextMenuRef","_d","useState","contextStyle","setContextStyle","status","sendingStatus","isByMe","checkIsByMe","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","MemoizedMessageText","useMemo","splitMessage","split","matchedMessage","map","word","React","updatedAt","push","uuidv4","LabelTypography","BODY_1","LabelColors","ONBACKGROUND_2","MESSAGE_EDITED","useEffect","current","clientHeight","top","window","innerWidth","__spreadArray","Array","isArray","join","toggleDropdown","profileUrl","closeDropdown","paddingTop","paddingBottom","user","close","UserProfile","CAPTION_2","SECONDARY_3","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","ONBACKGROUND_1","IconTypes","SPINNER","IconColors","PRIMARY","ERROR","showMenuTrigger","MORE","CONTENT_INVERSE","isFineCopy","copyToClipboard","CONTEXT_MENU_DROPDOWN__COPY","isFineEdit","CONTEXT_MENU_DROPDOWN__EDIT","isFineResend","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE"],"mappings":"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"}
1
+ {"version":3,"file":"OpenchannelUserMessage.js","sources":["../../src/ui/OpenchannelUserMessage/index.tsx"],"sourcesContent":["import React, {\n useMemo,\n useContext,\n useRef,\n useState,\n ReactElement,\n useEffect,\n} 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 Label, { LabelTypography, LabelColors } from '../Label';\nimport Loader from '../Loader';\nimport UserProfile from '../UserProfile';\nimport { UserProfileContext } from '../../lib/UserProfileContext';\n\nimport { useLocalization } from '../../lib/LocalizationContext';\nimport { copyToClipboard } from './utils';\nimport uuidv4 from '../../utils/uuid';\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 className?: string | Array<string>;\n message: UserMessage;\n userId: 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}\n\nexport default function OpenchannelUserMessage({\n className,\n message,\n userId,\n resendMessage,\n disabled,\n showEdit,\n showRemove,\n chainTop,\n}: Props): ReactElement {\n if (!message || message.messageType !== 'user') {\n return null;\n }\n\n // hooks\n const { stringSet, dateLocale } = useLocalization();\n const { disableUserProfile, renderUserProfile } = useContext(UserProfileContext);\n const messageRef = useRef(null);\n const avatarRef = useRef(null);\n const contextMenuRef = useRef(null);\n const [contextStyle, setContextStyle] = useState({});\n\n // consts\n const status = message?.sendingStatus;\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 splitMessage = message.message.split(/\\r/);\n const matchedMessage = splitMessage.map((word) => (word !== '' ? word : <br />));\n if (message.updatedAt > 0) {\n matchedMessage.push(\n <Label\n key={uuidv4()}\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_2}\n calssName=\"sendbird-openchannel-user-message-word\"\n >\n {` ${stringSet.MESSAGE_EDITED} `}\n </Label>,\n );\n }\n return matchedMessage;\n }, [message, message.updatedAt]);\n\n // place context menu top depending clientHeight of message component\n useEffect(() => {\n if (messageRef?.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-user-message',\n ].join(' ')}\n ref={messageRef}\n >\n <div className=\"sendbird-openchannel-user-message__left\">\n {\n !chainTop && (\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n <Avatar\n className=\"sendbird-openchannel-user-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-user-message__right\">\n {\n !chainTop && (\n <div className=\"sendbird-openchannel-user-message__right__top\">\n <Label\n className=\"sendbird-openchannel-user-message__right__top__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-user-message__right__top__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-user-message__right__bottom\">\n <Label\n className=\"sendbird-openchannel-user-message__right__bottom__message\"\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_1}\n >\n {MemoizedMessageText()}\n </Label>\n </div>\n {\n (isPending || isFailed) && (\n <div className=\"sendbird-openchannel-user-message__right__tail\">\n {\n isPending && (\n <Loader\n width=\"16px\"\n height=\"16px\"\n >\n <Icon\n className=\"sendbird-openchannel-user-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-user-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 {\n <div\n className=\"sendbird-openchannel-user-message__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-user-message__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: message, userId: userId, status: status }) && (\n <MenuItem\n className=\"sendbird-openchannel-user-message__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: message, userId: userId, status: status }) && (\n <MenuItem\n className=\"sendbird-openchannel-user-message__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: message, userId: userId, status: status }) && (\n <MenuItem\n className=\"sendbird-openchannel-user-message__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: message, userId: userId, status: status }) && (\n <MenuItem\n className=\"sendbird-openchannel-user-message__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 );\n}\n"],"names":["OpenchannelUserMessage","_a","className","message","userId","resendMessage","disabled","showEdit","showRemove","chainTop","messageType","_b","useLocalization","stringSet","dateLocale","_c","useContext","UserProfileContext","disableUserProfile","renderUserProfile","messageRef","useRef","avatarRef","contextMenuRef","_d","useState","contextStyle","setContextStyle","status","sendingStatus","isByMe","checkIsByMe","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","MemoizedMessageText","useMemo","splitMessage","split","matchedMessage","map","word","React","updatedAt","push","uuidv4","LabelTypography","BODY_1","LabelColors","ONBACKGROUND_2","MESSAGE_EDITED","useEffect","current","clientHeight","top","window","innerWidth","__spreadArray","Array","isArray","join","toggleDropdown","profileUrl","closeDropdown","paddingTop","paddingBottom","user","close","UserProfile","CAPTION_2","SECONDARY_3","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","ONBACKGROUND_1","IconTypes","SPINNER","IconColors","PRIMARY","ERROR","showMenuTrigger","MORE","CONTENT_INVERSE","isFineCopy","copyToClipboard","CONTEXT_MENU_DROPDOWN__COPY","isFineEdit","CONTEXT_MENU_DROPDOWN__EDIT","isFineResend","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE"],"mappings":"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"}
package/ui/PlaceHolder.js CHANGED
@@ -1,11 +1,11 @@
1
- import '../_rollupPluginBabelHelpers-d10f91b9.js';
1
+ import '../_rollupPluginBabelHelpers-084fb589.js';
2
2
  import 'react';
3
3
  import 'prop-types';
4
4
  import './Icon.js';
5
5
  import './Loader.js';
6
- import '../LocalizationContext-5b0a9339.js';
7
- import '../index-17cf7808.js';
8
- export { a as PlaceHolderTypes, P as default } from '../index-691dc8da.js';
9
- import '../stringSet-5a85ff4b.js';
10
- import '../index-94489c17.js';
6
+ import '../LocalizationContext-fb3dafcd.js';
7
+ import '../index-71e2bf26.js';
8
+ export { a as PlaceHolderTypes, P as default } from '../index-c95d2aab.js';
9
+ import '../stringSet-d3a8a2a0.js';
10
+ import '../index-13729368.js';
11
11
  //# sourceMappingURL=PlaceHolder.js.map
@@ -1,41 +1,41 @@
1
1
  import React__default, { useContext, useState } from 'react';
2
2
  import Icon, { IconTypes, IconColors } from './Icon.js';
3
- import { L as Label, a as LabelTypography, b as LabelColors } from '../index-17cf7808.js';
3
+ import { L as Label, a as LabelTypography, b as LabelColors } from '../index-71e2bf26.js';
4
4
  import ImageRenderer from './ImageRenderer.js';
5
- import { a as LocalizationContext } from '../LocalizationContext-5b0a9339.js';
6
- import { M as getUIKitFileTypes, j as getClassName, s as isUserMessage, o as isThumbnailMessage, A as isVideo, N as isGif, m as isFileMessage, z as isSupportedFileView, L as getUIKitFileType, t as truncateString } from '../index-902c2068.js';
7
- import '../_rollupPluginBabelHelpers-d10f91b9.js';
5
+ import { a as LocalizationContext } from '../LocalizationContext-fb3dafcd.js';
6
+ import { M as getUIKitFileTypes, k as getClassName, u as isUserMessage, p as isThumbnailMessage, B as isVideo, N as isGif, n as isFileMessage, A as isSupportedFileView, L as getUIKitFileType, t as truncateString } from '../index-8e6a607b.js';
7
+ import '../_rollupPluginBabelHelpers-084fb589.js';
8
8
  import 'prop-types';
9
- import '../stringSet-5a85ff4b.js';
10
- import '../index-94489c17.js';
11
- import '../tslib.es6-2c4d01e9.js';
9
+ import '../stringSet-d3a8a2a0.js';
10
+ import '../index-13729368.js';
11
+ import '../tslib.es6-a7db0cc5.js';
12
12
 
13
13
  function QuoteMessage(_a) {
14
14
  var _b;
15
15
 
16
- var _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
16
+ var _c, _d, _e, _f;
17
17
 
18
18
  var message = _a.message,
19
- _p = _a.userId,
20
- userId = _p === void 0 ? '' : _p,
21
- _q = _a.isByMe,
22
- isByMe = _q === void 0 ? false : _q,
19
+ _g = _a.userId,
20
+ userId = _g === void 0 ? '' : _g,
21
+ _h = _a.isByMe,
22
+ isByMe = _h === void 0 ? false : _h,
23
23
  className = _a.className,
24
24
  _onClick = _a.onClick;
25
25
  var stringSet = useContext(LocalizationContext).stringSet;
26
26
  var parentMessage = message.parentMessage;
27
- var parentMessageSender = (_c = parentMessage) === null || _c === void 0 ? void 0 : _c.sender;
27
+ var parentMessageSender = parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.sender;
28
28
  var parentMessageSenderNickname = userId === (parentMessageSender === null || parentMessageSender === void 0 ? void 0 : parentMessageSender.userId) ? stringSet.QUOTED_MESSAGE__CURRENT_USER : parentMessageSender === null || parentMessageSender === void 0 ? void 0 : parentMessageSender.nickname;
29
- var parentMessageUrl = ((_d = parentMessage) === null || _d === void 0 ? void 0 : _d.url) || '';
30
- var parentMessageType = (_e = parentMessage) === null || _e === void 0 ? void 0 : _e.type;
31
- var currentMessageSenderNickname = userId === ((_f = message === null || message === void 0 ? void 0 : message.sender) === null || _f === void 0 ? void 0 : _f.userId) ? stringSet.QUOTED_MESSAGE__CURRENT_USER : (_g = message === null || message === void 0 ? void 0 : message.sender) === null || _g === void 0 ? void 0 : _g.nickname;
29
+ var parentMessageUrl = (parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.url) || '';
30
+ var parentMessageType = parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.type;
31
+ var currentMessageSenderNickname = userId === ((_c = message === null || message === void 0 ? void 0 : message.sender) === null || _c === void 0 ? void 0 : _c.userId) ? stringSet.QUOTED_MESSAGE__CURRENT_USER : (_d = message === null || message === void 0 ? void 0 : message.sender) === null || _d === void 0 ? void 0 : _d.nickname;
32
32
 
33
- var _r = useState(false),
34
- isThumbnailLoaded = _r[0],
35
- setThumbnailLoaded = _r[1];
33
+ var _j = useState(false),
34
+ isThumbnailLoaded = _j[0],
35
+ setThumbnailLoaded = _j[1];
36
36
 
37
37
  var uikitFileTypes = getUIKitFileTypes();
38
- var splitFileName = ((_h = parentMessage) === null || _h === void 0 ? void 0 : _h.name) ? parentMessage.name.split('/') : parentMessageUrl.split('/');
38
+ var splitFileName = (parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.name) ? parentMessage.name.split('/') : parentMessageUrl.split('/');
39
39
  return /*#__PURE__*/React__default.createElement("div", {
40
40
  className: getClassName([className, 'sendbird-quote-message', isByMe ? 'outgoing' : 'incoming']),
41
41
  key: parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.messageId,
@@ -54,15 +54,15 @@ function QuoteMessage(_a) {
54
54
  className: "sendbird-quote-message__replied-to__text",
55
55
  type: LabelTypography.CAPTION_2,
56
56
  color: LabelColors.ONBACKGROUND_3
57
- }, currentMessageSenderNickname + " " + stringSet.QUOTED_MESSAGE__REPLIED_TO + " " + parentMessageSenderNickname)), /*#__PURE__*/React__default.createElement("div", {
57
+ }, "".concat(currentMessageSenderNickname, " ").concat(stringSet.QUOTED_MESSAGE__REPLIED_TO, " ").concat(parentMessageSenderNickname))), /*#__PURE__*/React__default.createElement("div", {
58
58
  className: "sendbird-quote-message__replied-message"
59
- }, isUserMessage(parentMessage) && ((_k = (_j = parentMessage) === null || _j === void 0 ? void 0 : _j.message) === null || _k === void 0 ? void 0 : _k.length) > 0 && /*#__PURE__*/React__default.createElement("div", {
59
+ }, isUserMessage(parentMessage) && ((_e = parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.message) === null || _e === void 0 ? void 0 : _e.length) > 0 && /*#__PURE__*/React__default.createElement("div", {
60
60
  className: "sendbird-quote-message__replied-message__text-message"
61
61
  }, /*#__PURE__*/React__default.createElement(Label, {
62
62
  className: "sendbird-quote-message__replied-message__text-message__word",
63
63
  type: LabelTypography.BODY_2,
64
64
  color: LabelColors.ONBACKGROUND_1
65
- }, (_l = parentMessage) === null || _l === void 0 ? void 0 : _l.message)), isThumbnailMessage(parentMessage) && parentMessageUrl && /*#__PURE__*/React__default.createElement("div", {
65
+ }, parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.message)), isThumbnailMessage(parentMessage) && parentMessageUrl && /*#__PURE__*/React__default.createElement("div", {
66
66
  className: "sendbird-quote-message__replied-message__thumbnail-message"
67
67
  }, /*#__PURE__*/React__default.createElement(ImageRenderer, {
68
68
  className: "sendbird-quote-message__replied-message__thumbnail-message__image",
@@ -83,7 +83,7 @@ function QuoteMessage(_a) {
83
83
  width: "22px",
84
84
  height: "22px"
85
85
  })))
86
- }), isVideo(parentMessageType) && !(((_o = (_m = parentMessage) === null || _m === void 0 ? void 0 : _m.thumbnails) === null || _o === void 0 ? void 0 : _o.length) > 0) && /*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement("video", {
86
+ }), isVideo(parentMessageType) && !(((_f = parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.thumbnails) === null || _f === void 0 ? void 0 : _f.length) > 0) && /*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement("video", {
87
87
  className: "sendbird-quote-message__replied-message__thumbnail-message__video"
88
88
  }, /*#__PURE__*/React__default.createElement("source", {
89
89
  src: parentMessageUrl,