@sendbird/uikit-react 3.0.0-beta.5 → 3.0.0-rc.1

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 (601) hide show
  1. package/App.js +48 -45
  2. package/App.js.map +1 -1
  3. package/CHANGELOG.md +43 -1
  4. package/Channel/components/ChannelHeader.js +25 -21
  5. package/Channel/components/ChannelHeader.js.map +1 -1
  6. package/Channel/components/ChannelUI.js +30 -27
  7. package/Channel/components/ChannelUI.js.map +1 -1
  8. package/Channel/components/FileViewer.js +18 -16
  9. package/Channel/components/FileViewer.js.map +1 -1
  10. package/Channel/components/FrozenNotification.js +5 -5
  11. package/Channel/components/Message.js +36 -27
  12. package/Channel/components/Message.js.map +1 -1
  13. package/Channel/components/MessageInput.js +32 -20
  14. package/Channel/components/MessageInput.js.map +1 -1
  15. package/Channel/components/MessageList.js +32 -29
  16. package/Channel/components/MessageList.js.map +1 -1
  17. package/Channel/components/RemoveMessageModal.js +21 -19
  18. package/Channel/components/RemoveMessageModal.js.map +1 -1
  19. package/Channel/components/SuggestedMentionList.js +119 -63
  20. package/Channel/components/SuggestedMentionList.js.map +1 -1
  21. package/Channel/components/TypingIndicator.js +37 -33
  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 +16 -14
  26. package/Channel/context.js.map +1 -1
  27. package/Channel.js +30 -27
  28. package/Channel.js.map +1 -1
  29. package/ChannelList/components/AddChannel.js +17 -17
  30. package/ChannelList/components/ChannelListHeader.js +8 -8
  31. package/ChannelList/components/ChannelListUI.js +44 -45
  32. package/ChannelList/components/ChannelListUI.js.map +1 -1
  33. package/ChannelList/components/ChannelPreview.js +38 -33
  34. package/ChannelList/components/ChannelPreview.js.map +1 -1
  35. package/ChannelList/components/ChannelPreviewAction.js +18 -16
  36. package/ChannelList/components/ChannelPreviewAction.js.map +1 -1
  37. package/ChannelList/context.js +11 -9
  38. package/ChannelList/context.js.map +1 -1
  39. package/ChannelList.js +31 -29
  40. package/ChannelList.js.map +1 -1
  41. package/{ChannelListProvider-a7bdd63a.js → ChannelListProvider-c3810392.js} +219 -198
  42. package/ChannelListProvider-c3810392.js.map +1 -0
  43. package/{ChannelProvider-923b58df.js → ChannelProvider-03ec9238.js} +384 -423
  44. package/ChannelProvider-03ec9238.js.map +1 -0
  45. package/ChannelSettings/components/ChannelProfile.js +17 -17
  46. package/ChannelSettings/components/ChannelProfile.js.map +1 -1
  47. package/ChannelSettings/components/ChannelSettingsUI.js +24 -24
  48. package/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
  49. package/ChannelSettings/components/EditDetailsModal.js +23 -19
  50. package/ChannelSettings/components/EditDetailsModal.js.map +1 -1
  51. package/ChannelSettings/components/LeaveChannel.js +14 -14
  52. package/ChannelSettings/components/LeaveChannel.js.map +1 -1
  53. package/ChannelSettings/components/{AdminPanel.js → ModerationPanel.js} +88 -142
  54. package/ChannelSettings/components/ModerationPanel.js.map +1 -0
  55. package/ChannelSettings/components/UserListItem.js +19 -18
  56. package/ChannelSettings/components/UserListItem.js.map +1 -1
  57. package/ChannelSettings/components/UserPanel.js +20 -20
  58. package/ChannelSettings/components/UserPanel.js.map +1 -1
  59. package/ChannelSettings/context.js +11 -11
  60. package/ChannelSettings/context.js.map +1 -1
  61. package/ChannelSettings.js +21 -21
  62. package/CreateChannel/components/CreateChannelUI.js +18 -18
  63. package/CreateChannel/components/CreateChannelUI.js.map +1 -1
  64. package/CreateChannel/components/{InviteMembers.js → InviteUsers.js} +24 -28
  65. package/CreateChannel/components/InviteUsers.js.map +1 -0
  66. package/CreateChannel/components/SelectChannelType.js +13 -13
  67. package/CreateChannel/components/SelectChannelType.js.map +1 -1
  68. package/CreateChannel/context.js +6 -5
  69. package/CreateChannel/context.js.map +1 -1
  70. package/CreateChannel.js +17 -17
  71. package/{CreateChannelProvider-e491613f.js → CreateChannelProvider-adb7afa8.js} +3 -3
  72. package/CreateChannelProvider-adb7afa8.js.map +1 -0
  73. package/EditUserProfile/components/EditUserProfileUI.js +14 -14
  74. package/EditUserProfile/context.js +2 -2
  75. package/EditUserProfile/context.js.map +1 -1
  76. package/EditUserProfile.js +14 -14
  77. package/{LocalizationContext-0e05ddca.js → LocalizationContext-0293a3fd.js} +3 -3
  78. package/{LocalizationContext-0e05ddca.js.map → LocalizationContext-0293a3fd.js.map} +1 -1
  79. package/{MemberList-ed7da941.js → MemberList-4e057ef8.js} +47 -68
  80. package/MemberList-4e057ef8.js.map +1 -0
  81. package/MessageSearch/components/MessageSearchUI.js +16 -16
  82. package/MessageSearch/components/MessageSearchUI.js.map +1 -1
  83. package/MessageSearch/context.js +56 -61
  84. package/MessageSearch/context.js.map +1 -1
  85. package/MessageSearch.js +22 -22
  86. package/MessageSearch.js.map +1 -1
  87. package/OpenChannel/components/FrozenChannelNotification.js +5 -5
  88. package/OpenChannel/components/OpenChannelHeader.js +17 -15
  89. package/OpenChannel/components/OpenChannelHeader.js.map +1 -1
  90. package/OpenChannel/components/OpenChannelInput.js +20 -18
  91. package/OpenChannel/components/OpenChannelInput.js.map +1 -1
  92. package/OpenChannel/components/OpenChannelMessage.js +44 -39
  93. package/OpenChannel/components/OpenChannelMessage.js.map +1 -1
  94. package/OpenChannel/components/OpenChannelMessageList.js +38 -37
  95. package/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
  96. package/OpenChannel/components/OpenChannelUI.js +28 -26
  97. package/OpenChannel/components/OpenChannelUI.js.map +1 -1
  98. package/OpenChannel/context.js +12 -10
  99. package/OpenChannel/context.js.map +1 -1
  100. package/OpenChannel.js +28 -26
  101. package/OpenChannel.js.map +1 -1
  102. package/{OpenChannelProvider-45a848a3.js → OpenChannelProvider-0572862e.js} +629 -694
  103. package/OpenChannelProvider-0572862e.js.map +1 -0
  104. package/OpenChannelSettings/components/EditDetailsModal.js +30 -36
  105. package/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
  106. package/OpenChannelSettings/components/OpenChannelProfile.js +16 -16
  107. package/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
  108. package/OpenChannelSettings/components/OpenChannelSettingsUI.js +39 -23
  109. package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
  110. package/OpenChannelSettings/components/OperatorUI.js +46 -31
  111. package/OpenChannelSettings/components/OperatorUI.js.map +1 -1
  112. package/OpenChannelSettings/components/ParticipantUI.js +30 -57
  113. package/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
  114. package/OpenChannelSettings/context.js +16 -16
  115. package/OpenChannelSettings/context.js.map +1 -1
  116. package/OpenChannelSettings.js +19 -19
  117. package/README.md +1 -2
  118. package/SendbirdProvider.js +60 -40
  119. package/SendbirdProvider.js.map +1 -1
  120. package/{UserProfileContext-90704c73.js → UserProfileContext-bcfe2804.js} +1 -1
  121. package/{UserProfileContext-90704c73.js.map → UserProfileContext-bcfe2804.js.map} +1 -1
  122. package/__bundle-7dfccc8c-a0cba188.js +24 -0
  123. package/__bundle-7dfccc8c-a0cba188.js.map +1 -0
  124. package/{_rollupPluginBabelHelpers-c7eeba03.js → _rollupPluginBabelHelpers-38569358.js} +1 -1
  125. package/{_rollupPluginBabelHelpers-c7eeba03.js.map → _rollupPluginBabelHelpers-38569358.js.map} +1 -1
  126. package/{actionTypes-e0f4e19c.js → actionTypes-c12e9c30.js} +1 -1
  127. package/{actionTypes-e0f4e19c.js.map → actionTypes-c12e9c30.js.map} +1 -1
  128. package/cjs/App.js +48 -45
  129. package/cjs/App.js.map +1 -1
  130. package/cjs/Channel/components/ChannelHeader.js +25 -21
  131. package/cjs/Channel/components/ChannelHeader.js.map +1 -1
  132. package/cjs/Channel/components/ChannelUI.js +30 -27
  133. package/cjs/Channel/components/ChannelUI.js.map +1 -1
  134. package/cjs/Channel/components/FileViewer.js +18 -16
  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 +36 -27
  138. package/cjs/Channel/components/Message.js.map +1 -1
  139. package/cjs/Channel/components/MessageInput.js +32 -20
  140. package/cjs/Channel/components/MessageInput.js.map +1 -1
  141. package/cjs/Channel/components/MessageList.js +32 -29
  142. package/cjs/Channel/components/MessageList.js.map +1 -1
  143. package/cjs/Channel/components/RemoveMessageModal.js +21 -19
  144. package/cjs/Channel/components/RemoveMessageModal.js.map +1 -1
  145. package/cjs/Channel/components/SuggestedMentionList.js +119 -63
  146. package/cjs/Channel/components/SuggestedMentionList.js.map +1 -1
  147. package/cjs/Channel/components/TypingIndicator.js +37 -33
  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 +17 -15
  152. package/cjs/Channel/context.js.map +1 -1
  153. package/cjs/Channel.js +30 -27
  154. package/cjs/Channel.js.map +1 -1
  155. package/cjs/ChannelList/components/AddChannel.js +17 -17
  156. package/cjs/ChannelList/components/ChannelListHeader.js +8 -8
  157. package/cjs/ChannelList/components/ChannelListUI.js +44 -45
  158. package/cjs/ChannelList/components/ChannelListUI.js.map +1 -1
  159. package/cjs/ChannelList/components/ChannelPreview.js +38 -33
  160. package/cjs/ChannelList/components/ChannelPreview.js.map +1 -1
  161. package/cjs/ChannelList/components/ChannelPreviewAction.js +18 -16
  162. package/cjs/ChannelList/components/ChannelPreviewAction.js.map +1 -1
  163. package/cjs/ChannelList/context.js +11 -10
  164. package/cjs/ChannelList/context.js.map +1 -1
  165. package/cjs/ChannelList.js +31 -29
  166. package/cjs/ChannelList.js.map +1 -1
  167. package/cjs/{ChannelListProvider-01864e22.js → ChannelListProvider-8f421c0d.js} +218 -198
  168. package/cjs/ChannelListProvider-8f421c0d.js.map +1 -0
  169. package/cjs/{ChannelProvider-3ef2a755.js → ChannelProvider-397c5f03.js} +384 -423
  170. package/cjs/ChannelProvider-397c5f03.js.map +1 -0
  171. package/cjs/ChannelSettings/components/ChannelProfile.js +16 -16
  172. package/cjs/ChannelSettings/components/ChannelProfile.js.map +1 -1
  173. package/cjs/ChannelSettings/components/ChannelSettingsUI.js +23 -23
  174. package/cjs/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
  175. package/cjs/ChannelSettings/components/EditDetailsModal.js +22 -18
  176. package/cjs/ChannelSettings/components/EditDetailsModal.js.map +1 -1
  177. package/cjs/ChannelSettings/components/LeaveChannel.js +13 -13
  178. package/cjs/ChannelSettings/components/LeaveChannel.js.map +1 -1
  179. package/cjs/ChannelSettings/components/{AdminPanel.js → ModerationPanel.js} +87 -141
  180. package/cjs/ChannelSettings/components/ModerationPanel.js.map +1 -0
  181. package/cjs/ChannelSettings/components/UserListItem.js +19 -18
  182. package/cjs/ChannelSettings/components/UserListItem.js.map +1 -1
  183. package/cjs/ChannelSettings/components/UserPanel.js +19 -19
  184. package/cjs/ChannelSettings/components/UserPanel.js.map +1 -1
  185. package/cjs/ChannelSettings/context.js +11 -11
  186. package/cjs/ChannelSettings/context.js.map +1 -1
  187. package/cjs/ChannelSettings.js +21 -21
  188. package/cjs/CreateChannel/components/CreateChannelUI.js +18 -18
  189. package/cjs/CreateChannel/components/CreateChannelUI.js.map +1 -1
  190. package/cjs/CreateChannel/components/{InviteMembers.js → InviteUsers.js} +24 -28
  191. package/cjs/CreateChannel/components/InviteUsers.js.map +1 -0
  192. package/cjs/CreateChannel/components/SelectChannelType.js +13 -13
  193. package/cjs/CreateChannel/components/SelectChannelType.js.map +1 -1
  194. package/cjs/CreateChannel/context.js +6 -5
  195. package/cjs/CreateChannel/context.js.map +1 -1
  196. package/cjs/CreateChannel.js +17 -17
  197. package/cjs/{CreateChannelProvider-0d01dcbf.js → CreateChannelProvider-adb49afd.js} +3 -3
  198. package/cjs/CreateChannelProvider-adb49afd.js.map +1 -0
  199. package/cjs/EditUserProfile/components/EditUserProfileUI.js +14 -14
  200. package/cjs/EditUserProfile/context.js +2 -2
  201. package/cjs/EditUserProfile/context.js.map +1 -1
  202. package/cjs/EditUserProfile.js +14 -14
  203. package/cjs/{LocalizationContext-4c0a4a70.js → LocalizationContext-af3a239a.js} +3 -3
  204. package/cjs/{LocalizationContext-4c0a4a70.js.map → LocalizationContext-af3a239a.js.map} +1 -1
  205. package/cjs/{MemberList-b917d2b8.js → MemberList-a507429a.js} +46 -67
  206. package/cjs/MemberList-a507429a.js.map +1 -0
  207. package/cjs/MessageSearch/components/MessageSearchUI.js +15 -15
  208. package/cjs/MessageSearch/components/MessageSearchUI.js.map +1 -1
  209. package/cjs/MessageSearch/context.js +56 -61
  210. package/cjs/MessageSearch/context.js.map +1 -1
  211. package/cjs/MessageSearch.js +22 -22
  212. package/cjs/MessageSearch.js.map +1 -1
  213. package/cjs/OpenChannel/components/FrozenChannelNotification.js +5 -5
  214. package/cjs/OpenChannel/components/OpenChannelHeader.js +17 -15
  215. package/cjs/OpenChannel/components/OpenChannelHeader.js.map +1 -1
  216. package/cjs/OpenChannel/components/OpenChannelInput.js +20 -18
  217. package/cjs/OpenChannel/components/OpenChannelInput.js.map +1 -1
  218. package/cjs/OpenChannel/components/OpenChannelMessage.js +44 -39
  219. package/cjs/OpenChannel/components/OpenChannelMessage.js.map +1 -1
  220. package/cjs/OpenChannel/components/OpenChannelMessageList.js +38 -37
  221. package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
  222. package/cjs/OpenChannel/components/OpenChannelUI.js +28 -26
  223. package/cjs/OpenChannel/components/OpenChannelUI.js.map +1 -1
  224. package/cjs/OpenChannel/context.js +13 -11
  225. package/cjs/OpenChannel/context.js.map +1 -1
  226. package/cjs/OpenChannel.js +28 -26
  227. package/cjs/OpenChannel.js.map +1 -1
  228. package/cjs/{OpenChannelProvider-862a55ec.js → OpenChannelProvider-e0ff3593.js} +629 -694
  229. package/cjs/OpenChannelProvider-e0ff3593.js.map +1 -0
  230. package/cjs/OpenChannelSettings/components/EditDetailsModal.js +29 -35
  231. package/cjs/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
  232. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js +15 -15
  233. package/cjs/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
  234. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js +38 -22
  235. package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
  236. package/cjs/OpenChannelSettings/components/OperatorUI.js +43 -28
  237. package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -1
  238. package/cjs/OpenChannelSettings/components/ParticipantUI.js +29 -56
  239. package/cjs/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
  240. package/cjs/OpenChannelSettings/context.js +16 -16
  241. package/cjs/OpenChannelSettings/context.js.map +1 -1
  242. package/cjs/OpenChannelSettings.js +19 -19
  243. package/cjs/SendbirdProvider.js +61 -42
  244. package/cjs/SendbirdProvider.js.map +1 -1
  245. package/cjs/{UserProfileContext-0081d7b2.js → UserProfileContext-1a32d7da.js} +1 -1
  246. package/cjs/{UserProfileContext-0081d7b2.js.map → UserProfileContext-1a32d7da.js.map} +1 -1
  247. package/cjs/__bundle-7dfccc8c-3aa3a536.js +151 -0
  248. package/cjs/__bundle-7dfccc8c-3aa3a536.js.map +1 -0
  249. package/cjs/{_rollupPluginBabelHelpers-08d1d0ec.js → _rollupPluginBabelHelpers-1be0417a.js} +1 -1
  250. package/cjs/{_rollupPluginBabelHelpers-08d1d0ec.js.map → _rollupPluginBabelHelpers-1be0417a.js.map} +1 -1
  251. package/cjs/{actionTypes-03bdd863.js → actionTypes-9635e2a1.js} +1 -1
  252. package/cjs/{actionTypes-03bdd863.js.map → actionTypes-9635e2a1.js.map} +1 -1
  253. package/cjs/{color-37edcf95.js → color-79441155.js} +1 -1
  254. package/cjs/{color-37edcf95.js.map → color-79441155.js.map} +1 -1
  255. package/cjs/{compareIds-1cb14940.js → compareIds-9e929882.js} +1 -1
  256. package/cjs/{compareIds-1cb14940.js.map → compareIds-9e929882.js.map} +1 -1
  257. package/cjs/{const-21636adb.js → const-3ec42b99.js} +1 -1
  258. package/cjs/{const-21636adb.js.map → const-3ec42b99.js.map} +1 -1
  259. package/cjs/{const-64185108.js → const-c45b3772.js} +1 -1
  260. package/cjs/{const-64185108.js.map → const-c45b3772.js.map} +1 -1
  261. package/cjs/{context-8f183eb3.js → context-7f20c4fc.js} +2 -2
  262. package/cjs/{context-8f183eb3.js.map → context-7f20c4fc.js.map} +1 -1
  263. package/{index.css → cjs/dist/index.css} +243 -103
  264. package/cjs/dist/index.css.map +1 -0
  265. package/cjs/groupChannel-57828c97.js +9 -0
  266. package/cjs/groupChannel-57828c97.js.map +1 -0
  267. package/cjs/{index-30e8e785.js → index-101e25b6.js} +5 -5
  268. package/cjs/index-101e25b6.js.map +1 -0
  269. package/cjs/{index-1a6c1893.js → index-7b1f120b.js} +1 -1
  270. package/cjs/{index-1a6c1893.js.map → index-7b1f120b.js.map} +1 -1
  271. package/cjs/{index-7532e1ca.js → index-82b738a4.js} +4 -4
  272. package/cjs/{index-7532e1ca.js.map → index-82b738a4.js.map} +1 -1
  273. package/cjs/{index-4e4d7494.js → index-c3d974a8.js} +1 -1
  274. package/cjs/{index-4e4d7494.js.map → index-c3d974a8.js.map} +1 -1
  275. package/cjs/{index-8479199c.js → index-c42f8ea9.js} +12 -9
  276. package/cjs/index-c42f8ea9.js.map +1 -0
  277. package/cjs/{index-6d82098c.js → index-c4440bd2.js} +4 -4
  278. package/cjs/{index-6d82098c.js.map → index-c4440bd2.js.map} +1 -1
  279. package/cjs/{index-630f8d1b.js → index-ebb83a37.js} +5 -5
  280. package/cjs/index-ebb83a37.js.map +1 -0
  281. package/cjs/{index-dcd38046.js → index-f21d728f.js} +2 -2
  282. package/cjs/{index-dcd38046.js.map → index-f21d728f.js.map} +1 -1
  283. package/cjs/{index-a40d57a5.js → index-f3cc1992.js} +36 -29
  284. package/cjs/index-f3cc1992.js.map +1 -0
  285. package/cjs/{index-23c51d89.js → index-fddacd70.js} +2 -2
  286. package/cjs/{index-23c51d89.js.map → index-fddacd70.js.map} +1 -1
  287. package/cjs/index.js +43 -40
  288. package/cjs/index.js.map +1 -1
  289. package/cjs/openChannel-19ee9ebe.js +13 -0
  290. package/cjs/openChannel-19ee9ebe.js.map +1 -0
  291. package/cjs/{openChannelUtils-46a3a403.js → openChannelUtils-d4258320.js} +10 -5
  292. package/cjs/openChannelUtils-d4258320.js.map +1 -0
  293. package/cjs/sendbirdSelectors.js +696 -0
  294. package/cjs/sendbirdSelectors.js.map +1 -0
  295. package/cjs/{stringSet-d9121aa6.js → stringSet-ed353b6e.js} +1 -1
  296. package/cjs/{stringSet-d9121aa6.js.map → stringSet-ed353b6e.js.map} +1 -1
  297. package/cjs/{topics-4fc933cb.js → topics-1e190fcd.js} +1 -1
  298. package/cjs/{topics-4fc933cb.js.map → topics-1e190fcd.js.map} +1 -1
  299. package/cjs/{tslib.es6-571bbfc9.js → tslib.es6-4b07fef2.js} +1 -1
  300. package/cjs/{tslib.es6-571bbfc9.js.map → tslib.es6-4b07fef2.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 +100 -0
  336. package/cjs/ui/MentionLabel.js.map +1 -0
  337. package/cjs/ui/MentionUserLabel.js +1 -1
  338. package/cjs/ui/MentionUserLabel.js.map +1 -1
  339. package/cjs/ui/MessageContent.js +54 -48
  340. package/cjs/ui/MessageContent.js.map +1 -1
  341. package/cjs/ui/MessageInput.js +18 -14
  342. package/cjs/ui/MessageInput.js.map +1 -1
  343. package/cjs/ui/MessageItemMenu.js +14 -18
  344. package/cjs/ui/MessageItemMenu.js.map +1 -1
  345. package/cjs/ui/MessageItemReactionMenu.js +5 -5
  346. package/cjs/ui/MessageItemReactionMenu.js.map +1 -1
  347. package/cjs/ui/MessageSearchFileItem.js +12 -11
  348. package/cjs/ui/MessageSearchFileItem.js.map +1 -1
  349. package/cjs/ui/MessageSearchItem.js +10 -10
  350. package/cjs/ui/MessageSearchItem.js.map +1 -1
  351. package/cjs/ui/MessageStatus.js +11 -11
  352. package/cjs/ui/MessageStatus.js.map +1 -1
  353. package/cjs/ui/Modal.js +8 -8
  354. package/cjs/ui/MutedAvatarOverlay.js +7 -7
  355. package/cjs/ui/MutedAvatarOverlay.js.map +1 -1
  356. package/cjs/ui/OGMessageItemBody.js +25 -13
  357. package/cjs/ui/OGMessageItemBody.js.map +1 -1
  358. package/cjs/ui/OpenChannelAdminMessage.js +4 -4
  359. package/cjs/ui/OpenChannelAdminMessage.js.map +1 -1
  360. package/cjs/ui/OpenChannelAvatar.js +11 -11
  361. package/cjs/ui/OpenChannelAvatar.js.map +1 -1
  362. package/cjs/ui/OpenchannelConversationHeader.js +7 -7
  363. package/cjs/ui/OpenchannelFileMessage.js +17 -16
  364. package/cjs/ui/OpenchannelFileMessage.js.map +1 -1
  365. package/cjs/ui/OpenchannelOGMessage.js +17 -16
  366. package/cjs/ui/OpenchannelOGMessage.js.map +1 -1
  367. package/cjs/ui/OpenchannelThumbnailMessage.js +18 -17
  368. package/cjs/ui/OpenchannelThumbnailMessage.js.map +1 -1
  369. package/cjs/ui/OpenchannelUserMessage.js +18 -17
  370. package/cjs/ui/OpenchannelUserMessage.js.map +1 -1
  371. package/cjs/ui/PlaceHolder.js +6 -6
  372. package/cjs/ui/QuoteMessage.js +24 -24
  373. package/cjs/ui/QuoteMessage.js.map +1 -1
  374. package/cjs/ui/QuoteMessageInput.js +11 -13
  375. package/cjs/ui/QuoteMessageInput.js.map +1 -1
  376. package/cjs/ui/ReactionBadge.js +3 -3
  377. package/cjs/ui/ReactionButton.js +1 -1
  378. package/cjs/ui/SortByRow.js +1 -1
  379. package/cjs/ui/TextButton.js +2 -2
  380. package/cjs/ui/TextMessageItemBody.js +26 -12
  381. package/cjs/ui/TextMessageItemBody.js.map +1 -1
  382. package/cjs/ui/ThumbnailMessageItemBody.js +3 -3
  383. package/cjs/ui/ThumbnailMessageItemBody.js.map +1 -1
  384. package/cjs/ui/Tooltip.js +3 -3
  385. package/cjs/ui/TooltipWrapper.js +1 -1
  386. package/cjs/ui/UnknownMessageItemBody.js +7 -7
  387. package/cjs/ui/UnknownMessageItemBody.js.map +1 -1
  388. package/cjs/ui/UserListItem.js +14 -13
  389. package/cjs/ui/UserListItem.js.map +1 -1
  390. package/cjs/ui/UserProfile.js +22 -21
  391. package/cjs/ui/UserProfile.js.map +1 -1
  392. package/cjs/{index-94e8cf13.js → ui/Word.js} +35 -13
  393. package/cjs/ui/Word.js.map +1 -0
  394. package/cjs/useSendbirdStateContext.js +3 -3
  395. package/cjs/useSendbirdStateContext.js.map +1 -1
  396. package/cjs/{utils-b88eb3e0.js → utils-6ff87257.js} +1 -1
  397. package/cjs/{utils-b88eb3e0.js.map → utils-6ff87257.js.map} +1 -1
  398. package/cjs/{utils-63225dc9.js → utils-88672f3d.js} +1 -1
  399. package/cjs/{utils-63225dc9.js.map → utils-88672f3d.js.map} +1 -1
  400. package/cjs/{utils-f734965d.js → utils-c15722aa.js} +8 -8
  401. package/cjs/utils-c15722aa.js.map +1 -0
  402. package/cjs/{uuid-086f0c34.js → uuid-c63c6c5a.js} +1 -1
  403. package/cjs/{uuid-086f0c34.js.map → uuid-c63c6c5a.js.map} +1 -1
  404. package/cjs/{withSendBird.js → withSendbird.js} +2 -2
  405. package/cjs/{withSendBird.js.map → withSendbird.js.map} +1 -1
  406. package/{color-a3d3742c.js → color-8ef428b9.js} +1 -1
  407. package/{color-a3d3742c.js.map → color-8ef428b9.js.map} +1 -1
  408. package/{compareIds-2bfd667a.js → compareIds-d0f57b59.js} +1 -1
  409. package/{compareIds-2bfd667a.js.map → compareIds-d0f57b59.js.map} +1 -1
  410. package/{const-9f83647a.js → const-c751cfe7.js} +1 -1
  411. package/{const-9f83647a.js.map → const-c751cfe7.js.map} +1 -1
  412. package/{const-a8df15de.js → const-da7e79d6.js} +1 -1
  413. package/{const-a8df15de.js.map → const-da7e79d6.js.map} +1 -1
  414. package/{context-ae164d45.js → context-64a89b1b.js} +2 -2
  415. package/{context-ae164d45.js.map → context-64a89b1b.js.map} +1 -1
  416. package/dist/index.css +243 -103
  417. package/dist/index.css.map +1 -1
  418. package/groupChannel-45ccdf2b.js +6 -0
  419. package/groupChannel-45ccdf2b.js.map +1 -0
  420. package/{index-df459121.js → index-03332d0e.js} +4 -4
  421. package/{index-df459121.js.map → index-03332d0e.js.map} +1 -1
  422. package/{index-d7840fad.js → index-244760b9.js} +4 -4
  423. package/{index-d7840fad.js.map → index-244760b9.js.map} +1 -1
  424. package/{index-e1b93b3a.js → index-5729e2f0.js} +5 -5
  425. package/index-5729e2f0.js.map +1 -0
  426. package/{index-e7c0bc26.js → index-6924378b.js} +1 -1
  427. package/{index-e7c0bc26.js.map → index-6924378b.js.map} +1 -1
  428. package/{index-89f5a4ba.js → index-87a997c3.js} +12 -9
  429. package/index-87a997c3.js.map +1 -0
  430. package/{index-f78ebc31.js → index-b9a1f38d.js} +5 -5
  431. package/index-b9a1f38d.js.map +1 -0
  432. package/{index-2c56786f.js → index-c3d16dc1.js} +2 -2
  433. package/{index-2c56786f.js.map → index-c3d16dc1.js.map} +1 -1
  434. package/{index-29563598.js → index-e0ff03bb.js} +2 -2
  435. package/{index-29563598.js.map → index-e0ff03bb.js.map} +1 -1
  436. package/{index-03baba6a.js → index-f1c7b834.js} +36 -30
  437. package/index-f1c7b834.js.map +1 -0
  438. package/{index-80e330a9.js → index-f6405407.js} +1 -1
  439. package/{index-80e330a9.js.map → index-f6405407.js.map} +1 -1
  440. package/index.d.ts +1035 -900
  441. package/index.d.ts_bkup +1883 -0
  442. package/index.js +41 -38
  443. package/index.js.map +1 -1
  444. package/openChannel-a604a724.js +8 -0
  445. package/openChannel-a604a724.js.map +1 -0
  446. package/{openChannelUtils-ae1d6038.js → openChannelUtils-d9f15020.js} +10 -5
  447. package/openChannelUtils-d9f15020.js.map +1 -0
  448. package/package.json +5 -5
  449. package/sendbirdSelectors.js +671 -0
  450. package/sendbirdSelectors.js.map +1 -0
  451. package/{stringSet-6c9c68ae.js → stringSet-6bcac8f5.js} +1 -1
  452. package/{stringSet-6c9c68ae.js.map → stringSet-6bcac8f5.js.map} +1 -1
  453. package/{topics-d347c996.js → topics-997dc2ef.js} +2 -2
  454. package/{topics-d347c996.js.map → topics-997dc2ef.js.map} +1 -1
  455. package/{tslib.es6-61821688.js → tslib.es6-528d1472.js} +1 -1
  456. package/{tslib.es6-61821688.js.map → tslib.es6-528d1472.js.map} +1 -1
  457. package/ui/Accordion.js +4 -4
  458. package/ui/AccordionGroup.js +2 -2
  459. package/ui/AccordionGroup.js.map +1 -1
  460. package/ui/AdminMessage.js +4 -3
  461. package/ui/AdminMessage.js.map +1 -1
  462. package/ui/Avatar.js +3 -3
  463. package/ui/Badge.js +5 -5
  464. package/ui/Button.js +4 -4
  465. package/ui/ChannelAvatar.js +8 -8
  466. package/ui/ChannelAvatar.js.map +1 -1
  467. package/ui/ChannelPreview.js +28 -21
  468. package/ui/ChannelPreview.js.map +1 -1
  469. package/ui/ChatHeader.js +19 -12
  470. package/ui/ChatHeader.js.map +1 -1
  471. package/ui/Checkbox.js +1 -1
  472. package/ui/ConnectionStatus.js +5 -5
  473. package/ui/ContextMenu.js +9 -30
  474. package/ui/ContextMenu.js.map +1 -1
  475. package/ui/DateSeparator.js +5 -5
  476. package/ui/DateSeparator.js.map +1 -1
  477. package/ui/Dropdown.js +3 -3
  478. package/ui/EmojiReactions.js +10 -10
  479. package/ui/EmojiReactions.js.map +1 -1
  480. package/ui/FileMessageItemBody.js +6 -6
  481. package/ui/FileMessageItemBody.js.map +1 -1
  482. package/ui/FileViewer.js +7 -7
  483. package/ui/Icon.js +5 -1
  484. package/ui/Icon.js.map +1 -1
  485. package/ui/IconButton.js +1 -1
  486. package/ui/ImageRenderer.js +1 -1
  487. package/ui/Input.js +3 -3
  488. package/ui/Label.js +3 -3
  489. package/ui/LinkLabel.js +3 -3
  490. package/ui/Loader.js +1 -1
  491. package/ui/MentionLabel.js +94 -0
  492. package/ui/MentionLabel.js.map +1 -0
  493. package/ui/MentionUserLabel.js +1 -1
  494. package/ui/MentionUserLabel.js.map +1 -1
  495. package/ui/MessageContent.js +56 -50
  496. package/ui/MessageContent.js.map +1 -1
  497. package/ui/MessageInput.js +18 -14
  498. package/ui/MessageInput.js.map +1 -1
  499. package/ui/MessageItemMenu.js +14 -18
  500. package/ui/MessageItemMenu.js.map +1 -1
  501. package/ui/MessageItemReactionMenu.js +5 -5
  502. package/ui/MessageItemReactionMenu.js.map +1 -1
  503. package/ui/MessageSearchFileItem.js +12 -11
  504. package/ui/MessageSearchFileItem.js.map +1 -1
  505. package/ui/MessageSearchItem.js +10 -10
  506. package/ui/MessageSearchItem.js.map +1 -1
  507. package/ui/MessageStatus.js +11 -11
  508. package/ui/MessageStatus.js.map +1 -1
  509. package/ui/Modal.js +8 -8
  510. package/ui/MutedAvatarOverlay.js +7 -7
  511. package/ui/MutedAvatarOverlay.js.map +1 -1
  512. package/ui/OGMessageItemBody.js +23 -11
  513. package/ui/OGMessageItemBody.js.map +1 -1
  514. package/ui/OpenChannelAdminMessage.js +4 -4
  515. package/ui/OpenChannelAdminMessage.js.map +1 -1
  516. package/ui/OpenChannelAvatar.js +11 -11
  517. package/ui/OpenChannelAvatar.js.map +1 -1
  518. package/ui/OpenchannelConversationHeader.js +7 -7
  519. package/ui/OpenchannelFileMessage.js +17 -16
  520. package/ui/OpenchannelFileMessage.js.map +1 -1
  521. package/ui/OpenchannelOGMessage.js +17 -16
  522. package/ui/OpenchannelOGMessage.js.map +1 -1
  523. package/ui/OpenchannelThumbnailMessage.js +18 -17
  524. package/ui/OpenchannelThumbnailMessage.js.map +1 -1
  525. package/ui/OpenchannelUserMessage.js +18 -17
  526. package/ui/OpenchannelUserMessage.js.map +1 -1
  527. package/ui/PlaceHolder.js +6 -6
  528. package/ui/QuoteMessage.js +24 -24
  529. package/ui/QuoteMessage.js.map +1 -1
  530. package/ui/QuoteMessageInput.js +11 -13
  531. package/ui/QuoteMessageInput.js.map +1 -1
  532. package/ui/ReactionBadge.js +3 -3
  533. package/ui/ReactionButton.js +1 -1
  534. package/ui/SortByRow.js +1 -1
  535. package/ui/TextButton.js +2 -2
  536. package/ui/TextMessageItemBody.js +25 -11
  537. package/ui/TextMessageItemBody.js.map +1 -1
  538. package/ui/ThumbnailMessageItemBody.js +3 -3
  539. package/ui/ThumbnailMessageItemBody.js.map +1 -1
  540. package/ui/Tooltip.js +3 -3
  541. package/ui/TooltipWrapper.js +1 -1
  542. package/ui/UnknownMessageItemBody.js +7 -7
  543. package/ui/UnknownMessageItemBody.js.map +1 -1
  544. package/ui/UserListItem.js +14 -13
  545. package/ui/UserListItem.js.map +1 -1
  546. package/ui/UserProfile.js +20 -19
  547. package/ui/UserProfile.js.map +1 -1
  548. package/ui/Word.js +70 -0
  549. package/ui/Word.js.map +1 -0
  550. package/useSendbirdStateContext.js +2 -2
  551. package/useSendbirdStateContext.js.map +1 -1
  552. package/{utils-aed86fb8.js → utils-77d4fd35.js} +1 -1
  553. package/{utils-aed86fb8.js.map → utils-77d4fd35.js.map} +1 -1
  554. package/{utils-5e25aca3.js → utils-91321bf8.js} +8 -8
  555. package/utils-91321bf8.js.map +1 -0
  556. package/{utils-4e85584a.js → utils-d0e53d6f.js} +1 -1
  557. package/{utils-4e85584a.js.map → utils-d0e53d6f.js.map} +1 -1
  558. package/{uuid-6e6389e2.js → uuid-ae0ebd46.js} +1 -1
  559. package/{uuid-6e6389e2.js.map → uuid-ae0ebd46.js.map} +1 -1
  560. package/{withSendBird.js → withSendbird.js} +2 -2
  561. package/{withSendBird.js.map → withSendbird.js.map} +1 -1
  562. package/ChannelListProvider-a7bdd63a.js.map +0 -1
  563. package/ChannelProvider-923b58df.js.map +0 -1
  564. package/ChannelSettings/components/AdminPanel.js.map +0 -1
  565. package/CreateChannel/components/InviteMembers.js.map +0 -1
  566. package/CreateChannelProvider-e491613f.js.map +0 -1
  567. package/MemberList-ed7da941.js.map +0 -1
  568. package/OpenChannelProvider-45a848a3.js.map +0 -1
  569. package/cjs/ChannelListProvider-01864e22.js.map +0 -1
  570. package/cjs/ChannelProvider-3ef2a755.js.map +0 -1
  571. package/cjs/ChannelSettings/components/AdminPanel.js.map +0 -1
  572. package/cjs/CreateChannel/components/InviteMembers.js.map +0 -1
  573. package/cjs/CreateChannelProvider-0d01dcbf.js.map +0 -1
  574. package/cjs/MemberList-b917d2b8.js.map +0 -1
  575. package/cjs/OpenChannelProvider-862a55ec.js.map +0 -1
  576. package/cjs/index-30e8e785.js.map +0 -1
  577. package/cjs/index-630f8d1b.js.map +0 -1
  578. package/cjs/index-8479199c.js.map +0 -1
  579. package/cjs/index-94e8cf13.js.map +0 -1
  580. package/cjs/index-a40d57a5.js.map +0 -1
  581. package/cjs/index.css +0 -4463
  582. package/cjs/index.css.map +0 -1
  583. package/cjs/openChannelUtils-46a3a403.js.map +0 -1
  584. package/cjs/sendBirdSelectors.js +0 -741
  585. package/cjs/sendBirdSelectors.js.map +0 -1
  586. package/cjs/ui/OpenChannelMessageContent.js +0 -14
  587. package/cjs/ui/OpenChannelMessageContent.js.map +0 -1
  588. package/cjs/utils-f734965d.js.map +0 -1
  589. package/index-03baba6a.js.map +0 -1
  590. package/index-13eb0f5e.js +0 -48
  591. package/index-13eb0f5e.js.map +0 -1
  592. package/index-89f5a4ba.js.map +0 -1
  593. package/index-e1b93b3a.js.map +0 -1
  594. package/index-f78ebc31.js.map +0 -1
  595. package/index.css.map +0 -1
  596. package/openChannelUtils-ae1d6038.js.map +0 -1
  597. package/sendBirdSelectors.js +0 -713
  598. package/sendBirdSelectors.js.map +0 -1
  599. package/ui/OpenChannelMessageContent.js +0 -8
  600. package/ui/OpenChannelMessageContent.js.map +0 -1
  601. package/utils-5e25aca3.js.map +0 -1
@@ -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","Icon","IconColors","ON_BACKGROUND_2","isByMe","checkIsByMe","isMessageSent","checkIsSent","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","useEffect","thumbnailWidth","current","clientWidth","__spreadArray","Array","isArray","join","ContextMenu","toggleDropdown","Avatar","profileUrl","closeDropdown","MenuItems","paddingTop","paddingBottom","user","close","UserProfile","Label","LabelTypography","CAPTION_2","LabelColors","SECONDARY_3","ONBACKGROUND_2","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","_b","ImageRenderer","IconTypes","PLAY","PHOTO","Loader","SPINNER","PRIMARY","ERROR","showMenuTrigger","IconButton","MORE","CONTENT_INVERSE","isFineResend","MenuItem","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE"],"mappings":"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"}
1
+ {"version":3,"file":"OpenchannelThumbnailMessage.js","sources":["../../../src/ui/OpenchannelThumbnailMessage/utils.ts","../../../src/ui/OpenchannelThumbnailMessage/index.tsx"],"sourcesContent":["export const SUPPORTING_TYPES = {\n IMAGE: 'IMAGE',\n VIDEO: 'VIDEO',\n UNSUPPORTED: 'UNSUPPORTED',\n};\n\nconst SUPPORTED_MIMES = {\n IMAGE: [\n 'image/jpeg',\n 'image/jpg',\n 'image/png',\n 'image/gif',\n 'image/webp',\n ],\n VIDEO: [\n 'video/mpeg',\n 'video/ogg',\n 'video/webm',\n 'video/mp4',\n ],\n};\n\nexport const getSupportingFileType = (type: string): string => {\n if (SUPPORTED_MIMES.IMAGE.indexOf(type) >= 0) {\n return SUPPORTING_TYPES.IMAGE;\n }\n if (SUPPORTED_MIMES.VIDEO.indexOf(type) >= 0) {\n return SUPPORTING_TYPES.VIDEO;\n }\n return SUPPORTING_TYPES.UNSUPPORTED;\n}\n","import React, {\n useRef,\n useMemo,\n useState,\n useEffect,\n useContext,\n} from 'react';\nimport { FileMessage } from '@sendbird/chat/message';\nimport format from 'date-fns/format';\nimport './index.scss';\nimport { SUPPORTING_TYPES, getSupportingFileType } from './utils';\nimport { useLocalization } from '../../lib/LocalizationContext';\n\nimport Avatar from '../Avatar';\nimport ContextMenu, { MenuItems, MenuItem } from '../ContextMenu';\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport IconButton from '../IconButton';\nimport ImageRenderer from '../ImageRenderer';\nimport Label, { LabelTypography, LabelColors } from '../Label';\nimport Loader from '../Loader';\nimport UserProfile from '../UserProfile';\nimport { UserProfileContext } from '../../lib/UserProfileContext';\nimport {\n checkIsByMe,\n checkIsSent,\n checkIsPending,\n checkIsFailed,\n isFineResend,\n isFineDelete,\n showMenuTrigger,\n} from '../../utils/openChannelUtils';\nimport { getSenderFromMessage } from '../../utils/openChannelUtils';\n\ninterface LocalUrl {\n localUrl?: string;\n}\ninterface Props {\n className?: string | Array<string>;\n message: FileMessage;\n disabled: boolean;\n userId: string;\n chainTop: boolean;\n chainBottom: boolean;\n onClick(bool: boolean): void,\n showRemove(bool: boolean): void,\n resendMessage(message: FileMessage): void;\n}\n\nexport default function OpenchannelThumbnailMessage({\n className,\n message,\n disabled,\n userId,\n chainTop,\n onClick,\n showRemove,\n resendMessage,\n}: Props): JSX.Element {\n const {\n type,\n url,\n thumbnails,\n localUrl,\n }: FileMessage & LocalUrl = message;\n const status = message?.sendingStatus;\n const thumbnailUrl = (thumbnails && thumbnails.length > 0 && thumbnails[0].url) || null;\n const { stringSet, dateLocale } = useLocalization();\n const { disableUserProfile, renderUserProfile } = useContext(UserProfileContext);\n const [messageWidth, setMessageWidth] = useState(360);\n const messageRef = useRef(null);\n const contextMenuRef = useRef(null);\n const avatarRef = useRef(null);\n\n const memorizedThumbnailPlaceHolder = useMemo(() => (type) => ({ style }) => ( // eslint-disable-line\n <div style={style}>\n <Icon\n type={type}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n </div>\n ), []);\n\n const isByMe = checkIsByMe(message, userId);\n const isMessageSent = checkIsSent(status);\n const isPending = checkIsPending(status);\n const isFailed = checkIsFailed(status);\n const sender = getSenderFromMessage(message);\n\n useEffect(() => {\n const thumbnailWidth = messageRef?.current?.clientWidth - 80;\n setMessageWidth(thumbnailWidth > 360 ? 360 : thumbnailWidth);\n }, []);\n\n return (\n <div\n className={[\n ...(Array.isArray(className) ? className : [className]),\n 'sendbird-openchannel-thumbnail-message',\n ].join(' ')}\n ref={messageRef}\n >\n <div className=\"sendbird-openchannel-thumbnail-message__left\">\n {\n !chainTop && (\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n <Avatar\n className=\"sendbird-openchannel-thumbnail-message__left__avatar\"\n src={sender.profileUrl || ''}\n ref={avatarRef}\n width=\"28px\"\n height=\"28px\"\n onClick={() => {\n if (!disableUserProfile) {\n toggleDropdown();\n }\n }}\n />\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={avatarRef}\n parentContainRef={avatarRef}\n closeDropdown={closeDropdown}\n style={{ paddingTop: 0, paddingBottom: 0 }}\n >\n {\n renderUserProfile\n ? (\n renderUserProfile({\n user: sender,\n close: closeDropdown,\n })\n )\n : (\n <UserProfile\n user={sender}\n onSuccess={closeDropdown}\n disableMessaging\n />\n )\n }\n </MenuItems>\n )}\n />\n )\n }\n </div>\n <div className=\"sendbird-openchannel-thumbnail-message__right\">\n {\n !chainTop && (\n <div className=\"sendbird-openchannel-thumbnail-message__right__title\">\n <Label\n className=\"sendbird-openchannel-thumbnail-message__right__title__sender-name\"\n type={LabelTypography.CAPTION_2}\n color={isByMe ? LabelColors.SECONDARY_3 : LabelColors.ONBACKGROUND_2}\n >\n {\n sender && (\n sender.friendName\n || sender.nickname\n || sender.userId\n )\n }\n </Label>\n <Label\n className=\"sendbird-openchannel-thumbnail-message__right__title__sent-at\"\n type={LabelTypography.CAPTION_3}\n color={LabelColors.ONBACKGROUND_3}\n >\n {\n message?.createdAt && (\n format(message.createdAt, 'p', {\n locale: dateLocale,\n })\n )\n }\n </Label>\n </div>\n )\n }\n <div className=\"sendbird-openchannel-thumbnail-message__right__body\">\n <div\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap\"\n role=\"button\"\n onClick={() => {\n if (isMessageSent) {\n onClick(true);\n }\n }}\n onKeyDown={() => {\n if (isMessageSent) {\n onClick(true);\n }\n }}\n tabIndex={0}\n >\n <div className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__overlay\" />\n {\n {\n [SUPPORTING_TYPES.VIDEO]: (\n (url || localUrl)\n ? (\n <div className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video\" >\n {\n (thumbnailUrl)\n ? (\n <ImageRenderer\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video\"\n url={thumbnailUrl}\n width={messageWidth}\n height=\"270px\"\n alt=\"image\"\n placeHolder={memorizedThumbnailPlaceHolder(IconTypes.PLAY)}\n />\n )\n : (\n <video className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video__video\">\n <source src={url || localUrl} type={type} />\n </video>\n )\n }\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video__icon\"\n type={IconTypes.PLAY}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n </div>\n )\n : (\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video--icon\"\n type={IconTypes.PHOTO}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n )\n ),\n [SUPPORTING_TYPES.IMAGE]: (\n (url || localUrl)\n ? (\n <ImageRenderer\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__image\"\n url={thumbnailUrl || url || localUrl}\n alt=\"image\"\n width={messageWidth}\n height=\"270px\"\n placeHolder={memorizedThumbnailPlaceHolder(IconTypes.PHOTO)}\n />\n )\n : (\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__image--icon\"\n type={IconTypes.PHOTO}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n )\n ),\n [SUPPORTING_TYPES.UNSUPPORTED]: (\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__unknown\"\n type={IconTypes.PHOTO}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n ),\n }[getSupportingFileType(type)]\n }\n </div>\n </div>\n {\n (isPending || isFailed) && (\n <div className=\"sendbird-openchannel-thumbnail-message__right__tail\">\n {\n isPending && (\n <Loader\n width=\"16px\"\n height=\"16px\"\n >\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__tail__pending\"\n type={IconTypes.SPINNER}\n fillColor={IconColors.PRIMARY}\n width=\"16px\"\n height=\"16px\"\n />\n </Loader>\n )\n }\n {\n isFailed && (\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__tail__failed\"\n type={IconTypes.ERROR}\n fillColor={IconColors.ERROR}\n width=\"16px\"\n height=\"16px\"\n />\n )\n }\n </div>\n )\n }\n </div>\n <div\n className=\"sendbird-openchannel-thumbnail-message__context-menu\"\n ref={contextMenuRef}\n >\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n showMenuTrigger({ message, userId, status }) && (\n <IconButton\n className=\"sendbird-openchannel-thumbnail-message__context-menu--icon\"\n width=\"32px\"\n height=\"32px\"\n onClick={toggleDropdown}\n >\n <Icon\n type={IconTypes.MORE}\n fillColor={IconColors.CONTENT_INVERSE}\n width=\"24px\"\n height=\"24px\"\n />\n </IconButton>\n )\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={contextMenuRef}\n parentContainRef={contextMenuRef}\n closeDropdown={closeDropdown}\n openLeft\n >\n {\n isFineResend({ message, userId, status }) && (\n <MenuItem\n onClick={() => {\n resendMessage(message);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__RESEND}\n </MenuItem>\n )\n }\n {\n isFineDelete({ message, userId, status }) && (\n <MenuItem\n onClick={() => {\n if (disabled) {\n return;\n }\n showRemove(true);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__DELETE}\n </MenuItem>\n )\n }\n </MenuItems>\n )}\n />\n </div>\n </div>\n );\n}\n"],"names":["SUPPORTING_TYPES","IMAGE","VIDEO","UNSUPPORTED","SUPPORTED_MIMES","getSupportingFileType","type","indexOf","OpenchannelThumbnailMessage","_a","className","message","disabled","userId","chainTop","onClick","showRemove","resendMessage","url","thumbnails","localUrl","status","sendingStatus","thumbnailUrl","length","_c","useLocalization","stringSet","dateLocale","_d","useContext","UserProfileContext","disableUserProfile","renderUserProfile","_e","useState","messageWidth","setMessageWidth","messageRef","useRef","contextMenuRef","avatarRef","memorizedThumbnailPlaceHolder","useMemo","style","React","Icon","IconColors","ON_BACKGROUND_2","isByMe","checkIsByMe","isMessageSent","checkIsSent","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","useEffect","thumbnailWidth","current","clientWidth","__spreadArray","Array","isArray","join","ContextMenu","toggleDropdown","Avatar","profileUrl","closeDropdown","MenuItems","paddingTop","paddingBottom","user","close","UserProfile","Label","LabelTypography","CAPTION_2","LabelColors","SECONDARY_3","ONBACKGROUND_2","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","_b","ImageRenderer","IconTypes","PLAY","PHOTO","Loader","SPINNER","PRIMARY","ERROR","showMenuTrigger","IconButton","MORE","CONTENT_INVERSE","isFineResend","MenuItem","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAO,IAAMA,gBAAgB,GAAG;AAC9BC,EAAAA,KAAK,EAAE,OADuB;AAE9BC,EAAAA,KAAK,EAAE,OAFuB;AAG9BC,EAAAA,WAAW,EAAE;AAHiB,CAAzB;AAMP,IAAMC,eAAe,GAAG;AACtBH,EAAAA,KAAK,EAAE,CACL,YADK,EAEL,WAFK,EAGL,WAHK,EAIL,WAJK,EAKL,YALK,CADe;AAQtBC,EAAAA,KAAK,EAAE,CACL,YADK,EAEL,WAFK,EAGL,YAHK,EAIL,WAJK;AARe,CAAxB;AAgBO,IAAMG,qBAAqB,GAAG,SAAxBA,qBAAwB,CAACC,IAAD;AACnC,MAAIF,eAAe,CAACH,KAAhB,CAAsBM,OAAtB,CAA8BD,IAA9B,KAAuC,CAA3C,EAA8C;AAC5C,WAAON,gBAAgB,CAACC,KAAxB;AACD;;AACD,MAAIG,eAAe,CAACF,KAAhB,CAAsBK,OAAtB,CAA8BD,IAA9B,KAAuC,CAA3C,EAA8C;AAC5C,WAAON,gBAAgB,CAACE,KAAxB;AACD;;AACD,SAAOF,gBAAgB,CAACG,WAAxB;AACD,CARM;;SC0BiBK,4BAA4BC;;;MAClDC,SAAS;MACTC,OAAO;MACPC,QAAQ;MACRC,MAAM;MACNC,QAAQ;MACRC,QAAO;MACPC,UAAU;MACVC,aAAa;AAGX,MAAAX,IAAI,GAIsBK,OAAO,KAJjC;AAAA,MACAO,GAAG,GAGuBP,OAAO,IAJjC;AAAA,MAEAQ,UAAU,GAEgBR,OAAO,WAJjC;AAAA,MAGAS,QAAQ,GACkBT,OAAO,SAJjC;AAKF,MAAMU,MAAM,GAAGV,OAAO,SAAP,IAAAA,OAAO,WAAP,SAAA,GAAAA,OAAO,CAAEW,aAAxB;AACA,MAAMC,YAAY,GAAIJ,UAAU,IAAIA,UAAU,CAACK,MAAX,GAAoB,CAAlC,IAAuCL,UAAU,CAAC,CAAD,CAAV,CAAcD,GAAtD,IAA8D,IAAnF;;AACM,MAAAO,KAA4BC,mCAAe,EAA3C;AAAA,MAAEC,SAAS,eAAX;AAAA,MAAaC,UAAU,gBAAvB;;AACA,MAAAC,KAA4CC,gBAAU,CAACC,qCAAD,CAAtD;AAAA,MAAEC,kBAAkB,wBAApB;AAAA,MAAsBC,iBAAiB,uBAAvC;;AACA,MAAAC,KAAkCC,cAAQ,CAAC,GAAD,CAA1C;AAAA,MAACC,YAAY,QAAb;AAAA,MAAeC,eAAe,QAA9B;;AACN,MAAMC,UAAU,GAAGC,YAAM,CAAC,IAAD,CAAzB;AACA,MAAMC,cAAc,GAAGD,YAAM,CAAC,IAAD,CAA7B;AACA,MAAME,SAAS,GAAGF,YAAM,CAAC,IAAD,CAAxB;AAEA,MAAMG,6BAA6B,GAAGC,aAAO,CAAC;AAAM,WAAA,UAACrC,IAAD;AAAU,aAAA,UAACG,EAAD;YAAGmC,KAAK;AAAO;AAAA;AAAE;AAC7E;AAAK,YAAA,KAAK,EAAEA;AAAZ,0BACEC,wCAACC,kBAAD;AACE,YAAA,IAAI,EAAExC,IADR;AAEE,YAAA,SAAS,EAAEyC,kBAAU,CAACC,eAFxB;AAGE,YAAA,KAAK,EAAC,MAHR;AAIE,YAAA,MAAM,EAAC;AAJT,YADF;AAD2E;AAS5E,OAT6D;AAS7D,KATmD;AASnD,GAT4C,EAS1C,EAT0C,CAA7C;AAWA,MAAMC,MAAM,GAAGC,4BAAW,CAACvC,OAAD,EAAUE,MAAV,CAA1B;AACA,MAAMsC,aAAa,GAAGC,4BAAW,CAAC/B,MAAD,CAAjC;AACA,MAAMgC,SAAS,GAAGC,+BAAc,CAACjC,MAAD,CAAhC;AACA,MAAMkC,QAAQ,GAAGC,8BAAa,CAACnC,MAAD,CAA9B;AACA,MAAMoC,MAAM,GAAGC,qCAAoB,CAAC/C,OAAD,CAAnC;AAEAgD,EAAAA,eAAS,CAAC;;;AACR,QAAMC,cAAc,GAAG,CAAA,MAAAtB,UAAU,SAAV,IAAAA,UAAU,WAAV,SAAA,GAAAA,UAAU,CAAEuB,OAAZ,UAAA,iBAAA,SAAA,MAAqBC,WAArB,IAAmC,EAA1D;AACAzB,IAAAA,eAAe,CAACuB,cAAc,GAAG,GAAjB,GAAuB,GAAvB,GAA6BA,cAA9B,CAAf;AACD,GAHQ,EAGN,EAHM,CAAT;AAKA,sBACEf;AACE,IAAA,SAAS,EAAEkB,oDACLC,KAAK,CAACC,OAAN,CAAcvD,SAAd,IAA2BA,SAA3B,GAAuC,CAACA,SAAD,WAC3C,iDAFS,CAGTwD,IAHS,CAGJ,GAHI,CADb;AAKE,IAAA,GAAG,EAAE5B;AALP,kBAOEO;AAAK,IAAA,SAAS,EAAC;AAAf,KAEI,CAAC/B,QAAD,iBACE+B,wCAACsB,yBAAD;AACE,IAAA,WAAW,EAAE,qBAACC,cAAD;AAAoB,0BAC/BvB,wCAACwB,oBAAD;AACE,QAAA,SAAS,EAAC,sDADZ;AAEE,QAAA,GAAG,EAAEZ,MAAM,CAACa,UAAP,IAAqB,EAF5B;AAGE,QAAA,GAAG,EAAE7B,SAHP;AAIE,QAAA,KAAK,EAAC,MAJR;AAKE,QAAA,MAAM,EAAC,MALT;AAME,QAAA,OAAO,EAAE;AACP,cAAI,CAACT,kBAAL,EAAyB;AACvBoC,YAAAA,cAAc;AACf;AACF;AAVH,QAD+B;AAahC,KAdH;AAeE,IAAA,SAAS,EAAE,mBAACG,aAAD;AAAmB,0BAC5B1B,wCAAC2B,wBAAD;AACE,QAAA,SAAS,EAAE/B,SADb;AAEE,QAAA,gBAAgB,EAAEA,SAFpB;AAGE,QAAA,aAAa,EAAE8B,aAHjB;AAIE,QAAA,KAAK,EAAE;AAAEE,UAAAA,UAAU,EAAE,CAAd;AAAiBC,UAAAA,aAAa,EAAE;AAAhC;AAJT,SAOIzC,iBAAiB,GAEbA,iBAAiB,CAAC;AAChB0C,QAAAA,IAAI,EAAElB,MADU;AAEhBmB,QAAAA,KAAK,EAAEL;AAFS,OAAD,CAFJ,gBAQb1B,wCAACgC,cAAD;AACE,QAAA,IAAI,EAAEpB,MADR;AAEE,QAAA,SAAS,EAAEc,aAFb;AAGE,QAAA,gBAAgB;AAHlB,QAfR,CAD4B;AAwB7B;AAvCH,IAHN,CAPF,eAsDE1B;AAAK,IAAA,SAAS,EAAC;AAAf,KAEI,CAAC/B,QAAD,iBACE+B;AAAK,IAAA,SAAS,EAAC;AAAf,kBACEA,wCAACiC,cAAD;AACE,IAAA,SAAS,EAAC,mEADZ;AAEE,IAAA,IAAI,EAAEC,wBAAe,CAACC,SAFxB;AAGE,IAAA,KAAK,EAAE/B,MAAM,GAAGgC,oBAAW,CAACC,WAAf,GAA6BD,oBAAW,CAACE;AAHxD,KAMI1B,MAAM,KACJA,MAAM,CAAC2B,UAAP,IACG3B,MAAM,CAAC4B,QADV,IAEG5B,MAAM,CAAC5C,MAHN,CANV,CADF,eAcEgC,wCAACiC,cAAD;AACE,IAAA,SAAS,EAAC,+DADZ;AAEE,IAAA,IAAI,EAAEC,wBAAe,CAACO,SAFxB;AAGE,IAAA,KAAK,EAAEL,oBAAW,CAACM;AAHrB,KAMI,CAAA5E,OAAO,SAAP,IAAAA,OAAO,WAAP,SAAA,GAAAA,OAAO,CAAE6E,SAAT,KACEC,YAAM,CAAC9E,OAAO,CAAC6E,SAAT,EAAoB,GAApB,EAAyB;AAC7BE,IAAAA,MAAM,EAAE9D;AADqB,GAAzB,CAPZ,CAdF,CAHN,eAiCEiB;AAAK,IAAA,SAAS,EAAC;AAAf,kBACEA;AACE,IAAA,SAAS,EAAC,2DADZ;AAEE,IAAA,IAAI,EAAC,QAFP;AAGE,IAAA,OAAO,EAAE;AACP,UAAIM,aAAJ,EAAmB;AACjBpC,QAAAA,QAAO,CAAC,IAAD,CAAP;AACD;AACF,KAPH;AAQE,IAAA,SAAS,EAAE;AACT,UAAIoC,aAAJ,EAAmB;AACjBpC,QAAAA,QAAO,CAAC,IAAD,CAAP;AACD;AACF,KAZH;AAaE,IAAA,QAAQ,EAAE;AAbZ,kBAeE8B;AAAK,IAAA,SAAS,EAAC;AAAf,IAfF,EAiBI,UACE8C,GAAC3F,gBAAgB,CAACE,MAAlB,GACGgB,GAAG,IAAIE,QAAR,gBAEIyB;AAAK,IAAA,SAAS,EAAC;AAAf,KAEKtB,YAAD,gBAEIsB,wCAAC+C,gBAAD;AACE,IAAA,SAAS,EAAC,kEADZ;AAEE,IAAA,GAAG,EAAErE,YAFP;AAGE,IAAA,KAAK,EAAEa,YAHT;AAIE,IAAA,MAAM,EAAC,OAJT;AAKE,IAAA,GAAG,EAAC,OALN;AAME,IAAA,WAAW,EAAEM,6BAA6B,CAACmD,iBAAS,CAACC,IAAX;AAN5C,IAFJ,gBAYIjD;AAAO,IAAA,SAAS,EAAC;AAAjB,kBACEA;AAAQ,IAAA,GAAG,EAAE3B,GAAG,IAAIE,QAApB;AAA8B,IAAA,IAAI,EAAEd;AAApC,IADF,CAdR,eAmBEuC,wCAACC,kBAAD;AACE,IAAA,SAAS,EAAC,wEADZ;AAEE,IAAA,IAAI,EAAE+C,iBAAS,CAACC,IAFlB;AAGE,IAAA,SAAS,EAAE/C,kBAAU,CAACC,eAHxB;AAIE,IAAA,KAAK,EAAC,MAJR;AAKE,IAAA,MAAM,EAAC;AALT,IAnBF,CAFJ,gBA+BIH,wCAACC,kBAAD;AACE,IAAA,SAAS,EAAC,wEADZ;AAEE,IAAA,IAAI,EAAE+C,iBAAS,CAACE,KAFlB;AAGE,IAAA,SAAS,EAAEhD,kBAAU,CAACC,eAHxB;AAIE,IAAA,KAAK,EAAC,MAJR;AAKE,IAAA,MAAM,EAAC;AALT,MASN2C,GAAC3F,gBAAgB,CAACC,MAAlB,GACGiB,GAAG,IAAIE,QAAR,gBAEIyB,wCAAC+C,gBAAD;AACE,IAAA,SAAS,EAAC,kEADZ;AAEE,IAAA,GAAG,EAAErE,YAAY,IAAIL,GAAhB,IAAuBE,QAF9B;AAGE,IAAA,GAAG,EAAC,OAHN;AAIE,IAAA,KAAK,EAAEgB,YAJT;AAKE,IAAA,MAAM,EAAC,OALT;AAME,IAAA,WAAW,EAAEM,6BAA6B,CAACmD,iBAAS,CAACE,KAAX;AAN5C,IAFJ,gBAYIlD,wCAACC,kBAAD;AACE,IAAA,SAAS,EAAC,wEADZ;AAEE,IAAA,IAAI,EAAE+C,iBAAS,CAACE,KAFlB;AAGE,IAAA,SAAS,EAAEhD,kBAAU,CAACC,eAHxB;AAIE,IAAA,KAAK,EAAC,MAJR;AAKE,IAAA,MAAM,EAAC;AALT,MASN2C,GAAC3F,gBAAgB,CAACG,YAAlB,gBACE0C,wCAACC,kBAAD;AACE,IAAA,SAAS,EAAC,oEADZ;AAEE,IAAA,IAAI,EAAE+C,iBAAS,CAACE,KAFlB;AAGE,IAAA,SAAS,EAAEhD,kBAAU,CAACC,eAHxB;AAIE,IAAA,KAAK,EAAC,MAJR;AAKE,IAAA,MAAM,EAAC;AALT,QAjEJ,EAyEE3C,qBAAqB,CAACC,IAAD,CAzEvB,CAjBJ,CADF,CAjCF,EAiII,CAAC+C,SAAS,IAAIE,QAAd,kBACEV;AAAK,IAAA,SAAS,EAAC;AAAf,KAEIQ,SAAS,iBACPR,wCAACmD,SAAD;AACE,IAAA,KAAK,EAAC,MADR;AAEE,IAAA,MAAM,EAAC;AAFT,kBAIEnD,wCAACC,kBAAD;AACE,IAAA,SAAS,EAAC,8DADZ;AAEE,IAAA,IAAI,EAAE+C,iBAAS,CAACI,OAFlB;AAGE,IAAA,SAAS,EAAElD,kBAAU,CAACmD,OAHxB;AAIE,IAAA,KAAK,EAAC,MAJR;AAKE,IAAA,MAAM,EAAC;AALT,IAJF,CAHN,EAkBI3C,QAAQ,iBACNV,wCAACC,kBAAD;AACE,IAAA,SAAS,EAAC,6DADZ;AAEE,IAAA,IAAI,EAAE+C,iBAAS,CAACM,KAFlB;AAGE,IAAA,SAAS,EAAEpD,kBAAU,CAACoD,KAHxB;AAIE,IAAA,KAAK,EAAC,MAJR;AAKE,IAAA,MAAM,EAAC;AALT,IAnBN,CAlIN,CAtDF,eAwNEtD;AACE,IAAA,SAAS,EAAC,sDADZ;AAEE,IAAA,GAAG,EAAEL;AAFP,kBAIEK,wCAACsB,yBAAD;AACE,IAAA,WAAW,EAAE,qBAACC,cAAD;AAAoB,aAC/BgC,gCAAe,CAAC;AAAEzF,QAAAA,OAAO,SAAT;AAAWE,QAAAA,MAAM,QAAjB;AAAmBQ,QAAAA,MAAM;AAAzB,OAAD,CAAf,iBACEwB,wCAACwD,aAAD;AACE,QAAA,SAAS,EAAC,4DADZ;AAEE,QAAA,KAAK,EAAC,MAFR;AAGE,QAAA,MAAM,EAAC,MAHT;AAIE,QAAA,OAAO,EAAEjC;AAJX,sBAMEvB,wCAACC,kBAAD;AACE,QAAA,IAAI,EAAE+C,iBAAS,CAACS,IADlB;AAEE,QAAA,SAAS,EAAEvD,kBAAU,CAACwD,eAFxB;AAGE,QAAA,KAAK,EAAC,MAHR;AAIE,QAAA,MAAM,EAAC;AAJT,QANF,CAF6B;AAgBhC,KAjBH;AAkBE,IAAA,SAAS,EAAE,mBAAChC,aAAD;AAAmB,0BAC5B1B,wCAAC2B,wBAAD;AACE,QAAA,SAAS,EAAEhC,cADb;AAEE,QAAA,gBAAgB,EAAEA,cAFpB;AAGE,QAAA,aAAa,EAAE+B,aAHjB;AAIE,QAAA,QAAQ;AAJV,SAOIiC,6BAAY,CAAC;AAAE7F,QAAAA,OAAO,SAAT;AAAWE,QAAAA,MAAM,QAAjB;AAAmBQ,QAAAA,MAAM;AAAzB,OAAD,CAAZ,iBACEwB,wCAAC4D,uBAAD;AACE,QAAA,OAAO,EAAE;AACPxF,UAAAA,aAAa,CAACN,OAAD,CAAb;AACA4D,UAAAA,aAAa;AACd;AAJH,SAMG5C,SAAS,CAAC+E,6BANb,CARN,EAmBIC,6BAAY,CAAC;AAAEhG,QAAAA,OAAO,SAAT;AAAWE,QAAAA,MAAM,QAAjB;AAAmBQ,QAAAA,MAAM;AAAzB,OAAD,CAAZ,iBACEwB,wCAAC4D,uBAAD;AACE,QAAA,OAAO,EAAE;AACP,cAAI7F,QAAJ,EAAc;AACZ;AACD;;AACDI,UAAAA,UAAU,CAAC,IAAD,CAAV;AACAuD,UAAAA,aAAa;AACd;AAPH,SASG5C,SAAS,CAACiF,6BATb,CApBN,CAD4B;AAmC7B;AArDH,IAJF,CAxNF,CADF;AAuRD;;;;"}
@@ -1,32 +1,33 @@
1
1
  'use strict';
2
2
 
3
- var tslib_es6 = require('../tslib.es6-571bbfc9.js');
3
+ var tslib_es6 = require('../tslib.es6-4b07fef2.js');
4
4
  var React = require('react');
5
- var index = require('../index-dcd38046.js');
5
+ var index = require('../index-f21d728f.js');
6
6
  var ui_Avatar = require('./Avatar.js');
7
7
  var ui_ContextMenu = require('./ContextMenu.js');
8
8
  var ui_Icon = require('./Icon.js');
9
9
  var ui_IconButton = require('./IconButton.js');
10
- var ui_Label = require('../index-30e8e785.js');
10
+ var ui_Label = require('../index-101e25b6.js');
11
11
  var ui_Loader = require('./Loader.js');
12
12
  var ui_UserProfile = require('./UserProfile.js');
13
- var UserProfileContext = require('../UserProfileContext-0081d7b2.js');
14
- var LocalizationContext = require('../LocalizationContext-4c0a4a70.js');
15
- var utils = require('../utils-63225dc9.js');
16
- var uuid = require('../uuid-086f0c34.js');
17
- var openChannelUtils = require('../openChannelUtils-46a3a403.js');
18
- require('../index-4e4d7494.js');
13
+ var UserProfileContext = require('../UserProfileContext-1a32d7da.js');
14
+ var LocalizationContext = require('../LocalizationContext-af3a239a.js');
15
+ var utils = require('../utils-88672f3d.js');
16
+ var uuid = require('../uuid-c63c6c5a.js');
17
+ var openChannelUtils = require('../openChannelUtils-d4258320.js');
18
+ require('../index-c3d974a8.js');
19
19
  require('./ImageRenderer.js');
20
- require('../_rollupPluginBabelHelpers-08d1d0ec.js');
20
+ require('../_rollupPluginBabelHelpers-1be0417a.js');
21
21
  require('prop-types');
22
- require('../index-a40d57a5.js');
22
+ require('../index-f3cc1992.js');
23
23
  require('react-dom');
24
24
  require('./SortByRow.js');
25
- require('../stringSet-d9121aa6.js');
26
- require('../withSendBird.js');
27
- require('../sendBirdSelectors.js');
28
- require('../topics-4fc933cb.js');
29
- require('../index-630f8d1b.js');
25
+ require('../stringSet-ed353b6e.js');
26
+ require('../withSendbird.js');
27
+ require('../sendbirdSelectors.js');
28
+ require('../topics-1e190fcd.js');
29
+ require('../utils-6ff87257.js');
30
+ require('../index-ebb83a37.js');
30
31
 
31
32
  function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
32
33
 
@@ -82,7 +83,7 @@ function OpenchannelUserMessage(_a) {
82
83
  type: ui_Label.LabelTypography.BODY_1,
83
84
  color: ui_Label.LabelColors.ONBACKGROUND_2,
84
85
  calssName: "sendbird-openchannel-user-message-word"
85
- }, " " + stringSet.MESSAGE_EDITED + " "));
86
+ }, " ".concat(stringSet.MESSAGE_EDITED, " ")));
86
87
  }
