@sendbird/uikit-react 3.1.1-rc.3 → 3.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/App.js +35 -33
- package/App.js.map +1 -1
- package/CHANGELOG.md +8 -3
- package/Channel/components/ChannelHeader.js +19 -17
- package/Channel/components/ChannelHeader.js.map +1 -1
- package/Channel/components/ChannelUI.js +26 -24
- package/Channel/components/ChannelUI.js.map +1 -1
- package/Channel/components/FileViewer.js +18 -16
- package/Channel/components/FileViewer.js.map +1 -1
- package/Channel/components/FrozenNotification.js +5 -5
- package/Channel/components/Message.js +23 -21
- package/Channel/components/Message.js.map +1 -1
- package/Channel/components/MessageInput.js +20 -18
- package/Channel/components/MessageInput.js.map +1 -1
- package/Channel/components/MessageList.js +25 -23
- package/Channel/components/MessageList.js.map +1 -1
- package/Channel/components/RemoveMessageModal.js +21 -19
- package/Channel/components/RemoveMessageModal.js.map +1 -1
- package/Channel/components/SuggestedMentionList.js +19 -17
- package/Channel/components/SuggestedMentionList.js.map +1 -1
- package/Channel/components/TypingIndicator.js +18 -16
- package/Channel/components/TypingIndicator.js.map +1 -1
- package/Channel/components/UnreadCount.js +5 -5
- package/Channel/context.js +17 -15
- package/Channel/context.js.map +1 -1
- package/Channel.js +26 -24
- package/Channel.js.map +1 -1
- package/ChannelList/components/AddChannel.js +14 -14
- package/ChannelList/components/ChannelListHeader.js +7 -7
- package/ChannelList/components/ChannelListUI.js +30 -28
- package/ChannelList/components/ChannelListUI.js.map +1 -1
- package/ChannelList/components/ChannelPreview.js +23 -21
- package/ChannelList/components/ChannelPreview.js.map +1 -1
- package/ChannelList/components/ChannelPreviewAction.js +18 -16
- package/ChannelList/components/ChannelPreviewAction.js.map +1 -1
- package/ChannelList/context.js +12 -10
- package/ChannelList/context.js.map +1 -1
- package/ChannelList.js +30 -28
- package/ChannelList.js.map +1 -1
- package/{ChannelListProvider-ddd2e464.js → ChannelListProvider-bdac2e90.js} +9 -9
- package/{ChannelListProvider-ddd2e464.js.map → ChannelListProvider-bdac2e90.js.map} +1 -1
- package/{ChannelProvider-edd6d4b3.js → ChannelProvider-0174d0f3.js} +11 -11
- package/{ChannelProvider-edd6d4b3.js.map → ChannelProvider-0174d0f3.js.map} +1 -1
- package/ChannelSettings/components/ChannelProfile.js +13 -13
- package/ChannelSettings/components/ChannelSettingsUI.js +22 -20
- package/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
- package/ChannelSettings/components/EditDetailsModal.js +13 -13
- package/ChannelSettings/components/LeaveChannel.js +10 -10
- package/ChannelSettings/components/ModerationPanel.js +19 -17
- package/ChannelSettings/components/ModerationPanel.js.map +1 -1
- package/ChannelSettings/components/UserListItem.js +12 -12
- package/ChannelSettings/components/UserPanel.js +14 -14
- package/ChannelSettings/context.js +3 -3
- package/ChannelSettings.js +22 -20
- package/ChannelSettings.js.map +1 -1
- package/CreateChannel/components/CreateChannelUI.js +14 -14
- package/CreateChannel/components/InviteUsers.js +14 -14
- package/CreateChannel/components/SelectChannelType.js +10 -10
- package/CreateChannel/context.js +4 -4
- package/CreateChannel.js +14 -14
- package/{CreateChannelProvider-b4890246.js → CreateChannelProvider-1cf4ef27.js} +1 -1
- package/{CreateChannelProvider-b4890246.js.map → CreateChannelProvider-1cf4ef27.js.map} +1 -1
- package/EditUserProfile/components/EditUserProfileUI.js +13 -13
- package/EditUserProfile.js +13 -13
- package/{LocalizationContext-5ff68102.js → LocalizationContext-61a4a931.js} +3 -3
- package/{LocalizationContext-5ff68102.js.map → LocalizationContext-61a4a931.js.map} +1 -1
- package/{MemberList-35d58de2.js → MemberList-24ad6b63.js} +6 -6
- package/{MemberList-35d58de2.js.map → MemberList-24ad6b63.js.map} +1 -1
- package/MessageSearch/components/MessageSearchUI.js +11 -11
- package/MessageSearch/context.js +2 -2
- package/MessageSearch.js +11 -11
- package/OpenChannel/components/FrozenChannelNotification.js +5 -5
- package/OpenChannel/components/OpenChannelHeader.js +17 -15
- package/OpenChannel/components/OpenChannelHeader.js.map +1 -1
- package/OpenChannel/components/OpenChannelInput.js +21 -19
- package/OpenChannel/components/OpenChannelInput.js.map +1 -1
- package/OpenChannel/components/OpenChannelMessage.js +26 -24
- package/OpenChannel/components/OpenChannelMessage.js.map +1 -1
- package/OpenChannel/components/OpenChannelMessageList.js +28 -26
- package/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
- package/OpenChannel/components/OpenChannelUI.js +28 -26
- package/OpenChannel/components/OpenChannelUI.js.map +1 -1
- package/OpenChannel/context.js +14 -12
- package/OpenChannel/context.js.map +1 -1
- package/OpenChannel.js +28 -26
- package/OpenChannel.js.map +1 -1
- package/{OpenChannelProvider-3ef602e9.js → OpenChannelProvider-9b3a6eb1.js} +11 -10
- package/{OpenChannelProvider-3ef602e9.js.map → OpenChannelProvider-9b3a6eb1.js.map} +1 -1
- package/OpenChannelSettings/components/EditDetailsModal.js +16 -15
- package/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
- package/OpenChannelSettings/components/OpenChannelProfile.js +16 -15
- package/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
- package/OpenChannelSettings/components/OpenChannelSettingsUI.js +21 -20
- package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
- package/OpenChannelSettings/components/OperatorUI.js +20 -19
- package/OpenChannelSettings/components/OperatorUI.js.map +1 -1
- package/OpenChannelSettings/components/ParticipantUI.js +18 -17
- package/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
- package/OpenChannelSettings/context.js +6 -5
- package/OpenChannelSettings/context.js.map +1 -1
- package/OpenChannelSettings.js +21 -20
- package/OpenChannelSettings.js.map +1 -1
- package/SendbirdProvider.js +17 -15
- package/SendbirdProvider.js.map +1 -1
- package/{UserProfileContext-9cb73ef6.js → UserProfileContext-3524e64c.js} +1 -1
- package/{UserProfileContext-9cb73ef6.js.map → UserProfileContext-3524e64c.js.map} +1 -1
- package/__bundle-6316ce22-b659cee1.js +20 -0
- package/__bundle-6316ce22-b659cee1.js.map +1 -0
- package/__bundle-7dfccc8c-37d3f8ab.js +6 -0
- package/__bundle-7dfccc8c-37d3f8ab.js.map +1 -0
- package/__bundle-fbda47dd-ef31252f.js +6 -0
- package/__bundle-fbda47dd-ef31252f.js.map +1 -0
- package/{_rollupPluginBabelHelpers-83679d42.js → _rollupPluginBabelHelpers-30d122aa.js} +1 -1
- package/{_rollupPluginBabelHelpers-83679d42.js.map → _rollupPluginBabelHelpers-30d122aa.js.map} +1 -1
- package/{actionTypes-8b8cf058.js → actionTypes-d5d5ac7b.js} +1 -1
- package/{actionTypes-8b8cf058.js.map → actionTypes-d5d5ac7b.js.map} +1 -1
- package/cjs/App.js +35 -33
- package/cjs/App.js.map +1 -1
- package/cjs/Channel/components/ChannelHeader.js +19 -17
- package/cjs/Channel/components/ChannelHeader.js.map +1 -1
- package/cjs/Channel/components/ChannelUI.js +26 -24
- package/cjs/Channel/components/ChannelUI.js.map +1 -1
- package/cjs/Channel/components/FileViewer.js +18 -16
- package/cjs/Channel/components/FileViewer.js.map +1 -1
- package/cjs/Channel/components/FrozenNotification.js +5 -5
- package/cjs/Channel/components/Message.js +23 -21
- package/cjs/Channel/components/Message.js.map +1 -1
- package/cjs/Channel/components/MessageInput.js +20 -18
- package/cjs/Channel/components/MessageInput.js.map +1 -1
- package/cjs/Channel/components/MessageList.js +25 -23
- package/cjs/Channel/components/MessageList.js.map +1 -1
- package/cjs/Channel/components/RemoveMessageModal.js +21 -19
- package/cjs/Channel/components/RemoveMessageModal.js.map +1 -1
- package/cjs/Channel/components/SuggestedMentionList.js +19 -17
- package/cjs/Channel/components/SuggestedMentionList.js.map +1 -1
- package/cjs/Channel/components/TypingIndicator.js +18 -16
- package/cjs/Channel/components/TypingIndicator.js.map +1 -1
- package/cjs/Channel/components/UnreadCount.js +5 -5
- package/cjs/Channel/context.js +17 -15
- package/cjs/Channel/context.js.map +1 -1
- package/cjs/Channel.js +26 -24
- package/cjs/Channel.js.map +1 -1
- package/cjs/ChannelList/components/AddChannel.js +14 -14
- package/cjs/ChannelList/components/ChannelListHeader.js +7 -7
- package/cjs/ChannelList/components/ChannelListUI.js +30 -28
- package/cjs/ChannelList/components/ChannelListUI.js.map +1 -1
- package/cjs/ChannelList/components/ChannelPreview.js +23 -21
- package/cjs/ChannelList/components/ChannelPreview.js.map +1 -1
- package/cjs/ChannelList/components/ChannelPreviewAction.js +18 -16
- package/cjs/ChannelList/components/ChannelPreviewAction.js.map +1 -1
- package/cjs/ChannelList/context.js +12 -10
- package/cjs/ChannelList/context.js.map +1 -1
- package/cjs/ChannelList.js +30 -28
- package/cjs/ChannelList.js.map +1 -1
- package/cjs/{ChannelListProvider-d92853de.js → ChannelListProvider-e7756677.js} +9 -9
- package/cjs/{ChannelListProvider-d92853de.js.map → ChannelListProvider-e7756677.js.map} +1 -1
- package/cjs/{ChannelProvider-fef48131.js → ChannelProvider-c179835a.js} +15 -15
- package/cjs/{ChannelProvider-fef48131.js.map → ChannelProvider-c179835a.js.map} +1 -1
- package/cjs/ChannelSettings/components/ChannelProfile.js +13 -13
- package/cjs/ChannelSettings/components/ChannelSettingsUI.js +22 -20
- package/cjs/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
- package/cjs/ChannelSettings/components/EditDetailsModal.js +13 -13
- package/cjs/ChannelSettings/components/LeaveChannel.js +10 -10
- package/cjs/ChannelSettings/components/ModerationPanel.js +19 -17
- package/cjs/ChannelSettings/components/ModerationPanel.js.map +1 -1
- package/cjs/ChannelSettings/components/UserListItem.js +12 -12
- package/cjs/ChannelSettings/components/UserPanel.js +14 -14
- package/cjs/ChannelSettings/context.js +3 -3
- package/cjs/ChannelSettings.js +22 -20
- package/cjs/ChannelSettings.js.map +1 -1
- package/cjs/CreateChannel/components/CreateChannelUI.js +14 -14
- package/cjs/CreateChannel/components/InviteUsers.js +14 -14
- package/cjs/CreateChannel/components/SelectChannelType.js +10 -10
- package/cjs/CreateChannel/context.js +4 -4
- package/cjs/CreateChannel.js +14 -14
- package/cjs/{CreateChannelProvider-3401d665.js → CreateChannelProvider-a7ca5511.js} +1 -1
- package/cjs/{CreateChannelProvider-3401d665.js.map → CreateChannelProvider-a7ca5511.js.map} +1 -1
- package/cjs/EditUserProfile/components/EditUserProfileUI.js +13 -13
- package/cjs/EditUserProfile.js +13 -13
- package/cjs/{LocalizationContext-5680cc6c.js → LocalizationContext-f05328b8.js} +3 -3
- package/cjs/{LocalizationContext-5680cc6c.js.map → LocalizationContext-f05328b8.js.map} +1 -1
- package/cjs/{MemberList-1a472da3.js → MemberList-bfaafb40.js} +6 -6
- package/cjs/{MemberList-1a472da3.js.map → MemberList-bfaafb40.js.map} +1 -1
- package/cjs/MessageSearch/components/MessageSearchUI.js +11 -11
- package/cjs/MessageSearch/context.js +2 -2
- package/cjs/MessageSearch.js +11 -11
- package/cjs/OpenChannel/components/FrozenChannelNotification.js +5 -5
- package/cjs/OpenChannel/components/OpenChannelHeader.js +17 -15
- package/cjs/OpenChannel/components/OpenChannelHeader.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelInput.js +21 -19
- package/cjs/OpenChannel/components/OpenChannelInput.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelMessage.js +26 -24
- package/cjs/OpenChannel/components/OpenChannelMessage.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelMessageList.js +28 -26
- package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelUI.js +28 -26
- package/cjs/OpenChannel/components/OpenChannelUI.js.map +1 -1
- package/cjs/OpenChannel/context.js +14 -12
- package/cjs/OpenChannel/context.js.map +1 -1
- package/cjs/OpenChannel.js +28 -26
- package/cjs/OpenChannel.js.map +1 -1
- package/cjs/{OpenChannelProvider-a5da41f0.js → OpenChannelProvider-12e0412f.js} +11 -10
- package/cjs/{OpenChannelProvider-a5da41f0.js.map → OpenChannelProvider-12e0412f.js.map} +1 -1
- package/cjs/OpenChannelSettings/components/EditDetailsModal.js +16 -15
- package/cjs/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
- package/cjs/OpenChannelSettings/components/OpenChannelProfile.js +16 -15
- package/cjs/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
- package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js +21 -20
- package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
- package/cjs/OpenChannelSettings/components/OperatorUI.js +20 -19
- package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -1
- package/cjs/OpenChannelSettings/components/ParticipantUI.js +18 -17
- package/cjs/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
- package/cjs/OpenChannelSettings/context.js +6 -5
- package/cjs/OpenChannelSettings/context.js.map +1 -1
- package/cjs/OpenChannelSettings.js +21 -20
- package/cjs/OpenChannelSettings.js.map +1 -1
- package/cjs/SendbirdProvider.js +17 -16
- package/cjs/SendbirdProvider.js.map +1 -1
- package/cjs/{UserProfileContext-77c21d0a.js → UserProfileContext-87ebb4a4.js} +1 -1
- package/cjs/{UserProfileContext-77c21d0a.js.map → UserProfileContext-87ebb4a4.js.map} +1 -1
- package/cjs/__bundle-6316ce22-c57c6fe0.js +127 -0
- package/cjs/__bundle-6316ce22-c57c6fe0.js.map +1 -0
- package/cjs/__bundle-7dfccc8c-205c0e66.js +15 -0
- package/cjs/__bundle-7dfccc8c-205c0e66.js.map +1 -0
- package/cjs/__bundle-fbda47dd-f6e08be2.js +33 -0
- package/cjs/__bundle-fbda47dd-f6e08be2.js.map +1 -0
- package/cjs/{_rollupPluginBabelHelpers-d62bae4b.js → _rollupPluginBabelHelpers-92e5e012.js} +1 -1
- package/cjs/{_rollupPluginBabelHelpers-d62bae4b.js.map → _rollupPluginBabelHelpers-92e5e012.js.map} +1 -1
- package/cjs/{actionTypes-de71c3f0.js → actionTypes-331e63c2.js} +1 -1
- package/cjs/{actionTypes-de71c3f0.js.map → actionTypes-331e63c2.js.map} +1 -1
- package/cjs/{color-473a9c01.js → color-2f811855.js} +1 -1
- package/cjs/{color-473a9c01.js.map → color-2f811855.js.map} +1 -1
- package/cjs/{compareIds-73d28212.js → compareIds-2df40a8f.js} +1 -1
- package/cjs/{compareIds-73d28212.js.map → compareIds-2df40a8f.js.map} +1 -1
- package/cjs/{const-b8d99bdb.js → const-77f608c8.js} +1 -1
- package/cjs/{const-b8d99bdb.js.map → const-77f608c8.js.map} +1 -1
- package/cjs/{const-d6524415.js → const-e0dbad82.js} +1 -1
- package/cjs/{const-d6524415.js.map → const-e0dbad82.js.map} +1 -1
- package/cjs/{context-f56fb469.js → context-5e7ba41f.js} +2 -2
- package/cjs/{context-f56fb469.js.map → context-5e7ba41f.js.map} +1 -1
- package/cjs/dist/index.css +44 -44
- package/cjs/dist/index.css.map +1 -1
- package/cjs/groupChannel-ddd470ad.js +11 -0
- package/cjs/groupChannel-ddd470ad.js.map +1 -0
- package/cjs/handlers/ConnectionHandler.js +4 -2
- package/cjs/handlers/ConnectionHandler.js.map +1 -1
- package/cjs/handlers/GroupChannelHandler.js +4 -2
- package/cjs/handlers/GroupChannelHandler.js.map +1 -1
- package/cjs/handlers/OpenChannelHandler.js +3 -2
- package/cjs/handlers/OpenChannelHandler.js.map +1 -1
- package/cjs/handlers/UserEventHandler.js +4 -2
- package/cjs/handlers/UserEventHandler.js.map +1 -1
- package/cjs/{index-89b49811.js → index-10b68ab4.js} +2 -2
- package/cjs/{index-89b49811.js.map → index-10b68ab4.js.map} +1 -1
- package/cjs/{index-936fe34b.js → index-188e8e7f.js} +3 -3
- package/cjs/{index-936fe34b.js.map → index-188e8e7f.js.map} +1 -1
- package/cjs/{index-bc6e8fc4.js → index-1c009ee9.js} +4 -4
- package/cjs/{index-bc6e8fc4.js.map → index-1c009ee9.js.map} +1 -1
- package/cjs/{index-0200fe01.js → index-2dacade8.js} +1 -1
- package/cjs/{index-0200fe01.js.map → index-2dacade8.js.map} +1 -1
- package/cjs/{index-891aa437.js → index-39372722.js} +2 -2
- package/cjs/{index-891aa437.js.map → index-39372722.js.map} +1 -1
- package/cjs/{index-a07b1fcb.js → index-4911c708.js} +2 -2
- package/cjs/{index-a07b1fcb.js.map → index-4911c708.js.map} +1 -1
- package/cjs/{index-1b6e64e9.js → index-4bebe375.js} +1 -1
- package/cjs/{index-1b6e64e9.js.map → index-4bebe375.js.map} +1 -1
- package/cjs/{index-42072d9c.js → index-52631939.js} +9 -9
- package/cjs/{index-42072d9c.js.map → index-52631939.js.map} +1 -1
- package/cjs/{index-7c320a80.js → index-b1ed74bd.js} +4 -4
- package/cjs/{index-7c320a80.js.map → index-b1ed74bd.js.map} +1 -1
- package/cjs/{index-1bbcb92e.js → index-cce2b8c0.js} +3 -3
- package/cjs/{index-1bbcb92e.js.map → index-cce2b8c0.js.map} +1 -1
- package/cjs/{index-c6355119.js → index-edd379fd.js} +6 -6
- package/cjs/{index-c6355119.js.map → index-edd379fd.js.map} +1 -1
- package/cjs/index.js +39 -37
- package/cjs/index.js.map +1 -1
- package/cjs/openChannel-865f6910.js +10 -0
- package/cjs/openChannel-865f6910.js.map +1 -0
- package/cjs/{openChannelUtils-3febc4ad.js → openChannelUtils-341c5ad7.js} +1 -1
- package/cjs/{openChannelUtils-3febc4ad.js.map → openChannelUtils-341c5ad7.js.map} +1 -1
- package/cjs/sendbird-313241e2.js +11 -0
- package/cjs/sendbird-313241e2.js.map +1 -0
- package/cjs/sendbirdSelectors.js +2 -2
- package/cjs/{stringSet-293478fd.js → stringSet-afc1ff3b.js} +1 -1
- package/cjs/{stringSet-293478fd.js.map → stringSet-afc1ff3b.js.map} +1 -1
- package/cjs/{topics-726a037b.js → topics-57ad0394.js} +1 -1
- package/cjs/{topics-726a037b.js.map → topics-57ad0394.js.map} +1 -1
- package/cjs/{tslib.es6-74624c2f.js → tslib.es6-12c25052.js} +1 -1
- package/cjs/{tslib.es6-74624c2f.js.map → tslib.es6-12c25052.js.map} +1 -1
- package/cjs/ui/Accordion.js +4 -4
- package/cjs/ui/AccordionGroup.js +2 -2
- package/cjs/ui/AdminMessage.js +3 -3
- package/cjs/ui/Avatar.js +3 -3
- package/cjs/ui/Badge.js +5 -5
- package/cjs/ui/Button.js +4 -4
- package/cjs/ui/ChannelAvatar.js +4 -4
- package/cjs/ui/ChannelPreview.js +12 -12
- package/cjs/ui/ChatHeader.js +8 -8
- package/cjs/ui/ConnectionStatus.js +5 -5
- package/cjs/ui/ContextMenu.js +5 -5
- package/cjs/ui/DateSeparator.js +4 -4
- package/cjs/ui/Dropdown.js +3 -3
- package/cjs/ui/EmojiReactions.js +7 -7
- package/cjs/ui/FileMessageItemBody.js +6 -6
- package/cjs/ui/FileViewer.js +7 -7
- package/cjs/ui/Icon.js +1 -1
- package/cjs/ui/IconButton.js +1 -1
- package/cjs/ui/ImageRenderer.js +1 -1
- package/cjs/ui/Input.js +3 -3
- package/cjs/ui/Label.js +3 -3
- package/cjs/ui/LinkLabel.js +3 -3
- package/cjs/ui/Loader.js +1 -1
- package/cjs/ui/MentionLabel.js +11 -11
- package/cjs/ui/MessageContent.js +14 -14
- package/cjs/ui/MessageInput.js +10 -10
- package/cjs/ui/MessageItemMenu.js +7 -7
- package/cjs/ui/MessageItemReactionMenu.js +5 -5
- package/cjs/ui/MessageSearchFileItem.js +10 -10
- package/cjs/ui/MessageSearchItem.js +10 -10
- package/cjs/ui/MessageStatus.js +8 -8
- package/cjs/ui/Modal.js +8 -8
- package/cjs/ui/MutedAvatarOverlay.js +1 -1
- package/cjs/ui/OGMessageItemBody.js +11 -11
- package/cjs/ui/OpenChannelAdminMessage.js +4 -4
- package/cjs/ui/OpenChannelAvatar.js +7 -7
- package/cjs/ui/OpenchannelConversationHeader.js +7 -7
- package/cjs/ui/OpenchannelFileMessage.js +15 -15
- package/cjs/ui/OpenchannelOGMessage.js +15 -15
- package/cjs/ui/OpenchannelThumbnailMessage.js +14 -14
- package/cjs/ui/OpenchannelUserMessage.js +15 -15
- package/cjs/ui/PlaceHolder.js +6 -6
- package/cjs/ui/QuoteMessage.js +7 -7
- package/cjs/ui/QuoteMessageInput.js +7 -7
- package/cjs/ui/ReactionBadge.js +3 -3
- package/cjs/ui/ReactionButton.js +1 -1
- package/cjs/ui/SortByRow.js +1 -1
- package/cjs/ui/TextButton.js +2 -2
- package/cjs/ui/TextMessageItemBody.js +11 -11
- package/cjs/ui/ThumbnailMessageItemBody.js +3 -3
- package/cjs/ui/Tooltip.js +3 -3
- package/cjs/ui/TooltipWrapper.js +1 -1
- package/cjs/ui/UnknownMessageItemBody.js +7 -7
- package/cjs/ui/UserListItem.js +12 -12
- package/cjs/ui/UserProfile.js +10 -10
- package/cjs/ui/Word.js +11 -11
- package/cjs/useSendbirdStateContext.js +1 -1
- package/cjs/{utils-89af4b25.js → utils-1a8a0b72.js} +1 -1
- package/cjs/{utils-89af4b25.js.map → utils-1a8a0b72.js.map} +1 -1
- package/cjs/{utils-74dc34e0.js → utils-6f828dbd.js} +1 -1
- package/cjs/{utils-74dc34e0.js.map → utils-6f828dbd.js.map} +1 -1
- package/cjs/{utils-03b8d475.js → utils-71bd80e8.js} +1 -1
- package/cjs/{utils-03b8d475.js.map → utils-71bd80e8.js.map} +1 -1
- package/cjs/{uuid-eea66870.js → uuid-920ae00d.js} +1 -1
- package/cjs/{uuid-eea66870.js.map → uuid-920ae00d.js.map} +1 -1
- package/cjs/withSendbird.js +1 -1
- package/{color-28184b0b.js → color-f6548425.js} +1 -1
- package/{color-28184b0b.js.map → color-f6548425.js.map} +1 -1
- package/{compareIds-27997116.js → compareIds-8402fa74.js} +1 -1
- package/{compareIds-27997116.js.map → compareIds-8402fa74.js.map} +1 -1
- package/{const-41b49e0c.js → const-9039e539.js} +1 -1
- package/{const-41b49e0c.js.map → const-9039e539.js.map} +1 -1
- package/{const-3f6de8a5.js → const-c81e2d08.js} +1 -1
- package/{const-3f6de8a5.js.map → const-c81e2d08.js.map} +1 -1
- package/{context-dcda4755.js → context-3629064f.js} +2 -2
- package/{context-dcda4755.js.map → context-3629064f.js.map} +1 -1
- package/dist/index.css +44 -44
- package/dist/index.css.map +1 -1
- package/groupChannel-fc842dca.js +8 -0
- package/groupChannel-fc842dca.js.map +1 -0
- package/handlers/ConnectionHandler.js +4 -2
- package/handlers/ConnectionHandler.js.map +1 -1
- package/handlers/GroupChannelHandler.js +5 -3
- package/handlers/GroupChannelHandler.js.map +1 -1
- package/handlers/OpenChannelHandler.js +4 -3
- package/handlers/OpenChannelHandler.js.map +1 -1
- package/handlers/UserEventHandler.js +4 -2
- package/handlers/UserEventHandler.js.map +1 -1
- package/{index-5be8ad22.js → index-07cd4778.js} +3 -3
- package/{index-5be8ad22.js.map → index-07cd4778.js.map} +1 -1
- package/{index-6b7ea90c.js → index-17024830.js} +6 -6
- package/{index-6b7ea90c.js.map → index-17024830.js.map} +1 -1
- package/{index-aecb12d4.js → index-191d1d43.js} +1 -1
- package/{index-aecb12d4.js.map → index-191d1d43.js.map} +1 -1
- package/{index-3175e51c.js → index-2034978f.js} +4 -4
- package/{index-3175e51c.js.map → index-2034978f.js.map} +1 -1
- package/{index-d5a84010.js → index-42b2527f.js} +1 -1
- package/{index-d5a84010.js.map → index-42b2527f.js.map} +1 -1
- package/{index-3609eea7.js → index-5428ab4f.js} +2 -2
- package/{index-3609eea7.js.map → index-5428ab4f.js.map} +1 -1
- package/{index-3ca35bd9.js → index-65007eeb.js} +2 -2
- package/{index-3ca35bd9.js.map → index-65007eeb.js.map} +1 -1
- package/{index-24720843.js → index-aa2d32cc.js} +2 -2
- package/{index-24720843.js.map → index-aa2d32cc.js.map} +1 -1
- package/{index-8a6a965d.js → index-b1f9e3f9.js} +4 -4
- package/{index-8a6a965d.js.map → index-b1f9e3f9.js.map} +1 -1
- package/{index-07d9b26d.js → index-d3358aa9.js} +3 -3
- package/{index-07d9b26d.js.map → index-d3358aa9.js.map} +1 -1
- package/{index-bcb06ebd.js → index-fc480728.js} +9 -9
- package/{index-bcb06ebd.js.map → index-fc480728.js.map} +1 -1
- package/index.d.ts +5 -5
- package/index.js +39 -37
- package/index.js.map +1 -1
- package/{openChannel-ee550ee9.js → openChannel-2b51e3d3.js} +3 -2
- package/openChannel-2b51e3d3.js.map +1 -0
- package/{openChannelUtils-61f9d9d4.js → openChannelUtils-6a414996.js} +1 -1
- package/{openChannelUtils-61f9d9d4.js.map → openChannelUtils-6a414996.js.map} +1 -1
- package/package-lock.json +34500 -31
- package/package.json +1 -1
- package/sendbird-d625a809.js +7 -0
- package/sendbird-d625a809.js.map +1 -0
- package/sendbirdSelectors.js +2 -2
- package/{stringSet-0d86b370.js → stringSet-92f53c6e.js} +1 -1
- package/{stringSet-0d86b370.js.map → stringSet-92f53c6e.js.map} +1 -1
- package/{topics-804ec5d3.js → topics-71b67878.js} +1 -1
- package/{topics-804ec5d3.js.map → topics-71b67878.js.map} +1 -1
- package/{tslib.es6-3e3509d9.js → tslib.es6-c793443a.js} +1 -1
- package/{tslib.es6-3e3509d9.js.map → tslib.es6-c793443a.js.map} +1 -1
- package/ui/Accordion.js +4 -4
- package/ui/AccordionGroup.js +2 -2
- package/ui/AdminMessage.js +3 -3
- package/ui/Avatar.js +3 -3
- package/ui/Badge.js +5 -5
- package/ui/Button.js +4 -4
- package/ui/ChannelAvatar.js +4 -4
- package/ui/ChannelPreview.js +12 -12
- package/ui/ChatHeader.js +8 -8
- package/ui/ConnectionStatus.js +5 -5
- package/ui/ContextMenu.js +5 -5
- package/ui/DateSeparator.js +4 -4
- package/ui/Dropdown.js +3 -3
- package/ui/EmojiReactions.js +7 -7
- package/ui/FileMessageItemBody.js +6 -6
- package/ui/FileViewer.js +7 -7
- package/ui/Icon.js +1 -1
- package/ui/IconButton.js +1 -1
- package/ui/ImageRenderer.js +1 -1
- package/ui/Input.js +3 -3
- package/ui/Label.js +3 -3
- package/ui/LinkLabel.js +3 -3
- package/ui/Loader.js +1 -1
- package/ui/MentionLabel.js +11 -11
- package/ui/MessageContent.js +14 -14
- package/ui/MessageInput.js +10 -10
- package/ui/MessageItemMenu.js +7 -7
- package/ui/MessageItemReactionMenu.js +5 -5
- package/ui/MessageSearchFileItem.js +10 -10
- package/ui/MessageSearchItem.js +10 -10
- package/ui/MessageStatus.js +8 -8
- package/ui/Modal.js +8 -8
- package/ui/MutedAvatarOverlay.js +1 -1
- package/ui/OGMessageItemBody.js +11 -11
- package/ui/OpenChannelAdminMessage.js +4 -4
- package/ui/OpenChannelAvatar.js +7 -7
- package/ui/OpenchannelConversationHeader.js +7 -7
- package/ui/OpenchannelFileMessage.js +15 -15
- package/ui/OpenchannelOGMessage.js +15 -15
- package/ui/OpenchannelThumbnailMessage.js +14 -14
- package/ui/OpenchannelUserMessage.js +15 -15
- package/ui/PlaceHolder.js +6 -6
- package/ui/QuoteMessage.js +7 -7
- package/ui/QuoteMessageInput.js +7 -7
- package/ui/ReactionBadge.js +3 -3
- package/ui/ReactionButton.js +1 -1
- package/ui/SortByRow.js +1 -1
- package/ui/TextButton.js +2 -2
- package/ui/TextMessageItemBody.js +11 -11
- package/ui/ThumbnailMessageItemBody.js +3 -3
- package/ui/Tooltip.js +3 -3
- package/ui/TooltipWrapper.js +1 -1
- package/ui/UnknownMessageItemBody.js +7 -7
- package/ui/UserListItem.js +12 -12
- package/ui/UserProfile.js +10 -10
- package/ui/Word.js +11 -11
- package/useSendbirdStateContext.js +1 -1
- package/{utils-c9cdd5aa.js → utils-972c4edb.js} +1 -1
- package/{utils-c9cdd5aa.js.map → utils-972c4edb.js.map} +1 -1
- package/{utils-cbf805c7.js → utils-b37c6db3.js} +1 -1
- package/{utils-cbf805c7.js.map → utils-b37c6db3.js.map} +1 -1
- package/{utils-830ba47e.js → utils-b69f7583.js} +1 -1
- package/{utils-830ba47e.js.map → utils-b69f7583.js.map} +1 -1
- package/{uuid-85cc7825.js → uuid-7c3f59a3.js} +1 -1
- package/{uuid-85cc7825.js.map → uuid-7c3f59a3.js.map} +1 -1
- package/withSendbird.js +1 -1
- package/__bundle-7dfccc8c-1e79737e.js +0 -22
- package/__bundle-7dfccc8c-1e79737e.js.map +0 -1
- package/cjs/__bundle-7dfccc8c-771b48be.js +0 -120
- package/cjs/__bundle-7dfccc8c-771b48be.js.map +0 -1
- package/cjs/groupChannel-252dcb17.js +0 -11
- package/cjs/groupChannel-252dcb17.js.map +0 -1
- package/cjs/openChannel-f059cb82.js +0 -9
- package/cjs/openChannel-f059cb82.js.map +0 -1
- package/groupChannel-540f3a1a.js +0 -8
- package/groupChannel-540f3a1a.js.map +0 -1
- package/openChannel-ee550ee9.js.map +0 -1
|
@@ -1 +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, useEffect } from 'react';\nimport type { GroupChannel, Member, SendbirdGroupChat } from '@sendbird/chat/groupChannel';\nimport type { User } from '@sendbird/chat';\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: GroupChannel;\n onLeaveChannel(\n channel: GroupChannel,\n onLeaveChannelCb?: (c: GroupChannel) => void,\n );\n}\n\ninterface RenderUserProfileProps {\n user: Member | 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 as SendbirdGroupChat;\n const sdkError = sdkStore?.error;\n const sdkIntialized = sdkStore?.initialized || false;\n\n const [channelsTomarkAsRead, setChannelsToMarkAsRead] = useState([]);\n useEffect(() => {\n // https://stackoverflow.com/a/60907638\n let isMounted = true;\n if (channelsTomarkAsRead?.length > 0) {\n channelsTomarkAsRead?.forEach((c, idx) => {\n // Plan-based rate limits - minimum limit is 5 requests per second\n setTimeout(() => {\n if (isMounted) {\n c?.markAsDelivered();\n }\n }, 2000 * idx);\n });\n }\n return () => {\n isMounted = false;\n }\n }, [channelsTomarkAsRead]);\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().then((channelList) => {\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 setChannelsToMarkAsRead(channelList);\n }\n }).catch((err) => {\n logger.info('ChannelList: Fetching channels failed', err);\n channelListDispatcher({\n type: channelListActions.FETCH_CHANNELS_FAILURE,\n payload: err,\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","_e","channelsTomarkAsRead","setChannelsToMarkAsRead","useEffect","isMounted","length","forEach","c","idx","setTimeout","markAsDelivered","React","EditUserProfile","e","target","fetchMore","clientHeight","scrollTop","scrollHeight","hasNext","info","type","channelListActions","payload","next","then","channelList","canSetMarkAsDelivered","appInfo","premiumFeatureList","find","feature","catch","err","PlaceHolderTypes","WRONG","map","channel","onLeaveChannel","cb","leave","res","url","onClick","some","_a","LOADING","NO_CHANNELS"],"mappings":"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"}
|
|
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, useEffect } from 'react';\nimport type { GroupChannel, Member, SendbirdGroupChat } from '@sendbird/chat/groupChannel';\nimport type { User } from '@sendbird/chat';\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: GroupChannel;\n onLeaveChannel(\n channel: GroupChannel,\n onLeaveChannelCb?: (c: GroupChannel) => void,\n );\n}\n\ninterface RenderUserProfileProps {\n user: Member | 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 as SendbirdGroupChat;\n const sdkError = sdkStore?.error;\n const sdkIntialized = sdkStore?.initialized || false;\n\n const [channelsTomarkAsRead, setChannelsToMarkAsRead] = useState([]);\n useEffect(() => {\n // https://stackoverflow.com/a/60907638\n let isMounted = true;\n if (channelsTomarkAsRead?.length > 0) {\n channelsTomarkAsRead?.forEach((c, idx) => {\n // Plan-based rate limits - minimum limit is 5 requests per second\n setTimeout(() => {\n if (isMounted) {\n c?.markAsDelivered();\n }\n }, 2000 * idx);\n });\n }\n return () => {\n isMounted = false;\n }\n }, [channelsTomarkAsRead]);\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().then((channelList) => {\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 setChannelsToMarkAsRead(channelList);\n }\n }).catch((err) => {\n logger.info('ChannelList: Fetching channels failed', err);\n channelListDispatcher({\n type: channelListActions.FETCH_CHANNELS_FAILURE,\n payload: err,\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","_e","channelsTomarkAsRead","setChannelsToMarkAsRead","useEffect","isMounted","length","forEach","c","idx","setTimeout","markAsDelivered","React","EditUserProfile","e","target","fetchMore","clientHeight","scrollTop","scrollHeight","hasNext","info","type","channelListActions","payload","next","then","channelList","canSetMarkAsDelivered","appInfo","premiumFeatureList","find","feature","catch","err","PlaceHolderTypes","WRONG","map","channel","onLeaveChannel","cb","leave","res","url","onClick","some","_a","LOADING","NO_CHANNELS"],"mappings":"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"}
|
|
@@ -2,35 +2,37 @@ import React__default from 'react';
|
|
|
2
2
|
import ChannelAvatar from '../../ui/ChannelAvatar.js';
|
|
3
3
|
import Badge from '../../ui/Badge.js';
|
|
4
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-
|
|
6
|
-
import { i as isToday, a as isYesterday, f as formatRelative } from '../../index-
|
|
7
|
-
import { f as format } from '../../index-
|
|
8
|
-
import { t as truncateString, e as isEditedMessage } from '../../index-
|
|
5
|
+
import { c as LabelStringSet, L as Label, a as LabelTypography, b as LabelColors } from '../../index-07cd4778.js';
|
|
6
|
+
import { i as isToday, a as isYesterday, f as formatRelative } from '../../index-b1f9e3f9.js';
|
|
7
|
+
import { f as format } from '../../index-aa2d32cc.js';
|
|
8
|
+
import { t as truncateString, e as isEditedMessage } from '../../index-65007eeb.js';
|
|
9
9
|
import useSendbirdStateContext from '../../useSendbirdStateContext.js';
|
|
10
|
-
import { u as useLocalization } from '../../LocalizationContext-
|
|
10
|
+
import { u as useLocalization } from '../../LocalizationContext-61a4a931.js';
|
|
11
11
|
import MentionUserLabel from '../../ui/MentionUserLabel.js';
|
|
12
|
-
import { u as useChannelListContext } from '../../ChannelListProvider-
|
|
12
|
+
import { u as useChannelListContext } from '../../ChannelListProvider-bdac2e90.js';
|
|
13
13
|
import { TypingIndicatorText } from '../../Channel/components/TypingIndicator.js';
|
|
14
14
|
import MessageStatus from '../../ui/MessageStatus.js';
|
|
15
15
|
import '../../ui/Avatar.js';
|
|
16
|
-
import '../../tslib.es6-
|
|
16
|
+
import '../../tslib.es6-c793443a.js';
|
|
17
17
|
import '../../ui/ImageRenderer.js';
|
|
18
|
-
import '../../_rollupPluginBabelHelpers-
|
|
18
|
+
import '../../_rollupPluginBabelHelpers-30d122aa.js';
|
|
19
19
|
import 'prop-types';
|
|
20
|
-
import '../../uuid-
|
|
21
|
-
import '../../utils-
|
|
22
|
-
import '../../stringSet-
|
|
23
|
-
import '../../index-
|
|
24
|
-
import '../../index-
|
|
20
|
+
import '../../uuid-7c3f59a3.js';
|
|
21
|
+
import '../../utils-b37c6db3.js';
|
|
22
|
+
import '../../stringSet-92f53c6e.js';
|
|
23
|
+
import '../../index-5428ab4f.js';
|
|
24
|
+
import '../../index-191d1d43.js';
|
|
25
25
|
import '../../withSendbird.js';
|
|
26
|
-
import '../../groupChannel-
|
|
27
|
-
import '../../__bundle-
|
|
28
|
-
import '../../
|
|
29
|
-
import '../../
|
|
30
|
-
import '../../
|
|
31
|
-
import '../../
|
|
32
|
-
import '../../
|
|
33
|
-
import '../../
|
|
26
|
+
import '../../groupChannel-fc842dca.js';
|
|
27
|
+
import '../../__bundle-6316ce22-b659cee1.js';
|
|
28
|
+
import '../../__bundle-fbda47dd-ef31252f.js';
|
|
29
|
+
import '../../__bundle-7dfccc8c-37d3f8ab.js';
|
|
30
|
+
import '../../topics-71b67878.js';
|
|
31
|
+
import '../../utils-b69f7583.js';
|
|
32
|
+
import '../../UserProfileContext-3524e64c.js';
|
|
33
|
+
import '../../ChannelProvider-0174d0f3.js';
|
|
34
|
+
import '../../compareIds-8402fa74.js';
|
|
35
|
+
import '../../const-9039e539.js';
|
|
34
36
|
import '../../ui/ContextMenu.js';
|
|
35
37
|
import 'react-dom';
|
|
36
38
|
import '../../ui/SortByRow.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChannelPreview.js","sources":["../../../src/smart-components/ChannelList/components/ChannelPreview/utils.js","../../../src/smart-components/ChannelList/components/ChannelPreview/index.tsx"],"sourcesContent":["import isToday from 'date-fns/isToday';\nimport format from 'date-fns/format';\nimport formatRelative from 'date-fns/formatRelative';\nimport isYesterday from 'date-fns/isYesterday';\n\nimport { truncateString } from '../../../../utils';\nimport { LabelStringSet } from '../../../../ui/Label';\n\nexport const getChannelTitle = (channel = {}, currentUserId, stringSet = LabelStringSet) => {\n if (!channel?.name && !channel?.members) {\n return stringSet.NO_TITLE;\n }\n if (channel?.name && channel.name !== 'Group Channel') {\n return channel.name;\n }\n if (channel?.members?.length === 1) {\n return stringSet.NO_MEMBERS;\n }\n return (channel?.members || [])\n .filter(({ userId }) => userId !== currentUserId)\n .map(({ nickname }) => (nickname || stringSet.NO_NAME))\n .join(', ');\n};\n\nexport const getLastMessageCreatedAt = (channel, locale) => {\n const createdAt = channel?.lastMessage?.createdAt;\n const optionalParam = locale ? { locale } : null;\n if (!createdAt) {\n return '';\n }\n if (isToday(createdAt)) {\n return format(createdAt, 'p', optionalParam);\n }\n if (isYesterday(createdAt)) {\n return formatRelative(createdAt, new Date(), optionalParam);\n }\n return format(createdAt, 'MMM dd', optionalParam);\n};\n\nexport const getTotalMembers = (channel) => (\n channel?.memberCount\n ? channel.memberCount\n : 0\n);\n\nconst getPrettyLastMessage = (message = {}) => {\n const MAXLEN = 30;\n const { messageType, name } = message;\n if (messageType === 'file') {\n return truncateString(name, MAXLEN);\n }\n return message.message;\n};\n\nexport const getLastMessage = (channel) => (\n channel?.lastMessage\n ? getPrettyLastMessage(channel.lastMessage)\n : ''\n);\n\nexport const getChannelUnreadMessageCount = (channel) => (\n channel?.unreadMessageCount\n ? channel.unreadMessageCount\n : 0\n);\n","import './channel-preview.scss';\n\nimport React from 'react';\nimport type { GroupChannel } from '@sendbird/chat/groupChannel';\nimport type { FileMessage, UserMessage } from '@sendbird/chat/message';\n\nimport ChannelAvatar from '../../../../ui/ChannelAvatar';\nimport Badge from '../../../../ui/Badge';\nimport Icon, { IconColors, IconTypes } from '../../../../ui/Icon';\nimport Label, { LabelTypography, LabelColors } from '../../../../ui/Label';\n\nimport * as utils from './utils';\n\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport { useLocalization } from '../../../../lib/LocalizationContext';\nimport MentionUserLabel from '../../../../ui/MentionUserLabel';\nimport { useChannelListContext } from '../../context/ChannelListProvider';\nimport { TypingIndicatorText } from '../../../Channel/components/TypingIndicator';\nimport MessageStatus from '../../../../ui/MessageStatus';\nimport { isEditedMessage } from '../../../../utils';\n\ninterface ChannelPreviewInterface {\n channel: GroupChannel;\n isActive?: boolean;\n isTyping?: boolean;\n onClick: () => void;\n renderChannelAction: (props: { channel: GroupChannel }) => React.ReactNode;\n tabIndex: number;\n}\n\nconst ChannelPreview: React.FC<ChannelPreviewInterface> = ({\n channel,\n isActive = false,\n isTyping = false,\n renderChannelAction,\n onClick,\n tabIndex,\n}: ChannelPreviewInterface) => {\n const sbState = useSendbirdStateContext();\n const {\n isTypingIndicatorEnabled = false,\n isMessageReceiptStatusEnabled = false,\n } = useChannelListContext();\n const { dateLocale, stringSet } = useLocalization();\n const userId = sbState?.stores?.userStore?.user?.userId;\n const theme = sbState?.config?.theme;\n const isMentionEnabled = sbState?.config?.isMentionEnabled;\n const isFrozen = channel?.isFrozen || false;\n const isBroadcast = channel?.isBroadcast || false;\n const isChannelTyping = isTypingIndicatorEnabled && isTyping;\n const isMessageStatusEnabled = isMessageReceiptStatusEnabled\n && (channel?.lastMessage?.messageType === 'user' || channel?.lastMessage?.messageType === 'file')\n && (channel?.lastMessage as UserMessage | FileMessage)?.sender?.userId === userId;\n return (\n <div\n className={[\n 'sendbird-channel-preview',\n isActive ? 'sendbird-channel-preview--active' : '',\n ].join(' ')}\n role=\"link\"\n onClick={onClick}\n onKeyPress={onClick}\n tabIndex={tabIndex}\n >\n <div\n className=\"sendbird-channel-preview__avatar\"\n >\n <ChannelAvatar\n channel={channel}\n userId={userId}\n theme={theme}\n />\n </div>\n <div className=\"sendbird-channel-preview__content\">\n <div className=\"sendbird-channel-preview__content__upper\">\n <div className=\"sendbird-channel-preview__content__upper__header\">\n {\n isBroadcast\n && (\n <div className=\"sendbird-channel-preview__content__upper__header__broadcast-icon\">\n <Icon\n type={IconTypes.BROADCAST}\n fillColor={IconColors.SECONDARY}\n height=\"16px\"\n width=\"16px\"\n />\n </div>\n )\n }\n <Label\n className=\"sendbird-channel-preview__content__upper__header__channel-name\"\n type={LabelTypography.SUBTITLE_2}\n color={LabelColors.ONBACKGROUND_1}\n >\n {utils.getChannelTitle(channel, userId, stringSet)}\n </Label>\n <Label\n className=\"sendbird-channel-preview__content__upper__header__total-members\"\n type={LabelTypography.CAPTION_2}\n color={LabelColors.ONBACKGROUND_2}\n >\n {utils.getTotalMembers(channel)}\n </Label>\n {\n isFrozen\n && (\n <div title=\"Frozen\" className=\"sendbird-channel-preview__content__upper__header__frozen-icon\">\n <Icon\n type={IconTypes.FREEZE}\n fillColor={IconColors.PRIMARY}\n height={12}\n width={12}\n />\n </div>\n )\n }\n </div>\n {\n isMessageStatusEnabled\n ? (\n <MessageStatus\n className=\"sendbird-channel-preview__content__upper__last-message-at\"\n channel={channel}\n message={channel?.lastMessage as UserMessage | FileMessage}\n />\n )\n : (\n <Label\n className=\"sendbird-channel-preview__content__upper__last-message-at\"\n type={LabelTypography.CAPTION_3}\n color={LabelColors.ONBACKGROUND_2}\n >\n {utils.getLastMessageCreatedAt(channel, dateLocale)}\n </Label>\n )\n }\n </div>\n <div className=\"sendbird-channel-preview__content__lower\">\n <Label\n className=\"sendbird-channel-preview__content__lower__last-message\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_3}\n >\n {\n isChannelTyping && (\n <TypingIndicatorText members={channel?.getTypingUsers()} />\n )\n }\n {\n !isChannelTyping && (\n utils.getLastMessage(channel) + (isEditedMessage(channel?.lastMessage as UserMessage | FileMessage) ? ` ${stringSet.MESSAGE_EDITED}` : '')\n )\n }\n </Label>\n <div className=\"sendbird-channel-preview__content__lower__unread-message-count\">\n {\n (isMentionEnabled && channel?.unreadMentionCount > 0)\n ? (\n <MentionUserLabel\n className=\"sendbird-channel-preview__content__lower__unread-message-count__mention\"\n color=\"purple\"\n >\n {'@'}\n </MentionUserLabel>\n )\n : null\n }\n {\n utils.getChannelUnreadMessageCount(channel) // return number\n ? <Badge count={utils.getChannelUnreadMessageCount(channel)} />\n : null\n }\n </div>\n </div>\n </div>\n <div\n className=\"sendbird-channel-preview__action\"\n >\n {renderChannelAction({ channel })}\n </div>\n </div>\n );\n}\n\nexport default ChannelPreview;\n"],"names":["getChannelTitle","channel","currentUserId","stringSet","LabelStringSet","name","members","NO_TITLE","length","NO_MEMBERS","filter","userId","map","nickname","NO_NAME","join","getLastMessageCreatedAt","locale","createdAt","lastMessage","optionalParam","isToday","format","isYesterday","formatRelative","Date","getTotalMembers","memberCount","getPrettyLastMessage","message","MAXLEN","messageType","truncateString","getLastMessage","getChannelUnreadMessageCount","unreadMessageCount","ChannelPreview","_a","_l","isActive","_m","isTyping","renderChannelAction","onClick","tabIndex","sbState","useSendbirdStateContext","_o","useChannelListContext","_p","isTypingIndicatorEnabled","_q","isMessageReceiptStatusEnabled","_r","useLocalization","dateLocale","stores","userStore","user","theme","config","isMentionEnabled","isFrozen","isBroadcast","isChannelTyping","isMessageStatusEnabled","sender","React","IconTypes","BROADCAST","IconColors","SECONDARY","LabelTypography","SUBTITLE_2","LabelColors","ONBACKGROUND_1","utils","CAPTION_2","ONBACKGROUND_2","FREEZE","PRIMARY","CAPTION_3","BODY_2","ONBACKGROUND_3","getTypingUsers","isEditedMessage","MESSAGE_EDITED","unreadMentionCount"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ChannelPreview.js","sources":["../../../src/smart-components/ChannelList/components/ChannelPreview/utils.js","../../../src/smart-components/ChannelList/components/ChannelPreview/index.tsx"],"sourcesContent":["import isToday from 'date-fns/isToday';\nimport format from 'date-fns/format';\nimport formatRelative from 'date-fns/formatRelative';\nimport isYesterday from 'date-fns/isYesterday';\n\nimport { truncateString } from '../../../../utils';\nimport { LabelStringSet } from '../../../../ui/Label';\n\nexport const getChannelTitle = (channel = {}, currentUserId, stringSet = LabelStringSet) => {\n if (!channel?.name && !channel?.members) {\n return stringSet.NO_TITLE;\n }\n if (channel?.name && channel.name !== 'Group Channel') {\n return channel.name;\n }\n if (channel?.members?.length === 1) {\n return stringSet.NO_MEMBERS;\n }\n return (channel?.members || [])\n .filter(({ userId }) => userId !== currentUserId)\n .map(({ nickname }) => (nickname || stringSet.NO_NAME))\n .join(', ');\n};\n\nexport const getLastMessageCreatedAt = (channel, locale) => {\n const createdAt = channel?.lastMessage?.createdAt;\n const optionalParam = locale ? { locale } : null;\n if (!createdAt) {\n return '';\n }\n if (isToday(createdAt)) {\n return format(createdAt, 'p', optionalParam);\n }\n if (isYesterday(createdAt)) {\n return formatRelative(createdAt, new Date(), optionalParam);\n }\n return format(createdAt, 'MMM dd', optionalParam);\n};\n\nexport const getTotalMembers = (channel) => (\n channel?.memberCount\n ? channel.memberCount\n : 0\n);\n\nconst getPrettyLastMessage = (message = {}) => {\n const MAXLEN = 30;\n const { messageType, name } = message;\n if (messageType === 'file') {\n return truncateString(name, MAXLEN);\n }\n return message.message;\n};\n\nexport const getLastMessage = (channel) => (\n channel?.lastMessage\n ? getPrettyLastMessage(channel.lastMessage)\n : ''\n);\n\nexport const getChannelUnreadMessageCount = (channel) => (\n channel?.unreadMessageCount\n ? channel.unreadMessageCount\n : 0\n);\n","import './channel-preview.scss';\n\nimport React from 'react';\nimport type { GroupChannel } from '@sendbird/chat/groupChannel';\nimport type { FileMessage, UserMessage } from '@sendbird/chat/message';\n\nimport ChannelAvatar from '../../../../ui/ChannelAvatar';\nimport Badge from '../../../../ui/Badge';\nimport Icon, { IconColors, IconTypes } from '../../../../ui/Icon';\nimport Label, { LabelTypography, LabelColors } from '../../../../ui/Label';\n\nimport * as utils from './utils';\n\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport { useLocalization } from '../../../../lib/LocalizationContext';\nimport MentionUserLabel from '../../../../ui/MentionUserLabel';\nimport { useChannelListContext } from '../../context/ChannelListProvider';\nimport { TypingIndicatorText } from '../../../Channel/components/TypingIndicator';\nimport MessageStatus from '../../../../ui/MessageStatus';\nimport { isEditedMessage } from '../../../../utils';\n\ninterface ChannelPreviewInterface {\n channel: GroupChannel;\n isActive?: boolean;\n isTyping?: boolean;\n onClick: () => void;\n renderChannelAction: (props: { channel: GroupChannel }) => React.ReactNode;\n tabIndex: number;\n}\n\nconst ChannelPreview: React.FC<ChannelPreviewInterface> = ({\n channel,\n isActive = false,\n isTyping = false,\n renderChannelAction,\n onClick,\n tabIndex,\n}: ChannelPreviewInterface) => {\n const sbState = useSendbirdStateContext();\n const {\n isTypingIndicatorEnabled = false,\n isMessageReceiptStatusEnabled = false,\n } = useChannelListContext();\n const { dateLocale, stringSet } = useLocalization();\n const userId = sbState?.stores?.userStore?.user?.userId;\n const theme = sbState?.config?.theme;\n const isMentionEnabled = sbState?.config?.isMentionEnabled;\n const isFrozen = channel?.isFrozen || false;\n const isBroadcast = channel?.isBroadcast || false;\n const isChannelTyping = isTypingIndicatorEnabled && isTyping;\n const isMessageStatusEnabled = isMessageReceiptStatusEnabled\n && (channel?.lastMessage?.messageType === 'user' || channel?.lastMessage?.messageType === 'file')\n && (channel?.lastMessage as UserMessage | FileMessage)?.sender?.userId === userId;\n return (\n <div\n className={[\n 'sendbird-channel-preview',\n isActive ? 'sendbird-channel-preview--active' : '',\n ].join(' ')}\n role=\"link\"\n onClick={onClick}\n onKeyPress={onClick}\n tabIndex={tabIndex}\n >\n <div\n className=\"sendbird-channel-preview__avatar\"\n >\n <ChannelAvatar\n channel={channel}\n userId={userId}\n theme={theme}\n />\n </div>\n <div className=\"sendbird-channel-preview__content\">\n <div className=\"sendbird-channel-preview__content__upper\">\n <div className=\"sendbird-channel-preview__content__upper__header\">\n {\n isBroadcast\n && (\n <div className=\"sendbird-channel-preview__content__upper__header__broadcast-icon\">\n <Icon\n type={IconTypes.BROADCAST}\n fillColor={IconColors.SECONDARY}\n height=\"16px\"\n width=\"16px\"\n />\n </div>\n )\n }\n <Label\n className=\"sendbird-channel-preview__content__upper__header__channel-name\"\n type={LabelTypography.SUBTITLE_2}\n color={LabelColors.ONBACKGROUND_1}\n >\n {utils.getChannelTitle(channel, userId, stringSet)}\n </Label>\n <Label\n className=\"sendbird-channel-preview__content__upper__header__total-members\"\n type={LabelTypography.CAPTION_2}\n color={LabelColors.ONBACKGROUND_2}\n >\n {utils.getTotalMembers(channel)}\n </Label>\n {\n isFrozen\n && (\n <div title=\"Frozen\" className=\"sendbird-channel-preview__content__upper__header__frozen-icon\">\n <Icon\n type={IconTypes.FREEZE}\n fillColor={IconColors.PRIMARY}\n height={12}\n width={12}\n />\n </div>\n )\n }\n </div>\n {\n isMessageStatusEnabled\n ? (\n <MessageStatus\n className=\"sendbird-channel-preview__content__upper__last-message-at\"\n channel={channel}\n message={channel?.lastMessage as UserMessage | FileMessage}\n />\n )\n : (\n <Label\n className=\"sendbird-channel-preview__content__upper__last-message-at\"\n type={LabelTypography.CAPTION_3}\n color={LabelColors.ONBACKGROUND_2}\n >\n {utils.getLastMessageCreatedAt(channel, dateLocale)}\n </Label>\n )\n }\n </div>\n <div className=\"sendbird-channel-preview__content__lower\">\n <Label\n className=\"sendbird-channel-preview__content__lower__last-message\"\n type={LabelTypography.BODY_2}\n color={LabelColors.ONBACKGROUND_3}\n >\n {\n isChannelTyping && (\n <TypingIndicatorText members={channel?.getTypingUsers()} />\n )\n }\n {\n !isChannelTyping && (\n utils.getLastMessage(channel) + (isEditedMessage(channel?.lastMessage as UserMessage | FileMessage) ? ` ${stringSet.MESSAGE_EDITED}` : '')\n )\n }\n </Label>\n <div className=\"sendbird-channel-preview__content__lower__unread-message-count\">\n {\n (isMentionEnabled && channel?.unreadMentionCount > 0)\n ? (\n <MentionUserLabel\n className=\"sendbird-channel-preview__content__lower__unread-message-count__mention\"\n color=\"purple\"\n >\n {'@'}\n </MentionUserLabel>\n )\n : null\n }\n {\n utils.getChannelUnreadMessageCount(channel) // return number\n ? <Badge count={utils.getChannelUnreadMessageCount(channel)} />\n : null\n }\n </div>\n </div>\n </div>\n <div\n className=\"sendbird-channel-preview__action\"\n >\n {renderChannelAction({ channel })}\n </div>\n </div>\n );\n}\n\nexport default ChannelPreview;\n"],"names":["getChannelTitle","channel","currentUserId","stringSet","LabelStringSet","name","members","NO_TITLE","length","NO_MEMBERS","filter","userId","map","nickname","NO_NAME","join","getLastMessageCreatedAt","locale","createdAt","lastMessage","optionalParam","isToday","format","isYesterday","formatRelative","Date","getTotalMembers","memberCount","getPrettyLastMessage","message","MAXLEN","messageType","truncateString","getLastMessage","getChannelUnreadMessageCount","unreadMessageCount","ChannelPreview","_a","_l","isActive","_m","isTyping","renderChannelAction","onClick","tabIndex","sbState","useSendbirdStateContext","_o","useChannelListContext","_p","isTypingIndicatorEnabled","_q","isMessageReceiptStatusEnabled","_r","useLocalization","dateLocale","stores","userStore","user","theme","config","isMentionEnabled","isFrozen","isBroadcast","isChannelTyping","isMessageStatusEnabled","sender","React","IconTypes","BROADCAST","IconColors","SECONDARY","LabelTypography","SUBTITLE_2","LabelColors","ONBACKGROUND_1","utils","CAPTION_2","ONBACKGROUND_2","FREEZE","PRIMARY","CAPTION_3","BODY_2","ONBACKGROUND_3","getTypingUsers","isEditedMessage","MESSAGE_EDITED","unreadMentionCount"],"mappings":"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"}
|
|
@@ -1,29 +1,31 @@
|
|
|
1
|
-
import { a as _slicedToArray } from '../../_rollupPluginBabelHelpers-
|
|
1
|
+
import { a as _slicedToArray } from '../../_rollupPluginBabelHelpers-30d122aa.js';
|
|
2
2
|
import React__default, { useRef, useState, useContext } from 'react';
|
|
3
3
|
import PropTypes from 'prop-types';
|
|
4
|
-
import { a as LocalizationContext } from '../../LocalizationContext-
|
|
4
|
+
import { a as LocalizationContext } from '../../LocalizationContext-61a4a931.js';
|
|
5
5
|
import ContextMenu, { MenuItems, MenuItem } from '../../ui/ContextMenu.js';
|
|
6
6
|
import IconButton from '../../ui/IconButton.js';
|
|
7
7
|
import Icon, { IconTypes, IconColors } from '../../ui/Icon.js';
|
|
8
8
|
import useSendbirdStateContext from '../../useSendbirdStateContext.js';
|
|
9
|
-
import { n as noop } from '../../utils-
|
|
9
|
+
import { n as noop } from '../../utils-b69f7583.js';
|
|
10
10
|
import Modal from '../../ui/Modal.js';
|
|
11
|
-
import { u as useChannelListContext } from '../../ChannelListProvider-
|
|
12
|
-
import '../../stringSet-
|
|
13
|
-
import '../../index-
|
|
14
|
-
import '../../index-
|
|
15
|
-
import '../../index-
|
|
16
|
-
import '../../tslib.es6-
|
|
11
|
+
import { u as useChannelListContext } from '../../ChannelListProvider-bdac2e90.js';
|
|
12
|
+
import '../../stringSet-92f53c6e.js';
|
|
13
|
+
import '../../index-191d1d43.js';
|
|
14
|
+
import '../../index-07cd4778.js';
|
|
15
|
+
import '../../index-65007eeb.js';
|
|
16
|
+
import '../../tslib.es6-c793443a.js';
|
|
17
17
|
import 'react-dom';
|
|
18
18
|
import '../../ui/SortByRow.js';
|
|
19
19
|
import '../../withSendbird.js';
|
|
20
|
-
import '../../index-
|
|
21
|
-
import '../../index-
|
|
22
|
-
import '../../groupChannel-
|
|
23
|
-
import '../../__bundle-
|
|
24
|
-
import '../../
|
|
25
|
-
import '../../
|
|
26
|
-
import '../../
|
|
20
|
+
import '../../index-42b2527f.js';
|
|
21
|
+
import '../../index-d3358aa9.js';
|
|
22
|
+
import '../../groupChannel-fc842dca.js';
|
|
23
|
+
import '../../__bundle-6316ce22-b659cee1.js';
|
|
24
|
+
import '../../__bundle-fbda47dd-ef31252f.js';
|
|
25
|
+
import '../../__bundle-7dfccc8c-37d3f8ab.js';
|
|
26
|
+
import '../../topics-71b67878.js';
|
|
27
|
+
import '../../uuid-7c3f59a3.js';
|
|
28
|
+
import '../../UserProfileContext-3524e64c.js';
|
|
27
29
|
|
|
28
30
|
var LeaveChannel = function LeaveChannel(props) {
|
|
29
31
|
var _a, _b, _c;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChannelPreviewAction.js","sources":["../../../src/smart-components/ChannelList/components/LeaveChannel/index.tsx","../../../src/smart-components/ChannelList/components/ChannelPreviewAction.jsx"],"sourcesContent":["import React from 'react';\n\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport { noop } from '../../../../utils/utils';\n\nimport Modal from '../../../../ui/Modal';\nimport { useChannelListContext } from '../../context/ChannelListProvider';\n\nexport type LeaveChannelProps = {\n onSubmit: () => void;\n onCancel: () => void;\n}\n\nconst LeaveChannel: React.FC<LeaveChannelProps> = (props: LeaveChannelProps) => {\n const {\n onSubmit = noop,\n onCancel = noop,\n } = props;\n\n const channel = useChannelListContext()?.currentChannel;\n const state = useSendbirdStateContext();\n const logger = state?.config?.logger;\n const isOnline = state?.config?.isOnline;\n if (channel) {\n return (\n <Modal\n disabled={!isOnline}\n onCancel={onCancel}\n onSubmit={() => {\n logger.info('ChannelSettings: Leaving channel', channel);\n channel?.leave()\n .then(() => {\n logger.info('ChannelSettings: Leaving channel successful!', channel);\n onSubmit();\n });\n }}\n submitText=\"Leave\"\n titleText=\"Leave this channel?\"\n />\n );\n }\n};\n\nexport default LeaveChannel;\n","import React, {\n useState,\n useRef,\n useContext,\n} from 'react';\nimport PropTypes from 'prop-types';\n\nimport { LocalizationContext } from '../../../lib/LocalizationContext';\nimport ContextMenu, { MenuItem, MenuItems } from '../../../ui/ContextMenu';\nimport IconButton from '../../../ui/IconButton';\nimport Icon, { IconTypes, IconColors } from '../../../ui/Icon';\nimport LeaveChannelModal from './LeaveChannel';\n\nexport default function ChannelPreviewAction({ disabled, onLeaveChannel }) {\n const parentRef = useRef(null);\n const [showModal, setShowModal] = useState(false);\n const { stringSet } = useContext(LocalizationContext);\n\n return (\n <div\n role=\"button\"\n style={{ display: 'inline-block' }}\n onKeyDown={(e) => { e.stopPropagation(); }}\n tabIndex={0}\n onClick={(e) => { e.stopPropagation(); }}\n >\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n <IconButton\n ref={parentRef}\n onClick={toggleDropdown}\n height=\"32px\"\n width=\"32px\"\n >\n <Icon\n type={IconTypes.MORE}\n fillColor={IconColors.PRIMARY}\n width=\"24px\"\n height=\"24px\"\n />\n </IconButton>\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={parentRef}\n parentContainRef={parentRef}\n closeDropdown={closeDropdown}\n >\n <MenuItem\n onClick={() => {\n if (disabled) { return; }\n setShowModal(true);\n closeDropdown();\n }}\n >\n {stringSet.CHANNEL_SETTING__LEAVE_CHANNEL__TITLE}\n </MenuItem>\n </MenuItems>\n )}\n />\n {\n showModal && (\n <LeaveChannelModal\n onSubmit={() => {\n setShowModal(false);\n onLeaveChannel();\n }}\n onCancel={() => setShowModal(false)}\n />\n )\n }\n </div>\n );\n}\n\nChannelPreviewAction.propTypes = {\n disabled: PropTypes.bool,\n onLeaveChannel: PropTypes.func.isRequired,\n};\n\nChannelPreviewAction.defaultProps = {\n disabled: false,\n};\n"],"names":["LeaveChannel","props","_d","onSubmit","noop","_e","onCancel","channel","useChannelListContext","currentChannel","state","useSendbirdStateContext","logger","config","isOnline","React","info","leave","then","ChannelPreviewAction","disabled","onLeaveChannel","parentRef","useRef","useState","showModal","setShowModal","useContext","LocalizationContext","stringSet","display","e","stopPropagation","toggleDropdown","IconTypes","MORE","IconColors","PRIMARY","closeDropdown","CHANNEL_SETTING__LEAVE_CHANNEL__TITLE","LeaveChannelModal","propTypes","PropTypes","bool","func","isRequired","defaultProps"],"mappings":"
|
|
1
|
+
{"version":3,"file":"ChannelPreviewAction.js","sources":["../../../src/smart-components/ChannelList/components/LeaveChannel/index.tsx","../../../src/smart-components/ChannelList/components/ChannelPreviewAction.jsx"],"sourcesContent":["import React from 'react';\n\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport { noop } from '../../../../utils/utils';\n\nimport Modal from '../../../../ui/Modal';\nimport { useChannelListContext } from '../../context/ChannelListProvider';\n\nexport type LeaveChannelProps = {\n onSubmit: () => void;\n onCancel: () => void;\n}\n\nconst LeaveChannel: React.FC<LeaveChannelProps> = (props: LeaveChannelProps) => {\n const {\n onSubmit = noop,\n onCancel = noop,\n } = props;\n\n const channel = useChannelListContext()?.currentChannel;\n const state = useSendbirdStateContext();\n const logger = state?.config?.logger;\n const isOnline = state?.config?.isOnline;\n if (channel) {\n return (\n <Modal\n disabled={!isOnline}\n onCancel={onCancel}\n onSubmit={() => {\n logger.info('ChannelSettings: Leaving channel', channel);\n channel?.leave()\n .then(() => {\n logger.info('ChannelSettings: Leaving channel successful!', channel);\n onSubmit();\n });\n }}\n submitText=\"Leave\"\n titleText=\"Leave this channel?\"\n />\n );\n }\n};\n\nexport default LeaveChannel;\n","import React, {\n useState,\n useRef,\n useContext,\n} from 'react';\nimport PropTypes from 'prop-types';\n\nimport { LocalizationContext } from '../../../lib/LocalizationContext';\nimport ContextMenu, { MenuItem, MenuItems } from '../../../ui/ContextMenu';\nimport IconButton from '../../../ui/IconButton';\nimport Icon, { IconTypes, IconColors } from '../../../ui/Icon';\nimport LeaveChannelModal from './LeaveChannel';\n\nexport default function ChannelPreviewAction({ disabled, onLeaveChannel }) {\n const parentRef = useRef(null);\n const [showModal, setShowModal] = useState(false);\n const { stringSet } = useContext(LocalizationContext);\n\n return (\n <div\n role=\"button\"\n style={{ display: 'inline-block' }}\n onKeyDown={(e) => { e.stopPropagation(); }}\n tabIndex={0}\n onClick={(e) => { e.stopPropagation(); }}\n >\n <ContextMenu\n menuTrigger={(toggleDropdown) => (\n <IconButton\n ref={parentRef}\n onClick={toggleDropdown}\n height=\"32px\"\n width=\"32px\"\n >\n <Icon\n type={IconTypes.MORE}\n fillColor={IconColors.PRIMARY}\n width=\"24px\"\n height=\"24px\"\n />\n </IconButton>\n )}\n menuItems={(closeDropdown) => (\n <MenuItems\n parentRef={parentRef}\n parentContainRef={parentRef}\n closeDropdown={closeDropdown}\n >\n <MenuItem\n onClick={() => {\n if (disabled) { return; }\n setShowModal(true);\n closeDropdown();\n }}\n >\n {stringSet.CHANNEL_SETTING__LEAVE_CHANNEL__TITLE}\n </MenuItem>\n </MenuItems>\n )}\n />\n {\n showModal && (\n <LeaveChannelModal\n onSubmit={() => {\n setShowModal(false);\n onLeaveChannel();\n }}\n onCancel={() => setShowModal(false)}\n />\n )\n }\n </div>\n );\n}\n\nChannelPreviewAction.propTypes = {\n disabled: PropTypes.bool,\n onLeaveChannel: PropTypes.func.isRequired,\n};\n\nChannelPreviewAction.defaultProps = {\n disabled: false,\n};\n"],"names":["LeaveChannel","props","_d","onSubmit","noop","_e","onCancel","channel","useChannelListContext","currentChannel","state","useSendbirdStateContext","logger","config","isOnline","React","info","leave","then","ChannelPreviewAction","disabled","onLeaveChannel","parentRef","useRef","useState","showModal","setShowModal","useContext","LocalizationContext","stringSet","display","e","stopPropagation","toggleDropdown","IconTypes","MORE","IconColors","PRIMARY","closeDropdown","CHANNEL_SETTING__LEAVE_CHANNEL__TITLE","LeaveChannelModal","propTypes","PropTypes","bool","func","isRequired","defaultProps"],"mappings":"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"}
|
package/ChannelList/context.js
CHANGED
|
@@ -1,15 +1,17 @@
|
|
|
1
|
-
import '../tslib.es6-
|
|
1
|
+
import '../tslib.es6-c793443a.js';
|
|
2
2
|
import 'react';
|
|
3
|
-
import '../groupChannel-
|
|
4
|
-
export { C as ChannelListProvider, u as useChannelListContext } from '../ChannelListProvider-
|
|
5
|
-
import '../uuid-
|
|
6
|
-
import '../utils-
|
|
7
|
-
import '../UserProfileContext-
|
|
3
|
+
import '../groupChannel-fc842dca.js';
|
|
4
|
+
export { C as ChannelListProvider, u as useChannelListContext } from '../ChannelListProvider-bdac2e90.js';
|
|
5
|
+
import '../uuid-7c3f59a3.js';
|
|
6
|
+
import '../utils-b69f7583.js';
|
|
7
|
+
import '../UserProfileContext-3524e64c.js';
|
|
8
8
|
import '../useSendbirdStateContext.js';
|
|
9
|
-
import '../__bundle-
|
|
10
|
-
import '../
|
|
11
|
-
import '../
|
|
12
|
-
import '../
|
|
9
|
+
import '../__bundle-6316ce22-b659cee1.js';
|
|
10
|
+
import '../__bundle-fbda47dd-ef31252f.js';
|
|
11
|
+
import '../__bundle-7dfccc8c-37d3f8ab.js';
|
|
12
|
+
import '../topics-71b67878.js';
|
|
13
|
+
import '../_rollupPluginBabelHelpers-30d122aa.js';
|
|
14
|
+
import '../index-65007eeb.js';
|
|
13
15
|
import 'prop-types';
|
|
14
16
|
import '../withSendbird.js';
|
|
15
17
|
//# sourceMappingURL=context.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"context.js","sources":[],"sourcesContent":[],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"context.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;"}
|
package/ChannelList.js
CHANGED
|
@@ -1,23 +1,25 @@
|
|
|
1
1
|
import React__default from 'react';
|
|
2
|
-
import { C as ChannelListProvider } from './ChannelListProvider-
|
|
2
|
+
import { C as ChannelListProvider } from './ChannelListProvider-bdac2e90.js';
|
|
3
3
|
import ChannelListUI from './ChannelList/components/ChannelListUI.js';
|
|
4
|
-
import './tslib.es6-
|
|
5
|
-
import './groupChannel-
|
|
6
|
-
import './__bundle-
|
|
7
|
-
import './
|
|
8
|
-
import './
|
|
9
|
-
import './
|
|
10
|
-
import './
|
|
4
|
+
import './tslib.es6-c793443a.js';
|
|
5
|
+
import './groupChannel-fc842dca.js';
|
|
6
|
+
import './__bundle-6316ce22-b659cee1.js';
|
|
7
|
+
import './__bundle-fbda47dd-ef31252f.js';
|
|
8
|
+
import './__bundle-7dfccc8c-37d3f8ab.js';
|
|
9
|
+
import './topics-71b67878.js';
|
|
10
|
+
import './uuid-7c3f59a3.js';
|
|
11
|
+
import './utils-b69f7583.js';
|
|
12
|
+
import './UserProfileContext-3524e64c.js';
|
|
11
13
|
import 'prop-types';
|
|
12
14
|
import './useSendbirdStateContext.js';
|
|
13
15
|
import './withSendbird.js';
|
|
14
|
-
import './_rollupPluginBabelHelpers-
|
|
15
|
-
import './index-
|
|
16
|
+
import './_rollupPluginBabelHelpers-30d122aa.js';
|
|
17
|
+
import './index-65007eeb.js';
|
|
16
18
|
import './ChannelList/components/ChannelListHeader.js';
|
|
17
|
-
import './LocalizationContext-
|
|
18
|
-
import './stringSet-
|
|
19
|
-
import './index-
|
|
20
|
-
import './index-
|
|
19
|
+
import './LocalizationContext-61a4a931.js';
|
|
20
|
+
import './stringSet-92f53c6e.js';
|
|
21
|
+
import './index-191d1d43.js';
|
|
22
|
+
import './index-07cd4778.js';
|
|
21
23
|
import './ui/IconButton.js';
|
|
22
24
|
import './ui/Avatar.js';
|
|
23
25
|
import './ui/ImageRenderer.js';
|
|
@@ -25,13 +27,13 @@ import './ui/Icon.js';
|
|
|
25
27
|
import './ChannelList/components/AddChannel.js';
|
|
26
28
|
import './CreateChannel.js';
|
|
27
29
|
import './CreateChannel/components/CreateChannelUI.js';
|
|
28
|
-
import './CreateChannelProvider-
|
|
30
|
+
import './CreateChannelProvider-1cf4ef27.js';
|
|
29
31
|
import './sendbirdSelectors.js';
|
|
30
32
|
import './CreateChannel/components/InviteUsers.js';
|
|
31
33
|
import './ui/Modal.js';
|
|
32
34
|
import 'react-dom';
|
|
33
|
-
import './index-
|
|
34
|
-
import './index-
|
|
35
|
+
import './index-42b2527f.js';
|
|
36
|
+
import './index-d3358aa9.js';
|
|
35
37
|
import './ui/UserListItem.js';
|
|
36
38
|
import './ui/MutedAvatarOverlay.js';
|
|
37
39
|
import './ui/Checkbox.js';
|
|
@@ -41,27 +43,27 @@ import './ui/SortByRow.js';
|
|
|
41
43
|
import './CreateChannel/components/SelectChannelType.js';
|
|
42
44
|
import './ChannelList/components/ChannelPreview.js';
|
|
43
45
|
import './ui/ChannelAvatar.js';
|
|
44
|
-
import './utils-
|
|
46
|
+
import './utils-b37c6db3.js';
|
|
45
47
|
import './ui/Badge.js';
|
|
46
|
-
import './index-
|
|
47
|
-
import './index-
|
|
48
|
-
import './index-
|
|
48
|
+
import './index-b1f9e3f9.js';
|
|
49
|
+
import './index-5428ab4f.js';
|
|
50
|
+
import './index-aa2d32cc.js';
|
|
49
51
|
import './ui/MentionUserLabel.js';
|
|
50
52
|
import './Channel/components/TypingIndicator.js';
|
|
51
|
-
import './ChannelProvider-
|
|
52
|
-
import './compareIds-
|
|
53
|
-
import './const-
|
|
53
|
+
import './ChannelProvider-0174d0f3.js';
|
|
54
|
+
import './compareIds-8402fa74.js';
|
|
55
|
+
import './const-9039e539.js';
|
|
54
56
|
import './ui/ReactionButton.js';
|
|
55
57
|
import './ui/MessageStatus.js';
|
|
56
58
|
import './ui/Loader.js';
|
|
57
59
|
import './ChannelList/components/ChannelPreviewAction.js';
|
|
58
60
|
import './EditUserProfile.js';
|
|
59
|
-
import './index-
|
|
61
|
+
import './index-17024830.js';
|
|
60
62
|
import './ui/Input.js';
|
|
61
63
|
import './ui/TextButton.js';
|
|
62
|
-
import './color-
|
|
63
|
-
import './actionTypes-
|
|
64
|
-
import './index-
|
|
64
|
+
import './color-f6548425.js';
|
|
65
|
+
import './actionTypes-d5d5ac7b.js';
|
|
66
|
+
import './index-2034978f.js';
|
|
65
67
|
|
|
66
68
|
var ChannelList = function ChannelList(props) {
|
|
67
69
|
return /*#__PURE__*/React__default.createElement(ChannelListProvider, {
|
package/ChannelList.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ChannelList.js","sources":["../src/smart-components/ChannelList/index.tsx"],"sourcesContent":["import React from 'react';\nimport {\n ChannelListProvider,\n ChannelListProviderProps,\n} from './context/ChannelListProvider';\n\nimport ChannelListUI, { ChannelListUIProps } from './components/ChannelListUI';\n\ninterface ChannelListProps extends ChannelListProviderProps, ChannelListUIProps {}\n\nconst ChannelList: React.FC<ChannelListProps> = (props: ChannelListProps) => {\n return (\n <ChannelListProvider\n className={props?.className}\n disableUserProfile={props?.disableUserProfile}\n allowProfileEdit={props?.allowProfileEdit}\n onBeforeCreateChannel={props?.onBeforeCreateChannel}\n onThemeChange={props?.onThemeChange}\n onProfileEditSuccess={props?.onProfileEditSuccess}\n onChannelSelect={props?.onChannelSelect}\n sortChannelList={props?.sortChannelList}\n queries={props?.queries}\n disableAutoSelect={props?.disableAutoSelect}\n isTypingIndicatorEnabled={props?.isTypingIndicatorEnabled}\n isMessageReceiptStatusEnabled={props?.isMessageReceiptStatusEnabled}\n >\n <ChannelListUI\n renderChannelPreview={props?.renderChannelPreview}\n renderUserProfile={props?.renderUserProfile}\n renderHeader={props?.renderHeader}\n renderPlaceHolderEmptyList={props?.renderPlaceHolderEmptyList}\n renderPlaceHolderError={props?.renderPlaceHolderError}\n renderPlaceHolderLoading={props?.renderPlaceHolderLoading}\n />\n </ChannelListProvider>\n );\n}\n\nexport default ChannelList;\n"],"names":["ChannelList","props","React","className","disableUserProfile","allowProfileEdit","onBeforeCreateChannel","onThemeChange","onProfileEditSuccess","onChannelSelect","sortChannelList","queries","disableAutoSelect","isTypingIndicatorEnabled","isMessageReceiptStatusEnabled","renderChannelPreview","renderUserProfile","renderHeader","renderPlaceHolderEmptyList","renderPlaceHolderError","renderPlaceHolderLoading"],"mappings":"
|
|
1
|
+
{"version":3,"file":"ChannelList.js","sources":["../src/smart-components/ChannelList/index.tsx"],"sourcesContent":["import React from 'react';\nimport {\n ChannelListProvider,\n ChannelListProviderProps,\n} from './context/ChannelListProvider';\n\nimport ChannelListUI, { ChannelListUIProps } from './components/ChannelListUI';\n\ninterface ChannelListProps extends ChannelListProviderProps, ChannelListUIProps {}\n\nconst ChannelList: React.FC<ChannelListProps> = (props: ChannelListProps) => {\n return (\n <ChannelListProvider\n className={props?.className}\n disableUserProfile={props?.disableUserProfile}\n allowProfileEdit={props?.allowProfileEdit}\n onBeforeCreateChannel={props?.onBeforeCreateChannel}\n onThemeChange={props?.onThemeChange}\n onProfileEditSuccess={props?.onProfileEditSuccess}\n onChannelSelect={props?.onChannelSelect}\n sortChannelList={props?.sortChannelList}\n queries={props?.queries}\n disableAutoSelect={props?.disableAutoSelect}\n isTypingIndicatorEnabled={props?.isTypingIndicatorEnabled}\n isMessageReceiptStatusEnabled={props?.isMessageReceiptStatusEnabled}\n >\n <ChannelListUI\n renderChannelPreview={props?.renderChannelPreview}\n renderUserProfile={props?.renderUserProfile}\n renderHeader={props?.renderHeader}\n renderPlaceHolderEmptyList={props?.renderPlaceHolderEmptyList}\n renderPlaceHolderError={props?.renderPlaceHolderError}\n renderPlaceHolderLoading={props?.renderPlaceHolderLoading}\n />\n </ChannelListProvider>\n );\n}\n\nexport default ChannelList;\n"],"names":["ChannelList","props","React","className","disableUserProfile","allowProfileEdit","onBeforeCreateChannel","onThemeChange","onProfileEditSuccess","onChannelSelect","sortChannelList","queries","disableAutoSelect","isTypingIndicatorEnabled","isMessageReceiptStatusEnabled","renderChannelPreview","renderUserProfile","renderHeader","renderPlaceHolderEmptyList","renderPlaceHolderError","renderPlaceHolderLoading"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAUMA,WAAW,GAA+B,SAA1CA,WAA0C,CAACC,KAAD;AAC9C,sBACEC,6BAAC,mBAAD;AACE,IAAA,SAAS,EAAED,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEE,SADpB;AAEE,IAAA,kBAAkB,EAAEF,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEG,kBAF7B;AAGE,IAAA,gBAAgB,EAAEH,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEI,gBAH3B;AAIE,IAAA,qBAAqB,EAAEJ,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEK,qBAJhC;AAKE,IAAA,aAAa,EAAEL,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEM,aALxB;AAME,IAAA,oBAAoB,EAAEN,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEO,oBAN/B;AAOE,IAAA,eAAe,EAAEP,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEQ,eAP1B;AAQE,IAAA,eAAe,EAAER,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAES,eAR1B;AASE,IAAA,OAAO,EAAET,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEU,OATlB;AAUE,IAAA,iBAAiB,EAAEV,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEW,iBAV5B;AAWE,IAAA,wBAAwB,EAAEX,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEY,wBAXnC;AAYE,IAAA,6BAA6B,EAAEZ,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEa;AAZxC,kBAcEZ,6BAAC,aAAD;AACE,IAAA,oBAAoB,EAAED,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEc,oBAD/B;AAEE,IAAA,iBAAiB,EAAEd,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEe,iBAF5B;AAGE,IAAA,YAAY,EAAEf,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEgB,YAHvB;AAIE,IAAA,0BAA0B,EAAEhB,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEiB,0BAJrC;AAKE,IAAA,sBAAsB,EAAEjB,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEkB,sBALjC;AAME,IAAA,wBAAwB,EAAElB,KAAK,SAAL,IAAAA,KAAK,WAAL,SAAA,GAAAA,KAAK,CAAEmB;AANnC,IAdF,CADF;AAyBD;;;;"}
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
import { a as __spreadArray, _ as __assign } from './tslib.es6-
|
|
1
|
+
import { a as __spreadArray, _ as __assign } from './tslib.es6-c793443a.js';
|
|
2
2
|
import React__default, { useReducer, useState, useEffect, useMemo, useContext } from 'react';
|
|
3
|
-
import { Y as Yr } from './groupChannel-
|
|
4
|
-
import { C as CREATE_CHANNEL$1, U as UPDATE_USER_MESSAGE, L as LEAVE_CHANNEL, S as SEND_MESSAGE_START } from './topics-
|
|
5
|
-
import { u as uuidv4 } from './uuid-
|
|
6
|
-
import { n as noop } from './utils-
|
|
7
|
-
import { U as UserProfileProvider } from './UserProfileContext-
|
|
3
|
+
import { Y as Yr } from './groupChannel-fc842dca.js';
|
|
4
|
+
import { C as CREATE_CHANNEL$1, U as UPDATE_USER_MESSAGE, L as LEAVE_CHANNEL, S as SEND_MESSAGE_START } from './topics-71b67878.js';
|
|
5
|
+
import { u as uuidv4 } from './uuid-7c3f59a3.js';
|
|
6
|
+
import { n as noop } from './utils-b69f7583.js';
|
|
7
|
+
import { U as UserProfileProvider } from './UserProfileContext-3524e64c.js';
|
|
8
8
|
import useSendbirdStateContext from './useSendbirdStateContext.js';
|
|
9
|
-
import { _ as _objectSpread2, b as _toConsumableArray } from './_rollupPluginBabelHelpers-
|
|
10
|
-
import { f as filterChannelListParams, g as getChannelsWithUpsertedChannel } from './index-
|
|
9
|
+
import { _ as _objectSpread2, b as _toConsumableArray } from './_rollupPluginBabelHelpers-30d122aa.js';
|
|
10
|
+
import { f as filterChannelListParams, g as getChannelsWithUpsertedChannel } from './index-65007eeb.js';
|
|
11
11
|
|
|
12
12
|
var RESET_CHANNEL_LIST = 'RESET_CHANNEL_LIST';
|
|
13
13
|
var CREATE_CHANNEL = 'CREATE_CHANNEL';
|
|
@@ -951,4 +951,4 @@ function useChannelListContext() {
|
|
|
951
951
|
}
|
|
952
952
|
|
|
953
953
|
export { ChannelListProvider as C, FETCH_CHANNELS_START as F, LEAVE_CHANNEL_SUCCESS as L, SET_CURRENT_CHANNEL as S, FETCH_CHANNELS_SUCCESS as a, FETCH_CHANNELS_FAILURE as b, useChannelListContext as u };
|
|
954
|
-
//# sourceMappingURL=ChannelListProvider-
|
|
954
|
+
//# sourceMappingURL=ChannelListProvider-bdac2e90.js.map
|