@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,127 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var ui_Tooltip = require('./Tooltip.js');
|
|
5
|
+
var ui_TooltipWrapper = require('./TooltipWrapper.js');
|
|
6
|
+
var ui_ReactionBadge = require('./ReactionBadge.js');
|
|
7
|
+
var ui_ReactionButton = require('./ReactionButton.js');
|
|
8
|
+
var ui_ImageRenderer = require('./ImageRenderer.js');
|
|
9
|
+
var ui_Icon = require('./Icon.js');
|
|
10
|
+
var ui_ContextMenu = require('./ContextMenu.js');
|
|
11
|
+
var index = require('../index-40d245a3.js');
|
|
12
|
+
var LocalizationContext = require('../LocalizationContext-5a6a0f67.js');
|
|
13
|
+
require('../_rollupPluginBabelHelpers-d984e855.js');
|
|
14
|
+
require('prop-types');
|
|
15
|
+
require('../index-df05e765.js');
|
|
16
|
+
require('../stringSet-2f3588b5.js');
|
|
17
|
+
require('react-dom');
|
|
18
|
+
require('./SortByRow.js');
|
|
19
|
+
require('../tslib.es6-d9c7aa8b.js');
|
|
20
|
+
require('../index-72479c2a.js');
|
|
21
|
+
|
|
22
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
23
|
+
|
|
24
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
25
|
+
|
|
26
|
+
var EmojiReactions = function EmojiReactions(_a) {
|
|
27
|
+
var _b, _c;
|
|
28
|
+
|
|
29
|
+
var className = _a.className,
|
|
30
|
+
userId = _a.userId,
|
|
31
|
+
message = _a.message,
|
|
32
|
+
emojiContainer = _a.emojiContainer,
|
|
33
|
+
memberNicknamesMap = _a.memberNicknamesMap,
|
|
34
|
+
_d = _a.spaceFromTrigger,
|
|
35
|
+
spaceFromTrigger = _d === void 0 ? {} : _d,
|
|
36
|
+
_e = _a.isByMe,
|
|
37
|
+
isByMe = _e === void 0 ? false : _e,
|
|
38
|
+
toggleReaction = _a.toggleReaction;
|
|
39
|
+
var stringSet = React.useContext(LocalizationContext.LocalizationContext).stringSet;
|
|
40
|
+
var emojisMap = index.getEmojiMapAll(emojiContainer);
|
|
41
|
+
var addReactionRef = React.useRef(null);
|
|
42
|
+
return /*#__PURE__*/React__default["default"].createElement("div", {
|
|
43
|
+
className: index.getClassName([className, 'sendbird-emoji-reactions', isByMe ? 'outgoing' : 'incoming'])
|
|
44
|
+
}, ((_b = message === null || message === void 0 ? void 0 : message.reactions) === null || _b === void 0 ? void 0 : _b.length) > 0 && message.reactions.map(function (reaction) {
|
|
45
|
+
var _a, _b;
|
|
46
|
+
|
|
47
|
+
var reactedByMe = index.isReactedBy(userId, reaction);
|
|
48
|
+
return /*#__PURE__*/React__default["default"].createElement(ui_TooltipWrapper, {
|
|
49
|
+
className: "sendbird-emoji-reactions__reaction-badge",
|
|
50
|
+
key: reaction === null || reaction === void 0 ? void 0 : reaction.key,
|
|
51
|
+
hoverTooltip: ((_a = reaction === null || reaction === void 0 ? void 0 : reaction.userIds) === null || _a === void 0 ? void 0 : _a.length) > 0 && /*#__PURE__*/React__default["default"].createElement(ui_Tooltip, null, index.getEmojiTooltipString(reaction, userId, memberNicknamesMap, stringSet))
|
|
52
|
+
}, /*#__PURE__*/React__default["default"].createElement(ui_ReactionBadge, {
|
|
53
|
+
count: reaction.userIds.length,
|
|
54
|
+
selected: reactedByMe,
|
|
55
|
+
onClick: function onClick() {
|
|
56
|
+
return toggleReaction(message, reaction.key, reactedByMe);
|
|
57
|
+
}
|
|
58
|
+
}, /*#__PURE__*/React__default["default"].createElement(ui_ImageRenderer, {
|
|
59
|
+
circle: true,
|
|
60
|
+
url: ((_b = emojisMap.get(reaction === null || reaction === void 0 ? void 0 : reaction.key)) === null || _b === void 0 ? void 0 : _b.url) || '',
|
|
61
|
+
width: "20px",
|
|
62
|
+
height: "20px",
|
|
63
|
+
defaultComponent: /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
|
|
64
|
+
width: "20px",
|
|
65
|
+
height: "20px",
|
|
66
|
+
type: ui_Icon.IconTypes.QUESTION
|
|
67
|
+
})
|
|
68
|
+
})));
|
|
69
|
+
}), ((_c = message === null || message === void 0 ? void 0 : message.reactions) === null || _c === void 0 ? void 0 : _c.length) < emojisMap.size && /*#__PURE__*/React__default["default"].createElement(ui_ContextMenu["default"], {
|
|
70
|
+
menuTrigger: function menuTrigger(toggleDropdown) {
|
|
71
|
+
return /*#__PURE__*/React__default["default"].createElement(ui_ReactionBadge, {
|
|
72
|
+
className: "sendbird-emoji-reactions__add-reaction-badge",
|
|
73
|
+
ref: addReactionRef,
|
|
74
|
+
isAdd: true,
|
|
75
|
+
onClick: toggleDropdown
|
|
76
|
+
}, /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
|
|
77
|
+
type: ui_Icon.IconTypes.EMOJI_MORE,
|
|
78
|
+
fillColor: ui_Icon.IconColors.ON_BACKGROUND_3,
|
|
79
|
+
width: "20px",
|
|
80
|
+
height: "20px"
|
|
81
|
+
}));
|
|
82
|
+
},
|
|
83
|
+
menuItems: function menuItems(closeDropdown) {
|
|
84
|
+
return /*#__PURE__*/React__default["default"].createElement(ui_ContextMenu.EmojiListItems, {
|
|
85
|
+
parentRef: addReactionRef,
|
|
86
|
+
parentContainRef: addReactionRef,
|
|
87
|
+
closeDropdown: closeDropdown,
|
|
88
|
+
spacefromTrigger: spaceFromTrigger
|
|
89
|
+
}, index.getEmojiListAll(emojiContainer).map(function (emoji) {
|
|
90
|
+
var _a, _b, _c;
|
|
91
|
+
|
|
92
|
+
var isReacted = (_c = (_b = (_a = message === null || message === void 0 ? void 0 : message.reactions) === null || _a === void 0 ? void 0 : _a.filter(function (reaction) {
|
|
93
|
+
return reaction.key === emoji.key;
|
|
94
|
+
})[0]) === null || _b === void 0 ? void 0 : _b.userIds) === null || _c === void 0 ? void 0 : _c.some(function (reactorId) {
|
|
95
|
+
return reactorId === userId;
|
|
96
|
+
});
|
|
97
|
+
return /*#__PURE__*/React__default["default"].createElement(ui_ReactionButton, {
|
|
98
|
+
key: emoji.key,
|
|
99
|
+
width: "36px",
|
|
100
|
+
height: "36px",
|
|
101
|
+
selected: isReacted,
|
|
102
|
+
onClick: function onClick() {
|
|
103
|
+
closeDropdown();
|
|
104
|
+
toggleReaction(message, emoji.key, isReacted);
|
|
105
|
+
}
|
|
106
|
+
}, /*#__PURE__*/React__default["default"].createElement(ui_ImageRenderer, {
|
|
107
|
+
url: (emoji === null || emoji === void 0 ? void 0 : emoji.url) || '',
|
|
108
|
+
width: "28px",
|
|
109
|
+
height: "28px",
|
|
110
|
+
placeHolder: function placeHolder(style) {
|
|
111
|
+
return /*#__PURE__*/React__default["default"].createElement("div", {
|
|
112
|
+
style: style
|
|
113
|
+
}, /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
|
|
114
|
+
type: ui_Icon.IconTypes.QUESTION,
|
|
115
|
+
fillColor: ui_Icon.IconColors.ON_BACKGROUND_3,
|
|
116
|
+
width: "28px",
|
|
117
|
+
height: "28px"
|
|
118
|
+
}));
|
|
119
|
+
}
|
|
120
|
+
}));
|
|
121
|
+
}));
|
|
122
|
+
}
|
|
123
|
+
}));
|
|
124
|
+
};
|
|
125
|
+
|
|
126
|
+
module.exports = EmojiReactions;
|
|
127
|
+
//# sourceMappingURL=EmojiReactions.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EmojiReactions.js","sources":["../../../src/ui/EmojiReactions/index.tsx"],"sourcesContent":["import './index.scss';\nimport React, { ReactElement, useContext, useRef } from 'react';\nimport type { FileMessage, Reaction, UserMessage } from '@sendbird/chat/message';\nimport type { Emoji, EmojiContainer } from '@sendbird/chat';\n\nimport Tooltip from '../Tooltip';\nimport TooltipWrapper from '../TooltipWrapper';\nimport ReactionBadge from '../ReactionBadge';\nimport ReactionButton from '../ReactionButton';\nimport ImageRenderer from '../ImageRenderer';\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport ContextMenu, { EmojiListItems } from '../ContextMenu';\n\nimport { getClassName, getEmojiListAll, getEmojiMapAll, getEmojiTooltipString, isReactedBy } from '../../utils';\nimport { LocalizationContext } from '../../lib/LocalizationContext';\n\ninterface Props {\n className?: string | Array<string>;\n userId: string;\n message: UserMessage | FileMessage;\n emojiContainer: EmojiContainer;\n memberNicknamesMap: Map<string, string>;\n spaceFromTrigger?: Record<string, unknown>;\n isByMe?: boolean;\n toggleReaction?: (message: UserMessage | FileMessage, key: string, byMe: boolean) => void;\n}\n\nconst EmojiReactions = ({\n className,\n userId,\n message,\n emojiContainer,\n memberNicknamesMap,\n spaceFromTrigger = {},\n isByMe = false,\n toggleReaction,\n}: Props): ReactElement => {\n const { stringSet } = useContext(LocalizationContext);\n const emojisMap = getEmojiMapAll(emojiContainer);\n const addReactionRef = useRef(null);\n\n return (\n <div className={getClassName([\n className, 'sendbird-emoji-reactions',\n isByMe ? 'outgoing' : 'incoming',\n ])}>\n {(message?.reactions?.length > 0) && (\n message.reactions.map((reaction: Reaction): ReactElement => {\n const reactedByMe = isReactedBy(userId, reaction);\n return (\n <TooltipWrapper\n className=\"sendbird-emoji-reactions__reaction-badge\"\n key={reaction?.key}\n hoverTooltip={(reaction?.userIds?.length > 0) && (\n <Tooltip>\n {getEmojiTooltipString(reaction, userId, memberNicknamesMap, stringSet)}\n </Tooltip>\n )}\n >\n <ReactionBadge\n count={reaction.userIds.length}\n selected={reactedByMe}\n onClick={() => toggleReaction(message, reaction.key, reactedByMe)}\n >\n <ImageRenderer\n circle\n url={emojisMap.get(reaction?.key)?.url || ''}\n width=\"20px\"\n height=\"20px\"\n defaultComponent={(\n <Icon width=\"20px\" height=\"20px\" type={IconTypes.QUESTION} />\n )}\n />\n </ReactionBadge>\n </TooltipWrapper>\n );\n })\n )}\n {(message?.reactions?.length < emojisMap.size) && (\n <ContextMenu\n menuTrigger={(toggleDropdown: () => void): ReactElement => (\n <ReactionBadge\n className=\"sendbird-emoji-reactions__add-reaction-badge\"\n ref={addReactionRef}\n isAdd\n onClick={toggleDropdown}\n >\n <Icon\n type={IconTypes.EMOJI_MORE}\n fillColor={IconColors.ON_BACKGROUND_3}\n width=\"20px\"\n height=\"20px\"\n />\n </ReactionBadge>\n )}\n menuItems={(closeDropdown: () => void): ReactElement => (\n <EmojiListItems\n parentRef={addReactionRef}\n parentContainRef={addReactionRef}\n closeDropdown={closeDropdown}\n spacefromTrigger={spaceFromTrigger}\n >\n {getEmojiListAll(emojiContainer).map((emoji: Emoji): ReactElement => {\n const isReacted: boolean = message?.reactions?.\n filter((reaction: Reaction): boolean => reaction.key === emoji.key)[0]?.userIds?.\n some((reactorId: string): boolean => reactorId === userId);\n return (\n <ReactionButton\n key={emoji.key}\n width=\"36px\"\n height=\"36px\"\n selected={isReacted}\n onClick={(): void => {\n closeDropdown();\n toggleReaction(message, emoji.key, isReacted);\n }}\n >\n <ImageRenderer\n url={emoji?.url || ''}\n width=\"28px\"\n height=\"28px\"\n placeHolder={(style: Record<string, unknown>): ReactElement => (\n <div style={style}>\n <Icon\n type={IconTypes.QUESTION}\n fillColor={IconColors.ON_BACKGROUND_3}\n width=\"28px\"\n height=\"28px\"\n />\n </div>\n )}\n />\n </ReactionButton>\n );\n })}\n </EmojiListItems>\n )}\n />\n )}\n </div>\n );\n}\n\nexport default EmojiReactions;\n"],"names":["EmojiReactions","_a","className","userId","message","emojiContainer","memberNicknamesMap","_d","spaceFromTrigger","_e","isByMe","toggleReaction","stringSet","useContext","LocalizationContext","emojisMap","getEmojiMapAll","addReactionRef","useRef","React","getClassName","reactions","length","map","reaction","reactedByMe","isReactedBy","TooltipWrapper","key","userIds","Tooltip","getEmojiTooltipString","ReactionBadge","ImageRenderer","get","url","Icon","IconTypes","QUESTION","size","ContextMenu","toggleDropdown","EMOJI_MORE","IconColors","ON_BACKGROUND_3","closeDropdown","EmojiListItems","getEmojiListAll","emoji","isReacted","filter","some","reactorId","ReactionButton","style"],"mappings":"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"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var React = require('react');
|
|
4
|
+
var ui_Label = require('../index-df05e765.js');
|
|
5
|
+
var ui_Icon = require('./Icon.js');
|
|
6
|
+
var ui_TextButton = require('./TextButton.js');
|
|
7
|
+
var index = require('../index-40d245a3.js');
|
|
8
|
+
require('../_rollupPluginBabelHelpers-d984e855.js');
|
|
9
|
+
require('prop-types');
|
|
10
|
+
require('../stringSet-2f3588b5.js');
|
|
11
|
+
require('../color-b30f84a2.js');
|
|
12
|
+
require('../tslib.es6-d9c7aa8b.js');
|
|
13
|
+
|
|
14
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
15
|
+
|
|
16
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
17
|
+
|
|
18
|
+
function FileMessageItemBody(_a) {
|
|
19
|
+
var _b;
|
|
20
|
+
|
|
21
|
+
var className = _a.className,
|
|
22
|
+
message = _a.message,
|
|
23
|
+
_c = _a.isByMe,
|
|
24
|
+
isByMe = _c === void 0 ? false : _c,
|
|
25
|
+
_d = _a.mouseHover,
|
|
26
|
+
mouseHover = _d === void 0 ? false : _d;
|
|
27
|
+
return /*#__PURE__*/React__default["default"].createElement("div", {
|
|
28
|
+
className: index.getClassName([className, 'sendbird-file-message-item-body', isByMe ? 'outgoing' : 'incoming', mouseHover ? 'mouse-hover' : '', ((_b = message === null || message === void 0 ? void 0 : message.reactions) === null || _b === void 0 ? void 0 : _b.length) > 0 ? 'reactions' : ''])
|
|
29
|
+
}, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
30
|
+
className: "sendbird-file-message-item-body__file-icon"
|
|
31
|
+
}, /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
|
|
32
|
+
className: 'sendbird-file-message-item-body__file-icon__icon',
|
|
33
|
+
type: {
|
|
34
|
+
IMAGE: ui_Icon.IconTypes.PHOTO,
|
|
35
|
+
VIDEO: ui_Icon.IconTypes.PLAY,
|
|
36
|
+
AUDIO: ui_Icon.IconTypes.FILE_AUDIO,
|
|
37
|
+
GIF: ui_Icon.IconTypes.GIF,
|
|
38
|
+
OTHERS: ui_Icon.IconTypes.FILE_DOCUMENT
|
|
39
|
+
}[index.getUIKitFileType(message === null || message === void 0 ? void 0 : message.type)],
|
|
40
|
+
fillColor: ui_Icon.IconColors.PRIMARY,
|
|
41
|
+
width: "24px",
|
|
42
|
+
height: "24px"
|
|
43
|
+
})), /*#__PURE__*/React__default["default"].createElement(ui_TextButton, {
|
|
44
|
+
className: "sendbird-file-message-item-body__file-name",
|
|
45
|
+
onClick: function onClick() {
|
|
46
|
+
window.open(message === null || message === void 0 ? void 0 : message.url);
|
|
47
|
+
},
|
|
48
|
+
color: isByMe ? ui_Label.LabelColors.ONCONTENT_1 : ui_Label.LabelColors.ONBACKGROUND_1
|
|
49
|
+
}, /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
|
|
50
|
+
className: "sendbird-file-message-item-body__file-name__text",
|
|
51
|
+
type: ui_Label.LabelTypography.BODY_1,
|
|
52
|
+
color: isByMe ? ui_Label.LabelColors.ONCONTENT_1 : ui_Label.LabelColors.ONBACKGROUND_1
|
|
53
|
+
}, index.truncateString((message === null || message === void 0 ? void 0 : message.name) || (message === null || message === void 0 ? void 0 : message.url)))));
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
module.exports = FileMessageItemBody;
|
|
57
|
+
//# sourceMappingURL=FileMessageItemBody.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FileMessageItemBody.js","sources":["../../../src/ui/FileMessageItemBody/index.tsx"],"sourcesContent":["import './index.scss';\nimport React, { ReactElement } from 'react';\nimport type { FileMessage } from '@sendbird/chat/message';\n\nimport Label, { LabelTypography, LabelColors } from '../Label';\nimport Icon, { IconTypes, IconColors } from '../Icon';\nimport TextButton from '../TextButton';\nimport { getClassName, getUIKitFileType, truncateString } from '../../utils';\n\ninterface Props {\n className?: string | Array<string>;\n message: FileMessage;\n isByMe?: boolean;\n mouseHover?: boolean;\n}\n\nexport default function FileMessageItemBody({\n className,\n message,\n isByMe = false,\n mouseHover = false,\n}: Props): ReactElement {\n\n return (\n <div className={getClassName([\n className,\n 'sendbird-file-message-item-body',\n isByMe ? 'outgoing' : 'incoming',\n mouseHover ? 'mouse-hover' : '',\n message?.reactions?.length > 0 ? 'reactions' : '',\n ])}>\n <div className=\"sendbird-file-message-item-body__file-icon\">\n <Icon\n className={'sendbird-file-message-item-body__file-icon__icon'}\n type={{\n IMAGE: IconTypes.PHOTO,\n VIDEO: IconTypes.PLAY,\n AUDIO: IconTypes.FILE_AUDIO,\n GIF: IconTypes.GIF,\n OTHERS: IconTypes.FILE_DOCUMENT,\n }[getUIKitFileType(message?.type)]}\n fillColor={IconColors.PRIMARY}\n width=\"24px\"\n height=\"24px\"\n />\n </div>\n <TextButton\n className=\"sendbird-file-message-item-body__file-name\"\n onClick={() => { window.open(message?.url) }}\n color={isByMe ? LabelColors.ONCONTENT_1 : LabelColors.ONBACKGROUND_1}\n >\n <Label\n className=\"sendbird-file-message-item-body__file-name__text\"\n type={LabelTypography.BODY_1}\n color={isByMe ? LabelColors.ONCONTENT_1 : LabelColors.ONBACKGROUND_1}\n >\n {truncateString(message?.name || message?.url)}\n </Label>\n </TextButton>\n </div>\n );\n}\n"],"names":["FileMessageItemBody","_a","className","message","_c","isByMe","_d","mouseHover","React","getClassName","reactions","length","Icon","IMAGE","IconTypes","PHOTO","VIDEO","PLAY","AUDIO","FILE_AUDIO","GIF","OTHERS","FILE_DOCUMENT","getUIKitFileType","type","IconColors","PRIMARY","TextButton","window","open","url","LabelColors","ONCONTENT_1","ONBACKGROUND_1","Label","LabelTypography","BODY_1","truncateString","name"],"mappings":";;;;;;;;;;;;;;;;;SAgBwBA,oBAAoBC;;;MAC1CC,SAAS;MACTC,OAAO;MACPC;MAAAC,MAAM,mBAAG;MACTC;MAAAC,UAAU,mBAAG;AAGb,sBACEC;AAAK,IAAA,SAAS,EAAEC,kBAAY,CAAC,CAC3BP,SAD2B,EAE3B,iCAF2B,EAG3BG,MAAM,GAAG,UAAH,GAAgB,UAHK,EAI3BE,UAAU,GAAG,aAAH,GAAmB,EAJF,EAK3B,CAAA,MAAAJ,OAAO,SAAP,IAAAA,OAAO,WAAP,SAAA,GAAAA,OAAO,CAAEO,SAAT,UAAA,iBAAA,SAAA,MAAoBC,MAApB,IAA6B,CAA7B,GAAiC,WAAjC,GAA+C,EALpB,CAAD;AAA5B,kBAOEH;AAAK,IAAA,SAAS,EAAC;AAAf,kBACEA,wCAACI,kBAAD;AACE,IAAA,SAAS,EAAE,kDADb;AAEE,IAAA,IAAI,EAAE;AACJC,MAAAA,KAAK,EAAEC,iBAAS,CAACC,KADb;AAEJC,MAAAA,KAAK,EAAEF,iBAAS,CAACG,IAFb;AAGJC,MAAAA,KAAK,EAAEJ,iBAAS,CAACK,UAHb;AAIJC,MAAAA,GAAG,EAAEN,iBAAS,CAACM,GAJX;AAKJC,MAAAA,MAAM,EAAEP,iBAAS,CAACQ;AALd,MAMJC,sBAAgB,CAACpB,OAAO,SAAP,IAAAA,OAAO,WAAP,SAAA,GAAAA,OAAO,CAAEqB,IAAV,CANZ,CAFR;AASE,IAAA,SAAS,EAAEC,kBAAU,CAACC,OATxB;AAUE,IAAA,KAAK,EAAC,MAVR;AAWE,IAAA,MAAM,EAAC;AAXT,IADF,CAPF,eAsBElB,wCAACmB,aAAD;AACE,IAAA,SAAS,EAAC,4CADZ;AAEE,IAAA,OAAO,EAAE;AAAQC,MAAAA,MAAM,CAACC,IAAP,CAAY1B,OAAO,SAAP,IAAAA,OAAO,WAAP,SAAA,GAAAA,OAAO,CAAE2B,GAArB;AAA2B,KAF9C;AAGE,IAAA,KAAK,EAAEzB,MAAM,GAAG0B,oBAAW,CAACC,WAAf,GAA6BD,oBAAW,CAACE;AAHxD,kBAKEzB,wCAAC0B,cAAD;AACE,IAAA,SAAS,EAAC,kDADZ;AAEE,IAAA,IAAI,EAAEC,wBAAe,CAACC,MAFxB;AAGE,IAAA,KAAK,EAAE/B,MAAM,GAAG0B,oBAAW,CAACC,WAAf,GAA6BD,oBAAW,CAACE;AAHxD,KAKGI,oBAAc,CAAC,CAAAlC,OAAO,SAAP,IAAAA,OAAO,WAAP,SAAA,GAAAA,OAAO,CAAEmC,IAAT,MAAiBnC,OAAO,SAAP,IAAAA,OAAO,WAAP,SAAA,GAAAA,OAAO,CAAE2B,GAA1B,CAAD,CALjB,CALF,CAtBF,CADF;AAsCD;;;;"}
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var React = require('react');
|
|
6
|
+
var PropTypes = require('prop-types');
|
|
7
|
+
var reactDom = require('react-dom');
|
|
8
|
+
var ui_Avatar = require('./Avatar.js');
|
|
9
|
+
var ui_Label = require('../index-df05e765.js');
|
|
10
|
+
var ui_Icon = require('./Icon.js');
|
|
11
|
+
var index = require('../index-ce679d41.js');
|
|
12
|
+
var index$1 = require('../index-40d245a3.js');
|
|
13
|
+
require('../tslib.es6-d9c7aa8b.js');
|
|
14
|
+
require('./ImageRenderer.js');
|
|
15
|
+
require('../_rollupPluginBabelHelpers-d984e855.js');
|
|
16
|
+
require('../uuid-099485ae.js');
|
|
17
|
+
require('../stringSet-2f3588b5.js');
|
|
18
|
+
|
|
19
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
20
|
+
|
|
21
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
22
|
+
var PropTypes__default = /*#__PURE__*/_interopDefaultLegacy(PropTypes);
|
|
23
|
+
|
|
24
|
+
var FileViewerComponent = function FileViewerComponent(_ref) {
|
|
25
|
+
var profileUrl = _ref.profileUrl,
|
|
26
|
+
nickname = _ref.nickname,
|
|
27
|
+
name = _ref.name,
|
|
28
|
+
type = _ref.type,
|
|
29
|
+
url = _ref.url,
|
|
30
|
+
isByMe = _ref.isByMe,
|
|
31
|
+
onClose = _ref.onClose,
|
|
32
|
+
onDelete = _ref.onDelete,
|
|
33
|
+
disableDelete = _ref.disableDelete;
|
|
34
|
+
return /*#__PURE__*/React__default["default"].createElement("div", {
|
|
35
|
+
className: "sendbird-fileviewer"
|
|
36
|
+
}, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
37
|
+
className: "sendbird-fileviewer__header"
|
|
38
|
+
}, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
39
|
+
className: "sendbird-fileviewer__header__left"
|
|
40
|
+
}, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
41
|
+
className: "sendbird-fileviewer__header__left__avatar"
|
|
42
|
+
}, /*#__PURE__*/React__default["default"].createElement(ui_Avatar["default"], {
|
|
43
|
+
height: "32px",
|
|
44
|
+
width: "32px",
|
|
45
|
+
src: profileUrl
|
|
46
|
+
})), /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
|
|
47
|
+
className: "sendbird-fileviewer__header__left__filename",
|
|
48
|
+
type: ui_Label.LabelTypography.H_2,
|
|
49
|
+
color: ui_Label.LabelColors.ONBACKGROUND_1
|
|
50
|
+
}, name), /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
|
|
51
|
+
className: "sendbird-fileviewer__header__left__sender-name",
|
|
52
|
+
type: ui_Label.LabelTypography.BODY_1,
|
|
53
|
+
color: ui_Label.LabelColors.ONBACKGROUND_2
|
|
54
|
+
}, nickname)), /*#__PURE__*/React__default["default"].createElement("div", {
|
|
55
|
+
className: "sendbird-fileviewer__header__right"
|
|
56
|
+
}, index$1.isSupportedFileView(type) && /*#__PURE__*/React__default["default"].createElement("div", {
|
|
57
|
+
className: "sendbird-fileviewer__header__right__actions"
|
|
58
|
+
}, /*#__PURE__*/React__default["default"].createElement("a", {
|
|
59
|
+
className: "sendbird-fileviewer__header__right__actions__download",
|
|
60
|
+
rel: "noopener noreferrer",
|
|
61
|
+
href: url,
|
|
62
|
+
target: "_blank"
|
|
63
|
+
}, /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
|
|
64
|
+
type: ui_Icon.IconTypes.DOWNLOAD,
|
|
65
|
+
fillColor: ui_Icon.IconColors.ON_BACKGROUND_1,
|
|
66
|
+
height: "24px",
|
|
67
|
+
width: "24px"
|
|
68
|
+
})), onDelete && isByMe && /*#__PURE__*/React__default["default"].createElement("div", {
|
|
69
|
+
className: "sendbird-fileviewer__header__right__actions__delete"
|
|
70
|
+
}, /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
|
|
71
|
+
className: disableDelete ? 'disabled' : '',
|
|
72
|
+
type: ui_Icon.IconTypes.DELETE,
|
|
73
|
+
fillColor: disableDelete ? ui_Icon.IconColors.GRAY : ui_Icon.IconColors.ON_BACKGROUND_1,
|
|
74
|
+
height: "24px",
|
|
75
|
+
width: "24px",
|
|
76
|
+
onClick: function onClick() {
|
|
77
|
+
if (!disableDelete) {
|
|
78
|
+
onDelete();
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}))), /*#__PURE__*/React__default["default"].createElement("div", {
|
|
82
|
+
className: "sendbird-fileviewer__header__right__actions__close"
|
|
83
|
+
}, /*#__PURE__*/React__default["default"].createElement(ui_Icon["default"], {
|
|
84
|
+
type: ui_Icon.IconTypes.CLOSE,
|
|
85
|
+
fillColor: ui_Icon.IconColors.ON_BACKGROUND_1,
|
|
86
|
+
height: "24px",
|
|
87
|
+
width: "24px",
|
|
88
|
+
onClick: onClose
|
|
89
|
+
})))), /*#__PURE__*/React__default["default"].createElement("div", {
|
|
90
|
+
className: "sendbird-fileviewer__content"
|
|
91
|
+
}, index$1.isVideo(type) &&
|
|
92
|
+
/*#__PURE__*/
|
|
93
|
+
// eslint-disable-next-line jsx-a11y/media-has-caption
|
|
94
|
+
React__default["default"].createElement("video", {
|
|
95
|
+
controls: true,
|
|
96
|
+
className: "sendbird-fileviewer__content__video"
|
|
97
|
+
}, /*#__PURE__*/React__default["default"].createElement("source", {
|
|
98
|
+
src: url,
|
|
99
|
+
type: type
|
|
100
|
+
})), index$1.isImage(type) && /*#__PURE__*/React__default["default"].createElement("img", {
|
|
101
|
+
src: url,
|
|
102
|
+
alt: name,
|
|
103
|
+
className: "sendbird-fileviewer__content__img"
|
|
104
|
+
}), !index$1.isSupportedFileView(type) && /*#__PURE__*/React__default["default"].createElement("div", {
|
|
105
|
+
className: "sendbird-fileviewer__content__unsupported"
|
|
106
|
+
}, /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
|
|
107
|
+
type: ui_Label.LabelTypography.H_1,
|
|
108
|
+
color: ui_Label.LabelColors.ONBACKGROUND_1
|
|
109
|
+
}, "Unsupoprted message"))));
|
|
110
|
+
};
|
|
111
|
+
FileViewerComponent.propTypes = {
|
|
112
|
+
profileUrl: PropTypes__default["default"].string.isRequired,
|
|
113
|
+
nickname: PropTypes__default["default"].string.isRequired,
|
|
114
|
+
type: PropTypes__default["default"].string.isRequired,
|
|
115
|
+
url: PropTypes__default["default"].string.isRequired,
|
|
116
|
+
name: PropTypes__default["default"].string.isRequired,
|
|
117
|
+
onClose: PropTypes__default["default"].func.isRequired,
|
|
118
|
+
onDelete: PropTypes__default["default"].func.isRequired,
|
|
119
|
+
isByMe: PropTypes__default["default"].bool,
|
|
120
|
+
disableDelete: PropTypes__default["default"].bool
|
|
121
|
+
};
|
|
122
|
+
FileViewerComponent.defaultProps = {
|
|
123
|
+
isByMe: true,
|
|
124
|
+
disableDelete: false
|
|
125
|
+
};
|
|
126
|
+
function FileViewer(props) {
|
|
127
|
+
var message = props.message,
|
|
128
|
+
isByMe = props.isByMe,
|
|
129
|
+
onClose = props.onClose,
|
|
130
|
+
onDelete = props.onDelete;
|
|
131
|
+
var sender = message.sender,
|
|
132
|
+
type = message.type,
|
|
133
|
+
url = message.url,
|
|
134
|
+
_message$name = message.name,
|
|
135
|
+
name = _message$name === void 0 ? '' : _message$name,
|
|
136
|
+
_message$threadInfo = message.threadInfo,
|
|
137
|
+
threadInfo = _message$threadInfo === void 0 ? {} : _message$threadInfo;
|
|
138
|
+
var disableDelete = (threadInfo === null || threadInfo === void 0 ? void 0 : threadInfo.replyCount) > 0;
|
|
139
|
+
var profileUrl = sender.profileUrl,
|
|
140
|
+
_sender$nickname = sender.nickname,
|
|
141
|
+
nickname = _sender$nickname === void 0 ? '' : _sender$nickname;
|
|
142
|
+
return /*#__PURE__*/reactDom.createPortal( /*#__PURE__*/React__default["default"].createElement(FileViewerComponent, {
|
|
143
|
+
profileUrl: profileUrl,
|
|
144
|
+
nickname: nickname,
|
|
145
|
+
type: type,
|
|
146
|
+
url: url,
|
|
147
|
+
name: name,
|
|
148
|
+
onClose: onClose,
|
|
149
|
+
onDelete: onDelete,
|
|
150
|
+
isByMe: isByMe,
|
|
151
|
+
disableDelete: disableDelete
|
|
152
|
+
}), document.getElementById(index.MODAL_ROOT));
|
|
153
|
+
}
|
|
154
|
+
FileViewer.propTypes = {
|
|
155
|
+
message: PropTypes__default["default"].shape({
|
|
156
|
+
sender: PropTypes__default["default"].shape({
|
|
157
|
+
profileUrl: PropTypes__default["default"].string,
|
|
158
|
+
nickname: PropTypes__default["default"].string
|
|
159
|
+
}),
|
|
160
|
+
type: PropTypes__default["default"].string,
|
|
161
|
+
url: PropTypes__default["default"].string,
|
|
162
|
+
name: PropTypes__default["default"].string
|
|
163
|
+
}).isRequired,
|
|
164
|
+
isByMe: PropTypes__default["default"].bool,
|
|
165
|
+
onClose: PropTypes__default["default"].func.isRequired,
|
|
166
|
+
onDelete: PropTypes__default["default"].func.isRequired
|
|
167
|
+
};
|
|
168
|
+
FileViewer.defaultProps = {
|
|
169
|
+
isByMe: true
|
|
170
|
+
};
|
|
171
|
+
|
|
172
|
+
exports.FileViewerComponent = FileViewerComponent;
|
|
173
|
+
exports["default"] = FileViewer;
|
|
174
|
+
//# sourceMappingURL=FileViewer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"FileViewer.js","sources":["../../../src/ui/FileViewer/index.jsx"],"sourcesContent":["import React from 'react';\nimport PropTypes from 'prop-types';\nimport { createPortal } from 'react-dom';\n\nimport './index.scss';\nimport Avatar from '../Avatar/index';\nimport Label, { LabelTypography, LabelColors } from '../Label';\nimport Icon, { IconColors, IconTypes } from '../Icon';\nimport { MODAL_ROOT } from '../../hooks/useModal/ModalRoot';\n\nimport { isImage, isVideo, isSupportedFileView } from '../../utils';\n\nexport const FileViewerComponent = ({\n // sender\n profileUrl,\n nickname,\n // file\n name,\n type,\n url,\n // others\n isByMe,\n onClose,\n onDelete,\n disableDelete,\n}) => (\n <div className=\"sendbird-fileviewer\">\n <div className=\"sendbird-fileviewer__header\">\n <div className=\"sendbird-fileviewer__header__left\">\n <div className=\"sendbird-fileviewer__header__left__avatar\">\n <Avatar height=\"32px\" width=\"32px\" src={profileUrl} />\n </div>\n <Label\n className=\"sendbird-fileviewer__header__left__filename\"\n type={LabelTypography.H_2}\n color={LabelColors.ONBACKGROUND_1}\n >\n {name}\n </Label>\n <Label\n className=\"sendbird-fileviewer__header__left__sender-name\"\n type={LabelTypography.BODY_1}\n color={LabelColors.ONBACKGROUND_2}\n >\n {nickname}\n </Label>\n </div>\n <div className=\"sendbird-fileviewer__header__right\">\n {\n isSupportedFileView(type) && (\n <div className=\"sendbird-fileviewer__header__right__actions\">\n <a\n className=\"sendbird-fileviewer__header__right__actions__download\"\n rel=\"noopener noreferrer\"\n href={url}\n target=\"_blank\"\n >\n <Icon\n type={IconTypes.DOWNLOAD}\n fillColor={IconColors.ON_BACKGROUND_1}\n height=\"24px\"\n width=\"24px\"\n />\n </a>\n {\n onDelete && isByMe && (\n <div className=\"sendbird-fileviewer__header__right__actions__delete\">\n <Icon\n className={disableDelete ? 'disabled' : ''}\n type={IconTypes.DELETE}\n fillColor={disableDelete ? IconColors.GRAY : IconColors.ON_BACKGROUND_1}\n height=\"24px\"\n width=\"24px\"\n onClick={() => { if (!disableDelete) { onDelete(); } }}\n />\n </div>\n )\n }\n </div>\n )\n }\n <div className=\"sendbird-fileviewer__header__right__actions__close\">\n <Icon\n type={IconTypes.CLOSE}\n fillColor={IconColors.ON_BACKGROUND_1}\n height=\"24px\"\n width=\"24px\"\n onClick={onClose}\n />\n </div>\n </div>\n </div>\n <div className=\"sendbird-fileviewer__content\">\n {isVideo(type) && (\n // eslint-disable-next-line jsx-a11y/media-has-caption\n <video controls className=\"sendbird-fileviewer__content__video\">\n <source src={url} type={type} />\n </video>\n )}\n {\n isImage(type) && (\n <img\n src={url}\n alt={name}\n className=\"sendbird-fileviewer__content__img\"\n />\n )\n }\n {\n !isSupportedFileView(type) && (\n <div className=\"sendbird-fileviewer__content__unsupported\">\n <Label type={LabelTypography.H_1} color={LabelColors.ONBACKGROUND_1}>\n Unsupoprted message\n </Label>\n </div>\n )\n }\n </div>\n </div>\n);\n\nFileViewerComponent.propTypes = {\n profileUrl: PropTypes.string.isRequired,\n nickname: PropTypes.string.isRequired,\n type: PropTypes.string.isRequired,\n url: PropTypes.string.isRequired,\n name: PropTypes.string.isRequired,\n onClose: PropTypes.func.isRequired,\n onDelete: PropTypes.func.isRequired,\n isByMe: PropTypes.bool,\n disableDelete: PropTypes.bool,\n};\n\nFileViewerComponent.defaultProps = {\n isByMe: true,\n disableDelete: false,\n};\n\nexport default function FileViewer(props) {\n const {\n message,\n isByMe,\n onClose,\n onDelete,\n } = props;\n const {\n sender,\n type,\n url,\n name = '',\n threadInfo = {},\n } = message;\n const disableDelete = threadInfo?.replyCount > 0;\n const { profileUrl, nickname = '' } = sender;\n return createPortal(\n (\n <FileViewerComponent\n profileUrl={profileUrl}\n nickname={nickname}\n type={type}\n url={url}\n name={name}\n onClose={onClose}\n onDelete={onDelete}\n isByMe={isByMe}\n disableDelete={disableDelete}\n />\n ),\n document.getElementById(MODAL_ROOT),\n );\n}\n\nFileViewer.propTypes = {\n message: PropTypes.shape({\n sender: PropTypes.shape({\n profileUrl: PropTypes.string,\n nickname: PropTypes.string,\n }),\n type: PropTypes.string,\n url: PropTypes.string,\n name: PropTypes.string,\n }).isRequired,\n isByMe: PropTypes.bool,\n onClose: PropTypes.func.isRequired,\n onDelete: PropTypes.func.isRequired,\n};\n\nFileViewer.defaultProps = {\n isByMe: true,\n};\n"],"names":["FileViewerComponent","profileUrl","nickname","name","type","url","isByMe","onClose","onDelete","disableDelete","React","Avatar","Label","LabelTypography","H_2","LabelColors","ONBACKGROUND_1","BODY_1","ONBACKGROUND_2","isSupportedFileView","Icon","IconTypes","DOWNLOAD","IconColors","ON_BACKGROUND_1","DELETE","GRAY","CLOSE","isVideo","isImage","H_1","propTypes","PropTypes","string","isRequired","func","bool","defaultProps","FileViewer","props","message","sender","threadInfo","replyCount","createPortal","document","getElementById","MODAL_ROOT","shape"],"mappings":"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"}
|