87
88
 
88
89
  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","Label","uuidv4","LabelTypography","BODY_1","LabelColors","ONBACKGROUND_2","MESSAGE_EDITED","useEffect","current","clientHeight","top","window","innerWidth","__spreadArray","Array","isArray","join","ContextMenu","toggleDropdown","Avatar","profileUrl","closeDropdown","MenuItems","paddingTop","paddingBottom","user","close","UserProfile","CAPTION_2","SECONDARY_3","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","ONBACKGROUND_1","Loader","Icon","IconTypes","SPINNER","IconColors","PRIMARY","ERROR","showMenuTrigger","IconButton","MORE","CONTENT_INVERSE","isFineCopy","MenuItem","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","Label","uuidv4","LabelTypography","BODY_1","LabelColors","ONBACKGROUND_2","MESSAGE_EDITED","useEffect","current","clientHeight","top","window","innerWidth","__spreadArray","Array","isArray","join","ContextMenu","toggleDropdown","Avatar","profileUrl","closeDropdown","MenuItems","paddingTop","paddingBottom","user","close","UserProfile","CAPTION_2","SECONDARY_3","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","ONBACKGROUND_1","Loader","Icon","IconTypes","SPINNER","IconColors","PRIMARY","ERROR","showMenuTrigger","IconButton","MORE","CONTENT_INVERSE","isFineCopy","MenuItem","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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"}
