@sendbird/uikit-react 3.0.0-beta.4 → 3.0.0-beta.5
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 +313 -0
- package/App.js.map +1 -0
- package/Channel/components/ChannelHeader.js +117 -0
- package/Channel/components/ChannelHeader.js.map +1 -0
- package/Channel/components/ChannelUI.js +179 -0
- package/Channel/components/ChannelUI.js.map +1 -0
- package/Channel/components/FileViewer.js +151 -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 +355 -0
- package/Channel/components/Message.js.map +1 -0
- package/Channel/components/MessageInput.js +202 -0
- package/Channel/components/MessageInput.js.map +1 -0
- package/Channel/components/MessageList.js +239 -0
- package/Channel/components/MessageList.js.map +1 -0
- package/Channel/components/RemoveMessageModal.js +53 -0
- package/Channel/components/RemoveMessageModal.js.map +1 -0
- package/Channel/components/SuggestedMentionList.js +250 -0
- package/Channel/components/SuggestedMentionList.js.map +1 -0
- package/Channel/components/TypingIndicator.js +98 -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 +24 -0
- package/Channel/context.js.map +1 -0
- package/Channel.js +106 -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 +236 -0
- package/ChannelList/components/ChannelListUI.js.map +1 -0
- package/ChannelList/components/ChannelPreview.js +211 -0
- package/ChannelList/components/ChannelPreview.js.map +1 -0
- package/ChannelList/components/ChannelPreviewAction.js +131 -0
- package/ChannelList/components/ChannelPreviewAction.js.map +1 -0
- package/ChannelList/context.js +13 -0
- package/ChannelList/context.js.map +1 -0
- package/ChannelList.js +89 -0
- package/ChannelList.js.map +1 -0
- package/ChannelListProvider-a7bdd63a.js +923 -0
- package/ChannelListProvider-a7bdd63a.js.map +1 -0
- package/ChannelProvider-923b58df.js +2114 -0
- package/ChannelProvider-923b58df.js.map +1 -0
- package/ChannelSettings/components/AdminPanel.js +905 -0
- package/ChannelSettings/components/AdminPanel.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 +154 -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/UserListItem.js +105 -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/InviteMembers.js +184 -0
- package/CreateChannel/components/InviteMembers.js.map +1 -0
- package/CreateChannel/components/SelectChannelType.js +131 -0
- package/CreateChannel/components/SelectChannelType.js.map +1 -0
- package/CreateChannel/context.js +8 -0
- package/CreateChannel/context.js.map +1 -0
- package/CreateChannel.js +53 -0
- package/CreateChannel.js.map +1 -0
- package/CreateChannelProvider-e491613f.js +53 -0
- package/CreateChannelProvider-e491613f.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-0e05ddca.js +22 -0
- package/LocalizationContext-0e05ddca.js.map +1 -0
- package/MemberList-ed7da941.js +425 -0
- package/MemberList-ed7da941.js.map +1 -0
- package/MessageSearch/components/MessageSearchUI.js +151 -0
- package/MessageSearch/components/MessageSearchUI.js.map +1 -0
- package/MessageSearch/context.js +392 -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 +78 -0
- package/OpenChannel/components/OpenChannelHeader.js.map +1 -0
- package/OpenChannel/components/OpenChannelInput.js +56 -0
- package/OpenChannel/components/OpenChannelInput.js.map +1 -0
- package/OpenChannel/components/OpenChannelMessage.js +282 -0
- package/OpenChannel/components/OpenChannelMessage.js.map +1 -0
- package/OpenChannel/components/OpenChannelMessageList.js +157 -0
- package/OpenChannel/components/OpenChannelMessageList.js.map +1 -0
- package/OpenChannel/components/OpenChannelUI.js +109 -0
- package/OpenChannel/components/OpenChannelUI.js.map +1 -0
- package/OpenChannel/context.js +14 -0
- package/OpenChannel/context.js.map +1 -0
- package/OpenChannel.js +80 -0
- package/OpenChannel.js.map +1 -0
- package/OpenChannelProvider-45a848a3.js +2011 -0
- package/OpenChannelProvider-45a848a3.js.map +1 -0
- package/OpenChannelSettings/components/EditDetailsModal.js +149 -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 +104 -0
- package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -0
- package/OpenChannelSettings/components/OperatorUI.js +184 -0
- package/OpenChannelSettings/components/OperatorUI.js.map +1 -0
- package/OpenChannelSettings/components/ParticipantUI.js +172 -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/SendbirdProvider.js +762 -0
- package/SendbirdProvider.js.map +1 -0
- package/UserProfileContext-90704c73.js +38 -0
- package/UserProfileContext-90704c73.js.map +1 -0
- package/_rollupPluginBabelHelpers-c7eeba03.js +233 -0
- package/_rollupPluginBabelHelpers-c7eeba03.js.map +1 -0
- package/actionTypes-e0f4e19c.js +6 -0
- package/actionTypes-e0f4e19c.js.map +1 -0
- package/cjs/App.js +320 -0
- package/cjs/App.js.map +1 -0
- package/cjs/Channel/components/ChannelHeader.js +123 -0
- package/cjs/Channel/components/ChannelHeader.js.map +1 -0
- package/cjs/Channel/components/ChannelUI.js +185 -0
- package/cjs/Channel/components/ChannelUI.js.map +1 -0
- package/cjs/Channel/components/FileViewer.js +160 -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 +361 -0
- package/cjs/Channel/components/Message.js.map +1 -0
- package/cjs/Channel/components/MessageInput.js +208 -0
- package/cjs/Channel/components/MessageInput.js.map +1 -0
- package/cjs/Channel/components/MessageList.js +245 -0
- package/cjs/Channel/components/MessageList.js.map +1 -0
- package/cjs/Channel/components/RemoveMessageModal.js +59 -0
- package/cjs/Channel/components/RemoveMessageModal.js.map +1 -0
- package/cjs/Channel/components/SuggestedMentionList.js +256 -0
- package/cjs/Channel/components/SuggestedMentionList.js.map +1 -0
- package/cjs/Channel/components/TypingIndicator.js +107 -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 +33 -0
- package/cjs/Channel/context.js.map +1 -0
- package/cjs/Channel.js +112 -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 +242 -0
- package/cjs/ChannelList/components/ChannelListUI.js.map +1 -0
- package/cjs/ChannelList/components/ChannelPreview.js +217 -0
- package/cjs/ChannelList/components/ChannelPreview.js.map +1 -0
- package/cjs/ChannelList/components/ChannelPreviewAction.js +138 -0
- package/cjs/ChannelList/components/ChannelPreviewAction.js.map +1 -0
- package/cjs/ChannelList/context.js +23 -0
- package/cjs/ChannelList/context.js.map +1 -0
- package/cjs/ChannelList.js +95 -0
- package/cjs/ChannelList.js.map +1 -0
- package/cjs/ChannelListProvider-01864e22.js +936 -0
- package/cjs/ChannelListProvider-01864e22.js.map +1 -0
- package/cjs/ChannelProvider-3ef2a755.js +2127 -0
- package/cjs/ChannelProvider-3ef2a755.js.map +1 -0
- package/cjs/ChannelSettings/components/AdminPanel.js +911 -0
- package/cjs/ChannelSettings/components/AdminPanel.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 +160 -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/UserListItem.js +111 -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/InviteMembers.js +190 -0
- package/cjs/CreateChannel/components/InviteMembers.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 +17 -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-0d01dcbf.js +60 -0
- package/cjs/CreateChannelProvider-0d01dcbf.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-4c0a4a70.js +30 -0
- package/cjs/LocalizationContext-4c0a4a70.js.map +1 -0
- package/cjs/MemberList-b917d2b8.js +431 -0
- package/cjs/MemberList-b917d2b8.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 +401 -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 +84 -0
- package/cjs/OpenChannel/components/OpenChannelHeader.js.map +1 -0
- package/cjs/OpenChannel/components/OpenChannelInput.js +62 -0
- package/cjs/OpenChannel/components/OpenChannelInput.js.map +1 -0
- package/cjs/OpenChannel/components/OpenChannelMessage.js +288 -0
- package/cjs/OpenChannel/components/OpenChannelMessage.js.map +1 -0
- package/cjs/OpenChannel/components/OpenChannelMessageList.js +163 -0
- package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -0
- package/cjs/OpenChannel/components/OpenChannelUI.js +115 -0
- package/cjs/OpenChannel/components/OpenChannelUI.js.map +1 -0
- package/cjs/OpenChannel/context.js +23 -0
- package/cjs/OpenChannel/context.js.map +1 -0
- package/cjs/OpenChannel.js +86 -0
- package/cjs/OpenChannel.js.map +1 -0
- package/cjs/OpenChannelProvider-862a55ec.js +2020 -0
- package/cjs/OpenChannelProvider-862a55ec.js.map +1 -0
- package/cjs/OpenChannelSettings/components/EditDetailsModal.js +155 -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 +110 -0
- package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -0
- package/cjs/OpenChannelSettings/components/OperatorUI.js +194 -0
- package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -0
- package/cjs/OpenChannelSettings/components/ParticipantUI.js +178 -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 +771 -0
- package/cjs/SendbirdProvider.js.map +1 -0
- package/cjs/UserProfileContext-0081d7b2.js +46 -0
- package/cjs/UserProfileContext-0081d7b2.js.map +1 -0
- package/cjs/_rollupPluginBabelHelpers-08d1d0ec.js +243 -0
- package/cjs/_rollupPluginBabelHelpers-08d1d0ec.js.map +1 -0
- package/cjs/actionTypes-03bdd863.js +10 -0
- package/cjs/actionTypes-03bdd863.js.map +1 -0
- package/cjs/color-37edcf95.js +42 -0
- package/cjs/color-37edcf95.js.map +1 -0
- package/cjs/compareIds-1cb14940.js +20 -0
- package/cjs/compareIds-1cb14940.js.map +1 -0
- package/cjs/const-21636adb.js +22 -0
- package/cjs/const-21636adb.js.map +1 -0
- package/cjs/const-64185108.js +14 -0
- package/cjs/const-64185108.js.map +1 -0
- package/cjs/context-8f183eb3.js +19 -0
- package/cjs/context-8f183eb3.js.map +1 -0
- package/cjs/index-1a6c1893.js +9 -0
- package/cjs/index-1a6c1893.js.map +1 -0
- package/cjs/index-23c51d89.js +67 -0
- package/cjs/index-23c51d89.js.map +1 -0
- package/cjs/index-30e8e785.js +142 -0
- package/cjs/index-30e8e785.js.map +1 -0
- package/cjs/index-4e4d7494.js +514 -0
- package/cjs/index-4e4d7494.js.map +1 -0
- package/cjs/index-630f8d1b.js +97 -0
- package/cjs/index-630f8d1b.js.map +1 -0
- package/cjs/index-6d82098c.js +130 -0
- package/cjs/index-6d82098c.js.map +1 -0
- package/cjs/index-7532e1ca.js +284 -0
- package/cjs/index-7532e1ca.js.map +1 -0
- package/cjs/index-8479199c.js +175 -0
- package/cjs/index-8479199c.js.map +1 -0
- package/cjs/index-94e8cf13.js +54 -0
- package/cjs/index-94e8cf13.js.map +1 -0
- package/cjs/index-a40d57a5.js +722 -0
- package/cjs/index-a40d57a5.js.map +1 -0
- package/cjs/index-dcd38046.js +1880 -0
- package/cjs/index-dcd38046.js.map +1 -0
- package/cjs/index.css +4463 -0
- package/cjs/index.css.map +1 -0
- package/cjs/index.js +162 -0
- package/cjs/index.js.map +1 -0
- package/cjs/openChannelUtils-46a3a403.js +92 -0
- package/cjs/openChannelUtils-46a3a403.js.map +1 -0
- package/cjs/sendBirdSelectors.js +741 -0
- package/cjs/sendBirdSelectors.js.map +1 -0
- package/cjs/stringSet-d9121aa6.js +118 -0
- package/cjs/stringSet-d9121aa6.js.map +1 -0
- package/cjs/topics-4fc933cb.js +18 -0
- package/cjs/topics-4fc933cb.js.map +1 -0
- package/cjs/tslib.es6-571bbfc9.js +40 -0
- package/cjs/tslib.es6-571bbfc9.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 +44 -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 +201 -0
- package/cjs/ui/ChannelPreview.js.map +1 -0
- package/cjs/ui/ChatHeader.js +145 -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 +431 -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 +1462 -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/MentionUserLabel.js +25 -0
- package/cjs/ui/MentionUserLabel.js.map +1 -0
- package/cjs/ui/MessageContent.js +291 -0
- package/cjs/ui/MessageContent.js.map +1 -0
- package/cjs/ui/MessageInput.js +5048 -0
- package/cjs/ui/MessageInput.js.map +1 -0
- package/cjs/ui/MessageItemMenu.js +141 -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 +130 -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 +107 -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/OpenChannelMessageContent.js +14 -0
- package/cjs/ui/OpenChannelMessageContent.js.map +1 -0
- package/cjs/ui/OpenchannelConversationHeader.js +73 -0
- package/cjs/ui/OpenchannelConversationHeader.js.map +1 -0
- package/cjs/ui/OpenchannelFileMessage.js +230 -0
- package/cjs/ui/OpenchannelFileMessage.js.map +1 -0
- package/cjs/ui/OpenchannelOGMessage.js +345 -0
- package/cjs/ui/OpenchannelOGMessage.js.map +1 -0
- package/cjs/ui/OpenchannelThumbnailMessage.js +305 -0
- package/cjs/ui/OpenchannelThumbnailMessage.js.map +1 -0
- package/cjs/ui/OpenchannelUserMessage.js +264 -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 +99 -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 +62 -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 +158 -0
- package/cjs/ui/UserListItem.js.map +1 -0
- package/cjs/ui/UserProfile.js +87 -0
- package/cjs/ui/UserProfile.js.map +1 -0
- package/cjs/useSendbirdStateContext.js +22 -0
- package/cjs/useSendbirdStateContext.js.map +1 -0
- package/cjs/utils-63225dc9.js +32 -0
- package/cjs/utils-63225dc9.js.map +1 -0
- package/cjs/utils-b88eb3e0.js +6 -0
- package/cjs/utils-b88eb3e0.js.map +1 -0
- package/cjs/utils-f734965d.js +38 -0
- package/cjs/utils-f734965d.js.map +1 -0
- package/cjs/uuid-086f0c34.js +19 -0
- package/cjs/uuid-086f0c34.js.map +1 -0
- package/cjs/withSendBird.js +35 -0
- package/cjs/withSendBird.js.map +1 -0
- package/color-a3d3742c.js +39 -0
- package/color-a3d3742c.js.map +1 -0
- package/compareIds-2bfd667a.js +18 -0
- package/compareIds-2bfd667a.js.map +1 -0
- package/const-9f83647a.js +18 -0
- package/const-9f83647a.js.map +1 -0
- package/const-a8df15de.js +8 -0
- package/const-a8df15de.js.map +1 -0
- package/context-ae164d45.js +12 -0
- package/context-ae164d45.js.map +1 -0
- package/index-03baba6a.js +682 -0
- package/index-03baba6a.js.map +1 -0
- package/index-13eb0f5e.js +48 -0
- package/index-13eb0f5e.js.map +1 -0
- package/index-29563598.js +64 -0
- package/index-29563598.js.map +1 -0
- package/index-2c56786f.js +1873 -0
- package/index-2c56786f.js.map +1 -0
- package/index-80e330a9.js +7 -0
- package/index-80e330a9.js.map +1 -0
- package/index-89f5a4ba.js +168 -0
- package/index-89f5a4ba.js.map +1 -0
- package/index-d7840fad.js +280 -0
- package/index-d7840fad.js.map +1 -0
- package/index-df459121.js +121 -0
- package/index-df459121.js.map +1 -0
- package/index-e1b93b3a.js +131 -0
- package/index-e1b93b3a.js.map +1 -0
- package/index-e7c0bc26.js +512 -0
- package/index-e7c0bc26.js.map +1 -0
- package/index-f78ebc31.js +87 -0
- package/index-f78ebc31.js.map +1 -0
- package/index.css +4463 -0
- package/index.css.map +1 -0
- package/index.d.ts +1830 -0
- package/index.js +143 -0
- package/index.js.map +1 -0
- package/openChannelUtils-ae1d6038.js +81 -0
- package/openChannelUtils-ae1d6038.js.map +1 -0
- package/package.json +7 -29
- package/sendBirdSelectors.js +713 -0
- package/sendBirdSelectors.js.map +1 -0
- package/stringSet-6c9c68ae.js +116 -0
- package/stringSet-6c9c68ae.js.map +1 -0
- package/topics-d347c996.js +10 -0
- package/topics-d347c996.js.map +1 -0
- package/tslib.es6-61821688.js +38 -0
- package/tslib.es6-61821688.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 +37 -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 +194 -0
- package/ui/ChannelPreview.js.map +1 -0
- package/ui/ChatHeader.js +138 -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 +417 -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 +1432 -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/MentionUserLabel.js +19 -0
- package/ui/MentionUserLabel.js.map +1 -0
- package/ui/MessageContent.js +285 -0
- package/ui/MessageContent.js.map +1 -0
- package/ui/MessageInput.js +5040 -0
- package/ui/MessageInput.js.map +1 -0
- package/ui/MessageItemMenu.js +135 -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 +124 -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 +101 -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/OpenChannelMessageContent.js +8 -0
- package/ui/OpenChannelMessageContent.js.map +1 -0
- package/ui/OpenchannelConversationHeader.js +67 -0
- package/ui/OpenchannelConversationHeader.js.map +1 -0
- package/ui/OpenchannelFileMessage.js +224 -0
- package/ui/OpenchannelFileMessage.js.map +1 -0
- package/ui/OpenchannelOGMessage.js +339 -0
- package/ui/OpenchannelOGMessage.js.map +1 -0
- package/ui/OpenchannelThumbnailMessage.js +299 -0
- package/ui/OpenchannelThumbnailMessage.js.map +1 -0
- package/ui/OpenchannelUserMessage.js +258 -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 +93 -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 +56 -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 +151 -0
- package/ui/UserListItem.js.map +1 -0
- package/ui/UserProfile.js +81 -0
- package/ui/UserProfile.js.map +1 -0
- package/useSendbirdStateContext.js +20 -0
- package/useSendbirdStateContext.js.map +1 -0
- package/utils-4e85584a.js +4 -0
- package/utils-4e85584a.js.map +1 -0
- package/utils-5e25aca3.js +34 -0
- package/utils-5e25aca3.js.map +1 -0
- package/utils-aed86fb8.js +30 -0
- package/utils-aed86fb8.js.map +1 -0
- package/uuid-6e6389e2.js +17 -0
- package/uuid-6e6389e2.js.map +1 -0
- package/withSendBird.js +26 -0
- package/withSendBird.js.map +1 -0
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import React__default, { useState } from 'react';
|
|
2
|
+
import IconButton from '../../ui/IconButton.js';
|
|
3
|
+
import Icon, { IconTypes, IconColors } from '../../ui/Icon.js';
|
|
4
|
+
import CreateChannel from '../../CreateChannel.js';
|
|
5
|
+
import useSendbirdStateContext from '../../useSendbirdStateContext.js';
|
|
6
|
+
import '../../_rollupPluginBabelHelpers-c7eeba03.js';
|
|
7
|
+
import 'prop-types';
|
|
8
|
+
import '../../CreateChannel/components/CreateChannelUI.js';
|
|
9
|
+
import '../../CreateChannelProvider-e491613f.js';
|
|
10
|
+
import '../../sendBirdSelectors.js';
|
|
11
|
+
import '../../topics-d347c996.js';
|
|
12
|
+
import '../../CreateChannel/components/InviteMembers.js';
|
|
13
|
+
import '../../tslib.es6-61821688.js';
|
|
14
|
+
import '../../LocalizationContext-0e05ddca.js';
|
|
15
|
+
import '../../stringSet-6c9c68ae.js';
|
|
16
|
+
import '../../index-e7c0bc26.js';
|
|
17
|
+
import '../../ui/Modal.js';
|
|
18
|
+
import 'react-dom';
|
|
19
|
+
import '../../index-80e330a9.js';
|
|
20
|
+
import '../../index-f78ebc31.js';
|
|
21
|
+
import '../../index-e1b93b3a.js';
|
|
22
|
+
import '../../utils-4e85584a.js';
|
|
23
|
+
import '../../ui/UserListItem.js';
|
|
24
|
+
import '../../UserProfileContext-90704c73.js';
|
|
25
|
+
import '../../ui/Avatar.js';
|
|
26
|
+
import '../../ui/ImageRenderer.js';
|
|
27
|
+
import '../../uuid-6e6389e2.js';
|
|
28
|
+
import '../../ui/MutedAvatarOverlay.js';
|
|
29
|
+
import '../../ui/Checkbox.js';
|
|
30
|
+
import '../../ui/UserProfile.js';
|
|
31
|
+
import '../../withSendBird.js';
|
|
32
|
+
import '../../ui/ContextMenu.js';
|
|
33
|
+
import '../../index-03baba6a.js';
|
|
34
|
+
import '../../ui/SortByRow.js';
|
|
35
|
+
import '../../CreateChannel/components/SelectChannelType.js';
|
|
36
|
+
|
|
37
|
+
var AddChannel = function AddChannel() {
|
|
38
|
+
var _a;
|
|
39
|
+
|
|
40
|
+
var _b = useState(false),
|
|
41
|
+
showModal = _b[0],
|
|
42
|
+
setShowModal = _b[1];
|
|
43
|
+
|
|
44
|
+
var state = useSendbirdStateContext();
|
|
45
|
+
var isOnline = (_a = state === null || state === void 0 ? void 0 : state.config) === null || _a === void 0 ? void 0 : _a.isOnline;
|
|
46
|
+
var disabled = !isOnline;
|
|
47
|
+
return /*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement(IconButton, {
|
|
48
|
+
height: "32px",
|
|
49
|
+
width: "32px",
|
|
50
|
+
onClick: function onClick() {
|
|
51
|
+
setShowModal(true);
|
|
52
|
+
},
|
|
53
|
+
disabled: disabled
|
|
54
|
+
}, /*#__PURE__*/React__default.createElement(Icon, {
|
|
55
|
+
type: IconTypes.CREATE,
|
|
56
|
+
fillColor: IconColors.PRIMARY,
|
|
57
|
+
width: "24px",
|
|
58
|
+
height: "24px"
|
|
59
|
+
})), showModal && /*#__PURE__*/React__default.createElement(CreateChannel, {
|
|
60
|
+
onCancel: function onCancel() {
|
|
61
|
+
setShowModal(false);
|
|
62
|
+
},
|
|
63
|
+
onCreateChannel: function onCreateChannel() {
|
|
64
|
+
setShowModal(false);
|
|
65
|
+
}
|
|
66
|
+
}));
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
export { AddChannel, AddChannel as default };
|
|
70
|
+
//# sourceMappingURL=AddChannel.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AddChannel.js","sources":["../../../src/smart-components/ChannelList/components/AddChannel/index.tsx"],"sourcesContent":["import './add-channel.scss';\n\nimport React, { useState } from 'react';\n\nimport IconButton from '../../../../ui/IconButton';\nimport Icon, { IconTypes, IconColors } from '../../../../ui/Icon';\n\nimport CreateChannel from '../../../CreateChannel';\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\n\nexport const AddChannel: React.VoidFunctionComponent = () => {\n const [showModal, setShowModal] = useState(false);\n const state = useSendbirdStateContext();\n const isOnline = state?.config?.isOnline;\n const disabled = !isOnline;\n\n return (\n <>\n <IconButton\n height=\"32px\"\n width=\"32px\"\n onClick={() => {\n setShowModal(true);\n }}\n disabled={disabled}\n >\n <Icon\n type={IconTypes.CREATE}\n fillColor={IconColors.PRIMARY}\n width=\"24px\"\n height=\"24px\"\n />\n </IconButton>\n {\n showModal && (\n <CreateChannel\n onCancel={() => {\n setShowModal(false);\n }}\n onCreateChannel={() => {\n setShowModal(false);\n }}\n />\n )\n }\n </>\n );\n}\n\nexport default AddChannel;\n"],"names":["AddChannel","_b","useState","showModal","setShowModal","state","useSendbirdStateContext","isOnline","config","disabled","React","IconTypes","CREATE","IconColors","PRIMARY"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAUaA,UAAU,GAAgC,SAA1CA,UAA0C;;;AAC/C,MAAAC,KAA4BC,QAAQ,CAAC,KAAD,CAApC;AAAA,MAACC,SAAS,QAAV;AAAA,MAAYC,YAAY,QAAxB;;AACN,MAAMC,KAAK,GAAGC,uBAAuB,EAArC;AACA,MAAMC,QAAQ,GAAG,MAAAF,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEG,MAAP,UAAA,iBAAA,SAAA,MAAeD,QAAhC;AACA,MAAME,QAAQ,GAAG,CAACF,QAAlB;AAEA,sBACEG,yEACEA,6BAAC,UAAD;AACE,IAAA,MAAM,EAAC,MADT;AAEE,IAAA,KAAK,EAAC,MAFR;AAGE,IAAA,OAAO,EAAE;AACPN,MAAAA,YAAY,CAAC,IAAD,CAAZ;AACD,KALH;AAME,IAAA,QAAQ,EAAEK;AANZ,kBAQEC,6BAAC,IAAD;AACE,IAAA,IAAI,EAAEC,SAAS,CAACC,MADlB;AAEE,IAAA,SAAS,EAAEC,UAAU,CAACC,OAFxB;AAGE,IAAA,KAAK,EAAC,MAHR;AAIE,IAAA,MAAM,EAAC;AAJT,IARF,CADF,EAiBIX,SAAS,iBACPO,6BAAC,aAAD;AACE,IAAA,QAAQ,EAAE;AACRN,MAAAA,YAAY,CAAC,KAAD,CAAZ;AACD,KAHH;AAIE,IAAA,eAAe,EAAE;AACfA,MAAAA,YAAY,CAAC,KAAD,CAAZ;AACD;AANH,IAlBN,CADF;AA+BD;;;;"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import React__default, { useContext } from 'react';
|
|
2
|
+
import { a as LocalizationContext } from '../../LocalizationContext-0e05ddca.js';
|
|
3
|
+
import useSendbirdStateContext from '../../useSendbirdStateContext.js';
|
|
4
|
+
import { L as Label, a as LabelTypography, b as LabelColors } from '../../index-e1b93b3a.js';
|
|
5
|
+
import IconButton from '../../ui/IconButton.js';
|
|
6
|
+
import Avatar from '../../ui/Avatar.js';
|
|
7
|
+
import '../../stringSet-6c9c68ae.js';
|
|
8
|
+
import '../../index-e7c0bc26.js';
|
|
9
|
+
import '../../withSendBird.js';
|
|
10
|
+
import '../../_rollupPluginBabelHelpers-c7eeba03.js';
|
|
11
|
+
import 'prop-types';
|
|
12
|
+
import '../../tslib.es6-61821688.js';
|
|
13
|
+
import '../../ui/ImageRenderer.js';
|
|
14
|
+
import '../../ui/Icon.js';
|
|
15
|
+
import '../../uuid-6e6389e2.js';
|
|
16
|
+
|
|
17
|
+
var ChannelListHeader = function ChannelListHeader(_a) {
|
|
18
|
+
var _b;
|
|
19
|
+
|
|
20
|
+
var renderHeader = _a.renderHeader,
|
|
21
|
+
renderIconButton = _a.renderIconButton,
|
|
22
|
+
onEdit = _a.onEdit,
|
|
23
|
+
allowProfileEdit = _a.allowProfileEdit;
|
|
24
|
+
var sbState = useSendbirdStateContext();
|
|
25
|
+
var user = ((_b = sbState === null || sbState === void 0 ? void 0 : sbState.stores) === null || _b === void 0 ? void 0 : _b.userStore).user;
|
|
26
|
+
var stringSet = useContext(LocalizationContext).stringSet;
|
|
27
|
+
return /*#__PURE__*/React__default.createElement("div", {
|
|
28
|
+
className: ['sendbird-channel-header', allowProfileEdit ? 'sendbird-channel-header--allow-edit' : ''].join(' ')
|
|
29
|
+
}, renderHeader ? renderHeader() : /*#__PURE__*/React__default.createElement("div", {
|
|
30
|
+
className: "sendbird-channel-header__title",
|
|
31
|
+
role: "button",
|
|
32
|
+
onClick: function onClick() {
|
|
33
|
+
onEdit();
|
|
34
|
+
},
|
|
35
|
+
onKeyDown: function onKeyDown() {
|
|
36
|
+
onEdit();
|
|
37
|
+
},
|
|
38
|
+
tabIndex: 0
|
|
39
|
+
}, /*#__PURE__*/React__default.createElement("div", {
|
|
40
|
+
className: "sendbird-channel-header__title__left"
|
|
41
|
+
}, /*#__PURE__*/React__default.createElement(Avatar, {
|
|
42
|
+
width: "32px",
|
|
43
|
+
height: "32px",
|
|
44
|
+
src: user.profileUrl,
|
|
45
|
+
alt: user.nickname
|
|
46
|
+
})), /*#__PURE__*/React__default.createElement("div", {
|
|
47
|
+
className: "sendbird-channel-header__title__right"
|
|
48
|
+
}, /*#__PURE__*/React__default.createElement(Label, {
|
|
49
|
+
className: "sendbird-channel-header__title__right__name",
|
|
50
|
+
type: LabelTypography.SUBTITLE_2,
|
|
51
|
+
color: LabelColors.ONBACKGROUND_1
|
|
52
|
+
}, user.nickname || stringSet.NO_NAME), /*#__PURE__*/React__default.createElement(Label, {
|
|
53
|
+
className: "sendbird-channel-header__title__right__user-id",
|
|
54
|
+
type: LabelTypography.BODY_2,
|
|
55
|
+
color: LabelColors.ONBACKGROUND_2
|
|
56
|
+
}, user.userId))), /*#__PURE__*/React__default.createElement("div", {
|
|
57
|
+
className: "sendbird-channel-header__right-icon"
|
|
58
|
+
}, renderIconButton() || /*#__PURE__*/React__default.createElement(IconButton, null)));
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
export { ChannelListHeader as default };
|
|
62
|
+
//# sourceMappingURL=ChannelListHeader.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChannelListHeader.js","sources":["../../../src/smart-components/ChannelList/components/ChannelListHeader/index.tsx"],"sourcesContent":["import React, { useContext } from 'react';\n\nimport { LocalizationContext } from '../../../../lib/LocalizationContext';\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport Label, { LabelTypography, LabelColors } from '../../../../ui/Label';\nimport IconButton from '../../../../ui/IconButton';\n\nimport './index.scss';\nimport Avatar from '../../../../ui/Avatar';\n\ninterface ChannelListHeaderInterface {\n renderHeader?: (props: void) => React.ReactNode;\n renderIconButton?: (props: void) => React.ReactNode;\n onEdit?: (props: void) => void;\n allowProfileEdit?: boolean;\n}\n\nconst ChannelListHeader : React.FC<ChannelListHeaderInterface> = ({\n renderHeader,\n renderIconButton,\n onEdit,\n allowProfileEdit,\n}: ChannelListHeaderInterface) => {\n const sbState = useSendbirdStateContext();\n const { user } = sbState?.stores?.userStore;\n\n const { stringSet } = useContext(LocalizationContext);\n return (\n <div\n className={[\n 'sendbird-channel-header',\n allowProfileEdit ? 'sendbird-channel-header--allow-edit' : '',\n ].join(' ')}\n >\n {\n renderHeader\n ? renderHeader()\n : (\n <div\n className=\"sendbird-channel-header__title\"\n role=\"button\"\n onClick={() => { onEdit() }}\n onKeyDown={() => { onEdit() }}\n tabIndex={0}\n >\n <div className=\"sendbird-channel-header__title__left\">\n <Avatar\n width=\"32px\"\n height=\"32px\"\n src={user.profileUrl}\n alt={user.nickname}\n />\n </div>\n <div className=\"sendbird-channel-header__title__right\">\n <Label\n className=\"sendbird-channel-header__title__right__name\"\n type={LabelTypography.SUBTITLE_2}\n color={LabelColors.ONBACKGROUND_1}\n >\n {user.nickname || stringSet.NO_NAME}\n </Label>\n <Label\n className=\"sendbird-channel-header__title__right__user-id\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_2}\n >\n {user.userId}\n </Label>\n </div>\n </div>\n )\n }\n <div className=\"sendbird-channel-header__right-icon\">\n {renderIconButton() || <IconButton />}\n </div>\n </div>\n );\n}\n\nexport default ChannelListHeader;\n"],"names":["ChannelListHeader","_a","renderHeader","renderIconButton","onEdit","allowProfileEdit","sbState","useSendbirdStateContext","user","stores","userStore","stringSet","useContext","LocalizationContext","React","join","profileUrl","nickname","LabelTypography","SUBTITLE_2","LabelColors","ONBACKGROUND_1","NO_NAME","BODY_2","ONBACKGROUND_2","userId"],"mappings":";;;;;;;;;;;;;;;;IAiBMA,iBAAiB,GAA0C,SAA3DA,iBAA2D,CAACC,EAAD;;;MAC/DC,YAAY;MACZC,gBAAgB;MAChBC,MAAM;MACNC,gBAAgB;AAEhB,MAAMC,OAAO,GAAGC,uBAAuB,EAAvC;AACQ,MAAAC,IAAI,GAAK,CAAA,MAAAF,OAAO,SAAP,IAAAA,OAAO,WAAP,SAAA,GAAAA,OAAO,CAAEG,MAAT,UAAA,iBAAA,SAAA,MAAiBC,SAAjB,MAAT;AAEA,MAAAC,SAAS,GAAKC,UAAU,CAACC,mBAAD,CAAV,UAAd;AACR,sBACEC;AACE,IAAA,SAAS,EAAE,CACT,yBADS,EAETT,gBAAgB,GAAG,qCAAH,GAA2C,EAFlD,EAGTU,IAHS,CAGJ,GAHI;AADb,KAOIb,YAAY,GACRA,YAAY,EADJ,gBAGRY;AACE,IAAA,SAAS,EAAC,gCADZ;AAEE,IAAA,IAAI,EAAC,QAFP;AAGE,IAAA,OAAO,EAAE;AAAQV,MAAAA,MAAM;AAAI,KAH7B;AAIE,IAAA,SAAS,EAAE;AAAQA,MAAAA,MAAM;AAAI,KAJ/B;AAKE,IAAA,QAAQ,EAAE;AALZ,kBAOEU;AAAK,IAAA,SAAS,EAAC;AAAf,kBACEA,6BAAC,MAAD;AACE,IAAA,KAAK,EAAC,MADR;AAEE,IAAA,MAAM,EAAC,MAFT;AAGE,IAAA,GAAG,EAAEN,IAAI,CAACQ,UAHZ;AAIE,IAAA,GAAG,EAAER,IAAI,CAACS;AAJZ,IADF,CAPF,eAeEH;AAAK,IAAA,SAAS,EAAC;AAAf,kBACEA,6BAAC,KAAD;AACE,IAAA,SAAS,EAAC,6CADZ;AAEE,IAAA,IAAI,EAAEI,eAAe,CAACC,UAFxB;AAGE,IAAA,KAAK,EAAEC,WAAW,CAACC;AAHrB,KAKGb,IAAI,CAACS,QAAL,IAAiBN,SAAS,CAACW,OAL9B,CADF,eAQER,6BAAC,KAAD;AACE,IAAA,SAAS,EAAC,gDADZ;AAEE,IAAA,IAAI,EAAEI,eAAe,CAACK,MAFxB;AAGE,IAAA,KAAK,EAAEH,WAAW,CAACI;AAHrB,KAKGhB,IAAI,CAACiB,MALR,CARF,CAfF,CAVR,eA4CEX;AAAK,IAAA,SAAS,EAAC;AAAf,KACGX,gBAAgB,mBAAMW,6BAAC,UAAD,OADzB,CA5CF,CADF;AAkDD;;;;"}
|
|
@@ -0,0 +1,236 @@
|
|
|
1
|
+
import React__default, { useState } from 'react';
|
|
2
|
+
import ChannelListHeader from './ChannelListHeader.js';
|
|
3
|
+
import { AddChannel } from './AddChannel.js';
|
|
4
|
+
import ChannelPreview from './ChannelPreview.js';
|
|
5
|
+
import ChannelPreviewAction from './ChannelPreviewAction.js';
|
|
6
|
+
import { u as useChannelListContext, F as FETCH_CHANNELS_START, a as FETCH_CHANNELS_FAILURE, b as FETCH_CHANNELS_SUCCESS, L as LEAVE_CHANNEL_SUCCESS, S as SET_CURRENT_CHANNEL } from '../../ChannelListProvider-a7bdd63a.js';
|
|
7
|
+
import useSendbirdStateContext from '../../useSendbirdStateContext.js';
|
|
8
|
+
import EditProfile from '../../EditUserProfile.js';
|
|
9
|
+
import { P as PlaceHolder, a as PlaceHolderTypes } from '../../index-df459121.js';
|
|
10
|
+
import '../../LocalizationContext-0e05ddca.js';
|
|
11
|
+
import '../../stringSet-6c9c68ae.js';
|
|
12
|
+
import '../../index-e7c0bc26.js';
|
|
13
|
+
import '../../index-e1b93b3a.js';
|
|
14
|
+
import '../../_rollupPluginBabelHelpers-c7eeba03.js';
|
|
15
|
+
import 'prop-types';
|
|
16
|
+
import '../../ui/IconButton.js';
|
|
17
|
+
import '../../ui/Avatar.js';
|
|
18
|
+
import '../../tslib.es6-61821688.js';
|
|
19
|
+
import '../../ui/ImageRenderer.js';
|
|
20
|
+
import '../../ui/Icon.js';
|
|
21
|
+
import '../../uuid-6e6389e2.js';
|
|
22
|
+
import '../../CreateChannel.js';
|
|
23
|
+
import '../../CreateChannel/components/CreateChannelUI.js';
|
|
24
|
+
import '../../CreateChannelProvider-e491613f.js';
|
|
25
|
+
import '../../sendBirdSelectors.js';
|
|
26
|
+
import '../../topics-d347c996.js';
|
|
27
|
+
import '../../CreateChannel/components/InviteMembers.js';
|
|
28
|
+
import '../../ui/Modal.js';
|
|
29
|
+
import 'react-dom';
|
|
30
|
+
import '../../index-80e330a9.js';
|
|
31
|
+
import '../../index-f78ebc31.js';
|
|
32
|
+
import '../../utils-4e85584a.js';
|
|
33
|
+
import '../../ui/UserListItem.js';
|
|
34
|
+
import '../../UserProfileContext-90704c73.js';
|
|
35
|
+
import '../../ui/MutedAvatarOverlay.js';
|
|
36
|
+
import '../../ui/Checkbox.js';
|
|
37
|
+
import '../../ui/UserProfile.js';
|
|
38
|
+
import '../../withSendBird.js';
|
|
39
|
+
import '../../ui/ContextMenu.js';
|
|
40
|
+
import '../../index-03baba6a.js';
|
|
41
|
+
import '../../ui/SortByRow.js';
|
|
42
|
+
import '../../CreateChannel/components/SelectChannelType.js';
|
|
43
|
+
import '../../ui/ChannelAvatar.js';
|
|
44
|
+
import '../../utils-5e25aca3.js';
|
|
45
|
+
import '../../ui/Badge.js';
|
|
46
|
+
import '../../index-d7840fad.js';
|
|
47
|
+
import '../../index-29563598.js';
|
|
48
|
+
import '../../index-2c56786f.js';
|
|
49
|
+
import '../../ui/MentionUserLabel.js';
|
|
50
|
+
import '../../Channel/components/TypingIndicator.js';
|
|
51
|
+
import '../../ChannelProvider-923b58df.js';
|
|
52
|
+
import '../../compareIds-2bfd667a.js';
|
|
53
|
+
import '../../const-a8df15de.js';
|
|
54
|
+
import '../../ui/ReactionButton.js';
|
|
55
|
+
import '../../ui/MessageStatus.js';
|
|
56
|
+
import '../../ui/Loader.js';
|
|
57
|
+
import '../../index-89f5a4ba.js';
|
|
58
|
+
import '../../ui/Input.js';
|
|
59
|
+
import '../../ui/TextButton.js';
|
|
60
|
+
import '../../color-a3d3742c.js';
|
|
61
|
+
import '../../actionTypes-e0f4e19c.js';
|
|
62
|
+
|
|
63
|
+
var DELIVERY_RECIPT = 'delivery_receipt';
|
|
64
|
+
|
|
65
|
+
var ChannelListUI = function ChannelListUI(props) {
|
|
66
|
+
var _a, _b;
|
|
67
|
+
|
|
68
|
+
var renderHeader = props.renderHeader,
|
|
69
|
+
renderChannelPreview = props.renderChannelPreview,
|
|
70
|
+
renderPlaceHolderError = props.renderPlaceHolderError,
|
|
71
|
+
renderPlaceHolderLoading = props.renderPlaceHolderLoading,
|
|
72
|
+
renderPlaceHolderEmptyList = props.renderPlaceHolderEmptyList;
|
|
73
|
+
|
|
74
|
+
var _c = useState(false),
|
|
75
|
+
showProfileEdit = _c[0],
|
|
76
|
+
setShowProfileEdit = _c[1];
|
|
77
|
+
|
|
78
|
+
var _d = useChannelListContext(),
|
|
79
|
+
onThemeChange = _d.onThemeChange,
|
|
80
|
+
allowProfileEdit = _d.allowProfileEdit,
|
|
81
|
+
allChannels = _d.allChannels,
|
|
82
|
+
loading = _d.loading,
|
|
83
|
+
currentChannel = _d.currentChannel,
|
|
84
|
+
channelListDispatcher = _d.channelListDispatcher,
|
|
85
|
+
channelSource = _d.channelSource,
|
|
86
|
+
typingChannels = _d.typingChannels;
|
|
87
|
+
|
|
88
|
+
var state = useSendbirdStateContext();
|
|
89
|
+
var sdkStore = (_a = state === null || state === void 0 ? void 0 : state.stores) === null || _a === void 0 ? void 0 : _a.sdkStore;
|
|
90
|
+
var config = state === null || state === void 0 ? void 0 : state.config;
|
|
91
|
+
var isOnline = (_b = state === null || state === void 0 ? void 0 : state.config) === null || _b === void 0 ? void 0 : _b.isOnline;
|
|
92
|
+
var logger = config === null || config === void 0 ? void 0 : config.logger;
|
|
93
|
+
var sdk = sdkStore === null || sdkStore === void 0 ? void 0 : sdkStore.sdk;
|
|
94
|
+
var sdkError = sdkStore === null || sdkStore === void 0 ? void 0 : sdkStore.error;
|
|
95
|
+
var sdkIntialized = (sdkStore === null || sdkStore === void 0 ? void 0 : sdkStore.initialized) || false;
|
|
96
|
+
return /*#__PURE__*/React__default.createElement(React__default.Fragment, null, /*#__PURE__*/React__default.createElement("div", {
|
|
97
|
+
className: "sendbird-channel-list__header"
|
|
98
|
+
}, /*#__PURE__*/React__default.createElement(ChannelListHeader, {
|
|
99
|
+
renderHeader: renderHeader,
|
|
100
|
+
onEdit: function onEdit() {
|
|
101
|
+
if (allowProfileEdit) {
|
|
102
|
+
setShowProfileEdit(true);
|
|
103
|
+
}
|
|
104
|
+
},
|
|
105
|
+
allowProfileEdit: allowProfileEdit,
|
|
106
|
+
renderIconButton: function renderIconButton() {
|
|
107
|
+
return /*#__PURE__*/React__default.createElement(AddChannel, null);
|
|
108
|
+
}
|
|
109
|
+
})), showProfileEdit && /*#__PURE__*/React__default.createElement(EditProfile, {
|
|
110
|
+
onThemeChange: onThemeChange,
|
|
111
|
+
onCancel: function onCancel() {
|
|
112
|
+
setShowProfileEdit(false);
|
|
113
|
+
},
|
|
114
|
+
onEditProfile: function onEditProfile() {
|
|
115
|
+
setShowProfileEdit(false);
|
|
116
|
+
}
|
|
117
|
+
}), /*#__PURE__*/React__default.createElement("div", {
|
|
118
|
+
className: "sendbird-channel-list__body",
|
|
119
|
+
onScroll: function onScroll(e) {
|
|
120
|
+
var target = e === null || e === void 0 ? void 0 : e.target;
|
|
121
|
+
var fetchMore = target.clientHeight + target.scrollTop === target.scrollHeight;
|
|
122
|
+
|
|
123
|
+
if (fetchMore && (channelSource === null || channelSource === void 0 ? void 0 : channelSource.hasNext)) {
|
|
124
|
+
logger.info('ChannelList: Fetching more channels');
|
|
125
|
+
channelListDispatcher({
|
|
126
|
+
type: FETCH_CHANNELS_START,
|
|
127
|
+
payload: null
|
|
128
|
+
});
|
|
129
|
+
channelSource === null || channelSource === void 0 ? void 0 : channelSource.next(function (channelList, err) {
|
|
130
|
+
var _a, _b;
|
|
131
|
+
|
|
132
|
+
if (err) {
|
|
133
|
+
logger.info('ChannelList: Fetching channels failed', err);
|
|
134
|
+
channelListDispatcher({
|
|
135
|
+
type: FETCH_CHANNELS_FAILURE,
|
|
136
|
+
payload: channelList
|
|
137
|
+
});
|
|
138
|
+
return;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
logger.info('ChannelList: Fetching channels successful', channelList);
|
|
142
|
+
channelListDispatcher({
|
|
143
|
+
type: FETCH_CHANNELS_SUCCESS,
|
|
144
|
+
payload: channelList
|
|
145
|
+
});
|
|
146
|
+
var canSetMarkAsDelivered = (_b = (_a = sdk === null || sdk === void 0 ? void 0 : sdk.appInfo) === null || _a === void 0 ? void 0 : _a.premiumFeatureList) === null || _b === void 0 ? void 0 : _b.find(function (feature) {
|
|
147
|
+
return feature === DELIVERY_RECIPT;
|
|
148
|
+
});
|
|
149
|
+
|
|
150
|
+
if (canSetMarkAsDelivered) {
|
|
151
|
+
logger.info('ChannelList: Marking all channels as read'); // eslint-disable-next-line no-unused-expressions
|
|
152
|
+
|
|
153
|
+
channelList === null || channelList === void 0 ? void 0 : channelList.forEach(function (c, idx) {
|
|
154
|
+
// Plan-based rate limits - minimum limit is 5 requests per second
|
|
155
|
+
setTimeout(function () {
|
|
156
|
+
sdk === null || sdk === void 0 ? void 0 : sdk.markAsDelivered(c === null || c === void 0 ? void 0 : c.url);
|
|
157
|
+
}, 300 * idx);
|
|
158
|
+
});
|
|
159
|
+
}
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
}, sdkError && (renderPlaceHolderError && typeof renderPlaceHolderError === 'function' ? renderPlaceHolderError === null || renderPlaceHolderError === void 0 ? void 0 : renderPlaceHolderError() : /*#__PURE__*/React__default.createElement(PlaceHolder, {
|
|
164
|
+
type: PlaceHolderTypes.WRONG
|
|
165
|
+
})), /*#__PURE__*/React__default.createElement("div", null, allChannels && allChannels.map(function (channel, idx) {
|
|
166
|
+
var _onLeaveChannel = function onLeaveChannel(c, cb) {
|
|
167
|
+
logger.info('ChannelList: Leaving channel', c);
|
|
168
|
+
c.leave().then(function (res) {
|
|
169
|
+
logger.info('ChannelList: Leaving channel success', res);
|
|
170
|
+
|
|
171
|
+
if (cb && typeof cb === 'function') {
|
|
172
|
+
cb(res, null);
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
channelListDispatcher({
|
|
176
|
+
type: LEAVE_CHANNEL_SUCCESS,
|
|
177
|
+
payload: channel.url
|
|
178
|
+
});
|
|
179
|
+
}).catch(function (err) {
|
|
180
|
+
logger.error('ChannelList: Leaving channel failed', err);
|
|
181
|
+
|
|
182
|
+
if (cb && typeof cb === 'function') {
|
|
183
|
+
cb(null, err);
|
|
184
|
+
}
|
|
185
|
+
});
|
|
186
|
+
};
|
|
187
|
+
|
|
188
|
+
var onClick = function onClick() {
|
|
189
|
+
if (!isOnline) {
|
|
190
|
+
return;
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
logger.info('ChannelList: Clicked on channel:', channel);
|
|
194
|
+
channelListDispatcher({
|
|
195
|
+
type: SET_CURRENT_CHANNEL,
|
|
196
|
+
payload: channel
|
|
197
|
+
});
|
|
198
|
+
};
|
|
199
|
+
|
|
200
|
+
return renderChannelPreview ?
|
|
201
|
+
/*#__PURE__*/
|
|
202
|
+
// eslint-disable-next-line
|
|
203
|
+
React__default.createElement("div", {
|
|
204
|
+
key: channel.url,
|
|
205
|
+
onClick: onClick
|
|
206
|
+
}, renderChannelPreview({
|
|
207
|
+
channel: channel,
|
|
208
|
+
onLeaveChannel: _onLeaveChannel
|
|
209
|
+
})) : /*#__PURE__*/React__default.createElement(ChannelPreview, {
|
|
210
|
+
key: channel.url,
|
|
211
|
+
tabIndex: idx,
|
|
212
|
+
onClick: onClick,
|
|
213
|
+
channel: channel,
|
|
214
|
+
isActive: channel.url === (currentChannel === null || currentChannel === void 0 ? void 0 : currentChannel.url),
|
|
215
|
+
isTyping: typingChannels === null || typingChannels === void 0 ? void 0 : typingChannels.some(function (_a) {
|
|
216
|
+
var url = _a.url;
|
|
217
|
+
return url === channel.url;
|
|
218
|
+
}),
|
|
219
|
+
renderChannelAction: function renderChannelAction() {
|
|
220
|
+
return /*#__PURE__*/React__default.createElement(ChannelPreviewAction, {
|
|
221
|
+
disabled: !isOnline,
|
|
222
|
+
onLeaveChannel: function onLeaveChannel() {
|
|
223
|
+
return _onLeaveChannel(channel, null);
|
|
224
|
+
}
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
});
|
|
228
|
+
})), (!sdkIntialized || loading) && (renderPlaceHolderLoading && typeof renderPlaceHolderLoading === 'function' ? renderPlaceHolderLoading === null || renderPlaceHolderLoading === void 0 ? void 0 : renderPlaceHolderLoading() : /*#__PURE__*/React__default.createElement(PlaceHolder, {
|
|
229
|
+
type: PlaceHolderTypes.LOADING
|
|
230
|
+
})), (!allChannels || allChannels.length === 0) && (renderPlaceHolderEmptyList && typeof renderPlaceHolderEmptyList === 'function' ? renderPlaceHolderEmptyList === null || renderPlaceHolderEmptyList === void 0 ? void 0 : renderPlaceHolderEmptyList() : /*#__PURE__*/React__default.createElement(PlaceHolder, {
|
|
231
|
+
type: PlaceHolderTypes.NO_CHANNELS
|
|
232
|
+
}))));
|
|
233
|
+
};
|
|
234
|
+
|
|
235
|
+
export { ChannelListUI as default };
|
|
236
|
+
//# sourceMappingURL=ChannelListUI.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChannelListUI.js","sources":["../../../src/smart-components/ChannelList/components/ChannelListUI/index.tsx"],"sourcesContent":["import './channel-list-ui.scss';\n\nimport React, { useState } from 'react';\n\nimport SendBird from 'sendbird';\n\nimport ChannelListHeader from '../ChannelListHeader';\nimport AddChannel from '../AddChannel';\nimport ChannelPreview from '../ChannelPreview';\nimport ChannelPreviewAction from '../ChannelPreviewAction';\nimport { useChannelListContext } from '../../context/ChannelListProvider';\nimport * as channelListActions from '../../dux/actionTypes';\n\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport EditUserProfile from '../../../EditUserProfile';\nimport PlaceHolder, { PlaceHolderTypes } from '../../../../ui/PlaceHolder';\n\nconst DELIVERY_RECIPT = 'delivery_receipt';\n\ninterface RenderChannelPreviewProps {\n channel: SendBird.GroupChannel;\n onLeaveChannel(\n channel: SendBird.GroupChannel,\n onLeaveChannelCb?: (c: SendBird.GroupChannel) => void,\n );\n}\n\ninterface RenderUserProfileProps {\n user: SendBird.Member | SendBird.User;\n currentUserId: string;\n close(): void;\n}\n\nexport interface ChannelListUIProps {\n renderChannelPreview?: (props: RenderChannelPreviewProps) => React.ReactNode;\n renderUserProfile?: (props: RenderUserProfileProps) => React.ReactNode;\n renderHeader?: (props: void) => React.ReactNode;\n renderPlaceHolderError?: (props: void) => React.ReactNode;\n renderPlaceHolderLoading?: (props: void) => React.ReactNode;\n renderPlaceHolderEmptyList?: (props: void) => React.ReactNode;\n}\n\nconst ChannelListUI: React.FC<ChannelListUIProps> = (props: ChannelListUIProps) => {\n const {\n renderHeader,\n renderChannelPreview,\n renderPlaceHolderError,\n renderPlaceHolderLoading,\n renderPlaceHolderEmptyList,\n } = props;\n\n const [showProfileEdit, setShowProfileEdit] = useState(false);\n\n const {\n onThemeChange,\n allowProfileEdit,\n allChannels,\n loading,\n currentChannel,\n channelListDispatcher,\n channelSource,\n typingChannels,\n } = useChannelListContext();\n\n const state = useSendbirdStateContext();\n\n const sdkStore = state?.stores?.sdkStore;\n const config = state?.config;\n\n const isOnline = state?.config?.isOnline;\n const logger = config?.logger;\n\n const sdk = sdkStore?.sdk;\n const sdkError = sdkStore?.error;\n const sdkIntialized = sdkStore?.initialized || false;\n\n return (\n <>\n <div className=\"sendbird-channel-list__header\">\n <ChannelListHeader\n renderHeader={renderHeader}\n onEdit={() => {\n if (allowProfileEdit) {\n setShowProfileEdit(true);\n }\n }}\n allowProfileEdit={allowProfileEdit}\n renderIconButton={() => (\n <AddChannel />\n )}\n />\n </div>\n {\n showProfileEdit && (\n <EditUserProfile\n onThemeChange={onThemeChange}\n onCancel={() => { setShowProfileEdit(false); }}\n onEditProfile={() => {\n setShowProfileEdit(false);\n }}\n />\n )\n }\n <div\n className=\"sendbird-channel-list__body\"\n onScroll={(e) => {\n const target = e?.target as HTMLDivElement;\n const fetchMore = target.clientHeight + target.scrollTop === target.scrollHeight;\n if (fetchMore && channelSource?.hasNext) {\n logger.info('ChannelList: Fetching more channels');\n channelListDispatcher({\n type: channelListActions.FETCH_CHANNELS_START,\n payload: null,\n });\n channelSource?.next((channelList, err) => {\n if (err) {\n logger.info('ChannelList: Fetching channels failed', err);\n channelListDispatcher({\n type: channelListActions.FETCH_CHANNELS_FAILURE,\n payload: channelList,\n });\n return;\n }\n logger.info('ChannelList: Fetching channels successful', channelList);\n channelListDispatcher({\n type: channelListActions.FETCH_CHANNELS_SUCCESS,\n payload: channelList,\n });\n const canSetMarkAsDelivered = sdk?.appInfo?.premiumFeatureList\n ?.find((feature) => (feature === DELIVERY_RECIPT));\n\n if (canSetMarkAsDelivered) {\n logger.info('ChannelList: Marking all channels as read');\n // eslint-disable-next-line no-unused-expressions\n channelList?.forEach((c, idx) => {\n // Plan-based rate limits - minimum limit is 5 requests per second\n setTimeout(() => {\n sdk?.markAsDelivered(c?.url);\n }, 300 * idx);\n });\n }\n });\n }\n }}\n >\n {\n (sdkError) && (\n (renderPlaceHolderError && typeof renderPlaceHolderError === 'function') ? (\n renderPlaceHolderError?.()\n ): (\n <PlaceHolder type={PlaceHolderTypes.WRONG} />\n )\n )\n }\n {/*\n To do: Implement windowing\n Implement windowing if you are dealing with large number of messages/channels\n https://github.com/bvaughn/react-window -> recommendation\n We hesitate to bring one more dependency to our library,\n we are planning to implement it inside the library\n */}\n <div>\n {\n allChannels && allChannels.map((channel, idx) => {\n const onLeaveChannel = (c, cb) => {\n logger.info('ChannelList: Leaving channel', c);\n c.leave()\n .then((res) => {\n logger.info('ChannelList: Leaving channel success', res);\n if (cb && typeof cb === 'function') {\n cb(res, null);\n }\n channelListDispatcher({\n type: channelListActions.LEAVE_CHANNEL_SUCCESS,\n payload: channel.url,\n });\n })\n .catch((err) => {\n logger.error('ChannelList: Leaving channel failed', err);\n if (cb && typeof cb === 'function') {\n cb(null, err);\n }\n });\n };\n\n const onClick = () => {\n if (!isOnline) { return; }\n logger.info('ChannelList: Clicked on channel:', channel);\n channelListDispatcher({\n type: channelListActions.SET_CURRENT_CHANNEL,\n payload: channel,\n });\n };\n\n return (\n (renderChannelPreview)\n ? (\n // eslint-disable-next-line\n <div key={channel.url} onClick={onClick}>\n {renderChannelPreview({ channel, onLeaveChannel })}\n </div>\n )\n : (\n <ChannelPreview\n key={channel.url}\n tabIndex={idx}\n onClick={onClick}\n channel={channel}\n isActive={channel.url === currentChannel?.url}\n isTyping={typingChannels?.some(({ url }) => url === channel.url)}\n renderChannelAction={(() => (\n <ChannelPreviewAction\n disabled={!isOnline}\n onLeaveChannel={() => onLeaveChannel(channel, null)}\n />\n ))}\n />\n )\n );\n })\n }\n </div>\n {\n (!sdkIntialized || loading) && (\n (renderPlaceHolderLoading && typeof renderPlaceHolderLoading === 'function') ? (\n renderPlaceHolderLoading?.()\n ): (\n <PlaceHolder type={PlaceHolderTypes.LOADING} />\n )\n )\n }\n {\n (!allChannels || allChannels.length === 0) && (\n (renderPlaceHolderEmptyList && typeof renderPlaceHolderEmptyList === 'function') ? (\n renderPlaceHolderEmptyList?.()\n ): (\n <PlaceHolder type={PlaceHolderTypes.NO_CHANNELS} />\n )\n )\n }\n </div>\n </>\n );\n}\n\nexport default ChannelListUI;\n"],"names":["DELIVERY_RECIPT","ChannelListUI","props","renderHeader","renderChannelPreview","renderPlaceHolderError","renderPlaceHolderLoading","renderPlaceHolderEmptyList","_c","useState","showProfileEdit","setShowProfileEdit","_d","useChannelListContext","onThemeChange","allowProfileEdit","allChannels","loading","currentChannel","channelListDispatcher","channelSource","typingChannels","state","useSendbirdStateContext","sdkStore","stores","config","isOnline","logger","sdk","sdkError","error","sdkIntialized","initialized","React","EditUserProfile","e","target","fetchMore","clientHeight","scrollTop","scrollHeight","hasNext","info","type","channelListActions","payload","next","channelList","err","canSetMarkAsDelivered","appInfo","premiumFeatureList","find","feature","forEach","c","idx","setTimeout","markAsDelivered","url","PlaceHolderTypes","WRONG","map","channel","onLeaveChannel","cb","leave","then","res","catch","onClick","some","_a","LOADING","length","NO_CHANNELS"],"mappings":"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"}
|
|
@@ -0,0 +1,211 @@
|
|
|
1
|
+
import React__default from 'react';
|
|
2
|
+
import ChannelAvatar from '../../ui/ChannelAvatar.js';
|
|
3
|
+
import Badge from '../../ui/Badge.js';
|
|
4
|
+
import Icon, { IconTypes, IconColors } from '../../ui/Icon.js';
|
|
5
|
+
import { c as LabelStringSet, L as Label, a as LabelTypography, b as LabelColors } from '../../index-e1b93b3a.js';
|
|
6
|
+
import { i as isToday, a as isYesterday, f as formatRelative } from '../../index-d7840fad.js';
|
|
7
|
+
import { f as format } from '../../index-2c56786f.js';
|
|
8
|
+
import { t as truncateString } from '../../index-03baba6a.js';
|
|
9
|
+
import useSendbirdStateContext from '../../useSendbirdStateContext.js';
|
|
10
|
+
import { u as useLocalization } from '../../LocalizationContext-0e05ddca.js';
|
|
11
|
+
import MentionUserLabel from '../../ui/MentionUserLabel.js';
|
|
12
|
+
import { u as useChannelListContext } from '../../ChannelListProvider-a7bdd63a.js';
|
|
13
|
+
import { TypingIndicatorText } from '../../Channel/components/TypingIndicator.js';
|
|
14
|
+
import MessageStatus from '../../ui/MessageStatus.js';
|
|
15
|
+
import '../../ui/Avatar.js';
|
|
16
|
+
import '../../tslib.es6-61821688.js';
|
|
17
|
+
import '../../ui/ImageRenderer.js';
|
|
18
|
+
import '../../_rollupPluginBabelHelpers-c7eeba03.js';
|
|
19
|
+
import 'prop-types';
|
|
20
|
+
import '../../uuid-6e6389e2.js';
|
|
21
|
+
import '../../utils-5e25aca3.js';
|
|
22
|
+
import '../../stringSet-6c9c68ae.js';
|
|
23
|
+
import '../../index-29563598.js';
|
|
24
|
+
import '../../index-e7c0bc26.js';
|
|
25
|
+
import '../../withSendBird.js';
|
|
26
|
+
import '../../topics-d347c996.js';
|
|
27
|
+
import '../../utils-4e85584a.js';
|
|
28
|
+
import '../../UserProfileContext-90704c73.js';
|
|
29
|
+
import '../../ChannelProvider-923b58df.js';
|
|
30
|
+
import '../../compareIds-2bfd667a.js';
|
|
31
|
+
import '../../const-a8df15de.js';
|
|
32
|
+
import '../../ui/ContextMenu.js';
|
|
33
|
+
import 'react-dom';
|
|
34
|
+
import '../../ui/SortByRow.js';
|
|
35
|
+
import '../../ui/ReactionButton.js';
|
|
36
|
+
import '../../ui/Loader.js';
|
|
37
|
+
|
|
38
|
+
var getChannelTitle = function getChannelTitle() {
|
|
39
|
+
var channel = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
40
|
+
var currentUserId = arguments.length > 1 ? arguments[1] : undefined;
|
|
41
|
+
var stringSet = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : LabelStringSet;
|
|
42
|
+
|
|
43
|
+
if (!channel || !channel.name && !channel.members) {
|
|
44
|
+
return stringSet.NO_TITLE;
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
if (channel.name && channel.name !== 'Group Channel') {
|
|
48
|
+
return channel.name;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
if (channel.members.length === 1) {
|
|
52
|
+
return stringSet.NO_MEMBERS;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
return channel.members.filter(function (_ref) {
|
|
56
|
+
var userId = _ref.userId;
|
|
57
|
+
return userId !== currentUserId;
|
|
58
|
+
}).map(function (_ref2) {
|
|
59
|
+
var nickname = _ref2.nickname;
|
|
60
|
+
return nickname || stringSet.NO_NAME;
|
|
61
|
+
}).join(', ');
|
|
62
|
+
};
|
|
63
|
+
var getLastMessageCreatedAt = function getLastMessageCreatedAt(channel, locale) {
|
|
64
|
+
var _channel$lastMessage;
|
|
65
|
+
|
|
66
|
+
var createdAt = channel === null || channel === void 0 ? void 0 : (_channel$lastMessage = channel.lastMessage) === null || _channel$lastMessage === void 0 ? void 0 : _channel$lastMessage.createdAt;
|
|
67
|
+
var optionalParam = locale ? {
|
|
68
|
+
locale: locale
|
|
69
|
+
} : null;
|
|
70
|
+
|
|
71
|
+
if (!createdAt) {
|
|
72
|
+
return '';
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
if (isToday(createdAt)) {
|
|
76
|
+
return format(createdAt, 'p', optionalParam);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
if (isYesterday(createdAt)) {
|
|
80
|
+
return formatRelative(createdAt, new Date(), optionalParam);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
return format(createdAt, 'MMM dd', optionalParam);
|
|
84
|
+
};
|
|
85
|
+
var getTotalMembers = function getTotalMembers(channel) {
|
|
86
|
+
return channel && channel.memberCount ? channel.memberCount : 0;
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
var getPrettyLastMessage = function getPrettyLastMessage() {
|
|
90
|
+
var message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
91
|
+
var MAXLEN = 30;
|
|
92
|
+
var messageType = message.messageType,
|
|
93
|
+
name = message.name;
|
|
94
|
+
|
|
95
|
+
if (messageType === 'file') {
|
|
96
|
+
return truncateString(name, MAXLEN);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
return message.message;
|
|
100
|
+
};
|
|
101
|
+
|
|
102
|
+
var getLastMessage = function getLastMessage(channel) {
|
|
103
|
+
return channel && channel.lastMessage ? getPrettyLastMessage(channel.lastMessage) : '';
|
|
104
|
+
};
|
|
105
|
+
var getChannelUnreadMessageCount = function getChannelUnreadMessageCount(channel) {
|
|
106
|
+
return channel && channel.unreadMessageCount ? channel.unreadMessageCount : 0;
|
|
107
|
+
};
|
|
108
|
+
|
|
109
|
+
var ChannelPreview = function ChannelPreview(_a) {
|
|
110
|
+
var _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
|
111
|
+
|
|
112
|
+
var channel = _a.channel,
|
|
113
|
+
_l = _a.isActive,
|
|
114
|
+
isActive = _l === void 0 ? false : _l,
|
|
115
|
+
_m = _a.isTyping,
|
|
116
|
+
isTyping = _m === void 0 ? false : _m,
|
|
117
|
+
renderChannelAction = _a.renderChannelAction,
|
|
118
|
+
onClick = _a.onClick,
|
|
119
|
+
tabIndex = _a.tabIndex;
|
|
120
|
+
var sbState = useSendbirdStateContext();
|
|
121
|
+
|
|
122
|
+
var _o = useChannelListContext(),
|
|
123
|
+
_p = _o.isTypingIndicatorEnabled,
|
|
124
|
+
isTypingIndicatorEnabled = _p === void 0 ? false : _p,
|
|
125
|
+
_q = _o.isMessageReceiptStatusEnabled,
|
|
126
|
+
isMessageReceiptStatusEnabled = _q === void 0 ? false : _q;
|
|
127
|
+
|
|
128
|
+
var _r = useLocalization(),
|
|
129
|
+
dateLocale = _r.dateLocale,
|
|
130
|
+
stringSet = _r.stringSet;
|
|
131
|
+
|
|
132
|
+
var userId = (_d = (_c = (_b = sbState === null || sbState === void 0 ? void 0 : sbState.stores) === null || _b === void 0 ? void 0 : _b.userStore) === null || _c === void 0 ? void 0 : _c.user) === null || _d === void 0 ? void 0 : _d.userId;
|
|
133
|
+
var theme = (_e = sbState === null || sbState === void 0 ? void 0 : sbState.config) === null || _e === void 0 ? void 0 : _e.theme;
|
|
134
|
+
var isMentionEnabled = (_f = sbState === null || sbState === void 0 ? void 0 : sbState.config) === null || _f === void 0 ? void 0 : _f.isMentionEnabled;
|
|
135
|
+
var isBroadcast = channel.isBroadcast,
|
|
136
|
+
isFrozen = channel.isFrozen;
|
|
137
|
+
var isChannelTyping = isTypingIndicatorEnabled && isTyping;
|
|
138
|
+
var isMessageStatusEnabled = isMessageReceiptStatusEnabled && (((_g = channel === null || channel === void 0 ? void 0 : channel.lastMessage) === null || _g === void 0 ? void 0 : _g.messageType) === 'user' || ((_h = channel === null || channel === void 0 ? void 0 : channel.lastMessage) === null || _h === void 0 ? void 0 : _h.messageType) === 'file') && ((_k = (_j = channel === null || channel === void 0 ? void 0 : channel.lastMessage) === null || _j === void 0 ? void 0 : _j.sender) === null || _k === void 0 ? void 0 : _k.userId) === userId;
|
|
139
|
+
return /*#__PURE__*/React__default.createElement("div", {
|
|
140
|
+
className: ['sendbird-channel-preview', isActive ? 'sendbird-channel-preview--active' : ''].join(' '),
|
|
141
|
+
role: "link",
|
|
142
|
+
onClick: onClick,
|
|
143
|
+
onKeyPress: onClick,
|
|
144
|
+
tabIndex: tabIndex
|
|
145
|
+
}, /*#__PURE__*/React__default.createElement("div", {
|
|
146
|
+
className: "sendbird-channel-preview__avatar"
|
|
147
|
+
}, /*#__PURE__*/React__default.createElement(ChannelAvatar, {
|
|
148
|
+
channel: channel,
|
|
149
|
+
userId: userId,
|
|
150
|
+
theme: theme
|
|
151
|
+
})), /*#__PURE__*/React__default.createElement("div", {
|
|
152
|
+
className: "sendbird-channel-preview__content"
|
|
153
|
+
}, /*#__PURE__*/React__default.createElement("div", {
|
|
154
|
+
className: "sendbird-channel-preview__content__upper"
|
|
155
|
+
}, /*#__PURE__*/React__default.createElement("div", {
|
|
156
|
+
className: "sendbird-channel-preview__content__upper__header"
|
|
157
|
+
}, isBroadcast && /*#__PURE__*/React__default.createElement("div", {
|
|
158
|
+
className: "sendbird-channel-preview__content__upper__header__broadcast-icon"
|
|
159
|
+
}, /*#__PURE__*/React__default.createElement(Icon, {
|
|
160
|
+
type: IconTypes.BROADCAST,
|
|
161
|
+
fillColor: IconColors.SECONDARY,
|
|
162
|
+
height: "16px",
|
|
163
|
+
width: "16px"
|
|
164
|
+
})), /*#__PURE__*/React__default.createElement(Label, {
|
|
165
|
+
className: "sendbird-channel-preview__content__upper__header__channel-name",
|
|
166
|
+
type: LabelTypography.SUBTITLE_2,
|
|
167
|
+
color: LabelColors.ONBACKGROUND_1
|
|
168
|
+
}, getChannelTitle(channel, userId, stringSet)), /*#__PURE__*/React__default.createElement(Label, {
|
|
169
|
+
className: "sendbird-channel-preview__content__upper__header__total-members",
|
|
170
|
+
type: LabelTypography.CAPTION_2,
|
|
171
|
+
color: LabelColors.ONBACKGROUND_2
|
|
172
|
+
}, getTotalMembers(channel)), isFrozen && /*#__PURE__*/React__default.createElement("div", {
|
|
173
|
+
title: "Frozen",
|
|
174
|
+
className: "sendbird-channel-preview__content__upper__header__frozen-icon"
|
|
175
|
+
}, /*#__PURE__*/React__default.createElement(Icon, {
|
|
176
|
+
type: IconTypes.FREEZE,
|
|
177
|
+
fillColor: IconColors.PRIMARY,
|
|
178
|
+
height: 12,
|
|
179
|
+
width: 12
|
|
180
|
+
}))), isMessageStatusEnabled ? /*#__PURE__*/React__default.createElement(MessageStatus, {
|
|
181
|
+
className: "sendbird-channel-preview__content__upper__last-message-at",
|
|
182
|
+
channel: channel,
|
|
183
|
+
message: channel === null || channel === void 0 ? void 0 : channel.lastMessage
|
|
184
|
+
}) : /*#__PURE__*/React__default.createElement(Label, {
|
|
185
|
+
className: "sendbird-channel-preview__content__upper__last-message-at",
|
|
186
|
+
type: LabelTypography.CAPTION_3,
|
|
187
|
+
color: LabelColors.ONBACKGROUND_2
|
|
188
|
+
}, getLastMessageCreatedAt(channel, dateLocale))), /*#__PURE__*/React__default.createElement("div", {
|
|
189
|
+
className: "sendbird-channel-preview__content__lower"
|
|
190
|
+
}, /*#__PURE__*/React__default.createElement(Label, {
|
|
191
|
+
className: "sendbird-channel-preview__content__lower__last-message",
|
|
192
|
+
type: LabelTypography.BODY_2,
|
|
193
|
+
color: LabelColors.ONBACKGROUND_3
|
|
194
|
+
}, isChannelTyping ? /*#__PURE__*/React__default.createElement(TypingIndicatorText, {
|
|
195
|
+
members: channel === null || channel === void 0 ? void 0 : channel.getTypingMembers()
|
|
196
|
+
}) : getLastMessage(channel)), /*#__PURE__*/React__default.createElement("div", {
|
|
197
|
+
className: "sendbird-channel-preview__content__lower__unread-message-count"
|
|
198
|
+
}, isMentionEnabled && (channel === null || channel === void 0 ? void 0 : channel.unreadMentionCount) > 0 ? /*#__PURE__*/React__default.createElement(MentionUserLabel, {
|
|
199
|
+
color: "purple"
|
|
200
|
+
}, "@") : null, getChannelUnreadMessageCount(channel) // return number
|
|
201
|
+
? /*#__PURE__*/React__default.createElement(Badge, {
|
|
202
|
+
count: getChannelUnreadMessageCount(channel)
|
|
203
|
+
}) : null))), /*#__PURE__*/React__default.createElement("div", {
|
|
204
|
+
className: "sendbird-channel-preview__action"
|
|
205
|
+
}, renderChannelAction({
|
|
206
|
+
channel: channel
|
|
207
|
+
})));
|
|
208
|
+
};
|
|
209
|
+
|
|
210
|
+
export { ChannelPreview as default };
|
|
211
|
+
//# sourceMappingURL=ChannelPreview.js.map
|