@sendbird/uikit-react 3.0.0-beta.4 → 3.0.0-rc.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/App.js +316 -0
- package/App.js.map +1 -0
- package/CHANGELOG.md +43 -1
- package/Channel/components/ChannelHeader.js +121 -0
- package/Channel/components/ChannelHeader.js.map +1 -0
- package/Channel/components/ChannelUI.js +182 -0
- package/Channel/components/ChannelUI.js.map +1 -0
- package/Channel/components/FileViewer.js +153 -0
- package/Channel/components/FileViewer.js.map +1 -0
- package/Channel/components/FrozenNotification.js +20 -0
- package/Channel/components/FrozenNotification.js.map +1 -0
- package/Channel/components/Message.js +364 -0
- package/Channel/components/Message.js.map +1 -0
- package/Channel/components/MessageInput.js +214 -0
- package/Channel/components/MessageInput.js.map +1 -0
- package/Channel/components/MessageList.js +242 -0
- package/Channel/components/MessageList.js.map +1 -0
- package/Channel/components/RemoveMessageModal.js +55 -0
- package/Channel/components/RemoveMessageModal.js.map +1 -0
- package/Channel/components/SuggestedMentionList.js +306 -0
- package/Channel/components/SuggestedMentionList.js.map +1 -0
- package/Channel/components/TypingIndicator.js +102 -0
- package/Channel/components/TypingIndicator.js.map +1 -0
- package/Channel/components/UnreadCount.js +41 -0
- package/Channel/components/UnreadCount.js.map +1 -0
- package/Channel/context.js +26 -0
- package/Channel/context.js.map +1 -0
- package/Channel.js +109 -0
- package/Channel.js.map +1 -0
- package/ChannelList/components/AddChannel.js +70 -0
- package/ChannelList/components/AddChannel.js.map +1 -0
- package/ChannelList/components/ChannelListHeader.js +62 -0
- package/ChannelList/components/ChannelListHeader.js.map +1 -0
- package/ChannelList/components/ChannelListUI.js +235 -0
- package/ChannelList/components/ChannelListUI.js.map +1 -0
- package/ChannelList/components/ChannelPreview.js +216 -0
- package/ChannelList/components/ChannelPreview.js.map +1 -0
- package/ChannelList/components/ChannelPreviewAction.js +133 -0
- package/ChannelList/components/ChannelPreviewAction.js.map +1 -0
- package/ChannelList/context.js +15 -0
- package/ChannelList/context.js.map +1 -0
- package/ChannelList.js +91 -0
- package/ChannelList.js.map +1 -0
- package/ChannelListProvider-76b1ec23.js +944 -0
- package/ChannelListProvider-76b1ec23.js.map +1 -0
- package/ChannelProvider-c0ed5fae.js +2075 -0
- package/ChannelProvider-c0ed5fae.js.map +1 -0
- package/ChannelSettings/components/ChannelProfile.js +102 -0
- package/ChannelSettings/components/ChannelProfile.js.map +1 -0
- package/ChannelSettings/components/ChannelSettingsUI.js +152 -0
- package/ChannelSettings/components/ChannelSettingsUI.js.map +1 -0
- package/ChannelSettings/components/EditDetailsModal.js +158 -0
- package/ChannelSettings/components/EditDetailsModal.js.map +1 -0
- package/ChannelSettings/components/LeaveChannel.js +53 -0
- package/ChannelSettings/components/LeaveChannel.js.map +1 -0
- package/ChannelSettings/components/ModerationPanel.js +851 -0
- package/ChannelSettings/components/ModerationPanel.js.map +1 -0
- package/ChannelSettings/components/UserListItem.js +106 -0
- package/ChannelSettings/components/UserListItem.js.map +1 -0
- package/ChannelSettings/components/UserPanel.js +79 -0
- package/ChannelSettings/components/UserPanel.js.map +1 -0
- package/ChannelSettings/context.js +93 -0
- package/ChannelSettings/context.js.map +1 -0
- package/ChannelSettings.js +71 -0
- package/ChannelSettings.js.map +1 -0
- package/CreateChannel/components/CreateChannelUI.js +53 -0
- package/CreateChannel/components/CreateChannelUI.js.map +1 -0
- package/CreateChannel/components/InviteUsers.js +180 -0
- package/CreateChannel/components/InviteUsers.js.map +1 -0
- package/CreateChannel/components/SelectChannelType.js +131 -0
- package/CreateChannel/components/SelectChannelType.js.map +1 -0
- package/CreateChannel/context.js +9 -0
- package/CreateChannel/context.js.map +1 -0
- package/CreateChannel.js +53 -0
- package/CreateChannel.js.map +1 -0
- package/CreateChannelProvider-8c72aa06.js +53 -0
- package/CreateChannelProvider-8c72aa06.js.map +1 -0
- package/EditUserProfile/components/EditUserProfileUI.js +26 -0
- package/EditUserProfile/components/EditUserProfileUI.js.map +1 -0
- package/EditUserProfile/context.js +27 -0
- package/EditUserProfile/context.js.map +1 -0
- package/EditUserProfile.js +39 -0
- package/EditUserProfile.js.map +1 -0
- package/LocalizationContext-fb3dafcd.js +22 -0
- package/LocalizationContext-fb3dafcd.js.map +1 -0
- package/MemberList-01d3c8bf.js +404 -0
- package/MemberList-01d3c8bf.js.map +1 -0
- package/MessageSearch/components/MessageSearchUI.js +151 -0
- package/MessageSearch/components/MessageSearchUI.js.map +1 -0
- package/MessageSearch/context.js +387 -0
- package/MessageSearch/context.js.map +1 -0
- package/MessageSearch.js +146 -0
- package/MessageSearch.js.map +1 -0
- package/OpenChannel/components/FrozenChannelNotification.js +20 -0
- package/OpenChannel/components/FrozenChannelNotification.js.map +1 -0
- package/OpenChannel/components/OpenChannelHeader.js +80 -0
- package/OpenChannel/components/OpenChannelHeader.js.map +1 -0
- package/OpenChannel/components/OpenChannelInput.js +58 -0
- package/OpenChannel/components/OpenChannelInput.js.map +1 -0
- package/OpenChannel/components/OpenChannelMessage.js +287 -0
- package/OpenChannel/components/OpenChannelMessage.js.map +1 -0
- package/OpenChannel/components/OpenChannelMessageList.js +158 -0
- package/OpenChannel/components/OpenChannelMessageList.js.map +1 -0
- package/OpenChannel/components/OpenChannelUI.js +111 -0
- package/OpenChannel/components/OpenChannelUI.js.map +1 -0
- package/OpenChannel/context.js +16 -0
- package/OpenChannel/context.js.map +1 -0
- package/OpenChannel.js +82 -0
- package/OpenChannel.js.map +1 -0
- package/OpenChannelProvider-0fb27972.js +1946 -0
- package/OpenChannelProvider-0fb27972.js.map +1 -0
- package/OpenChannelSettings/components/EditDetailsModal.js +143 -0
- package/OpenChannelSettings/components/EditDetailsModal.js.map +1 -0
- package/OpenChannelSettings/components/OpenChannelProfile.js +81 -0
- package/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -0
- package/OpenChannelSettings/components/OpenChannelSettingsUI.js +120 -0
- package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -0
- package/OpenChannelSettings/components/OperatorUI.js +199 -0
- package/OpenChannelSettings/components/OperatorUI.js.map +1 -0
- package/OpenChannelSettings/components/ParticipantUI.js +145 -0
- package/OpenChannelSettings/components/ParticipantUI.js.map +1 -0
- package/OpenChannelSettings/context.js +64 -0
- package/OpenChannelSettings/context.js.map +1 -0
- package/OpenChannelSettings.js +64 -0
- package/OpenChannelSettings.js.map +1 -0
- package/README.md +0 -1
- package/SendbirdProvider.js +782 -0
- package/SendbirdProvider.js.map +1 -0
- package/UserProfileContext-6a387a08.js +38 -0
- package/UserProfileContext-6a387a08.js.map +1 -0
- package/__bundle-7dfccc8c-03df3ada.js +24 -0
- package/__bundle-7dfccc8c-03df3ada.js.map +1 -0
- package/_rollupPluginBabelHelpers-084fb589.js +233 -0
- package/_rollupPluginBabelHelpers-084fb589.js.map +1 -0
- package/actionTypes-302a2801.js +6 -0
- package/actionTypes-302a2801.js.map +1 -0
- package/cjs/App.js +323 -0
- package/cjs/App.js.map +1 -0
- package/cjs/Channel/components/ChannelHeader.js +127 -0
- package/cjs/Channel/components/ChannelHeader.js.map +1 -0
- package/cjs/Channel/components/ChannelUI.js +188 -0
- package/cjs/Channel/components/ChannelUI.js.map +1 -0
- package/cjs/Channel/components/FileViewer.js +162 -0
- package/cjs/Channel/components/FileViewer.js.map +1 -0
- package/cjs/Channel/components/FrozenNotification.js +26 -0
- package/cjs/Channel/components/FrozenNotification.js.map +1 -0
- package/cjs/Channel/components/Message.js +370 -0
- package/cjs/Channel/components/Message.js.map +1 -0
- package/cjs/Channel/components/MessageInput.js +220 -0
- package/cjs/Channel/components/MessageInput.js.map +1 -0
- package/cjs/Channel/components/MessageList.js +248 -0
- package/cjs/Channel/components/MessageList.js.map +1 -0
- package/cjs/Channel/components/RemoveMessageModal.js +61 -0
- package/cjs/Channel/components/RemoveMessageModal.js.map +1 -0
- package/cjs/Channel/components/SuggestedMentionList.js +312 -0
- package/cjs/Channel/components/SuggestedMentionList.js.map +1 -0
- package/cjs/Channel/components/TypingIndicator.js +111 -0
- package/cjs/Channel/components/TypingIndicator.js.map +1 -0
- package/cjs/Channel/components/UnreadCount.js +47 -0
- package/cjs/Channel/components/UnreadCount.js.map +1 -0
- package/cjs/Channel/context.js +35 -0
- package/cjs/Channel/context.js.map +1 -0
- package/cjs/Channel.js +115 -0
- package/cjs/Channel.js.map +1 -0
- package/cjs/ChannelList/components/AddChannel.js +79 -0
- package/cjs/ChannelList/components/AddChannel.js.map +1 -0
- package/cjs/ChannelList/components/ChannelListHeader.js +68 -0
- package/cjs/ChannelList/components/ChannelListHeader.js.map +1 -0
- package/cjs/ChannelList/components/ChannelListUI.js +241 -0
- package/cjs/ChannelList/components/ChannelListUI.js.map +1 -0
- package/cjs/ChannelList/components/ChannelPreview.js +222 -0
- package/cjs/ChannelList/components/ChannelPreview.js.map +1 -0
- package/cjs/ChannelList/components/ChannelPreviewAction.js +140 -0
- package/cjs/ChannelList/components/ChannelPreviewAction.js.map +1 -0
- package/cjs/ChannelList/context.js +24 -0
- package/cjs/ChannelList/context.js.map +1 -0
- package/cjs/ChannelList.js +97 -0
- package/cjs/ChannelList.js.map +1 -0
- package/cjs/ChannelListProvider-7d1c0466.js +956 -0
- package/cjs/ChannelListProvider-7d1c0466.js.map +1 -0
- package/cjs/ChannelProvider-a3ec5a56.js +2088 -0
- package/cjs/ChannelProvider-a3ec5a56.js.map +1 -0
- package/cjs/ChannelSettings/components/ChannelProfile.js +108 -0
- package/cjs/ChannelSettings/components/ChannelProfile.js.map +1 -0
- package/cjs/ChannelSettings/components/ChannelSettingsUI.js +158 -0
- package/cjs/ChannelSettings/components/ChannelSettingsUI.js.map +1 -0
- package/cjs/ChannelSettings/components/EditDetailsModal.js +164 -0
- package/cjs/ChannelSettings/components/EditDetailsModal.js.map +1 -0
- package/cjs/ChannelSettings/components/LeaveChannel.js +59 -0
- package/cjs/ChannelSettings/components/LeaveChannel.js.map +1 -0
- package/cjs/ChannelSettings/components/ModerationPanel.js +857 -0
- package/cjs/ChannelSettings/components/ModerationPanel.js.map +1 -0
- package/cjs/ChannelSettings/components/UserListItem.js +112 -0
- package/cjs/ChannelSettings/components/UserListItem.js.map +1 -0
- package/cjs/ChannelSettings/components/UserPanel.js +85 -0
- package/cjs/ChannelSettings/components/UserPanel.js.map +1 -0
- package/cjs/ChannelSettings/context.js +102 -0
- package/cjs/ChannelSettings/context.js.map +1 -0
- package/cjs/ChannelSettings.js +77 -0
- package/cjs/ChannelSettings.js.map +1 -0
- package/cjs/CreateChannel/components/CreateChannelUI.js +59 -0
- package/cjs/CreateChannel/components/CreateChannelUI.js.map +1 -0
- package/cjs/CreateChannel/components/InviteUsers.js +186 -0
- package/cjs/CreateChannel/components/InviteUsers.js.map +1 -0
- package/cjs/CreateChannel/components/SelectChannelType.js +137 -0
- package/cjs/CreateChannel/components/SelectChannelType.js.map +1 -0
- package/cjs/CreateChannel/context.js +18 -0
- package/cjs/CreateChannel/context.js.map +1 -0
- package/cjs/CreateChannel.js +59 -0
- package/cjs/CreateChannel.js.map +1 -0
- package/cjs/CreateChannelProvider-95fbfb06.js +60 -0
- package/cjs/CreateChannelProvider-95fbfb06.js.map +1 -0
- package/cjs/EditUserProfile/components/EditUserProfileUI.js +32 -0
- package/cjs/EditUserProfile/components/EditUserProfileUI.js.map +1 -0
- package/cjs/EditUserProfile/context.js +36 -0
- package/cjs/EditUserProfile/context.js.map +1 -0
- package/cjs/EditUserProfile.js +45 -0
- package/cjs/EditUserProfile.js.map +1 -0
- package/cjs/LocalizationContext-5a6a0f67.js +30 -0
- package/cjs/LocalizationContext-5a6a0f67.js.map +1 -0
- package/cjs/MemberList-bfecdd64.js +410 -0
- package/cjs/MemberList-bfecdd64.js.map +1 -0
- package/cjs/MessageSearch/components/MessageSearchUI.js +160 -0
- package/cjs/MessageSearch/components/MessageSearchUI.js.map +1 -0
- package/cjs/MessageSearch/context.js +396 -0
- package/cjs/MessageSearch/context.js.map +1 -0
- package/cjs/MessageSearch.js +152 -0
- package/cjs/MessageSearch.js.map +1 -0
- package/cjs/OpenChannel/components/FrozenChannelNotification.js +26 -0
- package/cjs/OpenChannel/components/FrozenChannelNotification.js.map +1 -0
- package/cjs/OpenChannel/components/OpenChannelHeader.js +86 -0
- package/cjs/OpenChannel/components/OpenChannelHeader.js.map +1 -0
- package/cjs/OpenChannel/components/OpenChannelInput.js +64 -0
- package/cjs/OpenChannel/components/OpenChannelInput.js.map +1 -0
- package/cjs/OpenChannel/components/OpenChannelMessage.js +293 -0
- package/cjs/OpenChannel/components/OpenChannelMessage.js.map +1 -0
- package/cjs/OpenChannel/components/OpenChannelMessageList.js +164 -0
- package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -0
- package/cjs/OpenChannel/components/OpenChannelUI.js +117 -0
- package/cjs/OpenChannel/components/OpenChannelUI.js.map +1 -0
- package/cjs/OpenChannel/context.js +25 -0
- package/cjs/OpenChannel/context.js.map +1 -0
- package/cjs/OpenChannel.js +88 -0
- package/cjs/OpenChannel.js.map +1 -0
- package/cjs/OpenChannelProvider-e8247193.js +1955 -0
- package/cjs/OpenChannelProvider-e8247193.js.map +1 -0
- package/cjs/OpenChannelSettings/components/EditDetailsModal.js +149 -0
- package/cjs/OpenChannelSettings/components/EditDetailsModal.js.map +1 -0
- package/cjs/OpenChannelSettings/components/OpenChannelProfile.js +87 -0
- package/cjs/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -0
- package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js +126 -0
- package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -0
- package/cjs/OpenChannelSettings/components/OperatorUI.js +209 -0
- package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -0
- package/cjs/OpenChannelSettings/components/ParticipantUI.js +151 -0
- package/cjs/OpenChannelSettings/components/ParticipantUI.js.map +1 -0
- package/cjs/OpenChannelSettings/context.js +73 -0
- package/cjs/OpenChannelSettings/context.js.map +1 -0
- package/cjs/OpenChannelSettings.js +70 -0
- package/cjs/OpenChannelSettings.js.map +1 -0
- package/cjs/SendbirdProvider.js +790 -0
- package/cjs/SendbirdProvider.js.map +1 -0
- package/cjs/UserProfileContext-17c8f75c.js +46 -0
- package/cjs/UserProfileContext-17c8f75c.js.map +1 -0
- package/cjs/__bundle-7dfccc8c-c3c55861.js +151 -0
- package/cjs/__bundle-7dfccc8c-c3c55861.js.map +1 -0
- package/cjs/_rollupPluginBabelHelpers-d984e855.js +243 -0
- package/cjs/_rollupPluginBabelHelpers-d984e855.js.map +1 -0
- package/cjs/actionTypes-7a330bec.js +10 -0
- package/cjs/actionTypes-7a330bec.js.map +1 -0
- package/cjs/color-b30f84a2.js +42 -0
- package/cjs/color-b30f84a2.js.map +1 -0
- package/cjs/compareIds-d8053014.js +20 -0
- package/cjs/compareIds-d8053014.js.map +1 -0
- package/cjs/const-2623fae1.js +22 -0
- package/cjs/const-2623fae1.js.map +1 -0
- package/cjs/const-6aa26f9f.js +14 -0
- package/cjs/const-6aa26f9f.js.map +1 -0
- package/cjs/context-83ecdafd.js +19 -0
- package/cjs/context-83ecdafd.js.map +1 -0
- package/cjs/dist/index.css +4603 -0
- package/cjs/dist/index.css.map +1 -0
- package/cjs/groupChannel-e311e26a.js +9 -0
- package/cjs/groupChannel-e311e26a.js.map +1 -0
- package/cjs/index-1e14c5b9.js +130 -0
- package/cjs/index-1e14c5b9.js.map +1 -0
- package/cjs/index-2537cbc7.js +284 -0
- package/cjs/index-2537cbc7.js.map +1 -0
- package/cjs/index-40d245a3.js +729 -0
- package/cjs/index-40d245a3.js.map +1 -0
- package/cjs/index-5e7b82c2.js +178 -0
- package/cjs/index-5e7b82c2.js.map +1 -0
- package/cjs/index-72479c2a.js +514 -0
- package/cjs/index-72479c2a.js.map +1 -0
- package/cjs/index-ab5d906d.js +67 -0
- package/cjs/index-ab5d906d.js.map +1 -0
- package/cjs/index-cdcd27bc.js +1880 -0
- package/cjs/index-cdcd27bc.js.map +1 -0
- package/cjs/index-ce679d41.js +9 -0
- package/cjs/index-ce679d41.js.map +1 -0
- package/cjs/index-df05e765.js +142 -0
- package/cjs/index-df05e765.js.map +1 -0
- package/cjs/index-f9677913.js +97 -0
- package/cjs/index-f9677913.js.map +1 -0
- package/cjs/index.js +165 -0
- package/cjs/index.js.map +1 -0
- package/cjs/openChannel-e9f65946.js +13 -0
- package/cjs/openChannel-e9f65946.js.map +1 -0
- package/cjs/openChannelUtils-4b7d2697.js +97 -0
- package/cjs/openChannelUtils-4b7d2697.js.map +1 -0
- package/cjs/sendbirdSelectors.js +696 -0
- package/cjs/sendbirdSelectors.js.map +1 -0
- package/cjs/stringSet-2f3588b5.js +118 -0
- package/cjs/stringSet-2f3588b5.js.map +1 -0
- package/cjs/topics-582e38dc.js +18 -0
- package/cjs/topics-582e38dc.js.map +1 -0
- package/cjs/tslib.es6-d9c7aa8b.js +40 -0
- package/cjs/tslib.es6-d9c7aa8b.js.map +1 -0
- package/cjs/ui/Accordion.js +74 -0
- package/cjs/ui/Accordion.js.map +1 -0
- package/cjs/ui/AccordionGroup.js +32 -0
- package/cjs/ui/AccordionGroup.js.map +1 -0
- package/cjs/ui/AdminMessage.js +45 -0
- package/cjs/ui/AdminMessage.js.map +1 -0
- package/cjs/ui/Avatar.js +226 -0
- package/cjs/ui/Avatar.js.map +1 -0
- package/cjs/ui/Badge.js +45 -0
- package/cjs/ui/Badge.js.map +1 -0
- package/cjs/ui/Button.js +17 -0
- package/cjs/ui/Button.js.map +1 -0
- package/cjs/ui/ChannelAvatar.js +59 -0
- package/cjs/ui/ChannelAvatar.js.map +1 -0
- package/cjs/ui/ChannelPreview.js +208 -0
- package/cjs/ui/ChannelPreview.js.map +1 -0
- package/cjs/ui/ChatHeader.js +152 -0
- package/cjs/ui/ChatHeader.js.map +1 -0
- package/cjs/ui/Checkbox.js +49 -0
- package/cjs/ui/Checkbox.js.map +1 -0
- package/cjs/ui/ConnectionStatus.js +34 -0
- package/cjs/ui/ConnectionStatus.js.map +1 -0
- package/cjs/ui/ContextMenu.js +410 -0
- package/cjs/ui/ContextMenu.js.map +1 -0
- package/cjs/ui/DateSeparator.js +44 -0
- package/cjs/ui/DateSeparator.js.map +1 -0
- package/cjs/ui/Dropdown.js +107 -0
- package/cjs/ui/Dropdown.js.map +1 -0
- package/cjs/ui/EmojiReactions.js +127 -0
- package/cjs/ui/EmojiReactions.js.map +1 -0
- package/cjs/ui/FileMessageItemBody.js +57 -0
- package/cjs/ui/FileMessageItemBody.js.map +1 -0
- package/cjs/ui/FileViewer.js +174 -0
- package/cjs/ui/FileViewer.js.map +1 -0
- package/cjs/ui/Icon.js +1466 -0
- package/cjs/ui/Icon.js.map +1 -0
- package/cjs/ui/IconButton.js +83 -0
- package/cjs/ui/IconButton.js.map +1 -0
- package/cjs/ui/ImageRenderer.js +138 -0
- package/cjs/ui/ImageRenderer.js.map +1 -0
- package/cjs/ui/Input.js +74 -0
- package/cjs/ui/Input.js.map +1 -0
- package/cjs/ui/Label.js +17 -0
- package/cjs/ui/Label.js.map +1 -0
- package/cjs/ui/LinkLabel.js +51 -0
- package/cjs/ui/LinkLabel.js.map +1 -0
- package/cjs/ui/Loader.js +44 -0
- package/cjs/ui/Loader.js.map +1 -0
- package/cjs/ui/MentionLabel.js +100 -0
- package/cjs/ui/MentionLabel.js.map +1 -0
- package/cjs/ui/MentionUserLabel.js +25 -0
- package/cjs/ui/MentionUserLabel.js.map +1 -0
- package/cjs/ui/MessageContent.js +297 -0
- package/cjs/ui/MessageContent.js.map +1 -0
- package/cjs/ui/MessageInput.js +5052 -0
- package/cjs/ui/MessageInput.js.map +1 -0
- package/cjs/ui/MessageItemMenu.js +137 -0
- package/cjs/ui/MessageItemMenu.js.map +1 -0
- package/cjs/ui/MessageItemReactionMenu.js +112 -0
- package/cjs/ui/MessageItemReactionMenu.js.map +1 -0
- package/cjs/ui/MessageSearchFileItem.js +131 -0
- package/cjs/ui/MessageSearchFileItem.js.map +1 -0
- package/cjs/ui/MessageSearchItem.js +93 -0
- package/cjs/ui/MessageSearchItem.js.map +1 -0
- package/cjs/ui/MessageStatus.js +66 -0
- package/cjs/ui/MessageStatus.js.map +1 -0
- package/cjs/ui/Modal.js +140 -0
- package/cjs/ui/Modal.js.map +1 -0
- package/cjs/ui/MutedAvatarOverlay.js +40 -0
- package/cjs/ui/MutedAvatarOverlay.js.map +1 -0
- package/cjs/ui/OGMessageItemBody.js +119 -0
- package/cjs/ui/OGMessageItemBody.js.map +1 -0
- package/cjs/ui/OpenChannelAdminMessage.js +27 -0
- package/cjs/ui/OpenChannelAdminMessage.js.map +1 -0
- package/cjs/ui/OpenChannelAvatar.js +41 -0
- package/cjs/ui/OpenChannelAvatar.js.map +1 -0
- package/cjs/ui/OpenchannelConversationHeader.js +73 -0
- package/cjs/ui/OpenchannelConversationHeader.js.map +1 -0
- package/cjs/ui/OpenchannelFileMessage.js +231 -0
- package/cjs/ui/OpenchannelFileMessage.js.map +1 -0
- package/cjs/ui/OpenchannelOGMessage.js +346 -0
- package/cjs/ui/OpenchannelOGMessage.js.map +1 -0
- package/cjs/ui/OpenchannelThumbnailMessage.js +306 -0
- package/cjs/ui/OpenchannelThumbnailMessage.js.map +1 -0
- package/cjs/ui/OpenchannelUserMessage.js +265 -0
- package/cjs/ui/OpenchannelUserMessage.js.map +1 -0
- package/cjs/ui/PlaceHolder.js +20 -0
- package/cjs/ui/PlaceHolder.js.map +1 -0
- package/cjs/ui/QuoteMessage.js +131 -0
- package/cjs/ui/QuoteMessage.js.map +1 -0
- package/cjs/ui/QuoteMessageInput.js +97 -0
- package/cjs/ui/QuoteMessageInput.js.map +1 -0
- package/cjs/ui/ReactionBadge.js +68 -0
- package/cjs/ui/ReactionBadge.js.map +1 -0
- package/cjs/ui/ReactionButton.js +55 -0
- package/cjs/ui/ReactionButton.js.map +1 -0
- package/cjs/ui/SortByRow.js +57 -0
- package/cjs/ui/SortByRow.js.map +1 -0
- package/cjs/ui/TextButton.js +45 -0
- package/cjs/ui/TextButton.js.map +1 -0
- package/cjs/ui/TextMessageItemBody.js +76 -0
- package/cjs/ui/TextMessageItemBody.js.map +1 -0
- package/cjs/ui/ThumbnailMessageItemBody.js +82 -0
- package/cjs/ui/ThumbnailMessageItemBody.js.map +1 -0
- package/cjs/ui/Tooltip.js +35 -0
- package/cjs/ui/Tooltip.js.map +1 -0
- package/cjs/ui/TooltipWrapper.js +65 -0
- package/cjs/ui/TooltipWrapper.js.map +1 -0
- package/cjs/ui/UnknownMessageItemBody.js +41 -0
- package/cjs/ui/UnknownMessageItemBody.js.map +1 -0
- package/cjs/ui/UserListItem.js +159 -0
- package/cjs/ui/UserListItem.js.map +1 -0
- package/cjs/ui/UserProfile.js +88 -0
- package/cjs/ui/UserProfile.js.map +1 -0
- package/cjs/ui/Word.js +76 -0
- package/cjs/ui/Word.js.map +1 -0
- package/cjs/useSendbirdStateContext.js +22 -0
- package/cjs/useSendbirdStateContext.js.map +1 -0
- package/cjs/utils-031aba48.js +6 -0
- package/cjs/utils-031aba48.js.map +1 -0
- package/cjs/utils-510b93ac.js +38 -0
- package/cjs/utils-510b93ac.js.map +1 -0
- package/cjs/utils-689065e6.js +32 -0
- package/cjs/utils-689065e6.js.map +1 -0
- package/cjs/uuid-099485ae.js +19 -0
- package/cjs/uuid-099485ae.js.map +1 -0
- package/cjs/withSendBird.js +35 -0
- package/cjs/withSendBird.js.map +1 -0
- package/color-9bf8c922.js +39 -0
- package/color-9bf8c922.js.map +1 -0
- package/compareIds-b78d7cd6.js +18 -0
- package/compareIds-b78d7cd6.js.map +1 -0
- package/const-40b58d8b.js +18 -0
- package/const-40b58d8b.js.map +1 -0
- package/const-99800b8d.js +8 -0
- package/const-99800b8d.js.map +1 -0
- package/context-bedea43b.js +12 -0
- package/context-bedea43b.js.map +1 -0
- package/dist/index.css +292 -152
- package/dist/index.css.map +1 -1
- package/groupChannel-96502de7.js +6 -0
- package/groupChannel-96502de7.js.map +1 -0
- package/index-13729368.js +512 -0
- package/index-13729368.js.map +1 -0
- package/index-16bed610.js +64 -0
- package/index-16bed610.js.map +1 -0
- package/index-1d112ad4.js +7 -0
- package/index-1d112ad4.js.map +1 -0
- package/index-71ad343b.js +171 -0
- package/index-71ad343b.js.map +1 -0
- package/index-71e2bf26.js +131 -0
- package/index-71e2bf26.js.map +1 -0
- package/index-8e6a607b.js +688 -0
- package/index-8e6a607b.js.map +1 -0
- package/index-a5e8849a.js +280 -0
- package/index-a5e8849a.js.map +1 -0
- package/index-b574cc8e.js +87 -0
- package/index-b574cc8e.js.map +1 -0
- package/index-c95d2aab.js +121 -0
- package/index-c95d2aab.js.map +1 -0
- package/index-ccd99cfe.js +1873 -0
- package/index-ccd99cfe.js.map +1 -0
- package/index.d.ts +1965 -0
- package/index.d.ts_bkup +1883 -0
- package/index.js +146 -0
- package/index.js.map +1 -0
- package/openChannel-dd5c9246.js +8 -0
- package/openChannel-dd5c9246.js.map +1 -0
- package/openChannelUtils-211a679a.js +86 -0
- package/openChannelUtils-211a679a.js.map +1 -0
- package/package.json +11 -33
- package/sendbirdSelectors.js +671 -0
- package/sendbirdSelectors.js.map +1 -0
- package/stringSet-d3a8a2a0.js +116 -0
- package/stringSet-d3a8a2a0.js.map +1 -0
- package/topics-f941ba80.js +10 -0
- package/topics-f941ba80.js.map +1 -0
- package/tslib.es6-a7db0cc5.js +38 -0
- package/tslib.es6-a7db0cc5.js.map +1 -0
- package/ui/Accordion.js +65 -0
- package/ui/Accordion.js.map +1 -0
- package/ui/AccordionGroup.js +26 -0
- package/ui/AccordionGroup.js.map +1 -0
- package/ui/AdminMessage.js +38 -0
- package/ui/AdminMessage.js.map +1 -0
- package/ui/Avatar.js +217 -0
- package/ui/Avatar.js.map +1 -0
- package/ui/Badge.js +38 -0
- package/ui/Badge.js.map +1 -0
- package/ui/Button.js +7 -0
- package/ui/Button.js.map +1 -0
- package/ui/ChannelAvatar.js +53 -0
- package/ui/ChannelAvatar.js.map +1 -0
- package/ui/ChannelPreview.js +201 -0
- package/ui/ChannelPreview.js.map +1 -0
- package/ui/ChatHeader.js +145 -0
- package/ui/ChatHeader.js.map +1 -0
- package/ui/Checkbox.js +42 -0
- package/ui/Checkbox.js.map +1 -0
- package/ui/ConnectionStatus.js +28 -0
- package/ui/ConnectionStatus.js.map +1 -0
- package/ui/ContextMenu.js +396 -0
- package/ui/ContextMenu.js.map +1 -0
- package/ui/DateSeparator.js +37 -0
- package/ui/DateSeparator.js.map +1 -0
- package/ui/Dropdown.js +97 -0
- package/ui/Dropdown.js.map +1 -0
- package/ui/EmojiReactions.js +121 -0
- package/ui/EmojiReactions.js.map +1 -0
- package/ui/FileMessageItemBody.js +51 -0
- package/ui/FileMessageItemBody.js.map +1 -0
- package/ui/FileViewer.js +164 -0
- package/ui/FileViewer.js.map +1 -0
- package/ui/Icon.js +1436 -0
- package/ui/Icon.js.map +1 -0
- package/ui/IconButton.js +76 -0
- package/ui/IconButton.js.map +1 -0
- package/ui/ImageRenderer.js +131 -0
- package/ui/ImageRenderer.js.map +1 -0
- package/ui/Input.js +64 -0
- package/ui/Input.js.map +1 -0
- package/ui/Label.js +6 -0
- package/ui/Label.js.map +1 -0
- package/ui/LinkLabel.js +40 -0
- package/ui/LinkLabel.js.map +1 -0
- package/ui/Loader.js +37 -0
- package/ui/Loader.js.map +1 -0
- package/ui/MentionLabel.js +94 -0
- package/ui/MentionLabel.js.map +1 -0
- package/ui/MentionUserLabel.js +19 -0
- package/ui/MentionUserLabel.js.map +1 -0
- package/ui/MessageContent.js +291 -0
- package/ui/MessageContent.js.map +1 -0
- package/ui/MessageInput.js +5044 -0
- package/ui/MessageInput.js.map +1 -0
- package/ui/MessageItemMenu.js +131 -0
- package/ui/MessageItemMenu.js.map +1 -0
- package/ui/MessageItemReactionMenu.js +106 -0
- package/ui/MessageItemReactionMenu.js.map +1 -0
- package/ui/MessageSearchFileItem.js +125 -0
- package/ui/MessageSearchFileItem.js.map +1 -0
- package/ui/MessageSearchItem.js +87 -0
- package/ui/MessageSearchItem.js.map +1 -0
- package/ui/MessageStatus.js +57 -0
- package/ui/MessageStatus.js.map +1 -0
- package/ui/Modal.js +128 -0
- package/ui/Modal.js.map +1 -0
- package/ui/MutedAvatarOverlay.js +34 -0
- package/ui/MutedAvatarOverlay.js.map +1 -0
- package/ui/OGMessageItemBody.js +113 -0
- package/ui/OGMessageItemBody.js.map +1 -0
- package/ui/OpenChannelAdminMessage.js +21 -0
- package/ui/OpenChannelAdminMessage.js.map +1 -0
- package/ui/OpenChannelAvatar.js +35 -0
- package/ui/OpenChannelAvatar.js.map +1 -0
- package/ui/OpenchannelConversationHeader.js +67 -0
- package/ui/OpenchannelConversationHeader.js.map +1 -0
- package/ui/OpenchannelFileMessage.js +225 -0
- package/ui/OpenchannelFileMessage.js.map +1 -0
- package/ui/OpenchannelOGMessage.js +340 -0
- package/ui/OpenchannelOGMessage.js.map +1 -0
- package/ui/OpenchannelThumbnailMessage.js +300 -0
- package/ui/OpenchannelThumbnailMessage.js.map +1 -0
- package/ui/OpenchannelUserMessage.js +259 -0
- package/ui/OpenchannelUserMessage.js.map +1 -0
- package/ui/PlaceHolder.js +11 -0
- package/ui/PlaceHolder.js.map +1 -0
- package/ui/QuoteMessage.js +125 -0
- package/ui/QuoteMessage.js.map +1 -0
- package/ui/QuoteMessageInput.js +91 -0
- package/ui/QuoteMessageInput.js.map +1 -0
- package/ui/ReactionBadge.js +61 -0
- package/ui/ReactionBadge.js.map +1 -0
- package/ui/ReactionButton.js +48 -0
- package/ui/ReactionButton.js.map +1 -0
- package/ui/SortByRow.js +50 -0
- package/ui/SortByRow.js.map +1 -0
- package/ui/TextButton.js +38 -0
- package/ui/TextButton.js.map +1 -0
- package/ui/TextMessageItemBody.js +70 -0
- package/ui/TextMessageItemBody.js.map +1 -0
- package/ui/ThumbnailMessageItemBody.js +76 -0
- package/ui/ThumbnailMessageItemBody.js.map +1 -0
- package/ui/Tooltip.js +28 -0
- package/ui/Tooltip.js.map +1 -0
- package/ui/TooltipWrapper.js +58 -0
- package/ui/TooltipWrapper.js.map +1 -0
- package/ui/UnknownMessageItemBody.js +35 -0
- package/ui/UnknownMessageItemBody.js.map +1 -0
- package/ui/UserListItem.js +152 -0
- package/ui/UserListItem.js.map +1 -0
- package/ui/UserProfile.js +82 -0
- package/ui/UserProfile.js.map +1 -0
- package/ui/Word.js +70 -0
- package/ui/Word.js.map +1 -0
- package/useSendbirdStateContext.js +20 -0
- package/useSendbirdStateContext.js.map +1 -0
- package/utils-2e3623c0.js +30 -0
- package/utils-2e3623c0.js.map +1 -0
- package/utils-cadde06a.js +4 -0
- package/utils-cadde06a.js.map +1 -0
- package/utils-d9325ddf.js +34 -0
- package/utils-d9325ddf.js.map +1 -0
- package/uuid-748dae7a.js +17 -0
- package/uuid-748dae7a.js.map +1 -0
- package/withSendBird.js +26 -0
- package/withSendBird.js.map +1 -0
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
import { a as __spreadArray } from '../tslib.es6-a7db0cc5.js';
|
|
2
|
+
import React__default, { useRef, useContext } from 'react';
|
|
3
|
+
import { f as format } from '../index-ccd99cfe.js';
|
|
4
|
+
import Avatar from './Avatar.js';
|
|
5
|
+
import ContextMenu, { MenuItems, MenuItem } from './ContextMenu.js';
|
|
6
|
+
import { L as Label, a as LabelTypography, b as LabelColors } from '../index-71e2bf26.js';
|
|
7
|
+
import Loader from './Loader.js';
|
|
8
|
+
import Icon, { IconTypes, IconColors } from './Icon.js';
|
|
9
|
+
import IconButton from './IconButton.js';
|
|
10
|
+
import TextButton from './TextButton.js';
|
|
11
|
+
import ConnectedUserProfile from './UserProfile.js';
|
|
12
|
+
import { a as UserProfileContext } from '../UserProfileContext-6a387a08.js';
|
|
13
|
+
import { u as useLocalization } from '../LocalizationContext-fb3dafcd.js';
|
|
14
|
+
import { c as checkIsByMe, g as getSenderFromMessage, s as showMenuTrigger, b as isFineResend, d as isFineDelete, e as checkIsPending, f as checkIsFailed } from '../openChannelUtils-211a679a.js';
|
|
15
|
+
import '../index-13729368.js';
|
|
16
|
+
import './ImageRenderer.js';
|
|
17
|
+
import '../_rollupPluginBabelHelpers-084fb589.js';
|
|
18
|
+
import 'prop-types';
|
|
19
|
+
import '../uuid-748dae7a.js';
|
|
20
|
+
import '../index-8e6a607b.js';
|
|
21
|
+
import 'react-dom';
|
|
22
|
+
import './SortByRow.js';
|
|
23
|
+
import '../stringSet-d3a8a2a0.js';
|
|
24
|
+
import '../color-9bf8c922.js';
|
|
25
|
+
import '../withSendBird.js';
|
|
26
|
+
import '../sendbirdSelectors.js';
|
|
27
|
+
import '../topics-f941ba80.js';
|
|
28
|
+
import '../utils-cadde06a.js';
|
|
29
|
+
import '../index-b574cc8e.js';
|
|
30
|
+
|
|
31
|
+
var checkFileType = function checkFileType(fileUrl) {
|
|
32
|
+
var audioFile = /(\.mp3)$/i;
|
|
33
|
+
var gifFile = /(\.gif)$/i;
|
|
34
|
+
|
|
35
|
+
if (audioFile.test(fileUrl)) {
|
|
36
|
+
return IconTypes.FILE_AUDIO;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
if (gifFile.test(fileUrl)) {
|
|
40
|
+
return IconTypes.GIF;
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
return IconTypes.FILE_DOCUMENT;
|
|
44
|
+
};
|
|
45
|
+
var truncate = function truncate(fullStr, strLen) {
|
|
46
|
+
if (fullStr === null || fullStr === undefined) return '';
|
|
47
|
+
if (fullStr.length <= strLen) return fullStr;
|
|
48
|
+
var separator = '...';
|
|
49
|
+
var sepLen = separator.length;
|
|
50
|
+
var charsToShow = strLen - sepLen;
|
|
51
|
+
var frontChars = Math.ceil(charsToShow / 2);
|
|
52
|
+
var backChars = Math.floor(charsToShow / 2);
|
|
53
|
+
return fullStr.substr(0, frontChars) + separator + fullStr.substr(fullStr.length - backChars);
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
function OpenchannelFileMessage(_a) {
|
|
57
|
+
var className = _a.className,
|
|
58
|
+
message = _a.message,
|
|
59
|
+
userId = _a.userId,
|
|
60
|
+
disabled = _a.disabled,
|
|
61
|
+
chainTop = _a.chainTop,
|
|
62
|
+
showRemove = _a.showRemove,
|
|
63
|
+
resendMessage = _a.resendMessage;
|
|
64
|
+
var status = message === null || message === void 0 ? void 0 : message.sendingStatus;
|
|
65
|
+
|
|
66
|
+
var _b = useLocalization(),
|
|
67
|
+
dateLocale = _b.dateLocale,
|
|
68
|
+
stringSet = _b.stringSet;
|
|
69
|
+
|
|
70
|
+
var contextMenuRef = useRef(null);
|
|
71
|
+
var avatarRef = useRef(null);
|
|
72
|
+
|
|
73
|
+
var _c = useContext(UserProfileContext),
|
|
74
|
+
disableUserProfile = _c.disableUserProfile,
|
|
75
|
+
renderUserProfile = _c.renderUserProfile;
|
|
76
|
+
|
|
77
|
+
var openFileUrl = function openFileUrl() {
|
|
78
|
+
window.open(message.url);
|
|
79
|
+
};
|
|
80
|
+
|
|
81
|
+
var isByMe = checkIsByMe(message, userId);
|
|
82
|
+
var isPending = checkIsPending(status);
|
|
83
|
+
var isFailed = checkIsFailed(status);
|
|
84
|
+
var sender = getSenderFromMessage(message);
|
|
85
|
+
return /*#__PURE__*/React__default.createElement("div", {
|
|
86
|
+
className: __spreadArray(__spreadArray([], Array.isArray(className) ? className : [className], true), ['sendbird-openchannel-file-message'], false).join(' ')
|
|
87
|
+
}, /*#__PURE__*/React__default.createElement("div", {
|
|
88
|
+
className: "sendbird-openchannel-file-message__left"
|
|
89
|
+
}, !chainTop && /*#__PURE__*/React__default.createElement(ContextMenu, {
|
|
90
|
+
menuTrigger: function menuTrigger(toggleDropdown) {
|
|
91
|
+
return /*#__PURE__*/React__default.createElement(Avatar, {
|
|
92
|
+
className: "sendbird-openchannel-file-message__left__avatar",
|
|
93
|
+
src: sender.profileUrl || '',
|
|
94
|
+
ref: avatarRef,
|
|
95
|
+
width: "28px",
|
|
96
|
+
height: "28px",
|
|
97
|
+
onClick: function onClick() {
|
|
98
|
+
if (!disableUserProfile) {
|
|
99
|
+
toggleDropdown();
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
});
|
|
103
|
+
},
|
|
104
|
+
menuItems: function menuItems(closeDropdown) {
|
|
105
|
+
return /*#__PURE__*/React__default.createElement(MenuItems, {
|
|
106
|
+
parentRef: avatarRef,
|
|
107
|
+
parentContainRef: avatarRef,
|
|
108
|
+
closeDropdown: closeDropdown,
|
|
109
|
+
style: {
|
|
110
|
+
paddingTop: 0,
|
|
111
|
+
paddingBottom: 0
|
|
112
|
+
}
|
|
113
|
+
}, renderUserProfile ? renderUserProfile({
|
|
114
|
+
user: sender,
|
|
115
|
+
close: closeDropdown
|
|
116
|
+
}) : /*#__PURE__*/React__default.createElement(ConnectedUserProfile, {
|
|
117
|
+
user: sender,
|
|
118
|
+
onSuccess: closeDropdown,
|
|
119
|
+
disableMessaging: true
|
|
120
|
+
}));
|
|
121
|
+
}
|
|
122
|
+
})), /*#__PURE__*/React__default.createElement("div", {
|
|
123
|
+
className: "sendbird-openchannel-file-message__right"
|
|
124
|
+
}, !chainTop && /*#__PURE__*/React__default.createElement("div", {
|
|
125
|
+
className: "sendbird-openchannel-file-message__right__title"
|
|
126
|
+
}, /*#__PURE__*/React__default.createElement(Label, {
|
|
127
|
+
className: "sendbird-openchannel-file-message__right__title__sender-name",
|
|
128
|
+
type: LabelTypography.CAPTION_2,
|
|
129
|
+
color: isByMe ? LabelColors.SECONDARY_3 : LabelColors.ONBACKGROUND_2
|
|
130
|
+
}, sender && (sender.friendName || sender.nickname || sender.userId)), /*#__PURE__*/React__default.createElement(Label, {
|
|
131
|
+
className: "sendbird-openchannel-file-message__right__title__sent-at",
|
|
132
|
+
type: LabelTypography.CAPTION_3,
|
|
133
|
+
color: LabelColors.ONBACKGROUND_3
|
|
134
|
+
}, (message === null || message === void 0 ? void 0 : message.createdAt) && format(message.createdAt, 'p', {
|
|
135
|
+
locale: dateLocale
|
|
136
|
+
}))), /*#__PURE__*/React__default.createElement("div", {
|
|
137
|
+
className: "sendbird-openchannel-file-message__right__body"
|
|
138
|
+
}, checkFileType(message.url) && /*#__PURE__*/React__default.createElement(Icon, {
|
|
139
|
+
className: "sendbird-openchannel-file-message__right__body__icon",
|
|
140
|
+
type: checkFileType(message.url),
|
|
141
|
+
fillColor: IconColors.PRIMARY,
|
|
142
|
+
width: "48px",
|
|
143
|
+
height: "48px"
|
|
144
|
+
}), /*#__PURE__*/React__default.createElement(TextButton, {
|
|
145
|
+
className: "sendbird-openchannel-file-message__right__body__file-name",
|
|
146
|
+
onClick: openFileUrl
|
|
147
|
+
}, /*#__PURE__*/React__default.createElement(Label, {
|
|
148
|
+
type: LabelTypography.BODY_1,
|
|
149
|
+
color: LabelColors.ONBACKGROUND_1
|
|
150
|
+
}, truncate(message.name || message.url, 40)))), (isPending || isFailed) && /*#__PURE__*/React__default.createElement("div", {
|
|
151
|
+
className: "sendbird-openchannel-file-message__right__tail"
|
|
152
|
+
}, isPending && /*#__PURE__*/React__default.createElement(Loader, {
|
|
153
|
+
width: "16px",
|
|
154
|
+
height: "16px"
|
|
155
|
+
}, /*#__PURE__*/React__default.createElement(Icon, {
|
|
156
|
+
className: "sendbird-openchannel-file-message__right__tail__pending",
|
|
157
|
+
type: IconTypes.SPINNER,
|
|
158
|
+
fillColor: IconColors.PRIMARY,
|
|
159
|
+
width: "16px",
|
|
160
|
+
height: "16px"
|
|
161
|
+
})), isFailed && /*#__PURE__*/React__default.createElement(Icon, {
|
|
162
|
+
className: "sendbird-openchannel-file-message__right__tail__failed",
|
|
163
|
+
type: IconTypes.ERROR,
|
|
164
|
+
fillColor: IconColors.ERROR,
|
|
165
|
+
width: "16px",
|
|
166
|
+
height: "16px"
|
|
167
|
+
}))), /*#__PURE__*/React__default.createElement("div", {
|
|
168
|
+
className: "sendbird-openchannel-file-message__context-menu",
|
|
169
|
+
ref: contextMenuRef
|
|
170
|
+
}, /*#__PURE__*/React__default.createElement(ContextMenu, {
|
|
171
|
+
menuTrigger: function menuTrigger(toggleDropdown) {
|
|
172
|
+
return showMenuTrigger({
|
|
173
|
+
message: message,
|
|
174
|
+
userId: userId,
|
|
175
|
+
status: status
|
|
176
|
+
}) && /*#__PURE__*/React__default.createElement(IconButton, {
|
|
177
|
+
className: "sendbird-openchannel-file-message__context-menu__icon",
|
|
178
|
+
width: "32px",
|
|
179
|
+
height: "32px",
|
|
180
|
+
onClick: toggleDropdown
|
|
181
|
+
}, /*#__PURE__*/React__default.createElement(Icon, {
|
|
182
|
+
type: IconTypes.MORE,
|
|
183
|
+
width: "24px",
|
|
184
|
+
height: "24px"
|
|
185
|
+
}));
|
|
186
|
+
},
|
|
187
|
+
menuItems: function menuItems(closeDropdown) {
|
|
188
|
+
return /*#__PURE__*/React__default.createElement(MenuItems, {
|
|
189
|
+
parentRef: contextMenuRef,
|
|
190
|
+
parentContainRef: contextMenuRef,
|
|
191
|
+
closeDropdown: closeDropdown,
|
|
192
|
+
openLeft: true
|
|
193
|
+
}, isFineResend({
|
|
194
|
+
message: message,
|
|
195
|
+
userId: userId,
|
|
196
|
+
status: status
|
|
197
|
+
}) && /*#__PURE__*/React__default.createElement(MenuItem, {
|
|
198
|
+
onClick: function onClick() {
|
|
199
|
+
if (disabled) {
|
|
200
|
+
return;
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
resendMessage(message);
|
|
204
|
+
closeDropdown();
|
|
205
|
+
}
|
|
206
|
+
}, stringSet.CONTEXT_MENU_DROPDOWN__RESEND), isFineDelete({
|
|
207
|
+
message: message,
|
|
208
|
+
userId: userId,
|
|
209
|
+
status: status
|
|
210
|
+
}) && /*#__PURE__*/React__default.createElement(MenuItem, {
|
|
211
|
+
onClick: function onClick() {
|
|
212
|
+
if (disabled) {
|
|
213
|
+
return;
|
|
214
|
+
}
|
|
215
|
+
|
|
216
|
+
showRemove(true);
|
|
217
|
+
closeDropdown();
|
|
218
|
+
}
|
|
219
|
+
}, stringSet.CONTEXT_MENU_DROPDOWN__DELETE));
|
|
220
|
+
}
|
|
221
|
+
})));
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
export { OpenchannelFileMessage as default };
|
|
225
|
+
//# sourceMappingURL=OpenchannelFileMessage.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OpenchannelFileMessage.js","sources":["../../src/ui/OpenchannelFileMessage/utils.ts","../../src/ui/OpenchannelFileMessage/index.tsx"],"sourcesContent":["import { IconTypes } from '../Icon';\n\nexport const checkFileType = (fileUrl: string): string => {\n const audioFile = /(\\.mp3)$/i;\n const gifFile = /(\\.gif)$/i;\n if (audioFile.test(fileUrl)) {\n return IconTypes.FILE_AUDIO;\n }\n if (gifFile.test(fileUrl)) {\n return IconTypes.GIF\n }\n return IconTypes.FILE_DOCUMENT;\n}\n\nexport const truncate = (fullStr:string, strLen: number): string => {\n if (fullStr === null || fullStr === undefined) return '';\n if (fullStr.length <= strLen) return fullStr;\n const separator = '...';\n const sepLen = separator.length;\n const charsToShow = strLen - sepLen;\n const frontChars = Math.ceil(charsToShow / 2);\n const backChars = Math.floor(charsToShow / 2);\n return fullStr.substr(0, frontChars) + separator + fullStr.substr(fullStr.length - backChars);\n};\n","import React, { useContext, useRef } from 'react';\nimport { 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","toggleDropdown","profileUrl","closeDropdown","paddingTop","paddingBottom","user","close","UserProfile","LabelTypography","CAPTION_2","LabelColors","SECONDARY_3","ONBACKGROUND_2","friendName","nickname","CAPTION_3","ONBACKGROUND_3","createdAt","format","locale","IconColors","PRIMARY","BODY_1","ONBACKGROUND_1","name","SPINNER","ERROR","showMenuTrigger","MORE","isFineResend","CONTEXT_MENU_DROPDOWN__RESEND","isFineDelete","CONTEXT_MENU_DROPDOWN__DELETE"],"mappings":"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"}
|
|
@@ -0,0 +1,340 @@
|
|
|
1
|
+
import { a as __spreadArray } from '../tslib.es6-a7db0cc5.js';
|
|
2
|
+
import React__default, { useContext, useState, useRef, useMemo, useEffect } from 'react';
|
|
3
|
+
import { f as format } from '../index-ccd99cfe.js';
|
|
4
|
+
import Avatar from './Avatar.js';
|
|
5
|
+
import ContextMenu, { MenuItems, MenuItem } from './ContextMenu.js';
|
|
6
|
+
import Icon, { IconTypes, IconColors } from './Icon.js';
|
|
7
|
+
import IconButton from './IconButton.js';
|
|
8
|
+
import ImageRenderer from './ImageRenderer.js';
|
|
9
|
+
import LinkLabel from './LinkLabel.js';
|
|
10
|
+
import { a as LabelTypography, b as LabelColors, L as Label } from '../index-71e2bf26.js';
|
|
11
|
+
import Loader from './Loader.js';
|
|
12
|
+
import ConnectedUserProfile from './UserProfile.js';
|
|
13
|
+
import { a as UserProfileContext } from '../UserProfileContext-6a387a08.js';
|
|
14
|
+
import { u as uuidv4 } from '../uuid-748dae7a.js';
|
|
15
|
+
import { c as copyToClipboard } from '../utils-2e3623c0.js';
|
|
16
|
+
import { u as useLocalization } from '../LocalizationContext-fb3dafcd.js';
|
|
17
|
+
import { c as checkIsByMe, g as getSenderFromMessage, s as showMenuTrigger, i as isFineCopy, a as isFineEdit, b as isFineResend, d as isFineDelete, e as checkIsPending, f as checkIsFailed } from '../openChannelUtils-211a679a.js';
|
|
18
|
+
import '../index-13729368.js';
|
|
19
|
+
import '../_rollupPluginBabelHelpers-084fb589.js';
|
|
20
|
+
import 'prop-types';
|
|
21
|
+
import '../index-8e6a607b.js';
|
|
22
|
+
import 'react-dom';
|
|
23
|
+
import './SortByRow.js';
|
|
24
|
+
import '../stringSet-d3a8a2a0.js';
|
|
25
|
+
import '../withSendBird.js';
|
|
26
|
+
import '../sendbirdSelectors.js';
|
|
27
|
+
import '../topics-f941ba80.js';
|
|
28
|
+
import '../utils-cadde06a.js';
|
|
29
|
+
import '../index-b574cc8e.js';
|
|
30
|
+
|
|
31
|
+
var URL_REG = /[-a-zA-Z0-9@:%._+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_+.~#?&//=]*)/;
|
|
32
|
+
var createUrlTester = function createUrlTester(regexp) {
|
|
33
|
+
return function (text) {
|
|
34
|
+
return regexp.test(text);
|
|
35
|
+
};
|
|
36
|
+
};
|
|
37
|
+
var checkOGIsEnalbed = function checkOGIsEnalbed(message) {
|
|
38
|
+
var ogMetaData = message.ogMetaData;
|
|
39
|
+
|
|
40
|
+
if (!ogMetaData) {
|
|
41
|
+
return false;
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
var url = ogMetaData.url;
|
|
45
|
+
|
|
46
|
+
if (!url) {
|
|
47
|
+
return false;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
return true;
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
function OpenchannelOGMessage(_a) {
|
|
54
|
+
var message = _a.message,
|
|
55
|
+
className = _a.className,
|
|
56
|
+
disabled = _a.disabled,
|
|
57
|
+
showEdit = _a.showEdit,
|
|
58
|
+
showRemove = _a.showRemove,
|
|
59
|
+
resendMessage = _a.resendMessage,
|
|
60
|
+
chainTop = _a.chainTop,
|
|
61
|
+
userId = _a.userId;
|
|
62
|
+
|
|
63
|
+
if (!message || message.messageType !== 'user') {
|
|
64
|
+
return null;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
var status = message === null || message === void 0 ? void 0 : message.sendingStatus;
|
|
68
|
+
var ogMetaData = message.ogMetaData;
|
|
69
|
+
var defaultImage = ogMetaData.defaultImage;
|
|
70
|
+
|
|
71
|
+
var _b = useLocalization(),
|
|
72
|
+
stringSet = _b.stringSet,
|
|
73
|
+
dateLocale = _b.dateLocale;
|
|
74
|
+
|
|
75
|
+
var _c = useContext(UserProfileContext),
|
|
76
|
+
disableUserProfile = _c.disableUserProfile,
|
|
77
|
+
renderUserProfile = _c.renderUserProfile;
|
|
78
|
+
|
|
79
|
+
var _d = useState({}),
|
|
80
|
+
contextStyle = _d[0],
|
|
81
|
+
setContextStyle = _d[1];
|
|
82
|
+
|
|
83
|
+
var messageComponentRef = useRef(null);
|
|
84
|
+
var contextMenuRef = useRef(null);
|
|
85
|
+
var avatarRef = useRef(null);
|
|
86
|
+
var isUrl = createUrlTester(URL_REG);
|
|
87
|
+
var isByMe = checkIsByMe(message, userId);
|
|
88
|
+
var isPending = checkIsPending(status);
|
|
89
|
+
var isFailed = checkIsFailed(status);
|
|
90
|
+
var sender = getSenderFromMessage(message);
|
|
91
|
+
var MemoizedMessageText = useMemo(function () {
|
|
92
|
+
return function () {
|
|
93
|
+
var wordClassName = 'sendbird-openchannel-og-message--word';
|
|
94
|
+
var splitMessage = message.message.split(' ');
|
|
95
|
+
var matchedMessage = splitMessage.map(function (word) {
|
|
96
|
+
return isUrl(word) ? /*#__PURE__*/React__default.createElement(LinkLabel, {
|
|
97
|
+
key: uuidv4(),
|
|
98
|
+
className: [wordClassName, 'sendbird-openchannel-og-message--word--link'],
|
|
99
|
+
src: word,
|
|
100
|
+
type: LabelTypography.BODY_1,
|
|
101
|
+
color: LabelColors.PRIMARY
|
|
102
|
+
}, word) : /*#__PURE__*/React__default.createElement(Label, {
|
|
103
|
+
key: uuidv4(),
|
|
104
|
+
className: wordClassName,
|
|
105
|
+
type: LabelTypography.BODY_1,
|
|
106
|
+
color: LabelColors.ONBACKGROUND_1
|
|
107
|
+
}, word);
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
if (message.updatedAt > 0) {
|
|
111
|
+
matchedMessage.push( /*#__PURE__*/React__default.createElement(Label, {
|
|
112
|
+
key: uuidv4(),
|
|
113
|
+
className: wordClassName,
|
|
114
|
+
type: LabelTypography.BODY_1,
|
|
115
|
+
color: LabelColors.ONBACKGROUND_2
|
|
116
|
+
}, stringSet.MESSAGE_EDITED));
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
return matchedMessage;
|
|
120
|
+
};
|
|
121
|
+
}, [message, message.updatedAt]);
|
|
122
|
+
|
|
123
|
+
var openLink = function openLink() {
|
|
124
|
+
if (checkOGIsEnalbed(message)) {
|
|
125
|
+
var url = ogMetaData.url;
|
|
126
|
+
window.open(url);
|
|
127
|
+
}
|
|
128
|
+
}; // place conxt menu top depending clientHeight of message component
|
|
129
|
+
|
|
130
|
+
|
|
131
|
+
useEffect(function () {
|
|
132
|
+
var _a;
|
|
133
|
+
|
|
134
|
+
if (((_a = messageComponentRef === null || messageComponentRef === void 0 ? void 0 : messageComponentRef.current) === null || _a === void 0 ? void 0 : _a.clientHeight) > 36) {
|
|
135
|
+
setContextStyle({
|
|
136
|
+
top: '8px '
|
|
137
|
+
});
|
|
138
|
+
} else {
|
|
139
|
+
setContextStyle({
|
|
140
|
+
top: '2px'
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
}, [window.innerWidth]);
|
|
144
|
+
return /*#__PURE__*/React__default.createElement("div", {
|
|
145
|
+
className: __spreadArray(__spreadArray([], Array.isArray(className) ? className : [className], true), ['sendbird-openchannel-og-message'], false).join(' '),
|
|
146
|
+
ref: messageComponentRef
|
|
147
|
+
}, /*#__PURE__*/React__default.createElement("div", {
|
|
148
|
+
className: "sendbird-openchannel-og-message__top"
|
|
149
|
+
}, /*#__PURE__*/React__default.createElement("div", {
|
|
150
|
+
className: "sendbird-openchannel-og-message__top__left"
|
|
151
|
+
}, !chainTop && /*#__PURE__*/React__default.createElement(ContextMenu, {
|
|
152
|
+
menuTrigger: function menuTrigger(toggleDropdown) {
|
|
153
|
+
return /*#__PURE__*/React__default.createElement(Avatar, {
|
|
154
|
+
className: "sendbird-openchannel-og-message__top__left__avatar",
|
|
155
|
+
src: sender.profileUrl || '',
|
|
156
|
+
ref: avatarRef,
|
|
157
|
+
width: "28px",
|
|
158
|
+
height: "28px",
|
|
159
|
+
onClick: function onClick() {
|
|
160
|
+
if (!disableUserProfile) {
|
|
161
|
+
toggleDropdown();
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
});
|
|
165
|
+
},
|
|
166
|
+
menuItems: function menuItems(closeDropdown) {
|
|
167
|
+
return /*#__PURE__*/React__default.createElement(MenuItems, {
|
|
168
|
+
parentRef: avatarRef,
|
|
169
|
+
parentContainRef: avatarRef,
|
|
170
|
+
closeDropdown: closeDropdown,
|
|
171
|
+
style: {
|
|
172
|
+
paddingTop: 0,
|
|
173
|
+
paddingBottom: 0
|
|
174
|
+
}
|
|
175
|
+
}, renderUserProfile ? renderUserProfile({
|
|
176
|
+
user: sender,
|
|
177
|
+
close: closeDropdown
|
|
178
|
+
}) : /*#__PURE__*/React__default.createElement(ConnectedUserProfile, {
|
|
179
|
+
user: sender,
|
|
180
|
+
onSuccess: closeDropdown,
|
|
181
|
+
disableMessaging: true
|
|
182
|
+
}));
|
|
183
|
+
}
|
|
184
|
+
})), /*#__PURE__*/React__default.createElement("div", {
|
|
185
|
+
className: "sendbird-openchannel-og-message__top__right"
|
|
186
|
+
}, !chainTop && /*#__PURE__*/React__default.createElement("div", {
|
|
187
|
+
className: "sendbird-openchannel-og-message__top__right__title"
|
|
188
|
+
}, /*#__PURE__*/React__default.createElement(Label, {
|
|
189
|
+
className: "sendbird-openchannel-og-message__top__right__title__sender-name",
|
|
190
|
+
type: LabelTypography.CAPTION_2,
|
|
191
|
+
color: isByMe ? LabelColors.SECONDARY_3 : LabelColors.ONBACKGROUND_2
|
|
192
|
+
}, sender && (sender.friendName || sender.nickname || sender.userId)), /*#__PURE__*/React__default.createElement(Label, {
|
|
193
|
+
className: "sendbird-openchannel-og-message__top__right__title__sent-at",
|
|
194
|
+
type: LabelTypography.CAPTION_3,
|
|
195
|
+
color: LabelColors.ONBACKGROUND_3
|
|
196
|
+
}, (message === null || message === void 0 ? void 0 : message.createdAt) && format(message === null || message === void 0 ? void 0 : message.createdAt, 'p', {
|
|
197
|
+
locale: dateLocale
|
|
198
|
+
}))), /*#__PURE__*/React__default.createElement("div", {
|
|
199
|
+
className: "sendbird-openchannel-og-message__top__right__description"
|
|
200
|
+
}, /*#__PURE__*/React__default.createElement(Label, {
|
|
201
|
+
className: "sendbird-openchannel-og-message__top__right__description__message",
|
|
202
|
+
type: LabelTypography.BODY_1,
|
|
203
|
+
color: LabelColors.ONBACKGROUND_1
|
|
204
|
+
}, MemoizedMessageText()))), /*#__PURE__*/React__default.createElement("div", {
|
|
205
|
+
className: "sendbird-openchannel-og-message__top__context-menu",
|
|
206
|
+
ref: contextMenuRef,
|
|
207
|
+
style: contextStyle
|
|
208
|
+
}, /*#__PURE__*/React__default.createElement(ContextMenu, {
|
|
209
|
+
menuTrigger: function menuTrigger(toggleDropdown) {
|
|
210
|
+
return showMenuTrigger({
|
|
211
|
+
message: message,
|
|
212
|
+
userId: userId,
|
|
213
|
+
status: status
|
|
214
|
+
}) && /*#__PURE__*/React__default.createElement(IconButton, {
|
|
215
|
+
className: "sendbird-openchannel-og-message__top__context-menu--icon",
|
|
216
|
+
width: "32px",
|
|
217
|
+
height: "32px",
|
|
218
|
+
onClick: function onClick() {
|
|
219
|
+
toggleDropdown();
|
|
220
|
+
}
|
|
221
|
+
}, /*#__PURE__*/React__default.createElement(Icon, {
|
|
222
|
+
type: IconTypes.MORE,
|
|
223
|
+
fillColor: IconColors.CONTENT_INVERSE,
|
|
224
|
+
width: "24px",
|
|
225
|
+
height: "24px"
|
|
226
|
+
}));
|
|
227
|
+
},
|
|
228
|
+
menuItems: function menuItems(closeDropdown) {
|
|
229
|
+
return /*#__PURE__*/React__default.createElement(MenuItems, {
|
|
230
|
+
parentRef: contextMenuRef,
|
|
231
|
+
parentContainRef: contextMenuRef,
|
|
232
|
+
closeDropdown: closeDropdown,
|
|
233
|
+
openLeft: true
|
|
234
|
+
}, isFineCopy({
|
|
235
|
+
message: message,
|
|
236
|
+
userId: userId,
|
|
237
|
+
status: status
|
|
238
|
+
}) && /*#__PURE__*/React__default.createElement(MenuItem, {
|
|
239
|
+
className: "sendbird-openchannel-og-message__top__context-menu__copy",
|
|
240
|
+
onClick: function onClick() {
|
|
241
|
+
copyToClipboard(message.message);
|
|
242
|
+
closeDropdown();
|
|
243
|
+
}
|
|
244
|
+
}, stringSet.CONTEXT_MENU_DROPDOWN__COPY), isFineEdit({
|
|
245
|
+
message: message,
|
|
246
|
+
userId: userId,
|
|
247
|
+
status: status
|
|
248
|
+
}) && /*#__PURE__*/React__default.createElement(MenuItem, {
|
|
249
|
+
className: "sendbird-openchannel-og-message__top__context-menu__edit",
|
|
250
|
+
onClick: function onClick() {
|
|
251
|
+
if (disabled) {
|
|
252
|
+
return;
|
|
253
|
+
}
|
|
254
|
+
|
|
255
|
+
showEdit(true);
|
|
256
|
+
closeDropdown();
|
|
257
|
+
}
|
|
258
|
+
}, stringSet.CONTEXT_MENU_DROPDOWN__EDIT), isFineResend({
|
|
259
|
+
message: message,
|
|
260
|
+
userId: userId,
|
|
261
|
+
status: status
|
|
262
|
+
}) && /*#__PURE__*/React__default.createElement(MenuItem, {
|
|
263
|
+
className: "sendbird-openchannel-og-message__top__context-menu__resend",
|
|
264
|
+
onClick: function onClick() {
|
|
265
|
+
resendMessage(message);
|
|
266
|
+
closeDropdown();
|
|
267
|
+
}
|
|
268
|
+
}, stringSet.CONTEXT_MENU_DROPDOWN__RESEND), isFineDelete({
|
|
269
|
+
message: message,
|
|
270
|
+
userId: userId,
|
|
271
|
+
status: status
|
|
272
|
+
}) && /*#__PURE__*/React__default.createElement(MenuItem, {
|
|
273
|
+
className: "sendbird-openchannel-og-message__top__context-menu__delete",
|
|
274
|
+
onClick: function onClick() {
|
|
275
|
+
if (disabled) {
|
|
276
|
+
return;
|
|
277
|
+
}
|
|
278
|
+
|
|
279
|
+
showRemove(true);
|
|
280
|
+
closeDropdown();
|
|
281
|
+
}
|
|
282
|
+
}, stringSet.CONTEXT_MENU_DROPDOWN__DELETE));
|
|
283
|
+
}
|
|
284
|
+
}))), /*#__PURE__*/React__default.createElement("div", {
|
|
285
|
+
className: "sendbird-openchannel-og-message__bottom"
|
|
286
|
+
}, /*#__PURE__*/React__default.createElement("div", {
|
|
287
|
+
className: "sendbird-openchannel-og-message__bottom__og-tag"
|
|
288
|
+
}, ogMetaData.url && /*#__PURE__*/React__default.createElement(Label, {
|
|
289
|
+
className: "sendbird-openchannel-og-message__bottom__og-tag__url",
|
|
290
|
+
type: LabelTypography.CAPTION_3,
|
|
291
|
+
color: LabelColors.ONBACKGROUND_2
|
|
292
|
+
}, ogMetaData.url), ogMetaData.title && /*#__PURE__*/React__default.createElement(LinkLabel, {
|
|
293
|
+
className: "sendbird-openchannel-og-message__bottom__og-tag__title",
|
|
294
|
+
src: ogMetaData.url,
|
|
295
|
+
type: LabelTypography.SUBTITLE_2,
|
|
296
|
+
color: LabelColors.PRIMARY
|
|
297
|
+
}, ogMetaData.title), ogMetaData.description && /*#__PURE__*/React__default.createElement(Label, {
|
|
298
|
+
className: "sendbird-openchannel-og-message__bottom__og-tag__description",
|
|
299
|
+
type: LabelTypography.BODY_2,
|
|
300
|
+
color: LabelColors.ONBACKGROUND_1
|
|
301
|
+
}, ogMetaData.description), ogMetaData.url && /*#__PURE__*/React__default.createElement("div", {
|
|
302
|
+
className: "sendbird-openchannel-og-message__bottom__og-tag__thumbnail",
|
|
303
|
+
role: "button",
|
|
304
|
+
onClick: openLink,
|
|
305
|
+
onKeyDown: openLink,
|
|
306
|
+
tabIndex: 0
|
|
307
|
+
}, defaultImage && /*#__PURE__*/React__default.createElement(ImageRenderer, {
|
|
308
|
+
className: "sendbird-openchannel-og-message__bottom__og-tag__thumbnail__image",
|
|
309
|
+
url: defaultImage.url || '',
|
|
310
|
+
alt: defaultImage.alt || '',
|
|
311
|
+
height: "189px",
|
|
312
|
+
defaultComponent: /*#__PURE__*/React__default.createElement("div", {
|
|
313
|
+
className: "sendbird-openchannel-og-message__bottom__og-tag__thumbnail__image--placeholder"
|
|
314
|
+
}, /*#__PURE__*/React__default.createElement(Icon, {
|
|
315
|
+
type: IconTypes.THUMBNAIL_NONE,
|
|
316
|
+
width: "56px",
|
|
317
|
+
height: "56px"
|
|
318
|
+
}))
|
|
319
|
+
}))), (isPending || isFailed) && /*#__PURE__*/React__default.createElement("div", {
|
|
320
|
+
className: "sendbird-openchannel-og-message__top__right__tail"
|
|
321
|
+
}, isPending && /*#__PURE__*/React__default.createElement(Loader, {
|
|
322
|
+
width: "16px",
|
|
323
|
+
height: "16px"
|
|
324
|
+
}, /*#__PURE__*/React__default.createElement(Icon, {
|
|
325
|
+
className: "sendbird-openchannel-og-message__top__right__tail__pending",
|
|
326
|
+
type: IconTypes.SPINNER,
|
|
327
|
+
fillColor: IconColors.PRIMARY,
|
|
328
|
+
width: "16px",
|
|
329
|
+
height: "16px"
|
|
330
|
+
})), isFailed && /*#__PURE__*/React__default.createElement(Icon, {
|
|
331
|
+
className: "sendbird-openchannel-og-message__top__right__tail__failed",
|
|
332
|
+
type: IconTypes.ERROR,
|
|
333
|
+
fillColor: IconColors.ERROR,
|
|
334
|
+
width: "16px",
|
|
335
|
+
height: "16px"
|
|
336
|
+
}))));
|
|
337
|
+
}
|
|
338
|
+
|
|
339
|
+
export { OpenchannelOGMessage as default };
|
|
340
|
+
//# sourceMappingURL=OpenchannelOGMessage.js.map
|