@@ -2,16 +2,16 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- require('../_rollupPluginBabelHelpers-08d1d0ec.js');
5
+ require('../_rollupPluginBabelHelpers-1be0417a.js');
6
6
  require('react');
7
7
  require('prop-types');
8
8
  require('./Icon.js');
9
9
  require('./Loader.js');
10
- require('../LocalizationContext-4c0a4a70.js');
11
- require('../index-30e8e785.js');
12
- var ui_PlaceHolder = require('../index-6d82098c.js');
13
- require('../stringSet-d9121aa6.js');
14
- require('../index-4e4d7494.js');
10
+ require('../LocalizationContext-af3a239a.js');
11
+ require('../index-101e25b6.js');
12
+ var ui_PlaceHolder = require('../index-c4440bd2.js');
13
+ require('../stringSet-ed353b6e.js');
14
+ require('../index-c3d974a8.js');
15
15
 
16
16
 
17
17
 
@@ -2,15 +2,15 @@
2
2
 
3
3
  var React = require('react');
4
4
  var ui_Icon = require('./Icon.js');
5
- var ui_Label = require('../index-30e8e785.js');
5
+ var ui_Label = require('../index-101e25b6.js');
6
6
  var ui_ImageRenderer = require('./ImageRenderer.js');
7
- var LocalizationContext = require('../LocalizationContext-4c0a4a70.js');
8
- var index = require('../index-a40d57a5.js');
9
- require('../_rollupPluginBabelHelpers-08d1d0ec.js');
7
+ var LocalizationContext = require('../LocalizationContext-af3a239a.js');
8
+ var index = require('../index-f3cc1992.js');
9
+ require('../_rollupPluginBabelHelpers-1be0417a.js');
10
10
  require('prop-types');
