@sendbird/uikit-react 3.0.2-beta.2 → 3.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/App.js +32 -32
- package/CHANGELOG.md +11 -1
- package/Channel/components/ChannelHeader.js +17 -17
- package/Channel/components/ChannelUI.js +24 -24
- package/Channel/components/FileViewer.js +16 -16
- package/Channel/components/FrozenNotification.js +5 -5
- package/Channel/components/Message.js +21 -21
- package/Channel/components/MessageInput.js +18 -18
- package/Channel/components/MessageList.js +23 -23
- package/Channel/components/RemoveMessageModal.js +19 -19
- package/Channel/components/SuggestedMentionList.js +17 -17
- package/Channel/components/TypingIndicator.js +16 -16
- package/Channel/components/UnreadCount.js +5 -5
- package/Channel/context.js +15 -15
- package/Channel.js +24 -24
- package/ChannelList/components/AddChannel.js +14 -14
- package/ChannelList/components/ChannelListHeader.js +7 -7
- package/ChannelList/components/ChannelListUI.js +28 -28
- package/ChannelList/components/ChannelPreview.js +21 -21
- package/ChannelList/components/ChannelPreviewAction.js +16 -16
- package/ChannelList/context.js +10 -10
- package/ChannelList.js +28 -28
- package/{ChannelListProvider-ae51690a.js → ChannelListProvider-deca2b46.js} +9 -9
- package/{ChannelListProvider-ae51690a.js.map → ChannelListProvider-deca2b46.js.map} +1 -1
- package/{ChannelProvider-64e9f011.js → ChannelProvider-433ab63d.js} +11 -11
- package/{ChannelProvider-64e9f011.js.map → ChannelProvider-433ab63d.js.map} +1 -1
- package/ChannelSettings/components/ChannelProfile.js +13 -13
- package/ChannelSettings/components/ChannelSettingsUI.js +20 -18
- package/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
- package/ChannelSettings/components/EditDetailsModal.js +13 -13
- package/ChannelSettings/components/LeaveChannel.js +10 -10
- package/ChannelSettings/components/ModerationPanel.js +29 -26
- package/ChannelSettings/components/ModerationPanel.js.map +1 -1
- package/ChannelSettings/components/UserListItem.js +14 -14
- package/ChannelSettings/components/UserListItem.js.map +1 -1
- package/ChannelSettings/components/UserPanel.js +14 -14
- package/ChannelSettings/context.js +3 -3
- package/ChannelSettings.js +20 -18
- package/ChannelSettings.js.map +1 -1
- package/CreateChannel/components/CreateChannelUI.js +14 -14
- package/CreateChannel/components/InviteUsers.js +14 -14
- package/CreateChannel/components/SelectChannelType.js +10 -10
- package/CreateChannel/context.js +4 -4
- package/CreateChannel.js +14 -14
- package/{CreateChannelProvider-0e54306e.js → CreateChannelProvider-06a7aea1.js} +1 -1
- package/{CreateChannelProvider-0e54306e.js.map → CreateChannelProvider-06a7aea1.js.map} +1 -1
- package/EditUserProfile/components/EditUserProfileUI.js +13 -13
- package/EditUserProfile.js +13 -13
- package/{LocalizationContext-6e75b56a.js → LocalizationContext-9f3a97d4.js} +3 -3
- package/{LocalizationContext-6e75b56a.js.map → LocalizationContext-9f3a97d4.js.map} +1 -1
- package/{MemberList-1ef0c70c.js → MemberList-f02f2f2c.js} +25 -22
- package/MemberList-f02f2f2c.js.map +1 -0
- package/MessageSearch/components/MessageSearchUI.js +11 -11
- package/MessageSearch/context.js +2 -2
- package/MessageSearch.js +11 -11
- package/OpenChannel/components/FrozenChannelNotification.js +5 -5
- package/OpenChannel/components/OpenChannelHeader.js +14 -14
- package/OpenChannel/components/OpenChannelInput.js +18 -18
- package/OpenChannel/components/OpenChannelMessage.js +42 -28
- package/OpenChannel/components/OpenChannelMessage.js.map +1 -1
- package/OpenChannel/components/OpenChannelMessageList.js +26 -26
- package/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
- package/OpenChannel/components/OpenChannelUI.js +25 -25
- package/OpenChannel/context.js +11 -11
- package/OpenChannel.js +25 -25
- package/{OpenChannelProvider-a37f23fd.js → OpenChannelProvider-1161d100.js} +42 -15
- package/OpenChannelProvider-1161d100.js.map +1 -0
- package/OpenChannelSettings/components/EditDetailsModal.js +13 -13
- package/OpenChannelSettings/components/OpenChannelProfile.js +13 -13
- package/OpenChannelSettings/components/OpenChannelSettingsUI.js +21 -21
- package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
- package/OpenChannelSettings/components/OperatorUI.js +776 -27
- package/OpenChannelSettings/components/OperatorUI.js.map +1 -1
- package/OpenChannelSettings/components/ParticipantUI.js +28 -139
- package/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
- package/OpenChannelSettings/context.js +48 -4
- package/OpenChannelSettings/context.js.map +1 -1
- package/OpenChannelSettings.js +22 -22
- package/SendbirdProvider.js +12 -12
- package/{UserProfileContext-f367c086.js → UserProfileContext-0ab13769.js} +1 -1
- package/{UserProfileContext-f367c086.js.map → UserProfileContext-0ab13769.js.map} +1 -1
- package/__bundle-7dfccc8c-097677fe.js +24 -0
- package/__bundle-7dfccc8c-097677fe.js.map +1 -0
- package/{_rollupPluginBabelHelpers-c97525da.js → _rollupPluginBabelHelpers-e62b6c94.js} +1 -1
- package/{_rollupPluginBabelHelpers-c97525da.js.map → _rollupPluginBabelHelpers-e62b6c94.js.map} +1 -1
- package/{actionTypes-45239968.js → actionTypes-5b38ad2f.js} +1 -1
- package/{actionTypes-45239968.js.map → actionTypes-5b38ad2f.js.map} +1 -1
- package/cjs/App.js +32 -32
- package/cjs/Channel/components/ChannelHeader.js +17 -17
- package/cjs/Channel/components/ChannelUI.js +24 -24
- package/cjs/Channel/components/FileViewer.js +16 -16
- package/cjs/Channel/components/FrozenNotification.js +5 -5
- package/cjs/Channel/components/Message.js +21 -21
- package/cjs/Channel/components/MessageInput.js +18 -18
- package/cjs/Channel/components/MessageList.js +23 -23
- package/cjs/Channel/components/RemoveMessageModal.js +19 -19
- package/cjs/Channel/components/SuggestedMentionList.js +17 -17
- package/cjs/Channel/components/TypingIndicator.js +16 -16
- package/cjs/Channel/components/UnreadCount.js +5 -5
- package/cjs/Channel/context.js +15 -15
- package/cjs/Channel.js +24 -24
- package/cjs/ChannelList/components/AddChannel.js +14 -14
- package/cjs/ChannelList/components/ChannelListHeader.js +7 -7
- package/cjs/ChannelList/components/ChannelListUI.js +28 -28
- package/cjs/ChannelList/components/ChannelPreview.js +21 -21
- package/cjs/ChannelList/components/ChannelPreviewAction.js +16 -16
- package/cjs/ChannelList/context.js +10 -10
- package/cjs/ChannelList.js +28 -28
- package/cjs/{ChannelListProvider-038ef463.js → ChannelListProvider-adbb04ab.js} +9 -9
- package/cjs/{ChannelListProvider-038ef463.js.map → ChannelListProvider-adbb04ab.js.map} +1 -1
- package/cjs/{ChannelProvider-66622e53.js → ChannelProvider-cec988e8.js} +11 -11
- package/cjs/{ChannelProvider-66622e53.js.map → ChannelProvider-cec988e8.js.map} +1 -1
- package/cjs/ChannelSettings/components/ChannelProfile.js +13 -13
- package/cjs/ChannelSettings/components/ChannelSettingsUI.js +20 -18
- package/cjs/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
- package/cjs/ChannelSettings/components/EditDetailsModal.js +13 -13
- package/cjs/ChannelSettings/components/LeaveChannel.js +10 -10
- package/cjs/ChannelSettings/components/ModerationPanel.js +28 -25
- package/cjs/ChannelSettings/components/ModerationPanel.js.map +1 -1
- package/cjs/ChannelSettings/components/UserListItem.js +14 -14
- package/cjs/ChannelSettings/components/UserListItem.js.map +1 -1
- package/cjs/ChannelSettings/components/UserPanel.js +14 -14
- package/cjs/ChannelSettings/context.js +3 -3
- package/cjs/ChannelSettings.js +20 -18
- package/cjs/ChannelSettings.js.map +1 -1
- package/cjs/CreateChannel/components/CreateChannelUI.js +14 -14
- package/cjs/CreateChannel/components/InviteUsers.js +14 -14
- package/cjs/CreateChannel/components/SelectChannelType.js +10 -10
- package/cjs/CreateChannel/context.js +4 -4
- package/cjs/CreateChannel.js +14 -14
- package/cjs/{CreateChannelProvider-2e94ad28.js → CreateChannelProvider-7e76640c.js} +1 -1
- package/cjs/{CreateChannelProvider-2e94ad28.js.map → CreateChannelProvider-7e76640c.js.map} +1 -1
- package/cjs/EditUserProfile/components/EditUserProfileUI.js +13 -13
- package/cjs/EditUserProfile.js +13 -13
- package/cjs/{LocalizationContext-0bf3e760.js → LocalizationContext-672b9c94.js} +3 -3
- package/cjs/{LocalizationContext-0bf3e760.js.map → LocalizationContext-672b9c94.js.map} +1 -1
- package/cjs/{MemberList-a4c71b6e.js → MemberList-5fdc93f7.js} +24 -21
- package/cjs/MemberList-5fdc93f7.js.map +1 -0
- package/cjs/MessageSearch/components/MessageSearchUI.js +11 -11
- package/cjs/MessageSearch/context.js +2 -2
- package/cjs/MessageSearch.js +11 -11
- package/cjs/OpenChannel/components/FrozenChannelNotification.js +5 -5
- package/cjs/OpenChannel/components/OpenChannelHeader.js +14 -14
- package/cjs/OpenChannel/components/OpenChannelInput.js +18 -18
- package/cjs/OpenChannel/components/OpenChannelMessage.js +42 -28
- package/cjs/OpenChannel/components/OpenChannelMessage.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelMessageList.js +26 -26
- package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelUI.js +25 -25
- package/cjs/OpenChannel/context.js +11 -11
- package/cjs/OpenChannel.js +25 -25
- package/cjs/{OpenChannelProvider-000ca1cf.js → OpenChannelProvider-41c8a190.js} +42 -15
- package/cjs/OpenChannelProvider-41c8a190.js.map +1 -0
- package/cjs/OpenChannelSettings/components/EditDetailsModal.js +13 -13
- package/cjs/OpenChannelSettings/components/OpenChannelProfile.js +13 -13
- package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js +21 -21
- package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
- package/cjs/OpenChannelSettings/components/OperatorUI.js +775 -26
- package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -1
- package/cjs/OpenChannelSettings/components/ParticipantUI.js +29 -140
- package/cjs/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
- package/cjs/OpenChannelSettings/context.js +48 -4
- package/cjs/OpenChannelSettings/context.js.map +1 -1
- package/cjs/OpenChannelSettings.js +22 -22
- package/cjs/SendbirdProvider.js +12 -12
- package/cjs/{UserProfileContext-5b432968.js → UserProfileContext-d3290c6a.js} +1 -1
- package/cjs/{UserProfileContext-5b432968.js.map → UserProfileContext-d3290c6a.js.map} +1 -1
- package/cjs/__bundle-7dfccc8c-99e5ac3e.js +151 -0
- package/cjs/__bundle-7dfccc8c-99e5ac3e.js.map +1 -0
- package/cjs/{_rollupPluginBabelHelpers-8b01e58c.js → _rollupPluginBabelHelpers-f02175f2.js} +1 -1
- package/cjs/{_rollupPluginBabelHelpers-8b01e58c.js.map → _rollupPluginBabelHelpers-f02175f2.js.map} +1 -1
- package/cjs/{actionTypes-1798b025.js → actionTypes-80f60d16.js} +1 -1
- package/cjs/{actionTypes-1798b025.js.map → actionTypes-80f60d16.js.map} +1 -1
- package/cjs/{color-1807e249.js → color-478c93f8.js} +1 -1
- package/cjs/{color-1807e249.js.map → color-478c93f8.js.map} +1 -1
- package/cjs/{compareIds-8c7d8980.js → compareIds-26b51402.js} +1 -1
- package/cjs/{compareIds-8c7d8980.js.map → compareIds-26b51402.js.map} +1 -1
- package/cjs/{const-f86a2fb2.js → const-4106b8a9.js} +1 -1
- package/cjs/{const-f86a2fb2.js.map → const-4106b8a9.js.map} +1 -1
- package/cjs/{const-1902a74e.js → const-58d3edce.js} +1 -1
- package/cjs/{const-1902a74e.js.map → const-58d3edce.js.map} +1 -1
- package/cjs/{context-aab9d9b1.js → context-01116a29.js} +2 -2
- package/cjs/{context-aab9d9b1.js.map → context-01116a29.js.map} +1 -1
- package/cjs/dist/index.css +137 -88
- package/cjs/dist/index.css.map +1 -1
- package/cjs/groupChannel-9502b458.js +9 -0
- package/cjs/groupChannel-9502b458.js.map +1 -0
- package/cjs/{index-fd497c7c.js → index-1a2c6bb9.js} +1 -1
- package/cjs/{index-fd497c7c.js.map → index-1a2c6bb9.js.map} +1 -1
- package/cjs/{index-1da71f37.js → index-1d91484a.js} +4 -4
- package/cjs/{index-1da71f37.js.map → index-1d91484a.js.map} +1 -1
- package/cjs/{index-51e49cfe.js → index-24973446.js} +4 -4
- package/cjs/{index-51e49cfe.js.map → index-24973446.js.map} +1 -1
- package/cjs/index-3b747780.js +357 -0
- package/cjs/index-3b747780.js.map +1 -0
- package/cjs/{index-639e3f2f.js → index-3b9eca88.js} +5 -5
- package/cjs/index-3b9eca88.js.map +1 -0
- package/cjs/{index-13bf8604.js → index-52186645.js} +3 -3
- package/cjs/{index-13bf8604.js.map → index-52186645.js.map} +1 -1
- package/cjs/{index-ffc23504.js → index-6b7d2465.js} +3 -3
- package/cjs/{index-ffc23504.js.map → index-6b7d2465.js.map} +1 -1
- package/cjs/{index-7b8fdc11.js → index-84bd6fef.js} +1 -1
- package/cjs/{index-7b8fdc11.js.map → index-84bd6fef.js.map} +1 -1
- package/cjs/{index-cd933bf7.js → index-93b2249a.js} +2 -2
- package/cjs/{index-cd933bf7.js.map → index-93b2249a.js.map} +1 -1
- package/cjs/{index-bcb8a49a.js → index-ce704c05.js} +2 -2
- package/cjs/{index-bcb8a49a.js.map → index-ce704c05.js.map} +1 -1
- package/cjs/{index-8a98fd13.js → index-f240822b.js} +6 -6
- package/cjs/{index-8a98fd13.js.map → index-f240822b.js.map} +1 -1
- package/cjs/index.js +36 -36
- package/cjs/openChannel-f2448196.js +13 -0
- package/cjs/openChannel-f2448196.js.map +1 -0
- package/cjs/{openChannelUtils-08574a70.js → openChannelUtils-b411bbf8.js} +1 -2
- package/cjs/{openChannelUtils-08574a70.js.map → openChannelUtils-b411bbf8.js.map} +1 -1
- package/cjs/sendbirdSelectors.js +2 -2
- package/cjs/{stringSet-9b12d465.js → stringSet-da3df562.js} +28 -3
- package/cjs/stringSet-da3df562.js.map +1 -0
- package/cjs/{topics-b736a640.js → topics-1932f321.js} +1 -1
- package/cjs/{topics-b736a640.js.map → topics-1932f321.js.map} +1 -1
- package/cjs/{tslib.es6-a0ece28e.js → tslib.es6-306f32fb.js} +1 -1
- package/cjs/{tslib.es6-a0ece28e.js.map → tslib.es6-306f32fb.js.map} +1 -1
- package/cjs/ui/Accordion.js +4 -4
- package/cjs/ui/AccordionGroup.js +2 -2
- package/cjs/ui/AdminMessage.js +3 -3
- package/cjs/ui/Avatar.js +3 -3
- package/cjs/ui/Badge.js +5 -5
- package/cjs/ui/Button.js +4 -4
- package/cjs/ui/ChannelAvatar.js +4 -4
- package/cjs/ui/ChannelPreview.js +12 -12
- package/cjs/ui/ChatHeader.js +8 -8
- package/cjs/ui/Checkbox.js +12 -24
- package/cjs/ui/Checkbox.js.map +1 -1
- package/cjs/ui/ConnectionStatus.js +5 -5
- package/cjs/ui/ContextMenu.js +5 -5
- package/cjs/ui/DateSeparator.js +4 -4
- package/cjs/ui/Dropdown.js +3 -3
- package/cjs/ui/EmojiReactions.js +7 -7
- package/cjs/ui/FileMessageItemBody.js +6 -6
- package/cjs/ui/FileViewer.js +7 -7
- package/cjs/ui/Icon.js +1 -1
- package/cjs/ui/IconButton.js +1 -1
- package/cjs/ui/ImageRenderer.js +1 -1
- package/cjs/ui/Input.js +3 -3
- package/cjs/ui/Label.js +3 -3
- package/cjs/ui/LinkLabel.js +3 -3
- package/cjs/ui/Loader.js +1 -1
- package/cjs/ui/MentionLabel.js +11 -11
- package/cjs/ui/MessageContent.js +14 -14
- package/cjs/ui/MessageInput.js +10 -10
- package/cjs/ui/MessageItemMenu.js +7 -7
- package/cjs/ui/MessageItemReactionMenu.js +5 -5
- package/cjs/ui/MessageSearchFileItem.js +10 -10
- package/cjs/ui/MessageSearchItem.js +10 -10
- package/cjs/ui/MessageStatus.js +8 -8
- package/cjs/ui/Modal.js +12 -9
- package/cjs/ui/Modal.js.map +1 -1
- package/cjs/ui/MutedAvatarOverlay.js +1 -1
- package/cjs/ui/OGMessageItemBody.js +11 -11
- package/cjs/ui/OpenChannelAdminMessage.js +4 -4
- package/cjs/ui/OpenChannelAvatar.js +7 -7
- package/cjs/ui/OpenchannelConversationHeader.js +7 -7
- package/cjs/ui/OpenchannelFileMessage.js +17 -17
- package/cjs/ui/OpenchannelFileMessage.js.map +1 -1
- package/cjs/ui/OpenchannelOGMessage.js +17 -17
- package/cjs/ui/OpenchannelOGMessage.js.map +1 -1
- package/cjs/ui/OpenchannelThumbnailMessage.js +16 -16
- package/cjs/ui/OpenchannelThumbnailMessage.js.map +1 -1
- package/cjs/ui/OpenchannelUserMessage.js +17 -17
- package/cjs/ui/OpenchannelUserMessage.js.map +1 -1
- package/cjs/ui/PlaceHolder.js +6 -6
- package/cjs/ui/QuoteMessage.js +7 -7
- package/cjs/ui/QuoteMessageInput.js +7 -7
- package/cjs/ui/ReactionBadge.js +3 -3
- package/cjs/ui/ReactionButton.js +1 -1
- package/cjs/ui/SortByRow.js +1 -1
- package/cjs/ui/TextButton.js +2 -2
- package/cjs/ui/TextMessageItemBody.js +11 -11
- package/cjs/ui/ThumbnailMessageItemBody.js +3 -3
- package/cjs/ui/Tooltip.js +3 -3
- package/cjs/ui/TooltipWrapper.js +1 -1
- package/cjs/ui/UnknownMessageItemBody.js +7 -7
- package/cjs/ui/UserListItem.js +34 -62
- package/cjs/ui/UserListItem.js.map +1 -1
- package/cjs/ui/UserProfile.js +10 -10
- package/cjs/ui/Word.js +11 -11
- package/cjs/useSendbirdStateContext.js +1 -1
- package/cjs/{utils-80d26c50.js → utils-15fd96e3.js} +1 -1
- package/cjs/{utils-80d26c50.js.map → utils-15fd96e3.js.map} +1 -1
- package/cjs/{utils-2ad4070a.js → utils-59d39f8a.js} +1 -1
- package/cjs/{utils-2ad4070a.js.map → utils-59d39f8a.js.map} +1 -1
- package/cjs/{utils-bc3be007.js → utils-d06dfceb.js} +1 -1
- package/cjs/{utils-bc3be007.js.map → utils-d06dfceb.js.map} +1 -1
- package/cjs/{uuid-198218df.js → uuid-deaf6e4d.js} +1 -1
- package/cjs/{uuid-198218df.js.map → uuid-deaf6e4d.js.map} +1 -1
- package/cjs/withSendbird.js +1 -1
- package/{color-8a34313f.js → color-af7ca71d.js} +1 -1
- package/{color-8a34313f.js.map → color-af7ca71d.js.map} +1 -1
- package/{compareIds-f5c7e9e0.js → compareIds-0374f200.js} +1 -1
- package/{compareIds-f5c7e9e0.js.map → compareIds-0374f200.js.map} +1 -1
- package/{const-3c79b764.js → const-1df70d22.js} +1 -1
- package/{const-3c79b764.js.map → const-1df70d22.js.map} +1 -1
- package/{const-8cce96ac.js → const-e494c46a.js} +1 -1
- package/{const-8cce96ac.js.map → const-e494c46a.js.map} +1 -1
- package/{context-e14a3cd1.js → context-477db28c.js} +2 -2
- package/{context-e14a3cd1.js.map → context-477db28c.js.map} +1 -1
- package/dist/index.css +137 -88
- package/dist/index.css.map +1 -1
- package/{groupChannel-cc9fae2b.js → groupChannel-3295edad.js} +3 -3
- package/groupChannel-3295edad.js.map +1 -0
- package/index-018657f4.js +350 -0
- package/index-018657f4.js.map +1 -0
- package/{index-7324a9d2.js → index-0b5ccb8a.js} +3 -3
- package/{index-7324a9d2.js.map → index-0b5ccb8a.js.map} +1 -1
- package/{index-6f372bb8.js → index-0bca77f6.js} +2 -2
- package/{index-6f372bb8.js.map → index-0bca77f6.js.map} +1 -1
- package/{index-79815d20.js → index-626e0c91.js} +1 -1
- package/{index-79815d20.js.map → index-626e0c91.js.map} +1 -1
- package/{index-3444f2dd.js → index-6d9f27e9.js} +1 -1
- package/{index-3444f2dd.js.map → index-6d9f27e9.js.map} +1 -1
- package/{index-07c1cd2b.js → index-961dd650.js} +4 -4
- package/{index-07c1cd2b.js.map → index-961dd650.js.map} +1 -1
- package/{index-2de5002e.js → index-97340f01.js} +6 -6
- package/{index-2de5002e.js.map → index-97340f01.js.map} +1 -1
- package/{index-2a105a6a.js → index-b75c8b72.js} +5 -5
- package/index-b75c8b72.js.map +1 -0
- package/{index-0b740954.js → index-b9397b82.js} +2 -2
- package/{index-0b740954.js.map → index-b9397b82.js.map} +1 -1
- package/{index-7f7579cb.js → index-be56e57e.js} +3 -3
- package/{index-7f7579cb.js.map → index-be56e57e.js.map} +1 -1
- package/{index-9935530e.js → index-c6d2d378.js} +4 -4
- package/{index-9935530e.js.map → index-c6d2d378.js.map} +1 -1
- package/index.d.ts +2 -2
- package/index.js +36 -36
- package/openChannel-c960d007.js +8 -0
- package/openChannel-c960d007.js.map +1 -0
- package/{openChannelUtils-9b134f08.js → openChannelUtils-eb983c6e.js} +2 -2
- package/{openChannelUtils-9b134f08.js.map → openChannelUtils-eb983c6e.js.map} +1 -1
- package/package.json +1 -1
- package/sendbirdSelectors.js +2 -2
- package/{stringSet-7a28664f.js → stringSet-8471446d.js} +28 -3
- package/stringSet-8471446d.js.map +1 -0
- package/{topics-7ca110dd.js → topics-408562ae.js} +1 -1
- package/{topics-7ca110dd.js.map → topics-408562ae.js.map} +1 -1
- package/{tslib.es6-71164428.js → tslib.es6-bc2713d7.js} +1 -1
- package/{tslib.es6-71164428.js.map → tslib.es6-bc2713d7.js.map} +1 -1
- package/ui/Accordion.js +4 -4
- package/ui/AccordionGroup.js +2 -2
- package/ui/AdminMessage.js +3 -3
- package/ui/Avatar.js +3 -3
- package/ui/Badge.js +5 -5
- package/ui/Button.js +4 -4
- package/ui/ChannelAvatar.js +4 -4
- package/ui/ChannelPreview.js +12 -12
- package/ui/ChatHeader.js +8 -8
- package/ui/Checkbox.js +12 -23
- package/ui/Checkbox.js.map +1 -1
- package/ui/ConnectionStatus.js +5 -5
- package/ui/ContextMenu.js +5 -5
- package/ui/DateSeparator.js +4 -4
- package/ui/Dropdown.js +3 -3
- package/ui/EmojiReactions.js +7 -7
- package/ui/FileMessageItemBody.js +6 -6
- package/ui/FileViewer.js +7 -7
- package/ui/Icon.js +1 -1
- package/ui/IconButton.js +1 -1
- package/ui/ImageRenderer.js +1 -1
- package/ui/Input.js +3 -3
- package/ui/Label.js +3 -3
- package/ui/LinkLabel.js +3 -3
- package/ui/Loader.js +1 -1
- package/ui/MentionLabel.js +11 -11
- package/ui/MessageContent.js +14 -14
- package/ui/MessageInput.js +10 -10
- package/ui/MessageItemMenu.js +7 -7
- package/ui/MessageItemReactionMenu.js +5 -5
- package/ui/MessageSearchFileItem.js +10 -10
- package/ui/MessageSearchItem.js +10 -10
- package/ui/MessageStatus.js +8 -8
- package/ui/Modal.js +12 -9
- package/ui/Modal.js.map +1 -1
- package/ui/MutedAvatarOverlay.js +1 -1
- package/ui/OGMessageItemBody.js +11 -11
- package/ui/OpenChannelAdminMessage.js +4 -4
- package/ui/OpenChannelAvatar.js +7 -7
- package/ui/OpenchannelConversationHeader.js +7 -7
- package/ui/OpenchannelFileMessage.js +17 -17
- package/ui/OpenchannelFileMessage.js.map +1 -1
- package/ui/OpenchannelOGMessage.js +17 -17
- package/ui/OpenchannelOGMessage.js.map +1 -1
- package/ui/OpenchannelThumbnailMessage.js +16 -16
- package/ui/OpenchannelThumbnailMessage.js.map +1 -1
- package/ui/OpenchannelUserMessage.js +17 -17
- package/ui/OpenchannelUserMessage.js.map +1 -1
- package/ui/PlaceHolder.js +6 -6
- package/ui/QuoteMessage.js +7 -7
- package/ui/QuoteMessageInput.js +7 -7
- package/ui/ReactionBadge.js +3 -3
- package/ui/ReactionButton.js +1 -1
- package/ui/SortByRow.js +1 -1
- package/ui/TextButton.js +2 -2
- package/ui/TextMessageItemBody.js +11 -11
- package/ui/ThumbnailMessageItemBody.js +3 -3
- package/ui/Tooltip.js +3 -3
- package/ui/TooltipWrapper.js +1 -1
- package/ui/UnknownMessageItemBody.js +7 -7
- package/ui/UserListItem.js +34 -61
- package/ui/UserListItem.js.map +1 -1
- package/ui/UserProfile.js +10 -10
- package/ui/Word.js +11 -11
- package/useSendbirdStateContext.js +1 -1
- package/{utils-6c89c101.js → utils-14e75814.js} +1 -1
- package/{utils-6c89c101.js.map → utils-14e75814.js.map} +1 -1
- package/{utils-38a1ad56.js → utils-6f162725.js} +1 -1
- package/{utils-38a1ad56.js.map → utils-6f162725.js.map} +1 -1
- package/{utils-5807b354.js → utils-ed9ea372.js} +1 -1
- package/{utils-5807b354.js.map → utils-ed9ea372.js.map} +1 -1
- package/{uuid-39710dee.js → uuid-b172d222.js} +1 -1
- package/{uuid-39710dee.js.map → uuid-b172d222.js.map} +1 -1
- package/withSendbird.js +1 -1
- package/MemberList-1ef0c70c.js.map +0 -1
- package/OpenChannelProvider-a37f23fd.js.map +0 -1
- package/__bundle-7dfccc8c-a16aed7a.js +0 -4396
- package/__bundle-7dfccc8c-a16aed7a.js.map +0 -1
- package/cjs/MemberList-a4c71b6e.js.map +0 -1
- package/cjs/OpenChannelProvider-000ca1cf.js.map +0 -1
- package/cjs/__bundle-7dfccc8c-ed185b23.js +0 -4523
- package/cjs/__bundle-7dfccc8c-ed185b23.js.map +0 -1
- package/cjs/groupChannel-76c0795e.js +0 -9
- package/cjs/groupChannel-76c0795e.js.map +0 -1
- package/cjs/index-639e3f2f.js.map +0 -1
- package/cjs/openChannel-1e92ad1c.js +0 -5251
- package/cjs/openChannel-1e92ad1c.js.map +0 -1
- package/cjs/stringSet-9b12d465.js.map +0 -1
- package/groupChannel-cc9fae2b.js.map +0 -1
- package/index-2a105a6a.js.map +0 -1
- package/openChannel-15b0616c.js +0 -5246
- package/openChannel-15b0616c.js.map +0 -1
- package/package-lock.json +0 -26318
- package/stringSet-7a28664f.js.map +0 -1
|
@@ -4,15 +4,15 @@ var React = require('react');
|
|
|
4
4
|
var ui_Avatar = require('./Avatar.js');
|
|
5
5
|
var ui_Icon = require('./Icon.js');
|
|
6
6
|
var ui_IconButton = require('./IconButton.js');
|
|
7
|
-
var ui_Label = require('../index-
|
|
8
|
-
var LocalizationContext = require('../LocalizationContext-
|
|
9
|
-
require('../tslib.es6-
|
|
7
|
+
var ui_Label = require('../index-6b7d2465.js');
|
|
8
|
+
var LocalizationContext = require('../LocalizationContext-672b9c94.js');
|
|
9
|
+
require('../tslib.es6-306f32fb.js');
|
|
10
10
|
require('./ImageRenderer.js');
|
|
11
|
-
require('../_rollupPluginBabelHelpers-
|
|
11
|
+
require('../_rollupPluginBabelHelpers-f02175f2.js');
|
|
12
12
|
require('prop-types');
|
|
13
|
-
require('../uuid-
|
|
14
|
-
require('../stringSet-
|
|
15
|
-
require('../index-
|
|
13
|
+
require('../uuid-deaf6e4d.js');
|
|
14
|
+
require('../stringSet-da3df562.js');
|
|
15
|
+
require('../index-1a2c6bb9.js');
|
|
16
16
|
|
|
17
17
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
18
18
|
|
|
@@ -1,34 +1,34 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var tslib_es6 = require('../tslib.es6-
|
|
3
|
+
var tslib_es6 = require('../tslib.es6-306f32fb.js');
|
|
4
4
|
var React = require('react');
|
|
5
|
-
var index = require('../index-
|
|
5
|
+
var index = require('../index-93b2249a.js');
|
|
6
6
|
var ui_Avatar = require('./Avatar.js');
|
|
7
7
|
var ui_ContextMenu = require('./ContextMenu.js');
|
|
8
|
-
var ui_Label = require('../index-
|
|
8
|
+
var ui_Label = require('../index-6b7d2465.js');
|
|
9
9
|
var ui_Loader = require('./Loader.js');
|
|
10
10
|
var ui_Icon = require('./Icon.js');
|
|
11
11
|
var ui_IconButton = require('./IconButton.js');
|
|
12
12
|
var ui_TextButton = require('./TextButton.js');
|
|
13
13
|
var ui_UserProfile = require('./UserProfile.js');
|
|
14
|
-
var UserProfileContext = require('../UserProfileContext-
|
|
15
|
-
var LocalizationContext = require('../LocalizationContext-
|
|
16
|
-
var openChannelUtils = require('../openChannelUtils-
|
|
17
|
-
require('../index-
|
|
14
|
+
var UserProfileContext = require('../UserProfileContext-d3290c6a.js');
|
|
15
|
+
var LocalizationContext = require('../LocalizationContext-672b9c94.js');
|
|
16
|
+
var openChannelUtils = require('../openChannelUtils-b411bbf8.js');
|
|
17
|
+
require('../index-1a2c6bb9.js');
|
|
18
18
|
require('./ImageRenderer.js');
|
|
19
|
-
require('../_rollupPluginBabelHelpers-
|
|
19
|
+
require('../_rollupPluginBabelHelpers-f02175f2.js');
|
|
20
20
|
require('prop-types');
|
|
21
|
-
require('../uuid-
|
|
22
|
-
require('../index-
|
|
21
|
+
require('../uuid-deaf6e4d.js');
|
|
22
|
+
require('../index-3b9eca88.js');
|
|
23
23
|
require('react-dom');
|
|
24
24
|
require('./SortByRow.js');
|
|
25
|
-
require('../stringSet-
|
|
26
|
-
require('../color-
|
|
25
|
+
require('../stringSet-da3df562.js');
|
|
26
|
+
require('../color-478c93f8.js');
|
|
27
27
|
require('../withSendbird.js');
|
|
28
28
|
require('../sendbirdSelectors.js');
|
|
29
|
-
require('../topics-
|
|
30
|
-
require('../utils-
|
|
31
|
-
require('../index-
|
|
29
|
+
require('../topics-1932f321.js');
|
|
30
|
+
require('../utils-15fd96e3.js');
|
|
31
|
+
require('../index-52186645.js');
|
|
32
32
|
|
|
33
33
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
34
34
|
|
|
@@ -62,6 +62,7 @@ var truncate = function truncate(fullStr, strLen) {
|
|
|
62
62
|
function OpenchannelFileMessage(_a) {
|
|
63
63
|
var className = _a.className,
|
|
64
64
|
message = _a.message,
|
|
65
|
+
isOperator = _a.isOperator,
|
|
65
66
|
userId = _a.userId,
|
|
66
67
|
disabled = _a.disabled,
|
|
67
68
|
chainTop = _a.chainTop,
|
|
@@ -84,7 +85,6 @@ function OpenchannelFileMessage(_a) {
|
|
|
84
85
|
window.open(message.url);
|
|
85
86
|
};
|
|
86
87
|
|
|
87
|
-
var isByMe = openChannelUtils.checkIsByMe(message, userId);
|
|
88
88
|
var isPending = openChannelUtils.checkIsPending(status);
|
|
89
89
|
var isFailed = openChannelUtils.checkIsFailed(status);
|
|
90
90
|
var sender = openChannelUtils.getSenderFromMessage(message);
|
|
@@ -132,7 +132,7 @@ function OpenchannelFileMessage(_a) {
|
|
|
132
132
|
}, /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
|
|
133
133
|
className: "sendbird-openchannel-file-message__right__title__sender-name",
|
|
134
134
|
type: ui_Label.LabelTypography.CAPTION_2,
|
|
135
|
-
color:
|
|
135
|
+
color: isOperator ? ui_Label.LabelColors.SECONDARY_3 : ui_Label.LabelColors.ONBACKGROUND_2
|
|
136
136
|
}, sender && (sender.friendName || sender.nickname || sender.userId)), /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
|
|
137
137
|
className: "sendbird-openchannel-file-message__right__title__sent-at",
|
|
138
138
|
type: ui_Label.LabelTypography.CAPTION_3,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OpenchannelFileMessage.js","sources":["../../../src/ui/OpenchannelFileMessage/utils.ts","../../../src/ui/OpenchannelFileMessage/index.tsx"],"sourcesContent":["import { IconTypes } from '../Icon';\n\nexport const checkFileType = (fileUrl: string): string => {\n const audioFile = /(\\.mp3)$/i;\n const gifFile = /(\\.gif)$/i;\n if (audioFile.test(fileUrl)) {\n return IconTypes.FILE_AUDIO;\n }\n if (gifFile.test(fileUrl)) {\n return IconTypes.GIF\n }\n return IconTypes.FILE_DOCUMENT;\n}\n\nexport const truncate = (fullStr:string, strLen: number): string => {\n if (fullStr === null || fullStr === undefined) return '';\n if (fullStr.length <= strLen) return fullStr;\n const separator = '...';\n const sepLen = separator.length;\n const charsToShow = strLen - sepLen;\n const frontChars = Math.ceil(charsToShow / 2);\n const backChars = Math.floor(charsToShow / 2);\n return fullStr.substr(0, frontChars) + separator + fullStr.substr(fullStr.length - backChars);\n};\n","import React, { useContext, useRef } from 'react';\nimport { FileMessage } 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 Label, { LabelTypography, LabelColors } from '../Label';\nimport Loader from '../Loader';\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport IconButton from '../IconButton';\nimport TextButton from '../TextButton';\nimport UserProfile from '../UserProfile';\nimport { UserProfileContext } from '../../lib/UserProfileContext';\n\nimport { useLocalization } from '../../lib/LocalizationContext';\nimport { checkFileType, truncate } from './utils';\nimport {\n checkIsByMe,\n checkIsPending,\n checkIsFailed,\n isFineDelete,\n isFineResend,\n showMenuTrigger,\n} from '../../utils/openChannelUtils';\nimport { getSenderFromMessage } from '../../utils/openChannelUtils';\n\ninterface Props {\n className?: string | Array<string>;\n message: FileMessage;\n userId: string;\n disabled?: boolean;\n chainTop?: boolean;\n chainBottom?: boolean;\n showRemove(bool: boolean): void;\n resendMessage(message: FileMessage): void;\n}\n\nexport default function OpenchannelFileMessage({\n className,\n message,\n userId,\n disabled,\n chainTop,\n showRemove,\n resendMessage,\n}: Props): JSX.Element {\n const status = message?.sendingStatus;\n const { dateLocale, stringSet } = useLocalization();\n const contextMenuRef = useRef(null);\n const avatarRef = useRef(null);\n const { disableUserProfile, renderUserProfile } = useContext(UserProfileContext);\n\n const openFileUrl = () => { window.open(message.url); };\n\n const isByMe = checkIsByMe(message, userId);\n const isPending = checkIsPending(status);\n const isFailed = checkIsFailed(status);\n const sender = getSenderFromMessage(message);\n\n return (\n <div\n className={[\n ...(Array.isArray(className) ? className : [className]),\n 'sendbird-openchannel-file-message',\n ].join(' ')}\n >\n <div className=\"sendbird-openchannel-file-message__left\">\n {\n !chainTop && (\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n <Avatar\n className=\"sendbird-openchannel-file-message__left__avatar\"\n src={sender.profileUrl || ''}\n ref={avatarRef}\n width=\"28px\"\n height=\"28px\"\n onClick={() => {\n if (!disableUserProfile) {\n toggleDropdown();\n }\n }}\n />\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={avatarRef}\n parentContainRef={avatarRef}\n closeDropdown={closeDropdown}\n style={{ paddingTop: 0, paddingBottom: 0 }}\n >\n {\n renderUserProfile\n ? (\n renderUserProfile({\n user: sender,\n close: closeDropdown,\n })\n )\n : (\n <UserProfile\n user={sender}\n onSuccess={closeDropdown}\n disableMessaging\n />\n )\n }\n </MenuItems>\n )}\n />\n )\n }\n </div>\n <div className=\"sendbird-openchannel-file-message__right\">\n {\n !chainTop && (\n <div className=\"sendbird-openchannel-file-message__right__title\">\n <Label\n className=\"sendbird-openchannel-file-message__right__title__sender-name\"\n type={LabelTypography.CAPTION_2}\n color={isByMe ? LabelColors.SECONDARY_3 : LabelColors.ONBACKGROUND_2}\n >\n {\n sender && (\n sender.friendName\n || sender.nickname\n || sender.userId\n )\n }\n </Label>\n <Label\n className=\"sendbird-openchannel-file-message__right__title__sent-at\"\n type={LabelTypography.CAPTION_3}\n color={LabelColors.ONBACKGROUND_3}\n >\n {\n message?.createdAt && (\n format(message.createdAt, 'p', {\n locale: dateLocale,\n })\n )\n }\n </Label>\n </div>\n )\n }\n <div className=\"sendbird-openchannel-file-message__right__body\">\n {\n checkFileType(message.url) && (\n <Icon\n className=\"sendbird-openchannel-file-message__right__body__icon\"\n type={checkFileType(message.url)}\n fillColor={IconColors.PRIMARY}\n width=\"48px\"\n height=\"48px\"\n />\n )\n }\n <TextButton\n className=\"sendbird-openchannel-file-message__right__body__file-name\"\n onClick={openFileUrl}\n >\n <Label\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_1}\n >\n {truncate(message.name || message.url, 40)}\n </Label>\n </TextButton>\n </div>\n {\n (isPending || isFailed) && (\n <div className=\"sendbird-openchannel-file-message__right__tail\">\n {\n isPending && (\n <Loader\n width=\"16px\"\n height=\"16px\"\n >\n <Icon\n className=\"sendbird-openchannel-file-message__right__tail__pending\"\n type={IconTypes.SPINNER}\n fillColor={IconColors.PRIMARY}\n width=\"16px\"\n height=\"16px\"\n />\n </Loader>\n )\n }\n {\n isFailed && (\n <Icon\n className=\"sendbird-openchannel-file-message__right__tail__failed\"\n type={IconTypes.ERROR}\n fillColor={IconColors.ERROR}\n width=\"16px\"\n height=\"16px\"\n />\n )\n }\n </div>\n )\n }\n </div>\n <div\n className=\"sendbird-openchannel-file-message__context-menu\"\n ref={contextMenuRef}\n >\n {\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n showMenuTrigger({ message, userId, status }) && (\n <IconButton\n className=\"sendbird-openchannel-file-message__context-menu__icon\"\n width=\"32px\"\n height=\"32px\"\n onClick={toggleDropdown}\n >\n <Icon\n type={IconTypes.MORE}\n width=\"24px\"\n height=\"24px\"\n />\n </IconButton>\n )\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={contextMenuRef}\n parentContainRef={contextMenuRef}\n closeDropdown={closeDropdown}\n openLeft\n >\n {\n isFineResend({ message, userId, status }) && (\n <MenuItem\n onClick={() => {\n if (disabled) { return; }\n resendMessage(message);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__RESEND}\n </MenuItem>\n )\n }\n {\n isFineDelete({ message, userId, status }) && (\n <MenuItem\n onClick={() => {\n if (disabled) { return; }\n showRemove(true);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__DELETE}\n </MenuItem>\n )\n }\n </MenuItems>\n )}\n />\n }\n </div>\n </div>\n );\n}\n"],"names":["checkFileType","fileUrl","audioFile","gifFile","test","IconTypes","FILE_AUDIO","GIF","FILE_DOCUMENT","truncate","fullStr","strLen","undefined","length","separator","sepLen","charsToShow","frontChars","Math","ceil","backChars","floor","substr","OpenchannelFileMessage","_a","className","message","userId","disabled","chainTop","showRemove","resendMessage","status","sendingStatus","_b","useLocalization","dateLocale","stringSet","contextMenuRef","useRef","avatarRef","_c","useContext","UserProfileContext","disableUserProfile","renderUserProfile","openFileUrl","window","open","url","isByMe","checkIsByMe","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","React","__spreadArray","Array","isArray","join","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","Icon","IconColors","PRIMARY","TextButton","BODY_1","ONBACKGROUND_1","name","Loader","SPINNER","ERROR","showMenuTrigger","IconButton","MORE","isFineResend","MenuItem","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEO,IAAMA,aAAa,GAAG,SAAhBA,aAAgB,CAACC,OAAD;AAC3B,MAAMC,SAAS,GAAG,WAAlB;AACA,MAAMC,OAAO,GAAG,WAAhB;;AACA,MAAID,SAAS,CAACE,IAAV,CAAeH,OAAf,CAAJ,EAA6B;AAC3B,WAAOI,iBAAS,CAACC,UAAjB;AACD;;AACD,MAAIH,OAAO,CAACC,IAAR,CAAaH,OAAb,CAAJ,EAA2B;AACzB,WAAOI,iBAAS,CAACE,GAAjB;AACD;;AACD,SAAOF,iBAAS,CAACG,aAAjB;AACD,CAVM;AAYA,IAAMC,QAAQ,GAAG,SAAXA,QAAW,CAACC,OAAD,EAAiBC,MAAjB;AACtB,MAAID,OAAO,KAAK,IAAZ,IAAoBA,OAAO,KAAKE,SAApC,EAA+C,OAAO,EAAP;AAC/C,MAAIF,OAAO,CAACG,MAAR,IAAkBF,MAAtB,EAA8B,OAAOD,OAAP;AAC9B,MAAMI,SAAS,GAAG,KAAlB;AACA,MAAMC,MAAM,GAAGD,SAAS,CAACD,MAAzB;AACA,MAAMG,WAAW,GAAGL,MAAM,GAAGI,MAA7B;AACA,MAAME,UAAU,GAAGC,IAAI,CAACC,IAAL,CAAUH,WAAW,GAAG,CAAxB,CAAnB;AACA,MAAMI,SAAS,GAAGF,IAAI,CAACG,KAAL,CAAWL,WAAW,GAAG,CAAzB,CAAlB;AACA,SAAON,OAAO,CAACY,MAAR,CAAe,CAAf,EAAkBL,UAAlB,IAAgCH,SAAhC,GAA4CJ,OAAO,CAACY,MAAR,CAAeZ,OAAO,CAACG,MAAR,GAAiBO,SAAhC,CAAnD;AACD,CATM;;SCwBiBG,uBAAuBC;MAC7CC,SAAS;MACTC,OAAO;MACPC,MAAM;MACNC,QAAQ;MACRC,QAAQ;MACRC,UAAU;MACVC,aAAa;AAEb,MAAMC,MAAM,GAAGN,OAAO,SAAP,IAAAA,OAAO,WAAP,SAAA,GAAAA,OAAO,CAAEO,aAAxB;;AACM,MAAAC,KAA4BC,mCAAe,EAA3C;AAAA,MAAEC,UAAU,gBAAZ;AAAA,MAAcC,SAAS,eAAvB;;AACN,MAAMC,cAAc,GAAGC,YAAM,CAAC,IAAD,CAA7B;AACA,MAAMC,SAAS,GAAGD,YAAM,CAAC,IAAD,CAAxB;;AACM,MAAAE,KAA4CC,gBAAU,CAACC,qCAAD,CAAtD;AAAA,MAAEC,kBAAkB,wBAApB;AAAA,MAAsBC,iBAAiB,uBAAvC;;AAEN,MAAMC,WAAW,GAAG,SAAdA,WAAc;AAAQC,IAAAA,MAAM,CAACC,IAAP,CAAYtB,OAAO,CAACuB,GAApB;AAA2B,GAAvD;;AAEA,MAAMC,MAAM,GAAGC,4BAAW,CAACzB,OAAD,EAAUC,MAAV,CAA1B;AACA,MAAMyB,SAAS,GAAGC,+BAAc,CAACrB,MAAD,CAAhC;AACA,MAAMsB,QAAQ,GAAGC,8BAAa,CAACvB,MAAD,CAA9B;AACA,MAAMwB,MAAM,GAAGC,qCAAoB,CAAC/B,OAAD,CAAnC;AAEA,sBACEgC;AACE,IAAA,SAAS,EAAEC,oDACLC,KAAK,CAACC,OAAN,CAAcpC,SAAd,IAA2BA,SAA3B,GAAuC,CAACA,SAAD,WAC3C,4CAFS,CAGTqC,IAHS,CAGJ,GAHI;AADb,kBAMEJ;AAAK,IAAA,SAAS,EAAC;AAAf,KAEM,CAAC7B,QAAD,iBACE6B,wCAACK,yBAAD;AACE,IAAA,WAAW,EAAE,qBAACC,cAAD;AAAoB,0BAC/BN,wCAACO,oBAAD;AACE,QAAA,SAAS,EAAC,iDADZ;AAEE,QAAA,GAAG,EAAET,MAAM,CAACU,UAAP,IAAqB,EAF5B;AAGE,QAAA,GAAG,EAAE1B,SAHP;AAIE,QAAA,KAAK,EAAC,MAJR;AAKE,QAAA,MAAM,EAAC,MALT;AAME,QAAA,OAAO,EAAE;AACP,cAAI,CAACI,kBAAL,EAAyB;AACvBoB,YAAAA,cAAc;AACf;AACF;AAVH,QAD+B;AAahC,KAdH;AAeE,IAAA,SAAS,EAAE,mBAACG,aAAD;AAAmB,0BAC5BT,wCAACU,wBAAD;AACE,QAAA,SAAS,EAAE5B,SADb;AAEE,QAAA,gBAAgB,EAAEA,SAFpB;AAGE,QAAA,aAAa,EAAE2B,aAHjB;AAIE,QAAA,KAAK,EAAE;AAAEE,UAAAA,UAAU,EAAE,CAAd;AAAiBC,UAAAA,aAAa,EAAE;AAAhC;AAJT,SAOIzB,iBAAiB,GAEfA,iBAAiB,CAAC;AAChB0B,QAAAA,IAAI,EAAEf,MADU;AAEhBgB,QAAAA,KAAK,EAAEL;AAFS,OAAD,CAFF,gBAQfT,wCAACe,cAAD;AACE,QAAA,IAAI,EAAEjB,MADR;AAEE,QAAA,SAAS,EAAEW,aAFb;AAGE,QAAA,gBAAgB;AAHlB,QAfN,CAD4B;AAwB7B;AAvCH,IAHR,CANF,eAqDET;AAAK,IAAA,SAAS,EAAC;AAAf,KAEI,CAAC7B,QAAD,iBACE6B;AAAK,IAAA,SAAS,EAAC;AAAf,kBACEA,wCAACgB,cAAD;AACE,IAAA,SAAS,EAAC,8DADZ;AAEE,IAAA,IAAI,EAAEC,wBAAe,CAACC,SAFxB;AAGE,IAAA,KAAK,EAAE1B,MAAM,GAAG2B,oBAAW,CAACC,WAAf,GAA6BD,oBAAW,CAACE;AAHxD,KAMIvB,MAAM,KACJA,MAAM,CAACwB,UAAP,IACGxB,MAAM,CAACyB,QADV,IAEGzB,MAAM,CAAC7B,MAHN,CANV,CADF,eAcE+B,wCAACgB,cAAD;AACE,IAAA,SAAS,EAAC,0DADZ;AAEE,IAAA,IAAI,EAAEC,wBAAe,CAACO,SAFxB;AAGE,IAAA,KAAK,EAAEL,oBAAW,CAACM;AAHrB,KAMI,CAAAzD,OAAO,SAAP,IAAAA,OAAO,WAAP,SAAA,GAAAA,OAAO,CAAE0D,SAAT,KACEC,YAAM,CAAC3D,OAAO,CAAC0D,SAAT,EAAoB,GAApB,EAAyB;AAC7BE,IAAAA,MAAM,EAAElD;AADqB,GAAzB,CAPZ,CAdF,CAHN,eAiCEsB;AAAK,IAAA,SAAS,EAAC;AAAf,KAEI1D,aAAa,CAAC0B,OAAO,CAACuB,GAAT,CAAb,iBACES,wCAAC6B,kBAAD;AACE,IAAA,SAAS,EAAC,sDADZ;AAEE,IAAA,IAAI,EAAEvF,aAAa,CAAC0B,OAAO,CAACuB,GAAT,CAFrB;AAGE,IAAA,SAAS,EAAEuC,kBAAU,CAACC,OAHxB;AAIE,IAAA,KAAK,EAAC,MAJR;AAKE,IAAA,MAAM,EAAC;AALT,IAHN,eAYE/B,wCAACgC,aAAD;AACE,IAAA,SAAS,EAAC,2DADZ;AAEE,IAAA,OAAO,EAAE5C;AAFX,kBAIEY,wCAACgB,cAAD;AACE,IAAA,IAAI,EAAEC,wBAAe,CAACgB,MADxB;AAEE,IAAA,KAAK,EAAEd,oBAAW,CAACe;AAFrB,KAIGnF,QAAQ,CAACiB,OAAO,CAACmE,IAAR,IAAgBnE,OAAO,CAACuB,GAAzB,EAA8B,EAA9B,CAJX,CAJF,CAZF,CAjCF,EA0DI,CAACG,SAAS,IAAIE,QAAd,kBACEI;AAAK,IAAA,SAAS,EAAC;AAAf,KAEIN,SAAS,iBACPM,wCAACoC,SAAD;AACE,IAAA,KAAK,EAAC,MADR;AAEE,IAAA,MAAM,EAAC;AAFT,kBAIEpC,wCAAC6B,kBAAD;AACE,IAAA,SAAS,EAAC,yDADZ;AAEE,IAAA,IAAI,EAAElF,iBAAS,CAAC0F,OAFlB;AAGE,IAAA,SAAS,EAAEP,kBAAU,CAACC,OAHxB;AAIE,IAAA,KAAK,EAAC,MAJR;AAKE,IAAA,MAAM,EAAC;AALT,IAJF,CAHN,EAkBInC,QAAQ,iBACNI,wCAAC6B,kBAAD;AACE,IAAA,SAAS,EAAC,wDADZ;AAEE,IAAA,IAAI,EAAElF,iBAAS,CAAC2F,KAFlB;AAGE,IAAA,SAAS,EAAER,kBAAU,CAACQ,KAHxB;AAIE,IAAA,KAAK,EAAC,MAJR;AAKE,IAAA,MAAM,EAAC;AALT,IAnBN,CA3DN,CArDF,eAgJEtC;AACE,IAAA,SAAS,EAAC,iDADZ;AAEE,IAAA,GAAG,EAAEpB;AAFP,kBAKMoB,wCAACK,yBAAD;AACE,IAAA,WAAW,EAAE,qBAACC,cAAD;AAAoB,aAC/BiC,gCAAe,CAAC;AAAEvE,QAAAA,OAAO,SAAT;AAAWC,QAAAA,MAAM,QAAjB;AAAmBK,QAAAA,MAAM;AAAzB,OAAD,CAAf,iBACE0B,wCAACwC,aAAD;AACE,QAAA,SAAS,EAAC,uDADZ;AAEE,QAAA,KAAK,EAAC,MAFR;AAGE,QAAA,MAAM,EAAC,MAHT;AAIE,QAAA,OAAO,EAAElC;AAJX,sBAMEN,wCAAC6B,kBAAD;AACE,QAAA,IAAI,EAAElF,iBAAS,CAAC8F,IADlB;AAEE,QAAA,KAAK,EAAC,MAFR;AAGE,QAAA,MAAM,EAAC;AAHT,QANF,CAF6B;AAehC,KAhBH;AAiBE,IAAA,SAAS,EAAE,mBAAChC,aAAD;AAAmB,0BAC5BT,wCAACU,wBAAD;AACE,QAAA,SAAS,EAAE9B,cADb;AAEE,QAAA,gBAAgB,EAAEA,cAFpB;AAGE,QAAA,aAAa,EAAE6B,aAHjB;AAIE,QAAA,QAAQ;AAJV,SAOIiC,6BAAY,CAAC;AAAE1E,QAAAA,OAAO,SAAT;AAAWC,QAAAA,MAAM,QAAjB;AAAmBK,QAAAA,MAAM;AAAzB,OAAD,CAAZ,iBACE0B,wCAAC2C,uBAAD;AACE,QAAA,OAAO,EAAE;AACP,cAAIzE,QAAJ,EAAc;AAAE;AAAS;;AACzBG,UAAAA,aAAa,CAACL,OAAD,CAAb;AACAyC,UAAAA,aAAa;AACd;AALH,SAOG9B,SAAS,CAACiE,6BAPb,CARN,EAoBIC,6BAAY,CAAC;AAAE7E,QAAAA,OAAO,SAAT;AAAWC,QAAAA,MAAM,QAAjB;AAAmBK,QAAAA,MAAM;AAAzB,OAAD,CAAZ,iBACE0B,wCAAC2C,uBAAD;AACE,QAAA,OAAO,EAAE;AACP,cAAIzE,QAAJ,EAAc;AAAE;AAAS;;AACzBE,UAAAA,UAAU,CAAC,IAAD,CAAV;AACAqC,UAAAA,aAAa;AACd;AALH,SAOG9B,SAAS,CAACmE,6BAPb,CArBN,CAD4B;AAkC7B;AAnDH,IALN,CAhJF,CADF;AA+MD;;;;"}
|
|
1
|
+
{"version":3,"file":"OpenchannelFileMessage.js","sources":["../../../src/ui/OpenchannelFileMessage/utils.ts","../../../src/ui/OpenchannelFileMessage/index.tsx"],"sourcesContent":["import { IconTypes } from '../Icon';\n\nexport const checkFileType = (fileUrl: string): string => {\n const audioFile = /(\\.mp3)$/i;\n const gifFile = /(\\.gif)$/i;\n if (audioFile.test(fileUrl)) {\n return IconTypes.FILE_AUDIO;\n }\n if (gifFile.test(fileUrl)) {\n return IconTypes.GIF\n }\n return IconTypes.FILE_DOCUMENT;\n}\n\nexport const truncate = (fullStr:string, strLen: number): string => {\n if (fullStr === null || fullStr === undefined) return '';\n if (fullStr.length <= strLen) return fullStr;\n const separator = '...';\n const sepLen = separator.length;\n const charsToShow = strLen - sepLen;\n const frontChars = Math.ceil(charsToShow / 2);\n const backChars = Math.floor(charsToShow / 2);\n return fullStr.substr(0, frontChars) + separator + fullStr.substr(fullStr.length - backChars);\n};\n","import React, { useContext, useRef } from 'react';\nimport { FileMessage } 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 Label, { LabelTypography, LabelColors } from '../Label';\nimport Loader from '../Loader';\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport IconButton from '../IconButton';\nimport TextButton from '../TextButton';\nimport UserProfile from '../UserProfile';\nimport { UserProfileContext } from '../../lib/UserProfileContext';\n\nimport { useLocalization } from '../../lib/LocalizationContext';\nimport { checkFileType, truncate } from './utils';\nimport {\n checkIsPending,\n checkIsFailed,\n isFineDelete,\n isFineResend,\n showMenuTrigger,\n} from '../../utils/openChannelUtils';\nimport { getSenderFromMessage } from '../../utils/openChannelUtils';\n\ninterface Props {\n className?: string | Array<string>;\n message: FileMessage;\n isOperator?: boolean;\n userId: string;\n disabled?: boolean;\n chainTop?: boolean;\n chainBottom?: boolean;\n showRemove(bool: boolean): void;\n resendMessage(message: FileMessage): void;\n}\n\nexport default function OpenchannelFileMessage({\n className,\n message,\n isOperator,\n userId,\n disabled,\n chainTop,\n showRemove,\n resendMessage,\n}: Props): JSX.Element {\n const status = message?.sendingStatus;\n const { dateLocale, stringSet } = useLocalization();\n const contextMenuRef = useRef(null);\n const avatarRef = useRef(null);\n const { disableUserProfile, renderUserProfile } = useContext(UserProfileContext);\n\n const openFileUrl = () => { window.open(message.url); };\n\n const isPending = checkIsPending(status);\n const isFailed = checkIsFailed(status);\n const sender = getSenderFromMessage(message);\n\n return (\n <div\n className={[\n ...(Array.isArray(className) ? className : [className]),\n 'sendbird-openchannel-file-message',\n ].join(' ')}\n >\n <div className=\"sendbird-openchannel-file-message__left\">\n {\n !chainTop && (\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n <Avatar\n className=\"sendbird-openchannel-file-message__left__avatar\"\n src={sender.profileUrl || ''}\n ref={avatarRef}\n width=\"28px\"\n height=\"28px\"\n onClick={() => {\n if (!disableUserProfile) {\n toggleDropdown();\n }\n }}\n />\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={avatarRef}\n parentContainRef={avatarRef}\n closeDropdown={closeDropdown}\n style={{ paddingTop: 0, paddingBottom: 0 }}\n >\n {\n renderUserProfile\n ? (\n renderUserProfile({\n user: sender,\n close: closeDropdown,\n })\n )\n : (\n <UserProfile\n user={sender}\n onSuccess={closeDropdown}\n disableMessaging\n />\n )\n }\n </MenuItems>\n )}\n />\n )\n }\n </div>\n <div className=\"sendbird-openchannel-file-message__right\">\n {\n !chainTop && (\n <div className=\"sendbird-openchannel-file-message__right__title\">\n <Label\n className=\"sendbird-openchannel-file-message__right__title__sender-name\"\n type={LabelTypography.CAPTION_2}\n color={isOperator ? LabelColors.SECONDARY_3 : LabelColors.ONBACKGROUND_2}\n >\n {\n sender && (\n sender.friendName\n || sender.nickname\n || sender.userId\n )\n }\n </Label>\n <Label\n className=\"sendbird-openchannel-file-message__right__title__sent-at\"\n type={LabelTypography.CAPTION_3}\n color={LabelColors.ONBACKGROUND_3}\n >\n {\n message?.createdAt && (\n format(message.createdAt, 'p', {\n locale: dateLocale,\n })\n )\n }\n </Label>\n </div>\n )\n }\n <div className=\"sendbird-openchannel-file-message__right__body\">\n {\n checkFileType(message.url) && (\n <Icon\n className=\"sendbird-openchannel-file-message__right__body__icon\"\n type={checkFileType(message.url)}\n fillColor={IconColors.PRIMARY}\n width=\"48px\"\n height=\"48px\"\n />\n )\n }\n <TextButton\n className=\"sendbird-openchannel-file-message__right__body__file-name\"\n onClick={openFileUrl}\n >\n <Label\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_1}\n >\n {truncate(message.name || message.url, 40)}\n </Label>\n </TextButton>\n </div>\n {\n (isPending || isFailed) && (\n <div className=\"sendbird-openchannel-file-message__right__tail\">\n {\n isPending && (\n <Loader\n width=\"16px\"\n height=\"16px\"\n >\n <Icon\n className=\"sendbird-openchannel-file-message__right__tail__pending\"\n type={IconTypes.SPINNER}\n fillColor={IconColors.PRIMARY}\n width=\"16px\"\n height=\"16px\"\n />\n </Loader>\n )\n }\n {\n isFailed && (\n <Icon\n className=\"sendbird-openchannel-file-message__right__tail__failed\"\n type={IconTypes.ERROR}\n fillColor={IconColors.ERROR}\n width=\"16px\"\n height=\"16px\"\n />\n )\n }\n </div>\n )\n }\n </div>\n <div\n className=\"sendbird-openchannel-file-message__context-menu\"\n ref={contextMenuRef}\n >\n {\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n showMenuTrigger({ message, userId, status }) && (\n <IconButton\n className=\"sendbird-openchannel-file-message__context-menu__icon\"\n width=\"32px\"\n height=\"32px\"\n onClick={toggleDropdown}\n >\n <Icon\n type={IconTypes.MORE}\n width=\"24px\"\n height=\"24px\"\n />\n </IconButton>\n )\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={contextMenuRef}\n parentContainRef={contextMenuRef}\n closeDropdown={closeDropdown}\n openLeft\n >\n {\n isFineResend({ message, userId, status }) && (\n <MenuItem\n onClick={() => {\n if (disabled) { return; }\n resendMessage(message);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__RESEND}\n </MenuItem>\n )\n }\n {\n isFineDelete({ message, userId, status }) && (\n <MenuItem\n onClick={() => {\n if (disabled) { return; }\n showRemove(true);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__DELETE}\n </MenuItem>\n )\n }\n </MenuItems>\n )}\n />\n }\n </div>\n </div>\n );\n}\n"],"names":["checkFileType","fileUrl","audioFile","gifFile","test","IconTypes","FILE_AUDIO","GIF","FILE_DOCUMENT","truncate","fullStr","strLen","undefined","length","separator","sepLen","charsToShow","frontChars","Math","ceil","backChars","floor","substr","OpenchannelFileMessage","_a","className","message","isOperator","userId","disabled","chainTop","showRemove","resendMessage","status","sendingStatus","_b","useLocalization","dateLocale","stringSet","contextMenuRef","useRef","avatarRef","_c","useContext","UserProfileContext","disableUserProfile","renderUserProfile","openFileUrl","window","open","url","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","React","__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","Icon","IconColors","PRIMARY","TextButton","BODY_1","ONBACKGROUND_1","name","Loader","SPINNER","ERROR","showMenuTrigger","IconButton","MORE","isFineResend","MenuItem","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE"],"mappings":"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"}
|
|
@@ -1,34 +1,34 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var tslib_es6 = require('../tslib.es6-
|
|
3
|
+
var tslib_es6 = require('../tslib.es6-306f32fb.js');
|
|
4
4
|
var React = require('react');
|
|
5
|
-
var index = require('../index-
|
|
5
|
+
var index = require('../index-93b2249a.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
10
|
var ui_ImageRenderer = require('./ImageRenderer.js');
|
|
11
11
|
var ui_LinkLabel = require('./LinkLabel.js');
|
|
12
|
-
var ui_Label = require('../index-
|
|
12
|
+
var ui_Label = require('../index-6b7d2465.js');
|
|
13
13
|
var ui_Loader = require('./Loader.js');
|
|
14
14
|
var ui_UserProfile = require('./UserProfile.js');
|
|
15
|
-
var UserProfileContext = require('../UserProfileContext-
|
|
16
|
-
var uuid = require('../uuid-
|
|
17
|
-
var utils = require('../utils-
|
|
18
|
-
var LocalizationContext = require('../LocalizationContext-
|
|
19
|
-
var openChannelUtils = require('../openChannelUtils-
|
|
20
|
-
require('../index-
|
|
21
|
-
require('../_rollupPluginBabelHelpers-
|
|
15
|
+
var UserProfileContext = require('../UserProfileContext-d3290c6a.js');
|
|
16
|
+
var uuid = require('../uuid-deaf6e4d.js');
|
|
17
|
+
var utils = require('../utils-d06dfceb.js');
|
|
18
|
+
var LocalizationContext = require('../LocalizationContext-672b9c94.js');
|
|
19
|
+
var openChannelUtils = require('../openChannelUtils-b411bbf8.js');
|
|
20
|
+
require('../index-1a2c6bb9.js');
|
|
21
|
+
require('../_rollupPluginBabelHelpers-f02175f2.js');
|
|
22
22
|
require('prop-types');
|
|
23
|
-
require('../index-
|
|
23
|
+
require('../index-3b9eca88.js');
|
|
24
24
|
require('react-dom');
|
|
25
25
|
require('./SortByRow.js');
|
|
26
|
-
require('../stringSet-
|
|
26
|
+
require('../stringSet-da3df562.js');
|
|
27
27
|
require('../withSendbird.js');
|
|
28
28
|
require('../sendbirdSelectors.js');
|
|
29
|
-
require('../topics-
|
|
30
|
-
require('../utils-
|
|
31
|
-
require('../index-
|
|
29
|
+
require('../topics-1932f321.js');
|
|
30
|
+
require('../utils-15fd96e3.js');
|
|
31
|
+
require('../index-52186645.js');
|
|
32
32
|
|
|
33
33
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
34
34
|
|
|
@@ -58,6 +58,7 @@ var checkOGIsEnalbed = function checkOGIsEnalbed(message) {
|
|
|
58
58
|
|
|
59
59
|
function OpenchannelOGMessage(_a) {
|
|
60
60
|
var message = _a.message,
|
|
61
|
+
isOperator = _a.isOperator,
|
|
61
62
|
className = _a.className,
|
|
62
63
|
disabled = _a.disabled,
|
|
63
64
|
showEdit = _a.showEdit,
|
|
@@ -90,7 +91,6 @@ function OpenchannelOGMessage(_a) {
|
|
|
90
91
|
var contextMenuRef = React.useRef(null);
|
|
91
92
|
var avatarRef = React.useRef(null);
|
|
92
93
|
var isUrl = createUrlTester(URL_REG);
|
|
93
|
-
var isByMe = openChannelUtils.checkIsByMe(message, userId);
|
|
94
94
|
var isPending = openChannelUtils.checkIsPending(status);
|
|
95
95
|
var isFailed = openChannelUtils.checkIsFailed(status);
|
|
96
96
|
var sender = openChannelUtils.getSenderFromMessage(message);
|
|
@@ -194,7 +194,7 @@ function OpenchannelOGMessage(_a) {
|
|
|
194
194
|
}, /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
|
|
195
195
|
className: "sendbird-openchannel-og-message__top__right__title__sender-name",
|
|
196
196
|
type: ui_Label.LabelTypography.CAPTION_2,
|
|
197
|
-
color:
|
|
197
|
+
color: isOperator ? ui_Label.LabelColors.SECONDARY_3 : ui_Label.LabelColors.ONBACKGROUND_2
|
|
198
198
|
}, sender && (sender.friendName || sender.nickname || sender.userId)), /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
|
|
199
199
|
className: "sendbird-openchannel-og-message__top__right__title__sent-at",
|
|
200
200
|
type: ui_Label.LabelTypography.CAPTION_3,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"OpenchannelOGMessage.js","sources":["../../../src/ui/OpenchannelOGMessage/utils.ts","../../../src/ui/OpenchannelOGMessage/index.tsx"],"sourcesContent":["import type { UserMessage } from \"@sendbird/chat/message\";\n\nexport const URL_REG = /[-a-zA-Z0-9@:%._+~#=]{1,256}\\.[a-zA-Z0-9()]{1,6}\\b([-a-zA-Z0-9()@:%_+.~#?&//=]*)/;\nexport const createUrlTester = (regexp: RegExp) => (text: string): boolean => regexp.test(text);\nexport const checkOGIsEnalbed = (message: UserMessage): boolean => {\n const { ogMetaData } = message;\n if (!ogMetaData) {\n return false;\n }\n const { url } = ogMetaData;\n if (!url) {\n return false;\n }\n return true;\n};\n","import React, { useState, useContext, useMemo, useRef, useEffect } from 'react';\nimport { UserMessage } from '@sendbird/chat/message';\nimport format from 'date-fns/format';\nimport './index.scss';\n\nimport Avatar from '../Avatar';\nimport ContextMenu, { MenuItems, MenuItem } from '../ContextMenu';\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport IconButton from '../IconButton';\nimport ImageRenderer from '../ImageRenderer';\nimport LinkLabel from '../LinkLabel';\nimport Label, { LabelTypography, LabelColors } from '../Label';\nimport Loader from '../Loader';\nimport UserProfile from '../UserProfile';\nimport { UserProfileContext } from '../../lib/UserProfileContext';\n\nimport uuidv4 from '../../utils/uuid';\nimport { copyToClipboard } from '../OpenchannelUserMessage/utils';\nimport { useLocalization } from '../../lib/LocalizationContext';\nimport { checkOGIsEnalbed, createUrlTester, URL_REG } from './utils';\nimport {\n checkIsByMe,\n checkIsPending,\n checkIsFailed,\n isFineCopy,\n isFineEdit,\n isFineResend,\n isFineDelete,\n showMenuTrigger,\n} from '../../utils/openChannelUtils';\nimport { getSenderFromMessage } from '../../utils/openChannelUtils';\n\ninterface Props {\n message: UserMessage;\n className?: string | Array<string>;\n disabled?: boolean;\n showEdit(bool: boolean): void;\n showRemove(bool: boolean): void;\n resendMessage(message: UserMessage): void;\n chainTop?: boolean;\n chainBottom?: boolean;\n userId: string;\n}\n\nexport default function OpenchannelOGMessage({\n message,\n className,\n disabled,\n showEdit,\n showRemove,\n resendMessage,\n chainTop,\n userId,\n}: Props): JSX.Element {\n if (!message || message.messageType !== 'user') {\n return null;\n }\n\n const status = message?.sendingStatus;\n const { ogMetaData } = message;\n const { defaultImage } = ogMetaData;\n\n const { stringSet, dateLocale } = useLocalization();\n const { disableUserProfile, renderUserProfile } = useContext(UserProfileContext);\n const [contextStyle, setContextStyle] = useState({});\n const messageComponentRef = useRef(null);\n const contextMenuRef = useRef(null);\n const avatarRef = useRef(null);\n\n const isUrl = createUrlTester(URL_REG);\n const isByMe = checkIsByMe(message, userId);\n const isPending = checkIsPending(status);\n const isFailed = checkIsFailed(status);\n const sender = getSenderFromMessage(message);\n\n const MemoizedMessageText = useMemo(() => () => {\n const wordClassName = 'sendbird-openchannel-og-message--word';\n const splitMessage = message.message.split(' ');\n const matchedMessage = splitMessage\n .map((word) => (\n isUrl(word)\n ? (\n <LinkLabel\n key={uuidv4()}\n className={[\n wordClassName,\n 'sendbird-openchannel-og-message--word--link'\n ]}\n src={word}\n type={LabelTypography.BODY_1}\n color={LabelColors.PRIMARY}\n >\n {word}\n </LinkLabel>\n )\n : (\n <Label\n key={uuidv4()}\n className={wordClassName}\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_1}\n >\n {word}\n </Label>\n )\n ));\n\n if (message.updatedAt > 0) {\n matchedMessage.push(\n <Label\n key={uuidv4()}\n className={wordClassName}\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_2}\n >\n {stringSet.MESSAGE_EDITED}\n </Label>,\n );\n }\n\n return matchedMessage;\n }, [message, message.updatedAt]);\n\n const openLink = () => {\n if (checkOGIsEnalbed(message)) {\n const { url } = ogMetaData;\n window.open(url);\n }\n };\n\n // place conxt menu top depending clientHeight of message component\n useEffect(() => {\n if (messageComponentRef?.current?.clientHeight > 36) {\n setContextStyle({ top: '8px ' });\n } else {\n setContextStyle({ top: '2px' });\n }\n }, [window.innerWidth]);\n\n return (\n <div\n className={[\n ...(Array.isArray(className) ? className : [className]),\n 'sendbird-openchannel-og-message',\n ].join(' ')}\n ref={messageComponentRef}\n >\n <div\n className=\"sendbird-openchannel-og-message__top\"\n >\n <div className=\"sendbird-openchannel-og-message__top__left\">\n {\n !chainTop && (\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n <Avatar\n className=\"sendbird-openchannel-og-message__top__left__avatar\"\n src={sender.profileUrl || ''}\n ref={avatarRef}\n width=\"28px\"\n height=\"28px\"\n onClick={() => {\n if (!disableUserProfile) {\n toggleDropdown();\n }\n }}\n />\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={avatarRef}\n parentContainRef={avatarRef}\n closeDropdown={closeDropdown}\n style={{ paddingTop: 0, paddingBottom: 0 }}\n >\n {\n renderUserProfile\n ? (\n renderUserProfile({\n user: sender,\n close: closeDropdown,\n })\n )\n : (\n <UserProfile\n user={sender}\n onSuccess={closeDropdown}\n disableMessaging\n />\n )\n }\n </MenuItems>\n )}\n />\n )\n }\n </div>\n <div className=\"sendbird-openchannel-og-message__top__right\">\n {\n !chainTop && (\n <div className=\"sendbird-openchannel-og-message__top__right__title\">\n <Label\n className=\"sendbird-openchannel-og-message__top__right__title__sender-name\"\n type={LabelTypography.CAPTION_2}\n color={isByMe ? LabelColors.SECONDARY_3 : LabelColors.ONBACKGROUND_2}\n >\n {\n sender && (\n sender.friendName\n || sender.nickname\n || sender.userId\n )\n }\n </Label>\n <Label\n className=\"sendbird-openchannel-og-message__top__right__title__sent-at\"\n type={LabelTypography.CAPTION_3}\n color={LabelColors.ONBACKGROUND_3}\n >\n {\n message?.createdAt && (\n format(message?.createdAt, 'p', {\n locale: dateLocale,\n })\n )\n }\n </Label>\n </div>\n )\n }\n <div className=\"sendbird-openchannel-og-message__top__right__description\">\n <Label\n className=\"sendbird-openchannel-og-message__top__right__description__message\"\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_1}\n >\n {MemoizedMessageText()}\n </Label>\n </div>\n </div>\n {\n <div\n className=\"sendbird-openchannel-og-message__top__context-menu\"\n ref={contextMenuRef}\n style={contextStyle}\n >\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n showMenuTrigger({ message: message, userId: userId, status: status }) && (\n <IconButton\n className=\"sendbird-openchannel-og-message__top__context-menu--icon\"\n width=\"32px\"\n height=\"32px\"\n onClick={() => {\n toggleDropdown();\n }}\n >\n <Icon\n type={IconTypes.MORE}\n fillColor={IconColors.CONTENT_INVERSE}\n width=\"24px\"\n height=\"24px\"\n />\n </IconButton>\n )\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={contextMenuRef}\n parentContainRef={contextMenuRef}\n closeDropdown={closeDropdown}\n openLeft\n >\n {\n isFineCopy({ message, userId, status }) && (\n <MenuItem\n className=\"sendbird-openchannel-og-message__top__context-menu__copy\"\n onClick={() => {\n copyToClipboard(message.message);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__COPY}\n </MenuItem>\n )\n }\n {\n isFineEdit({ message, userId, status }) && (\n <MenuItem\n className=\"sendbird-openchannel-og-message__top__context-menu__edit\"\n onClick={() => {\n if (disabled) {\n return;\n }\n showEdit(true);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__EDIT}\n </MenuItem>\n )\n }\n {\n isFineResend({ message, userId, status }) && (\n <MenuItem\n className=\"sendbird-openchannel-og-message__top__context-menu__resend\"\n onClick={() => {\n resendMessage(message);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__RESEND}\n </MenuItem>\n )\n }\n {\n isFineDelete({ message, userId, status }) && (\n <MenuItem\n className=\"sendbird-openchannel-og-message__top__context-menu__delete\"\n onClick={() => {\n if (disabled) {\n return;\n }\n showRemove(true);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__DELETE}\n </MenuItem>\n )\n }\n </MenuItems>\n )}\n />\n </div>\n }\n </div>\n <div className=\"sendbird-openchannel-og-message__bottom\">\n <div className=\"sendbird-openchannel-og-message__bottom__og-tag\">\n {\n ogMetaData.url && (\n <Label\n className=\"sendbird-openchannel-og-message__bottom__og-tag__url\"\n type={LabelTypography.CAPTION_3}\n color={LabelColors.ONBACKGROUND_2}\n >\n {ogMetaData.url}\n </Label>\n )\n }\n {\n ogMetaData.title && (\n <LinkLabel\n className=\"sendbird-openchannel-og-message__bottom__og-tag__title\"\n src={ogMetaData.url}\n type={LabelTypography.SUBTITLE_2}\n color={LabelColors.PRIMARY}\n >\n {\n ogMetaData.title\n }\n </LinkLabel>\n )\n }\n {\n ogMetaData.description && (\n <Label\n className=\"sendbird-openchannel-og-message__bottom__og-tag__description\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_1}\n >\n {ogMetaData.description}\n </Label>\n )\n }\n {\n ogMetaData.url && (\n <div\n className=\"sendbird-openchannel-og-message__bottom__og-tag__thumbnail\"\n role=\"button\"\n onClick={openLink}\n onKeyDown={openLink}\n tabIndex={0}\n >\n {\n defaultImage && (\n <ImageRenderer\n className=\"sendbird-openchannel-og-message__bottom__og-tag__thumbnail__image\"\n url={defaultImage.url || ''}\n alt={defaultImage.alt || ''}\n height=\"189px\"\n defaultComponent={(\n <div className=\"sendbird-openchannel-og-message__bottom__og-tag__thumbnail__image--placeholder\">\n <Icon\n type={IconTypes.THUMBNAIL_NONE}\n width=\"56px\"\n height=\"56px\"\n />\n </div>\n )}\n />\n )\n }\n </div>\n )\n }\n </div>\n {\n (isPending || isFailed) && (\n <div className=\"sendbird-openchannel-og-message__top__right__tail\">\n {\n isPending && (\n <Loader\n width=\"16px\"\n height=\"16px\"\n >\n <Icon\n className=\"sendbird-openchannel-og-message__top__right__tail__pending\"\n type={IconTypes.SPINNER}\n fillColor={IconColors.PRIMARY}\n width=\"16px\"\n height=\"16px\"\n />\n </Loader>\n )\n }\n {\n isFailed && (\n <Icon\n className=\"sendbird-openchannel-og-message__top__right__tail__failed\"\n type={IconTypes.ERROR}\n fillColor={IconColors.ERROR}\n width=\"16px\"\n height=\"16px\"\n />\n )\n }\n </div>\n )\n }\n </div>\n </div>\n );\n}\n"],"names":["URL_REG","createUrlTester","regexp","text","test","checkOGIsEnalbed","message","ogMetaData","url","OpenchannelOGMessage","_a","className","disabled","showEdit","showRemove","resendMessage","chainTop","userId","messageType","status","sendingStatus","defaultImage","_b","useLocalization","stringSet","dateLocale","_c","useContext","UserProfileContext","disableUserProfile","renderUserProfile","_d","useState","contextStyle","setContextStyle","messageComponentRef","useRef","contextMenuRef","avatarRef","isUrl","isByMe","checkIsByMe","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","MemoizedMessageText","useMemo","wordClassName","splitMessage","split","matchedMessage","map","word","React","LinkLabel","uuidv4","LabelTypography","BODY_1","LabelColors","PRIMARY","Label","ONBACKGROUND_1","updatedAt","push","ONBACKGROUND_2","MESSAGE_EDITED","openLink","window","open","useEffect","current","clientHeight","top","innerWidth","__spreadArray","Array","isArray","join","ContextMenu","toggleDropdown","Avatar","profileUrl","closeDropdown","MenuItems","paddingTop","paddingBottom","user","close","UserProfile","CAPTION_2","SECONDARY_3","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","showMenuTrigger","IconButton","Icon","IconTypes","MORE","IconColors","CONTENT_INVERSE","isFineCopy","MenuItem","copyToClipboard","CONTEXT_MENU_DROPDOWN__COPY","isFineEdit","CONTEXT_MENU_DROPDOWN__EDIT","isFineResend","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE","title","SUBTITLE_2","description","BODY_2","ImageRenderer","alt","THUMBNAIL_NONE","Loader","SPINNER","ERROR"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"OpenchannelOGMessage.js","sources":["../../../src/ui/OpenchannelOGMessage/utils.ts","../../../src/ui/OpenchannelOGMessage/index.tsx"],"sourcesContent":["import type { UserMessage } from \"@sendbird/chat/message\";\n\nexport const URL_REG = /[-a-zA-Z0-9@:%._+~#=]{1,256}\\.[a-zA-Z0-9()]{1,6}\\b([-a-zA-Z0-9()@:%_+.~#?&//=]*)/;\nexport const createUrlTester = (regexp: RegExp) => (text: string): boolean => regexp.test(text);\nexport const checkOGIsEnalbed = (message: UserMessage): boolean => {\n const { ogMetaData } = message;\n if (!ogMetaData) {\n return false;\n }\n const { url } = ogMetaData;\n if (!url) {\n return false;\n }\n return true;\n};\n","import React, { useState, useContext, useMemo, useRef, useEffect } from 'react';\nimport { UserMessage } from '@sendbird/chat/message';\nimport format from 'date-fns/format';\nimport './index.scss';\n\nimport Avatar from '../Avatar';\nimport ContextMenu, { MenuItems, MenuItem } from '../ContextMenu';\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport IconButton from '../IconButton';\nimport ImageRenderer from '../ImageRenderer';\nimport LinkLabel from '../LinkLabel';\nimport Label, { LabelTypography, LabelColors } from '../Label';\nimport Loader from '../Loader';\nimport UserProfile from '../UserProfile';\nimport { UserProfileContext } from '../../lib/UserProfileContext';\n\nimport uuidv4 from '../../utils/uuid';\nimport { copyToClipboard } from '../OpenchannelUserMessage/utils';\nimport { useLocalization } from '../../lib/LocalizationContext';\nimport { checkOGIsEnalbed, createUrlTester, URL_REG } from './utils';\nimport {\n checkIsPending,\n checkIsFailed,\n isFineCopy,\n isFineEdit,\n isFineResend,\n isFineDelete,\n showMenuTrigger,\n} from '../../utils/openChannelUtils';\nimport { getSenderFromMessage } from '../../utils/openChannelUtils';\n\ninterface Props {\n message: UserMessage;\n isOperator?: boolean;\n className?: string | Array<string>;\n disabled?: boolean;\n showEdit(bool: boolean): void;\n showRemove(bool: boolean): void;\n resendMessage(message: UserMessage): void;\n chainTop?: boolean;\n chainBottom?: boolean;\n userId: string;\n}\n\nexport default function OpenchannelOGMessage({\n message,\n isOperator,\n className,\n disabled,\n showEdit,\n showRemove,\n resendMessage,\n chainTop,\n userId,\n}: Props): JSX.Element {\n if (!message || message.messageType !== 'user') {\n return null;\n }\n\n const status = message?.sendingStatus;\n const { ogMetaData } = message;\n const { defaultImage } = ogMetaData;\n\n const { stringSet, dateLocale } = useLocalization();\n const { disableUserProfile, renderUserProfile } = useContext(UserProfileContext);\n const [contextStyle, setContextStyle] = useState({});\n const messageComponentRef = useRef(null);\n const contextMenuRef = useRef(null);\n const avatarRef = useRef(null);\n\n const isUrl = createUrlTester(URL_REG);\n const isPending = checkIsPending(status);\n const isFailed = checkIsFailed(status);\n const sender = getSenderFromMessage(message);\n\n const MemoizedMessageText = useMemo(() => () => {\n const wordClassName = 'sendbird-openchannel-og-message--word';\n const splitMessage = message.message.split(' ');\n const matchedMessage = splitMessage\n .map((word) => (\n isUrl(word)\n ? (\n <LinkLabel\n key={uuidv4()}\n className={[\n wordClassName,\n 'sendbird-openchannel-og-message--word--link'\n ]}\n src={word}\n type={LabelTypography.BODY_1}\n color={LabelColors.PRIMARY}\n >\n {word}\n </LinkLabel>\n )\n : (\n <Label\n key={uuidv4()}\n className={wordClassName}\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_1}\n >\n {word}\n </Label>\n )\n ));\n\n if (message.updatedAt > 0) {\n matchedMessage.push(\n <Label\n key={uuidv4()}\n className={wordClassName}\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_2}\n >\n {stringSet.MESSAGE_EDITED}\n </Label>,\n );\n }\n\n return matchedMessage;\n }, [message, message.updatedAt]);\n\n const openLink = () => {\n if (checkOGIsEnalbed(message)) {\n const { url } = ogMetaData;\n window.open(url);\n }\n };\n\n // place conxt menu top depending clientHeight of message component\n useEffect(() => {\n if (messageComponentRef?.current?.clientHeight > 36) {\n setContextStyle({ top: '8px ' });\n } else {\n setContextStyle({ top: '2px' });\n }\n }, [window.innerWidth]);\n\n return (\n <div\n className={[\n ...(Array.isArray(className) ? className : [className]),\n 'sendbird-openchannel-og-message',\n ].join(' ')}\n ref={messageComponentRef}\n >\n <div\n className=\"sendbird-openchannel-og-message__top\"\n >\n <div className=\"sendbird-openchannel-og-message__top__left\">\n {\n !chainTop && (\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n <Avatar\n className=\"sendbird-openchannel-og-message__top__left__avatar\"\n src={sender.profileUrl || ''}\n ref={avatarRef}\n width=\"28px\"\n height=\"28px\"\n onClick={() => {\n if (!disableUserProfile) {\n toggleDropdown();\n }\n }}\n />\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={avatarRef}\n parentContainRef={avatarRef}\n closeDropdown={closeDropdown}\n style={{ paddingTop: 0, paddingBottom: 0 }}\n >\n {\n renderUserProfile\n ? (\n renderUserProfile({\n user: sender,\n close: closeDropdown,\n })\n )\n : (\n <UserProfile\n user={sender}\n onSuccess={closeDropdown}\n disableMessaging\n />\n )\n }\n </MenuItems>\n )}\n />\n )\n }\n </div>\n <div className=\"sendbird-openchannel-og-message__top__right\">\n {\n !chainTop && (\n <div className=\"sendbird-openchannel-og-message__top__right__title\">\n <Label\n className=\"sendbird-openchannel-og-message__top__right__title__sender-name\"\n type={LabelTypography.CAPTION_2}\n color={isOperator ? LabelColors.SECONDARY_3 : LabelColors.ONBACKGROUND_2}\n >\n {\n sender && (\n sender.friendName\n || sender.nickname\n || sender.userId\n )\n }\n </Label>\n <Label\n className=\"sendbird-openchannel-og-message__top__right__title__sent-at\"\n type={LabelTypography.CAPTION_3}\n color={LabelColors.ONBACKGROUND_3}\n >\n {\n message?.createdAt && (\n format(message?.createdAt, 'p', {\n locale: dateLocale,\n })\n )\n }\n </Label>\n </div>\n )\n }\n <div className=\"sendbird-openchannel-og-message__top__right__description\">\n <Label\n className=\"sendbird-openchannel-og-message__top__right__description__message\"\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_1}\n >\n {MemoizedMessageText()}\n </Label>\n </div>\n </div>\n {\n <div\n className=\"sendbird-openchannel-og-message__top__context-menu\"\n ref={contextMenuRef}\n style={contextStyle}\n >\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n showMenuTrigger({ message: message, userId: userId, status: status }) && (\n <IconButton\n className=\"sendbird-openchannel-og-message__top__context-menu--icon\"\n width=\"32px\"\n height=\"32px\"\n onClick={() => {\n toggleDropdown();\n }}\n >\n <Icon\n type={IconTypes.MORE}\n fillColor={IconColors.CONTENT_INVERSE}\n width=\"24px\"\n height=\"24px\"\n />\n </IconButton>\n )\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={contextMenuRef}\n parentContainRef={contextMenuRef}\n closeDropdown={closeDropdown}\n openLeft\n >\n {\n isFineCopy({ message, userId, status }) && (\n <MenuItem\n className=\"sendbird-openchannel-og-message__top__context-menu__copy\"\n onClick={() => {\n copyToClipboard(message.message);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__COPY}\n </MenuItem>\n )\n }\n {\n isFineEdit({ message, userId, status }) && (\n <MenuItem\n className=\"sendbird-openchannel-og-message__top__context-menu__edit\"\n onClick={() => {\n if (disabled) {\n return;\n }\n showEdit(true);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__EDIT}\n </MenuItem>\n )\n }\n {\n isFineResend({ message, userId, status }) && (\n <MenuItem\n className=\"sendbird-openchannel-og-message__top__context-menu__resend\"\n onClick={() => {\n resendMessage(message);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__RESEND}\n </MenuItem>\n )\n }\n {\n isFineDelete({ message, userId, status }) && (\n <MenuItem\n className=\"sendbird-openchannel-og-message__top__context-menu__delete\"\n onClick={() => {\n if (disabled) {\n return;\n }\n showRemove(true);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__DELETE}\n </MenuItem>\n )\n }\n </MenuItems>\n )}\n />\n </div>\n }\n </div>\n <div className=\"sendbird-openchannel-og-message__bottom\">\n <div className=\"sendbird-openchannel-og-message__bottom__og-tag\">\n {\n ogMetaData.url && (\n <Label\n className=\"sendbird-openchannel-og-message__bottom__og-tag__url\"\n type={LabelTypography.CAPTION_3}\n color={LabelColors.ONBACKGROUND_2}\n >\n {ogMetaData.url}\n </Label>\n )\n }\n {\n ogMetaData.title && (\n <LinkLabel\n className=\"sendbird-openchannel-og-message__bottom__og-tag__title\"\n src={ogMetaData.url}\n type={LabelTypography.SUBTITLE_2}\n color={LabelColors.PRIMARY}\n >\n {\n ogMetaData.title\n }\n </LinkLabel>\n )\n }\n {\n ogMetaData.description && (\n <Label\n className=\"sendbird-openchannel-og-message__bottom__og-tag__description\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_1}\n >\n {ogMetaData.description}\n </Label>\n )\n }\n {\n ogMetaData.url && (\n <div\n className=\"sendbird-openchannel-og-message__bottom__og-tag__thumbnail\"\n role=\"button\"\n onClick={openLink}\n onKeyDown={openLink}\n tabIndex={0}\n >\n {\n defaultImage && (\n <ImageRenderer\n className=\"sendbird-openchannel-og-message__bottom__og-tag__thumbnail__image\"\n url={defaultImage.url || ''}\n alt={defaultImage.alt || ''}\n height=\"189px\"\n defaultComponent={(\n <div className=\"sendbird-openchannel-og-message__bottom__og-tag__thumbnail__image--placeholder\">\n <Icon\n type={IconTypes.THUMBNAIL_NONE}\n width=\"56px\"\n height=\"56px\"\n />\n </div>\n )}\n />\n )\n }\n </div>\n )\n }\n </div>\n {\n (isPending || isFailed) && (\n <div className=\"sendbird-openchannel-og-message__top__right__tail\">\n {\n isPending && (\n <Loader\n width=\"16px\"\n height=\"16px\"\n >\n <Icon\n className=\"sendbird-openchannel-og-message__top__right__tail__pending\"\n type={IconTypes.SPINNER}\n fillColor={IconColors.PRIMARY}\n width=\"16px\"\n height=\"16px\"\n />\n </Loader>\n )\n }\n {\n isFailed && (\n <Icon\n className=\"sendbird-openchannel-og-message__top__right__tail__failed\"\n type={IconTypes.ERROR}\n fillColor={IconColors.ERROR}\n width=\"16px\"\n height=\"16px\"\n />\n )\n }\n </div>\n )\n }\n </div>\n </div>\n );\n}\n"],"names":["URL_REG","createUrlTester","regexp","text","test","checkOGIsEnalbed","message","ogMetaData","url","OpenchannelOGMessage","_a","isOperator","className","disabled","showEdit","showRemove","resendMessage","chainTop","userId","messageType","status","sendingStatus","defaultImage","_b","useLocalization","stringSet","dateLocale","_c","useContext","UserProfileContext","disableUserProfile","renderUserProfile","_d","useState","contextStyle","setContextStyle","messageComponentRef","useRef","contextMenuRef","avatarRef","isUrl","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","MemoizedMessageText","useMemo","wordClassName","splitMessage","split","matchedMessage","map","word","React","LinkLabel","uuidv4","LabelTypography","BODY_1","LabelColors","PRIMARY","Label","ONBACKGROUND_1","updatedAt","push","ONBACKGROUND_2","MESSAGE_EDITED","openLink","window","open","useEffect","current","clientHeight","top","innerWidth","__spreadArray","Array","isArray","join","ContextMenu","toggleDropdown","Avatar","profileUrl","closeDropdown","MenuItems","paddingTop","paddingBottom","user","close","UserProfile","CAPTION_2","SECONDARY_3","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","showMenuTrigger","IconButton","Icon","IconTypes","MORE","IconColors","CONTENT_INVERSE","isFineCopy","MenuItem","copyToClipboard","CONTEXT_MENU_DROPDOWN__COPY","isFineEdit","CONTEXT_MENU_DROPDOWN__EDIT","isFineResend","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE","title","SUBTITLE_2","description","BODY_2","ImageRenderer","alt","THUMBNAIL_NONE","Loader","SPINNER","ERROR"],"mappings":"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"}
|
|
@@ -1,32 +1,32 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var tslib_es6 = require('../tslib.es6-
|
|
3
|
+
var tslib_es6 = require('../tslib.es6-306f32fb.js');
|
|
4
4
|
var React = require('react');
|
|
5
|
-
var index = require('../index-
|
|
6
|
-
var LocalizationContext = require('../LocalizationContext-
|
|
5
|
+
var index = require('../index-93b2249a.js');
|
|
6
|
+
var LocalizationContext = require('../LocalizationContext-672b9c94.js');
|
|
7
7
|
var ui_Avatar = require('./Avatar.js');
|
|
8
8
|
var ui_ContextMenu = require('./ContextMenu.js');
|
|
9
9
|
var ui_Icon = require('./Icon.js');
|
|
10
10
|
var ui_IconButton = require('./IconButton.js');
|
|
11
11
|
var ui_ImageRenderer = require('./ImageRenderer.js');
|
|
12
|
-
var ui_Label = require('../index-
|
|
12
|
+
var ui_Label = require('../index-6b7d2465.js');
|
|
13
13
|
var ui_Loader = require('./Loader.js');
|
|
14
14
|
var ui_UserProfile = require('./UserProfile.js');
|
|
15
|
-
var UserProfileContext = require('../UserProfileContext-
|
|
16
|
-
var openChannelUtils = require('../openChannelUtils-
|
|
17
|
-
require('../index-
|
|
18
|
-
require('../stringSet-
|
|
19
|
-
require('../uuid-
|
|
20
|
-
require('../_rollupPluginBabelHelpers-
|
|
15
|
+
var UserProfileContext = require('../UserProfileContext-d3290c6a.js');
|
|
16
|
+
var openChannelUtils = require('../openChannelUtils-b411bbf8.js');
|
|
17
|
+
require('../index-1a2c6bb9.js');
|
|
18
|
+
require('../stringSet-da3df562.js');
|
|
19
|
+
require('../uuid-deaf6e4d.js');
|
|
20
|
+
require('../_rollupPluginBabelHelpers-f02175f2.js');
|
|
21
21
|
require('prop-types');
|
|
22
|
-
require('../index-
|
|
22
|
+
require('../index-3b9eca88.js');
|
|
23
23
|
require('react-dom');
|
|
24
24
|
require('./SortByRow.js');
|
|
25
25
|
require('../withSendbird.js');
|
|
26
26
|
require('../sendbirdSelectors.js');
|
|
27
|
-
require('../topics-
|
|
28
|
-
require('../utils-
|
|
29
|
-
require('../index-
|
|
27
|
+
require('../topics-1932f321.js');
|
|
28
|
+
require('../utils-15fd96e3.js');
|
|
29
|
+
require('../index-52186645.js');
|
|
30
30
|
|
|
31
31
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
32
32
|
|
|
@@ -58,6 +58,7 @@ function OpenchannelThumbnailMessage(_a) {
|
|
|
58
58
|
|
|
59
59
|
var className = _a.className,
|
|
60
60
|
message = _a.message,
|
|
61
|
+
isOperator = _a.isOperator,
|
|
61
62
|
disabled = _a.disabled,
|
|
62
63
|
userId = _a.userId,
|
|
63
64
|
chainTop = _a.chainTop,
|
|
@@ -105,7 +106,6 @@ function OpenchannelThumbnailMessage(_a) {
|
|
|
105
106
|
};
|
|
106
107
|
};
|
|
107
108
|
}, []);
|
|
108
|
-
var isByMe = openChannelUtils.checkIsByMe(message, userId);
|
|
109
109
|
var isMessageSent = openChannelUtils.checkIsSent(status);
|
|
110
110
|
var isPending = openChannelUtils.checkIsPending(status);
|
|
111
111
|
var isFailed = openChannelUtils.checkIsFailed(status);
|
|
@@ -161,7 +161,7 @@ function OpenchannelThumbnailMessage(_a) {
|
|
|
161
161
|
}, /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
|
|
162
162
|
className: "sendbird-openchannel-thumbnail-message__right__title__sender-name",
|
|
163
163
|
type: ui_Label.LabelTypography.CAPTION_2,
|
|
164
|
-
color:
|
|
164
|
+
color: isOperator ? ui_Label.LabelColors.SECONDARY_3 : ui_Label.LabelColors.ONBACKGROUND_2
|
|
165
165
|
}, sender && (sender.friendName || sender.nickname || sender.userId)), /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
|
|
166
166
|
className: "sendbird-openchannel-thumbnail-message__right__title__sent-at",
|
|
167
167
|
type: ui_Label.LabelTypography.CAPTION_3,
|
|
@@ -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 { FileMessage } from '@sendbird/chat/message';\nimport format from 'date-fns/format';\nimport './index.scss';\nimport { SUPPORTING_TYPES, getSupportingFileType } from './utils';\nimport { useLocalization } from '../../lib/LocalizationContext';\n\nimport Avatar from '../Avatar';\nimport ContextMenu, { MenuItems, MenuItem } from '../ContextMenu';\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport IconButton from '../IconButton';\nimport ImageRenderer from '../ImageRenderer';\nimport Label, { LabelTypography, LabelColors } from '../Label';\nimport Loader from '../Loader';\nimport UserProfile from '../UserProfile';\nimport { UserProfileContext } from '../../lib/UserProfileContext';\nimport {\n checkIsByMe,\n checkIsSent,\n checkIsPending,\n checkIsFailed,\n isFineResend,\n isFineDelete,\n showMenuTrigger,\n} from '../../utils/openChannelUtils';\nimport { getSenderFromMessage } from '../../utils/openChannelUtils';\n\ninterface LocalUrl {\n localUrl?: string;\n}\ninterface Props {\n className?: string | Array<string>;\n message: FileMessage;\n disabled: boolean;\n userId: string;\n chainTop: boolean;\n chainBottom: boolean;\n onClick(bool: boolean): void,\n showRemove(bool: boolean): void,\n resendMessage(message: FileMessage): void;\n}\n\nexport default function OpenchannelThumbnailMessage({\n className,\n message,\n disabled,\n userId,\n chainTop,\n onClick,\n showRemove,\n resendMessage,\n}: Props): JSX.Element {\n const {\n type,\n url,\n thumbnails,\n localUrl,\n }: FileMessage & LocalUrl = message;\n const status = message?.sendingStatus;\n const thumbnailUrl = (thumbnails && thumbnails.length > 0 && thumbnails[0].url) || null;\n const { stringSet, dateLocale } = useLocalization();\n const { disableUserProfile, renderUserProfile } = useContext(UserProfileContext);\n const [messageWidth, setMessageWidth] = useState(360);\n const messageRef = useRef(null);\n const contextMenuRef = useRef(null);\n const avatarRef = useRef(null);\n\n const memorizedThumbnailPlaceHolder = useMemo(() => (type) => ({ style }) => ( // eslint-disable-line\n <div style={style}>\n <Icon\n type={type}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n </div>\n ), []);\n\n const isByMe = checkIsByMe(message, userId);\n const isMessageSent = checkIsSent(status);\n const isPending = checkIsPending(status);\n const isFailed = checkIsFailed(status);\n const sender = getSenderFromMessage(message);\n\n useEffect(() => {\n const thumbnailWidth = messageRef?.current?.clientWidth - 80;\n setMessageWidth(thumbnailWidth > 360 ? 360 : thumbnailWidth);\n }, []);\n\n return (\n <div\n className={[\n ...(Array.isArray(className) ? className : [className]),\n 'sendbird-openchannel-thumbnail-message',\n ].join(' ')}\n ref={messageRef}\n >\n <div className=\"sendbird-openchannel-thumbnail-message__left\">\n {\n !chainTop && (\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n <Avatar\n className=\"sendbird-openchannel-thumbnail-message__left__avatar\"\n src={sender.profileUrl || ''}\n ref={avatarRef}\n width=\"28px\"\n height=\"28px\"\n onClick={() => {\n if (!disableUserProfile) {\n toggleDropdown();\n }\n }}\n />\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={avatarRef}\n parentContainRef={avatarRef}\n closeDropdown={closeDropdown}\n style={{ paddingTop: 0, paddingBottom: 0 }}\n >\n {\n renderUserProfile\n ? (\n renderUserProfile({\n user: sender,\n close: closeDropdown,\n })\n )\n : (\n <UserProfile\n user={sender}\n onSuccess={closeDropdown}\n disableMessaging\n />\n )\n }\n </MenuItems>\n )}\n />\n )\n }\n </div>\n <div className=\"sendbird-openchannel-thumbnail-message__right\">\n {\n !chainTop && (\n <div className=\"sendbird-openchannel-thumbnail-message__right__title\">\n <Label\n className=\"sendbird-openchannel-thumbnail-message__right__title__sender-name\"\n type={LabelTypography.CAPTION_2}\n color={isByMe ? LabelColors.SECONDARY_3 : LabelColors.ONBACKGROUND_2}\n >\n {\n sender && (\n sender.friendName\n || sender.nickname\n || sender.userId\n )\n }\n </Label>\n <Label\n className=\"sendbird-openchannel-thumbnail-message__right__title__sent-at\"\n type={LabelTypography.CAPTION_3}\n color={LabelColors.ONBACKGROUND_3}\n >\n {\n message?.createdAt && (\n format(message.createdAt, 'p', {\n locale: dateLocale,\n })\n )\n }\n </Label>\n </div>\n )\n }\n <div className=\"sendbird-openchannel-thumbnail-message__right__body\">\n <div\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap\"\n role=\"button\"\n onClick={() => {\n if (isMessageSent) {\n onClick(true);\n }\n }}\n onKeyDown={() => {\n if (isMessageSent) {\n onClick(true);\n }\n }}\n tabIndex={0}\n >\n <div className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__overlay\" />\n {\n {\n [SUPPORTING_TYPES.VIDEO]: (\n (url || localUrl)\n ? (\n <div className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video\" >\n {\n (thumbnailUrl)\n ? (\n <ImageRenderer\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video\"\n url={thumbnailUrl}\n width={messageWidth}\n height=\"270px\"\n alt=\"image\"\n placeHolder={memorizedThumbnailPlaceHolder(IconTypes.PLAY)}\n />\n )\n : (\n <video className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video__video\">\n <source src={url || localUrl} type={type} />\n </video>\n )\n }\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video__icon\"\n type={IconTypes.PLAY}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n </div>\n )\n : (\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__video--icon\"\n type={IconTypes.PHOTO}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n )\n ),\n [SUPPORTING_TYPES.IMAGE]: (\n (url || localUrl)\n ? (\n <ImageRenderer\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__image\"\n url={thumbnailUrl || url || localUrl}\n alt=\"image\"\n width={messageWidth}\n height=\"270px\"\n placeHolder={memorizedThumbnailPlaceHolder(IconTypes.PHOTO)}\n />\n )\n : (\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__image--icon\"\n type={IconTypes.PHOTO}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n )\n ),\n [SUPPORTING_TYPES.UNSUPPORTED]: (\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__body__wrap__unknown\"\n type={IconTypes.PHOTO}\n fillColor={IconColors.ON_BACKGROUND_2}\n width=\"56px\"\n height=\"56px\"\n />\n ),\n }[getSupportingFileType(type)]\n }\n </div>\n </div>\n {\n (isPending || isFailed) && (\n <div className=\"sendbird-openchannel-thumbnail-message__right__tail\">\n {\n isPending && (\n <Loader\n width=\"16px\"\n height=\"16px\"\n >\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__tail__pending\"\n type={IconTypes.SPINNER}\n fillColor={IconColors.PRIMARY}\n width=\"16px\"\n height=\"16px\"\n />\n </Loader>\n )\n }\n {\n isFailed && (\n <Icon\n className=\"sendbird-openchannel-thumbnail-message__right__tail__failed\"\n type={IconTypes.ERROR}\n fillColor={IconColors.ERROR}\n width=\"16px\"\n height=\"16px\"\n />\n )\n }\n </div>\n )\n }\n </div>\n <div\n className=\"sendbird-openchannel-thumbnail-message__context-menu\"\n ref={contextMenuRef}\n >\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n showMenuTrigger({ message, userId, status }) && (\n <IconButton\n className=\"sendbird-openchannel-thumbnail-message__context-menu--icon\"\n width=\"32px\"\n height=\"32px\"\n onClick={toggleDropdown}\n >\n <Icon\n type={IconTypes.MORE}\n fillColor={IconColors.CONTENT_INVERSE}\n width=\"24px\"\n height=\"24px\"\n />\n </IconButton>\n )\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={contextMenuRef}\n parentContainRef={contextMenuRef}\n closeDropdown={closeDropdown}\n openLeft\n >\n {\n isFineResend({ message, userId, status }) && (\n <MenuItem\n onClick={() => {\n resendMessage(message);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__RESEND}\n </MenuItem>\n )\n }\n {\n isFineDelete({ message, userId, status }) && (\n <MenuItem\n onClick={() => {\n if (disabled) {\n return;\n }\n showRemove(true);\n closeDropdown();\n }}\n >\n {stringSet.CONTEXT_MENU_DROPDOWN__DELETE}\n </MenuItem>\n )\n }\n </MenuItems>\n )}\n />\n </div>\n </div>\n );\n}\n"],"names":["SUPPORTING_TYPES","IMAGE","VIDEO","UNSUPPORTED","SUPPORTED_MIMES","getSupportingFileType","type","indexOf","OpenchannelThumbnailMessage","_a","className","message","disabled","userId","chainTop","onClick","showRemove","resendMessage","url","thumbnails","localUrl","status","sendingStatus","thumbnailUrl","length","_c","useLocalization","stringSet","dateLocale","_d","useContext","UserProfileContext","disableUserProfile","renderUserProfile","_e","useState","messageWidth","setMessageWidth","messageRef","useRef","contextMenuRef","avatarRef","memorizedThumbnailPlaceHolder","useMemo","style","React","Icon","IconColors","ON_BACKGROUND_2","isByMe","checkIsByMe","isMessageSent","checkIsSent","isPending","checkIsPending","isFailed","checkIsFailed","sender","getSenderFromMessage","useEffect","thumbnailWidth","current","clientWidth","__spreadArray","Array","isArray","join","ContextMenu","toggleDropdown","Avatar","profileUrl","closeDropdown","MenuItems","paddingTop","paddingBottom","user","close","UserProfile","Label","LabelTypography","CAPTION_2","LabelColors","SECONDARY_3","ONBACKGROUND_2","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","_b","ImageRenderer","IconTypes","PLAY","PHOTO","Loader","SPINNER","PRIMARY","ERROR","showMenuTrigger","IconButton","MORE","CONTENT_INVERSE","isFineResend","MenuItem","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE"],"mappings":"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"}
|
|
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 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 isOperator?: boolean;\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 isOperator,\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 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={isOperator ? 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","isOperator","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","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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"}
|