11
- require('../stringSet-d9121aa6.js');
12
- require('../index-4e4d7494.js');
13
- require('../tslib.es6-571bbfc9.js');
11
+ require('../stringSet-ed353b6e.js');
12
+ require('../index-c3d974a8.js');
13
+ require('../tslib.es6-4b07fef2.js');
14
14
 
15
15
  function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
16
16
 
@@ -19,29 +19,29 @@ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
19
19
  function QuoteMessage(_a) {
20
20
  var _b;
21
21
 
22
- var _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
22
+ var _c, _d, _e, _f;
23
23
 
24
24
  var message = _a.message,
25
- _p = _a.userId,
26
- userId = _p === void 0 ? '' : _p,
27
- _q = _a.isByMe,
28
- isByMe = _q === void 0 ? false : _q,
25
+ _g = _a.userId,
26
+ userId = _g === void 0 ? '' : _g,
27
+ _h = _a.isByMe,
28
+ isByMe = _h === void 0 ? false : _h,
29
29
  className = _a.className,
30
30
  _onClick = _a.onClick;
31
31
  var stringSet = React.useContext(LocalizationContext.LocalizationContext).stringSet;
32
32
  var parentMessage = message.parentMessage;
33
- var parentMessageSender = (_c = parentMessage) === null || _c === void 0 ? void 0 : _c.sender;
33
+ var parentMessageSender = parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.sender;
34
34
  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;
35
- var parentMessageUrl = ((_d = parentMessage) === null || _d === void 0 ? void 0 : _d.url) || '';
36
- var parentMessageType = (_e = parentMessage) === null || _e === void 0 ? void 0 : _e.type;
37
- 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;
35
+ var parentMessageUrl = (parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.url) || '';
36
+ var parentMessageType = parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.type;
37
+ 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;
38
38
 
39
- var _r = React.useState(false),
40
- isThumbnailLoaded = _r[0],
41
- setThumbnailLoaded = _r[1];
39
+ var _j = React.useState(false),
40
+ isThumbnailLoaded = _j[0],
41
+ setThumbnailLoaded = _j[1];
42
42
 
43
43
  var uikitFileTypes = index.getUIKitFileTypes();
44
- var splitFileName = ((_h = parentMessage) === null || _h === void 0 ? void 0 : _h.name) ? parentMessage.name.split('/') : parentMessageUrl.split('/');
44
+ var splitFileName = (parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.name) ? parentMessage.name.split('/') : parentMessageUrl.split('/');
45
45
  return /*#__PURE__*/React__default["default"].createElement("div", {
46
46
  className: index.getClassName([className, 'sendbird-quote-message', isByMe ? 'outgoing' : 'incoming']),
47
47
  key: parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.messageId,
@@ -60,15 +60,15 @@ function QuoteMessage(_a) {
60
60
  className: "sendbird-quote-message__replied-to__text",
61
61
  type: ui_Label.LabelTypography.CAPTION_2,
62
62
  color: ui_Label.LabelColors.ONBACKGROUND_3
63
- }, currentMessageSenderNickname + " " + stringSet.QUOTED_MESSAGE__REPLIED_TO + " " + parentMessageSenderNickname)), /*#__PURE__*/React__default["default"].createElement("div", {
63
+ }, "".concat(currentMessageSenderNickname, " ").concat(stringSet.QUOTED_MESSAGE__REPLIED_TO, " ").concat(parentMessageSenderNickname))), /*#__PURE__*/React__default["default"].createElement("div", {
64
64
  className: "sendbird-quote-message__replied-message"
65
- }, index.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["default"].createElement("div", {
65
+ }, index.isUserMessage(parentMessage) && ((_e = parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.message) === null || _e === void 0 ? void 0 : _e.length) > 0 && /*#__PURE__*/React__default["default"].createElement("div", {
66
66
  className: "sendbird-quote-message__replied-message__text-message"
67
67
  }, /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
68
68
  className: "sendbird-quote-message__replied-message__text-message__word",
69
69
  type: ui_Label.LabelTypography.BODY_2,
70
70
  color: ui_Label.LabelColors.ONBACKGROUND_1
71
- }, (_l = parentMessage) === null || _l === void 0 ? void 0 : _l.message)), index.isThumbnailMessage(parentMessage) && parentMessageUrl && /*#__PURE__*/React__default["default"].createElement("div", {
71
+ }, parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.message)), index.isThumbnailMessage(parentMessage) && parentMessageUrl && /*#__PURE__*/React__default["default"].createElement("div", {
72
72
  className: "sendbird-quote-message__replied-message__thumbnail-message"
73
73
  }, /*#__PURE__*/React__default["default"].createElement(ui_ImageRenderer, {
74
74
  className: "sendbird-quote-message__replied-message__thumbnail-message__image",
@@ -89,7 +89,7 @@ function QuoteMessage(_a) {
89
89
  width: "22px",
90
90
  height: "22px"
91
91
  })))
92
- }), index.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["default"].createElement(React__default["default"].Fragment, null, /*#__PURE__*/React__default["default"].createElement("video", {
92
+ }), index.isVideo(parentMessageType) && !(((_f = parentMessage === null || parentMessage === void 0 ? void 0 : parentMessage.thumbnails) === null || _f === void 0 ? void 0 : _f.length) > 0) && /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, /*#__PURE__*/React__default["default"].createElement("video", {
93
93
  className: "sendbird-quote-message__replied-message__thumbnail-message__video"
94
94
  }, /*#__PURE__*/React__default["default"].createElement("source", {
95
95
  src: parentMessageUrl,
@@ -1 +1 @@
1
- {"version":3,"file":"QuoteMessage.js","sources":["../../../src/ui/QuoteMessage/index.tsx"],"sourcesContent":["import React, { ReactElement, useContext, useState } from 'react';\nimport { FileMessage, UserMessage } from 'sendbird';\nimport './index.scss';\n\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport Label, { LabelTypography, LabelColors } from '../Label';\nimport ImageRenderer from '../ImageRenderer';\nimport { LocalizationContext } from '../../lib/LocalizationContext';\nimport {\n getClassName,\n getUIKitFileType,\n getUIKitFileTypes,\n isFileMessage,\n isGif,\n isSupportedFileView,\n isThumbnailMessage,\n isUserMessage,\n isVideo,\n truncateString,\n} from '../../utils';\ninterface Props {\n message?: UserMessage | FileMessage;\n userId?: string;\n isByMe?: boolean;\n className?: string | Array<string>;\n onClick?: () => void;\n}\n\nexport default function QuoteMessage({\n message,\n userId = '',\n isByMe = false,\n className,\n onClick,\n}: Props): ReactElement {\n const { stringSet } = useContext(LocalizationContext);\n\n const { parentMessage } = message;\n const parentMessageSender = (parentMessage as UserMessage | FileMessage)?.sender;\n const parentMessageSenderNickname = (userId === parentMessageSender?.userId) ? stringSet.QUOTED_MESSAGE__CURRENT_USER : parentMessageSender?.nickname;\n const parentMessageUrl = (parentMessage as FileMessage)?.url || '';\n const parentMessageType = (parentMessage as FileMessage)?.type;\n const currentMessageSenderNickname = (userId === message?.sender?.userId) ? stringSet.QUOTED_MESSAGE__CURRENT_USER : message?.sender?.nickname;\n\n const [isThumbnailLoaded, setThumbnailLoaded] = useState(false);\n const uikitFileTypes = getUIKitFileTypes();\n const splitFileName = (parentMessage as FileMessage)?.name ? (parentMessage as FileMessage).name.split('/') : parentMessageUrl.split('/');\n\n return (\n <div\n className={getClassName([className, 'sendbird-quote-message', isByMe ? 'outgoing' : 'incoming'])}\n key={parentMessage?.messageId}\n onClick={() => { if (onClick) onClick() }}\n >\n <div className=\"sendbird-quote-message__replied-to\">\n <Icon\n className=\"sendbird-quote-message__replied-to__icon\"\n type={IconTypes.REPLY}\n fillColor={IconColors.ON_BACKGROUND_3}\n width=\"12px\"\n height=\"12px\"\n />\n <Label\n className=\"sendbird-quote-message__replied-to__text\"\n type={LabelTypography.CAPTION_2}\n color={LabelColors.ONBACKGROUND_3}\n >\n {`${currentMessageSenderNickname} ${stringSet.QUOTED_MESSAGE__REPLIED_TO} ${parentMessageSenderNickname}`}\n </Label>\n </div>\n <div className=\"sendbird-quote-message__replied-message\">\n {/* text message */}\n {(isUserMessage(parentMessage as UserMessage) && (parentMessage as UserMessage)?.message?.length > 0) && (\n <div className=\"sendbird-quote-message__replied-message__text-message\">\n <Label\n className=\"sendbird-quote-message__replied-message__text-message__word\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_1}\n >\n {(parentMessage as UserMessage)?.message}\n </Label>\n </div>\n )}\n {/* thumbnail message */}\n {(isThumbnailMessage(parentMessage as FileMessage) && parentMessageUrl) && (\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message\">\n <ImageRenderer\n className=\"sendbird-quote-message__replied-message__thumbnail-message__image\"\n url={parentMessageUrl}\n alt={parentMessageType}\n width=\"144px\"\n height=\"108px\"\n onLoad={() => setThumbnailLoaded(true)}\n defaultComponent={(\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message__placeholder\">\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message__placeholder__icon\">\n <Icon\n type={isVideo(parentMessageType) ? IconTypes.PLAY : IconTypes.PHOTO}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"22px\"\n height=\"22px\"\n />\n </div>\n </div>\n )}\n />\n {(isVideo(parentMessageType) && !((parentMessage as FileMessage)?.thumbnails?.length > 0)) && (\n <>\n <video className=\"sendbird-quote-message__replied-message__thumbnail-message__video\">\n <source src={parentMessageUrl} type={parentMessageType} />\n </video>\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message__cover\">\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message__cover__icon\">\n <Icon\n type={IconTypes.PLAY}\n fillColor={IconColors.GRAY}\n width=\"14px\"\n height=\"14px\"\n />\n </div>\n </div>\n </>\n )}\n {(isThumbnailLoaded && isGif(parentMessageType)) && (\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message__cover\">\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message__cover__icon\">\n <Icon\n type={IconTypes.GIF}\n fillColor={IconColors.GRAY}\n width=\"14px\"\n height=\"14px\"\n />\n </div>\n </div>\n )}\n </div>\n )}\n {/* file message */}\n {(isFileMessage(parentMessage as FileMessage) && !isSupportedFileView((parentMessage as FileMessage).type) && parentMessageUrl) && (\n <div className=\"sendbird-quote-message__replied-message__file-message\">\n <Icon\n className=\"sendbird-quote-message__replied-message__file-message__type-icon\"\n type={{\n [uikitFileTypes.IMAGE]: IconTypes.PHOTO,\n [uikitFileTypes.VIDEO]: IconTypes.PLAY,\n [uikitFileTypes.AUDIO]: IconTypes.FILE_AUDIO,\n [uikitFileTypes.GIF]: IconTypes.GIF,\n [uikitFileTypes.OTHERS]: IconTypes.FILE_DOCUMENT,\n }[getUIKitFileType(parentMessageType)]}\n fillColor={IconColors.ON_BACKGROUND_3}\n width=\"16px\"\n height=\"16px\"\n />\n <Label\n className=\"sendbird-quote-message__replied-message__file-message__file-name\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_3}\n >\n {truncateString(splitFileName[splitFileName.length - 1])}\n </Label>\n </div>\n )}\n </div>\n </div>\n );\n}\n"],"names":["QuoteMessage","_a","message","_p","userId","_q","isByMe","className","onClick","stringSet","useContext","LocalizationContext","parentMessage","parentMessageSender","sender","parentMessageSenderNickname","QUOTED_MESSAGE__CURRENT_USER","nickname","parentMessageUrl","url","parentMessageType","type","currentMessageSenderNickname","_r","useState","isThumbnailLoaded","setThumbnailLoaded","uikitFileTypes","getUIKitFileTypes","splitFileName","name","split","React","getClassName","messageId","Icon","IconTypes","REPLY","IconColors","ON_BACKGROUND_3","Label","LabelTypography","CAPTION_2","LabelColors","ONBACKGROUND_3","QUOTED_MESSAGE__REPLIED_TO","isUserMessage","length","BODY_2","ONBACKGROUND_1","isThumbnailMessage","ImageRenderer","isVideo","PLAY","PHOTO","ON_BACKGROUND_2","thumbnails","GRAY","isGif","GIF","isFileMessage","isSupportedFileView","_b","IMAGE","VIDEO","AUDIO","FILE_AUDIO","OTHERS","FILE_DOCUMENT","getUIKitFileType","truncateString"],"mappings":"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"}
1
+ {"version":3,"file":"QuoteMessage.js","sources":["../../../src/ui/QuoteMessage/index.tsx"],"sourcesContent":["import './index.scss';\nimport React, { ReactElement, useContext, useState } from 'react';\nimport type { FileMessage, UserMessage } from '@sendbird/chat/message';\n\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport Label, { LabelTypography, LabelColors } from '../Label';\nimport ImageRenderer from '../ImageRenderer';\nimport { LocalizationContext } from '../../lib/LocalizationContext';\nimport {\n getClassName,\n getUIKitFileType,\n getUIKitFileTypes,\n isFileMessage,\n isGif,\n isSupportedFileView,\n isThumbnailMessage,\n isUserMessage,\n isVideo,\n truncateString,\n} from '../../utils';\ninterface Props {\n message?: UserMessage | FileMessage;\n userId?: string;\n isByMe?: boolean;\n className?: string | Array<string>;\n onClick?: () => void;\n}\n\nexport default function QuoteMessage({\n message,\n userId = '',\n isByMe = false,\n className,\n onClick,\n}: Props): ReactElement {\n const { stringSet } = useContext(LocalizationContext);\n\n const { parentMessage } = message;\n const parentMessageSender = (parentMessage as UserMessage | FileMessage)?.sender;\n const parentMessageSenderNickname = (userId === parentMessageSender?.userId) ? stringSet.QUOTED_MESSAGE__CURRENT_USER : parentMessageSender?.nickname;\n const parentMessageUrl = (parentMessage as FileMessage)?.url || '';\n const parentMessageType = (parentMessage as FileMessage)?.type;\n const currentMessageSenderNickname = (userId === message?.sender?.userId) ? stringSet.QUOTED_MESSAGE__CURRENT_USER : message?.sender?.nickname;\n\n const [isThumbnailLoaded, setThumbnailLoaded] = useState(false);\n const uikitFileTypes = getUIKitFileTypes();\n const splitFileName = (parentMessage as FileMessage)?.name ? (parentMessage as FileMessage).name.split('/') : parentMessageUrl.split('/');\n\n return (\n <div\n className={getClassName([className, 'sendbird-quote-message', isByMe ? 'outgoing' : 'incoming'])}\n key={parentMessage?.messageId}\n onClick={() => { if (onClick) onClick() }}\n >\n <div className=\"sendbird-quote-message__replied-to\">\n <Icon\n className=\"sendbird-quote-message__replied-to__icon\"\n type={IconTypes.REPLY}\n fillColor={IconColors.ON_BACKGROUND_3}\n width=\"12px\"\n height=\"12px\"\n />\n <Label\n className=\"sendbird-quote-message__replied-to__text\"\n type={LabelTypography.CAPTION_2}\n color={LabelColors.ONBACKGROUND_3}\n >\n {`${currentMessageSenderNickname} ${stringSet.QUOTED_MESSAGE__REPLIED_TO} ${parentMessageSenderNickname}`}\n </Label>\n </div>\n <div className=\"sendbird-quote-message__replied-message\">\n {/* text message */}\n {(isUserMessage(parentMessage as UserMessage) && (parentMessage as UserMessage)?.message?.length > 0) && (\n <div className=\"sendbird-quote-message__replied-message__text-message\">\n <Label\n className=\"sendbird-quote-message__replied-message__text-message__word\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_1}\n >\n {(parentMessage as UserMessage)?.message}\n </Label>\n </div>\n )}\n {/* thumbnail message */}\n {(isThumbnailMessage(parentMessage as FileMessage) && parentMessageUrl) && (\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message\">\n <ImageRenderer\n className=\"sendbird-quote-message__replied-message__thumbnail-message__image\"\n url={parentMessageUrl}\n alt={parentMessageType}\n width=\"144px\"\n height=\"108px\"\n onLoad={() => setThumbnailLoaded(true)}\n defaultComponent={(\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message__placeholder\">\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message__placeholder__icon\">\n <Icon\n type={isVideo(parentMessageType) ? IconTypes.PLAY : IconTypes.PHOTO}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"22px\"\n height=\"22px\"\n />\n </div>\n </div>\n )}\n />\n {(isVideo(parentMessageType) && !((parentMessage as FileMessage)?.thumbnails?.length > 0)) && (\n <>\n <video className=\"sendbird-quote-message__replied-message__thumbnail-message__video\">\n <source src={parentMessageUrl} type={parentMessageType} />\n </video>\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message__cover\">\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message__cover__icon\">\n <Icon\n type={IconTypes.PLAY}\n fillColor={IconColors.GRAY}\n width=\"14px\"\n height=\"14px\"\n />\n </div>\n </div>\n </>\n )}\n {(isThumbnailLoaded && isGif(parentMessageType)) && (\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message__cover\">\n <div className=\"sendbird-quote-message__replied-message__thumbnail-message__cover__icon\">\n <Icon\n type={IconTypes.GIF}\n fillColor={IconColors.GRAY}\n width=\"14px\"\n height=\"14px\"\n />\n </div>\n </div>\n )}\n </div>\n )}\n {/* file message */}\n {(isFileMessage(parentMessage as FileMessage) && !isSupportedFileView((parentMessage as FileMessage).type) && parentMessageUrl) && (\n <div className=\"sendbird-quote-message__replied-message__file-message\">\n <Icon\n className=\"sendbird-quote-message__replied-message__file-message__type-icon\"\n type={{\n [uikitFileTypes.IMAGE]: IconTypes.PHOTO,\n [uikitFileTypes.VIDEO]: IconTypes.PLAY,\n [uikitFileTypes.AUDIO]: IconTypes.FILE_AUDIO,\n [uikitFileTypes.GIF]: IconTypes.GIF,\n [uikitFileTypes.OTHERS]: IconTypes.FILE_DOCUMENT,\n }[getUIKitFileType(parentMessageType)]}\n fillColor={IconColors.ON_BACKGROUND_3}\n width=\"16px\"\n height=\"16px\"\n />\n <Label\n className=\"sendbird-quote-message__replied-message__file-message__file-name\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_3}\n >\n {truncateString(splitFileName[splitFileName.length - 1])}\n </Label>\n </div>\n )}\n </div>\n </div>\n );\n}\n"],"names":["QuoteMessage","_a","message","_g","userId","_h","isByMe","className","onClick","stringSet","useContext","LocalizationContext","parentMessage","parentMessageSender","sender","parentMessageSenderNickname","QUOTED_MESSAGE__CURRENT_USER","nickname","parentMessageUrl","url","parentMessageType","type","currentMessageSenderNickname","_j","useState","isThumbnailLoaded","setThumbnailLoaded","uikitFileTypes","getUIKitFileTypes","splitFileName","name","split","React","getClassName","messageId","Icon","IconTypes","REPLY","IconColors","ON_BACKGROUND_3","Label","LabelTypography","CAPTION_2","LabelColors","ONBACKGROUND_3","QUOTED_MESSAGE__REPLIED_TO","isUserMessage","length","BODY_2","ONBACKGROUND_1","isThumbnailMessage","ImageRenderer","isVideo","PLAY","PHOTO","ON_BACKGROUND_2","thumbnails","GRAY","isGif","GIF","isFileMessage","isSupportedFileView","_b","IMAGE","VIDEO","AUDIO","FILE_AUDIO","OTHERS","FILE_DOCUMENT","getUIKitFileType","truncateString"],"mappings":"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"}
@@ -1,16 +1,16 @@
1
1
  'use strict';
2
2
 
3
3
  var React = require('react');
4
- var index = require('../index-a40d57a5.js');
4
+ var index = require('../index-f3cc1992.js');
5
5
  var ui_Icon = require('./Icon.js');
6
- var ui_Label = require('../index-30e8e785.js');
7
- var LocalizationContext = require('../LocalizationContext-4c0a4a70.js');
6
+ var ui_Label = require('../index-101e25b6.js');
7
+ var LocalizationContext = require('../LocalizationContext-af3a239a.js');
8
8
  var ui_ImageRenderer = require('./ImageRenderer.js');
9
- require('../tslib.es6-571bbfc9.js');
10
- require('../_rollupPluginBabelHelpers-08d1d0ec.js');
9
+ require('../tslib.es6-4b07fef2.js');
10
+ require('../_rollupPluginBabelHelpers-1be0417a.js');
11
11
  require('prop-types');
12
- require('../stringSet-d9121aa6.js');
13
- require('../index-4e4d7494.js');
12
+ require('../stringSet-ed353b6e.js');
13
+ require('../index-c3d974a8.js');
14
14
 
15
15
  function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
16
16
 
@@ -57,14 +57,12 @@ function QuoteMessageThumbnail(_a) {
57
57
  }
58
58
 
59
59
  function QuoteMessageInput(_a) {
60
- var _b;
61
-
62
60
  var className = _a.className,
63
61
  replyingMessage = _a.replyingMessage,
64
62
  onClose = _a.onClose;
65
63
  var stringSet = React.useContext(LocalizationContext.LocalizationContext).stringSet;
66
64
  var fileMessage = replyingMessage;
67
- var sender = (_b = replyingMessage) === null || _b === void 0 ? void 0 : _b.sender;
65
+ var sender = replyingMessage === null || replyingMessage === void 0 ? void 0 : replyingMessage.sender;
68
66
  return /*#__PURE__*/React__default["default"].createElement("div", {
69
67
  className: index.getClassName(['sendbird-quote_message_input', className])
70
68
  }, /*#__PURE__*/React__default["default"].createElement(QuoteMessageThumbnail, {
@@ -72,14 +70,14 @@ function QuoteMessageInput(_a) {
72
70
  }), /*#__PURE__*/React__default["default"].createElement("div", {
73
71
  className: "sendbird-quote_message_input__body",
74
72
  style: {
75
- width: "calc(100% - " + (fileMessage.isFileMessage() ? '164px' : '120px') + ")",
76
- left: fileMessage.isFileMessage() ? '92px' : '40px'
73
+ width: "calc(100% - ".concat((fileMessage === null || fileMessage === void 0 ? void 0 : fileMessage.isFileMessage()) ? '164px' : '120px', ")"),
74
+ left: (fileMessage === null || fileMessage === void 0 ? void 0 : fileMessage.isFileMessage()) ? '92px' : '40px'
77
75
  }
78
76
  }, /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
79
77
  className: "sendbird-quote_message_input__body__sender-name",
80
78
  type: ui_Label.LabelTypography.CAPTION_1,
81
79
  color: ui_Label.LabelColors.ONBACKGROUND_1
82
- }, stringSet.QUOTE_MESSAGE_INPUT__REPLY_TO + " " + (sender && sender.nickname ? sender.nickname : stringSet.NO_NAME)), /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
80
+ }, "".concat(stringSet.QUOTE_MESSAGE_INPUT__REPLY_TO, " ").concat(sender && sender.nickname ? sender.nickname : stringSet.NO_NAME)), /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
83
81
  className: "sendbird-quote_message_input__body__message-content",
84
82
  type: ui_Label.LabelTypography.BODY_2,
85
83
  color: ui_Label.LabelColors.ONBACKGROUND_3
@@ -1 +1 @@
1
- {"version":3,"file":"QuoteMessageInput.js","sources":["../../../src/ui/QuoteMessageInput/QuoteMessageThumbnail.tsx","../../../src/ui/QuoteMessageInput/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\nimport { FileMessage } from 'sendbird';\n\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport ImageRenderer from '../ImageRenderer';\nimport { isAudioMessage, isFileMessage, isImageMessage, isThumbnailMessage } from '../../utils';\n\ninterface Props {\n message: FileMessage;\n}\n\nconst componentClassname = 'sendbird-quote_message_input__avatar';\n\nexport default function QuoteMessageThumbnail({ message }: Props): ReactElement {\n if (!isFileMessage(message)) {\n return null;\n }\n\n const thumbnailUrl: string = (message.thumbnails && message.thumbnails.length > 0 && message.thumbnails[0].url)\n || (isImageMessage(message) && message.url);\n if (isThumbnailMessage(message) && thumbnailUrl) {\n return (\n <ImageRenderer\n className={componentClassname}\n url={thumbnailUrl}\n alt={message.type}\n width=\"44px\"\n height=\"44px\"\n fixedSize\n />\n );\n } else if (isAudioMessage(message)) {\n return (\n <div className={componentClassname}>\n <Icon\n type={IconTypes.FILE_AUDIO}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"24px\"\n height=\"24px\"\n />\n </div>\n );\n } else {\n return (\n <div className={componentClassname}>\n <Icon\n type={IconTypes.FILE_DOCUMENT}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"24px\"\n height=\"24px\"\n />\n </div>\n );\n }\n}\n","import React, { ReactElement, useContext } from 'react';\nimport { FileMessage, UserMessage } from 'sendbird';\nimport {\n getClassName,\n isFileMessage,\n isGifMessage,\n isImageMessage,\n isThumbnailMessage,\n isUserMessage,\n isVideoMessage,\n} from '../../utils';\n\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport Label, { LabelTypography, LabelColors } from '../Label';\nimport { LocalizationContext } from '../../lib/LocalizationContext';\n\nimport QuoteMessageThumbnail from './QuoteMessageThumbnail';\nimport './index.scss';\n\ninterface Props {\n className?: string | Array<string>;\n replyingMessage: UserMessage | FileMessage;\n onClose?: (message: UserMessage | FileMessage) => void;\n}\n\nexport default function QuoteMessageInput({\n className,\n replyingMessage,\n onClose,\n}: Props): ReactElement {\n const { stringSet } = useContext(LocalizationContext);\n const fileMessage = replyingMessage as FileMessage;\n const sender = (replyingMessage as UserMessage | FileMessage)?.sender;\n\n return (\n <div className={getClassName(['sendbird-quote_message_input', className])}>\n <QuoteMessageThumbnail message={fileMessage} />\n <div\n className=\"sendbird-quote_message_input__body\"\n style={{\n width: `calc(100% - ${fileMessage.isFileMessage() ? '164px' : '120px'})`,\n left: fileMessage.isFileMessage() ? '92px' : '40px',\n }}\n >\n <Label\n className=\"sendbird-quote_message_input__body__sender-name\"\n type={LabelTypography.CAPTION_1}\n color={LabelColors.ONBACKGROUND_1}\n >\n {`${stringSet.QUOTE_MESSAGE_INPUT__REPLY_TO} ${(sender && sender.nickname) ? sender.nickname : stringSet.NO_NAME}`}\n </Label>\n <Label\n className=\"sendbird-quote_message_input__body__message-content\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_3}\n >\n {isImageMessage(fileMessage) && !isGifMessage(fileMessage) && stringSet.QUOTE_MESSAGE_INPUT__FILE_TYPE_IMAGE}\n {isVideoMessage(fileMessage) && stringSet.QUOTE_MESSAGE_INPUT__FILE_TYPE__VIDEO}\n {isGifMessage(fileMessage) && stringSet.QUOTE_MESSAGE_INPUT__FILE_TYPE_GIF}\n {isUserMessage(replyingMessage as UserMessage) && (replyingMessage as UserMessage).message}\n {(isFileMessage(fileMessage) && !isThumbnailMessage(fileMessage)) && fileMessage.name}\n </Label>\n </div>\n <Icon\n className=\"sendbird-quote_message_input__close-button\"\n type={IconTypes.CLOSE}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"24px\"\n height=\"24px\"\n onClick={() => onClose(replyingMessage)}\n />\n </div>\n );\n}\n"],"names":["componentClassname","QuoteMessageThumbnail","_a","message","isFileMessage","thumbnailUrl","thumbnails","length","url","isImageMessage","isThumbnailMessage","React","ImageRenderer","type","isAudioMessage","Icon","IconTypes","FILE_AUDIO","IconColors","ON_BACKGROUND_2","FILE_DOCUMENT","QuoteMessageInput","className","replyingMessage","onClose","stringSet","useContext","LocalizationContext","fileMessage","sender","getClassName","width","left","Label","LabelTypography","CAPTION_1","LabelColors","ONBACKGROUND_1","QUOTE_MESSAGE_INPUT__REPLY_TO","nickname","NO_NAME","BODY_2","ONBACKGROUND_3","isGifMessage","QUOTE_MESSAGE_INPUT__FILE_TYPE_IMAGE","isVideoMessage","QUOTE_MESSAGE_INPUT__FILE_TYPE__VIDEO","QUOTE_MESSAGE_INPUT__FILE_TYPE_GIF","isUserMessage","name","CLOSE"],"mappings":"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"}
1
+ {"version":3,"file":"QuoteMessageInput.js","sources":["../../../src/ui/QuoteMessageInput/QuoteMessageThumbnail.tsx","../../../src/ui/QuoteMessageInput/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\nimport type { FileMessage } from '@sendbird/chat/message';\n\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport ImageRenderer from '../ImageRenderer';\nimport { isAudioMessage, isFileMessage, isImageMessage, isThumbnailMessage } from '../../utils';\n\ninterface Props {\n message: FileMessage;\n}\n\nconst componentClassname = 'sendbird-quote_message_input__avatar';\n\nexport default function QuoteMessageThumbnail({ message }: Props): ReactElement {\n if (!isFileMessage(message)) {\n return null;\n }\n\n const thumbnailUrl: string = (message.thumbnails && message.thumbnails.length > 0 && message.thumbnails[0].url)\n || (isImageMessage(message) && message.url);\n if (isThumbnailMessage(message) && thumbnailUrl) {\n return (\n <ImageRenderer\n className={componentClassname}\n url={thumbnailUrl}\n alt={message.type}\n width=\"44px\"\n height=\"44px\"\n fixedSize\n />\n );\n } else if (isAudioMessage(message)) {\n return (\n <div className={componentClassname}>\n <Icon\n type={IconTypes.FILE_AUDIO}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"24px\"\n height=\"24px\"\n />\n </div>\n );\n } else {\n return (\n <div className={componentClassname}>\n <Icon\n type={IconTypes.FILE_DOCUMENT}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"24px\"\n height=\"24px\"\n />\n </div>\n );\n }\n}\n","import './index.scss';\n\nimport React, { ReactElement, useContext } from 'react';\nimport type { FileMessage, UserMessage } from '@sendbird/chat/message';\nimport {\n getClassName,\n isFileMessage,\n isGifMessage,\n isImageMessage,\n isThumbnailMessage,\n isUserMessage,\n isVideoMessage,\n} from '../../utils';\n\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport Label, { LabelTypography, LabelColors } from '../Label';\nimport { LocalizationContext } from '../../lib/LocalizationContext';\n\nimport QuoteMessageThumbnail from './QuoteMessageThumbnail';\n\ninterface Props {\n className?: string | Array<string>;\n replyingMessage: UserMessage | FileMessage;\n onClose?: (message: UserMessage | FileMessage) => void;\n}\n\nexport default function QuoteMessageInput({\n className,\n replyingMessage,\n onClose,\n}: Props): ReactElement {\n const { stringSet } = useContext(LocalizationContext);\n const fileMessage = replyingMessage as FileMessage;\n const sender = (replyingMessage as UserMessage | FileMessage)?.sender;\n\n return (\n <div className={getClassName(['sendbird-quote_message_input', className])}>\n <QuoteMessageThumbnail message={fileMessage} />\n <div\n className=\"sendbird-quote_message_input__body\"\n style={{\n width: `calc(100% - ${fileMessage?.isFileMessage() ? '164px' : '120px'})`,\n left: fileMessage?.isFileMessage() ? '92px' : '40px',\n }}\n >\n <Label\n className=\"sendbird-quote_message_input__body__sender-name\"\n type={LabelTypography.CAPTION_1}\n color={LabelColors.ONBACKGROUND_1}\n >\n {`${stringSet.QUOTE_MESSAGE_INPUT__REPLY_TO} ${(sender && sender.nickname) ? sender.nickname : stringSet.NO_NAME}`}\n </Label>\n <Label\n className=\"sendbird-quote_message_input__body__message-content\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_3}\n >\n {isImageMessage(fileMessage) && !isGifMessage(fileMessage) && stringSet.QUOTE_MESSAGE_INPUT__FILE_TYPE_IMAGE}\n {isVideoMessage(fileMessage) && stringSet.QUOTE_MESSAGE_INPUT__FILE_TYPE__VIDEO}\n {isGifMessage(fileMessage) && stringSet.QUOTE_MESSAGE_INPUT__FILE_TYPE_GIF}\n {isUserMessage(replyingMessage as UserMessage) && (replyingMessage as UserMessage).message}\n {(isFileMessage(fileMessage) && !isThumbnailMessage(fileMessage)) && fileMessage.name}\n </Label>\n </div>\n <Icon\n className=\"sendbird-quote_message_input__close-button\"\n type={IconTypes.CLOSE}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"24px\"\n height=\"24px\"\n onClick={() => onClose(replyingMessage)}\n />\n </div>\n );\n}\n"],"names":["componentClassname","QuoteMessageThumbnail","_a","message","isFileMessage","thumbnailUrl","thumbnails","length","url","isImageMessage","isThumbnailMessage","React","ImageRenderer","type","isAudioMessage","Icon","IconTypes","FILE_AUDIO","IconColors","ON_BACKGROUND_2","FILE_DOCUMENT","QuoteMessageInput","className","replyingMessage","onClose","stringSet","useContext","LocalizationContext","fileMessage","sender","getClassName","width","left","Label","LabelTypography","CAPTION_1","LabelColors","ONBACKGROUND_1","QUOTE_MESSAGE_INPUT__REPLY_TO","nickname","NO_NAME","BODY_2","ONBACKGROUND_3","isGifMessage","QUOTE_MESSAGE_INPUT__FILE_TYPE_IMAGE","isVideoMessage","QUOTE_MESSAGE_INPUT__FILE_TYPE__VIDEO","QUOTE_MESSAGE_INPUT__FILE_TYPE_GIF","isUserMessage","name","CLOSE"],"mappings":"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"}
@@ -1,10 +1,10 @@
1
1
  'use strict';
2
2
 
3
- var _rollupPluginBabelHelpers = require('../_rollupPluginBabelHelpers-08d1d0ec.js');
3
+ var _rollupPluginBabelHelpers = require('../_rollupPluginBabelHelpers-1be0417a.js');
4
4
  var React = require('react');
5
5
  var PropTypes = require('prop-types');
6
- var ui_Label = require('../index-30e8e785.js');
7
- require('../stringSet-d9121aa6.js');
6
+ var ui_Label = require('../index-101e25b6.js');
7
+ require('../stringSet-ed353b6e.js');
8
8
 
9
9
  function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
10
10
 
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var _rollupPluginBabelHelpers = require('../_rollupPluginBabelHelpers-08d1d0ec.js');
3
+ var _rollupPluginBabelHelpers = require('../_rollupPluginBabelHelpers-1be0417a.js');
4
4
  var React = require('react');
5
5
  var PropTypes = require('prop-types');
6
6