@sendbird/uikit-react 3.2.0-rc.0 → 3.2.0-rc.2
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 +85 -93
- package/App.js.map +1 -1
- package/CHANGELOG.md +1 -1
- package/Channel/components/ChannelHeader.js +21 -19
- package/Channel/components/ChannelHeader.js.map +1 -1
- package/Channel/components/ChannelUI.js +29 -26
- package/Channel/components/ChannelUI.js.map +1 -1
- package/Channel/components/FileViewer.js +22 -20
- package/Channel/components/FileViewer.js.map +1 -1
- package/Channel/components/FrozenNotification.js +5 -6
- package/Channel/components/FrozenNotification.js.map +1 -1
- package/Channel/components/Message.js +35 -32
- package/Channel/components/Message.js.map +1 -1
- package/Channel/components/MessageInput.js +33 -30
- package/Channel/components/MessageInput.js.map +1 -1
- package/Channel/components/MessageList.js +29 -26
- 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 +36 -34
- package/Channel/components/SuggestedMentionList.js.map +1 -1
- package/Channel/components/TypingIndicator.js +21 -19
- package/Channel/components/TypingIndicator.js.map +1 -1
- package/Channel/components/UnreadCount.js +5 -6
- package/Channel/components/UnreadCount.js.map +1 -1
- package/Channel/context.js +17 -15
- package/Channel/context.js.map +1 -1
- package/Channel.js +27 -24
- package/Channel.js.map +1 -1
- package/ChannelList/components/AddChannel.js +17 -17
- package/ChannelList/components/AddChannel.js.map +1 -1
- package/ChannelList/components/ChannelListHeader.js +10 -10
- package/ChannelList/components/ChannelListHeader.js.map +1 -1
- package/ChannelList/components/ChannelListUI.js +41 -39
- package/ChannelList/components/ChannelListUI.js.map +1 -1
- package/ChannelList/components/ChannelPreview.js +50 -48
- package/ChannelList/components/ChannelPreview.js.map +1 -1
- package/ChannelList/components/ChannelPreviewAction.js +59 -68
- 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-6e3b8f43.js → ChannelListProvider-1a22e404.js} +232 -216
- package/ChannelListProvider-1a22e404.js.map +1 -0
- package/{ChannelProvider-b8c6427f.js → ChannelProvider-e38bb434.js} +554 -521
- package/{ChannelProvider-b8c6427f.js.map → ChannelProvider-e38bb434.js.map} +1 -1
- package/ChannelSettings/components/ChannelProfile.js +16 -16
- package/ChannelSettings/components/ChannelProfile.js.map +1 -1
- package/ChannelSettings/components/ChannelSettingsUI.js +28 -26
- package/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
- package/ChannelSettings/components/EditDetailsModal.js +19 -21
- package/ChannelSettings/components/EditDetailsModal.js.map +1 -1
- package/ChannelSettings/components/LeaveChannel.js +14 -16
- package/ChannelSettings/components/LeaveChannel.js.map +1 -1
- package/ChannelSettings/components/ModerationPanel.js +79 -77
- package/ChannelSettings/components/ModerationPanel.js.map +1 -1
- package/ChannelSettings/components/UserListItem.js +15 -15
- package/ChannelSettings/components/UserListItem.js.map +1 -1
- package/ChannelSettings/components/UserPanel.js +17 -17
- package/ChannelSettings/components/UserPanel.js.map +1 -1
- package/ChannelSettings/context.js +6 -6
- package/ChannelSettings/context.js.map +1 -1
- package/ChannelSettings.js +22 -20
- package/ChannelSettings.js.map +1 -1
- package/CreateChannel/components/CreateChannelUI.js +18 -19
- package/CreateChannel/components/CreateChannelUI.js.map +1 -1
- package/CreateChannel/components/InviteUsers.js +21 -20
- package/CreateChannel/components/InviteUsers.js.map +1 -1
- package/CreateChannel/components/SelectChannelType.js +22 -22
- package/CreateChannel/components/SelectChannelType.js.map +1 -1
- package/CreateChannel/context.js +4 -4
- package/CreateChannel.js +14 -14
- package/CreateChannel.js.map +1 -1
- package/{CreateChannelProvider-712526fd.js → CreateChannelProvider-f740e1f0.js} +3 -3
- package/{CreateChannelProvider-712526fd.js.map → CreateChannelProvider-f740e1f0.js.map} +1 -1
- package/CreateOpenChannel/components/CreateOpenChannelUI.js +13 -13
- package/CreateOpenChannel/components/CreateOpenChannelUI.js.map +1 -1
- package/CreateOpenChannel/context.js +11 -11
- package/CreateOpenChannel/context.js.map +1 -1
- package/CreateOpenChannel.js +9 -9
- package/CreateOpenChannel.js.map +1 -1
- package/EditUserProfile/components/EditUserProfileUI.js +12 -12
- package/EditUserProfile/context.js +13 -13
- package/EditUserProfile/context.js.map +1 -1
- package/EditUserProfile.js +13 -13
- package/EditUserProfile.js.map +1 -1
- package/{LocalizationContext-4cefc770.js → LocalizationContext-78d3faa4.js} +5 -5
- package/{LocalizationContext-4cefc770.js.map → LocalizationContext-78d3faa4.js.map} +1 -1
- package/{MemberList-e4916e55.js → MemberList-057e2466.js} +34 -34
- package/{MemberList-e4916e55.js.map → MemberList-057e2466.js.map} +1 -1
- package/MessageSearch/components/MessageSearchUI.js +17 -17
- package/MessageSearch/components/MessageSearchUI.js.map +1 -1
- package/MessageSearch/context.js +6 -6
- package/MessageSearch/context.js.map +1 -1
- package/MessageSearch.js +14 -14
- package/MessageSearch.js.map +1 -1
- package/OpenChannel/components/FrozenChannelNotification.js +5 -6
- package/OpenChannel/components/FrozenChannelNotification.js.map +1 -1
- package/OpenChannel/components/OpenChannelHeader.js +17 -15
- package/OpenChannel/components/OpenChannelHeader.js.map +1 -1
- package/OpenChannel/components/OpenChannelInput.js +22 -19
- package/OpenChannel/components/OpenChannelInput.js.map +1 -1
- package/OpenChannel/components/OpenChannelMessage.js +35 -32
- package/OpenChannel/components/OpenChannelMessage.js.map +1 -1
- package/OpenChannel/components/OpenChannelMessageList.js +30 -27
- package/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
- package/OpenChannel/components/OpenChannelUI.js +29 -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 +29 -26
- package/OpenChannel.js.map +1 -1
- package/OpenChannelList/components/OpenChannelListUI.js +19 -19
- package/OpenChannelList/components/OpenChannelListUI.js.map +1 -1
- package/OpenChannelList/components/OpenChannelPreview.js +5 -6
- package/OpenChannelList/components/OpenChannelPreview.js.map +1 -1
- package/OpenChannelList/context.js +4 -4
- package/OpenChannelList.js +12 -12
- package/OpenChannelList.js.map +1 -1
- package/{OpenChannelListProvider-845a2162.js → OpenChannelListProvider-4bddc69f.js} +4 -4
- package/{OpenChannelListProvider-845a2162.js.map → OpenChannelListProvider-4bddc69f.js.map} +1 -1
- package/{OpenChannelProvider-5f19d5d7.js → OpenChannelProvider-bb348405.js} +49 -48
- package/{OpenChannelProvider-5f19d5d7.js.map → OpenChannelProvider-bb348405.js.map} +1 -1
- package/OpenChannelSettings/components/EditDetailsModal.js +20 -19
- package/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
- package/OpenChannelSettings/components/OpenChannelProfile.js +17 -16
- package/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
- package/OpenChannelSettings/components/OpenChannelSettingsUI.js +28 -27
- package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
- package/OpenChannelSettings/components/OperatorUI.js +88 -87
- package/OpenChannelSettings/components/OperatorUI.js.map +1 -1
- package/OpenChannelSettings/components/ParticipantUI.js +17 -16
- package/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
- package/OpenChannelSettings/context.js +15 -14
- package/OpenChannelSettings/context.js.map +1 -1
- package/OpenChannelSettings.js +21 -20
- package/OpenChannelSettings.js.map +1 -1
- package/README.md +2 -7
- package/SendbirdProvider.js +216 -251
- package/SendbirdProvider.js.map +1 -1
- package/{UserProfileContext-2e53d03a.js → UserProfileContext-bc040e78.js} +6 -4
- package/{UserProfileContext-2e53d03a.js.map → UserProfileContext-bc040e78.js.map} +1 -1
- package/__bundle-0dad34cd-6408fa97.js +6 -0
- package/__bundle-0dad34cd-6408fa97.js.map +1 -0
- package/__bundle-57e0c5af-dff5d7e0.js +6 -0
- package/__bundle-57e0c5af-dff5d7e0.js.map +1 -0
- package/__bundle-bd072f34-80eb9bbc.js +6 -0
- package/__bundle-bd072f34-80eb9bbc.js.map +1 -0
- package/_rollupPluginBabelHelpers-64f3f48c.js +43 -0
- package/_rollupPluginBabelHelpers-64f3f48c.js.map +1 -0
- package/actionTypes-fb6947e7.js +6 -0
- package/{actionTypes-517789b8.js.map → actionTypes-fb6947e7.js.map} +1 -1
- package/cjs/App.js +85 -93
- package/cjs/App.js.map +1 -1
- package/cjs/Channel/components/ChannelHeader.js +21 -19
- package/cjs/Channel/components/ChannelHeader.js.map +1 -1
- package/cjs/Channel/components/ChannelUI.js +29 -26
- package/cjs/Channel/components/ChannelUI.js.map +1 -1
- package/cjs/Channel/components/FileViewer.js +22 -20
- package/cjs/Channel/components/FileViewer.js.map +1 -1
- package/cjs/Channel/components/FrozenNotification.js +5 -6
- package/cjs/Channel/components/FrozenNotification.js.map +1 -1
- package/cjs/Channel/components/Message.js +35 -32
- package/cjs/Channel/components/Message.js.map +1 -1
- package/cjs/Channel/components/MessageInput.js +33 -30
- package/cjs/Channel/components/MessageInput.js.map +1 -1
- package/cjs/Channel/components/MessageList.js +29 -26
- 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 +36 -34
- package/cjs/Channel/components/SuggestedMentionList.js.map +1 -1
- package/cjs/Channel/components/TypingIndicator.js +21 -19
- package/cjs/Channel/components/TypingIndicator.js.map +1 -1
- package/cjs/Channel/components/UnreadCount.js +5 -6
- package/cjs/Channel/components/UnreadCount.js.map +1 -1
- package/cjs/Channel/context.js +17 -15
- package/cjs/Channel/context.js.map +1 -1
- package/cjs/Channel.js +27 -24
- package/cjs/Channel.js.map +1 -1
- package/cjs/ChannelList/components/AddChannel.js +17 -17
- package/cjs/ChannelList/components/AddChannel.js.map +1 -1
- package/cjs/ChannelList/components/ChannelListHeader.js +10 -10
- package/cjs/ChannelList/components/ChannelListHeader.js.map +1 -1
- package/cjs/ChannelList/components/ChannelListUI.js +41 -39
- package/cjs/ChannelList/components/ChannelListUI.js.map +1 -1
- package/cjs/ChannelList/components/ChannelPreview.js +50 -48
- package/cjs/ChannelList/components/ChannelPreview.js.map +1 -1
- package/cjs/ChannelList/components/ChannelPreviewAction.js +59 -68
- 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-781aa186.js → ChannelListProvider-852ab5ee.js} +231 -215
- package/cjs/ChannelListProvider-852ab5ee.js.map +1 -0
- package/cjs/{ChannelProvider-bbff4ae8.js → ChannelProvider-177cb9c3.js} +558 -525
- package/cjs/{ChannelProvider-bbff4ae8.js.map → ChannelProvider-177cb9c3.js.map} +1 -1
- package/cjs/ChannelSettings/components/ChannelProfile.js +16 -16
- package/cjs/ChannelSettings/components/ChannelProfile.js.map +1 -1
- package/cjs/ChannelSettings/components/ChannelSettingsUI.js +28 -26
- package/cjs/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
- package/cjs/ChannelSettings/components/EditDetailsModal.js +19 -21
- package/cjs/ChannelSettings/components/EditDetailsModal.js.map +1 -1
- package/cjs/ChannelSettings/components/LeaveChannel.js +14 -16
- package/cjs/ChannelSettings/components/LeaveChannel.js.map +1 -1
- package/cjs/ChannelSettings/components/ModerationPanel.js +79 -77
- package/cjs/ChannelSettings/components/ModerationPanel.js.map +1 -1
- package/cjs/ChannelSettings/components/UserListItem.js +15 -15
- package/cjs/ChannelSettings/components/UserListItem.js.map +1 -1
- package/cjs/ChannelSettings/components/UserPanel.js +17 -17
- package/cjs/ChannelSettings/components/UserPanel.js.map +1 -1
- package/cjs/ChannelSettings/context.js +6 -6
- package/cjs/ChannelSettings/context.js.map +1 -1
- package/cjs/ChannelSettings.js +22 -20
- package/cjs/ChannelSettings.js.map +1 -1
- package/cjs/CreateChannel/components/CreateChannelUI.js +18 -19
- package/cjs/CreateChannel/components/CreateChannelUI.js.map +1 -1
- package/cjs/CreateChannel/components/InviteUsers.js +21 -20
- package/cjs/CreateChannel/components/InviteUsers.js.map +1 -1
- package/cjs/CreateChannel/components/SelectChannelType.js +22 -22
- package/cjs/CreateChannel/components/SelectChannelType.js.map +1 -1
- package/cjs/CreateChannel/context.js +4 -4
- package/cjs/CreateChannel.js +14 -14
- package/cjs/CreateChannel.js.map +1 -1
- package/cjs/{CreateChannelProvider-80c88bba.js → CreateChannelProvider-ce623553.js} +3 -3
- package/cjs/{CreateChannelProvider-80c88bba.js.map → CreateChannelProvider-ce623553.js.map} +1 -1
- package/cjs/CreateOpenChannel/components/CreateOpenChannelUI.js +13 -13
- package/cjs/CreateOpenChannel/components/CreateOpenChannelUI.js.map +1 -1
- package/cjs/CreateOpenChannel/context.js +11 -11
- package/cjs/CreateOpenChannel/context.js.map +1 -1
- package/cjs/CreateOpenChannel.js +9 -9
- package/cjs/CreateOpenChannel.js.map +1 -1
- package/cjs/EditUserProfile/components/EditUserProfileUI.js +12 -12
- package/cjs/EditUserProfile/context.js +14 -14
- package/cjs/EditUserProfile/context.js.map +1 -1
- package/cjs/EditUserProfile.js +13 -13
- package/cjs/EditUserProfile.js.map +1 -1
- package/cjs/{LocalizationContext-b5fd4c38.js → LocalizationContext-bde4de59.js} +5 -5
- package/cjs/{LocalizationContext-b5fd4c38.js.map → LocalizationContext-bde4de59.js.map} +1 -1
- package/cjs/{MemberList-10def668.js → MemberList-5f6eaac3.js} +34 -34
- package/cjs/{MemberList-10def668.js.map → MemberList-5f6eaac3.js.map} +1 -1
- package/cjs/MessageSearch/components/MessageSearchUI.js +17 -17
- package/cjs/MessageSearch/components/MessageSearchUI.js.map +1 -1
- package/cjs/MessageSearch/context.js +6 -6
- package/cjs/MessageSearch/context.js.map +1 -1
- package/cjs/MessageSearch.js +14 -14
- package/cjs/MessageSearch.js.map +1 -1
- package/cjs/OpenChannel/components/FrozenChannelNotification.js +5 -6
- package/cjs/OpenChannel/components/FrozenChannelNotification.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelHeader.js +17 -15
- package/cjs/OpenChannel/components/OpenChannelHeader.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelInput.js +22 -19
- package/cjs/OpenChannel/components/OpenChannelInput.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelMessage.js +35 -32
- package/cjs/OpenChannel/components/OpenChannelMessage.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelMessageList.js +30 -27
- package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelUI.js +29 -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 +29 -26
- package/cjs/OpenChannel.js.map +1 -1
- package/cjs/OpenChannelList/components/OpenChannelListUI.js +19 -19
- package/cjs/OpenChannelList/components/OpenChannelListUI.js.map +1 -1
- package/cjs/OpenChannelList/components/OpenChannelPreview.js +5 -6
- package/cjs/OpenChannelList/components/OpenChannelPreview.js.map +1 -1
- package/cjs/OpenChannelList/context.js +4 -4
- package/cjs/OpenChannelList.js +12 -12
- package/cjs/OpenChannelList.js.map +1 -1
- package/cjs/{OpenChannelListProvider-8e425873.js → OpenChannelListProvider-26a67118.js} +4 -4
- package/cjs/{OpenChannelListProvider-8e425873.js.map → OpenChannelListProvider-26a67118.js.map} +1 -1
- package/cjs/{OpenChannelProvider-39f9e794.js → OpenChannelProvider-8a6ad3db.js} +49 -48
- package/cjs/{OpenChannelProvider-39f9e794.js.map → OpenChannelProvider-8a6ad3db.js.map} +1 -1
- package/cjs/OpenChannelSettings/components/EditDetailsModal.js +20 -19
- package/cjs/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
- package/cjs/OpenChannelSettings/components/OpenChannelProfile.js +17 -16
- package/cjs/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
- package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js +28 -27
- package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
- package/cjs/OpenChannelSettings/components/OperatorUI.js +88 -87
- package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -1
- package/cjs/OpenChannelSettings/components/ParticipantUI.js +17 -16
- package/cjs/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
- package/cjs/OpenChannelSettings/context.js +15 -14
- 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 +215 -251
- package/cjs/SendbirdProvider.js.map +1 -1
- package/cjs/{UserProfileContext-69c9649a.js → UserProfileContext-21660049.js} +6 -4
- package/cjs/{UserProfileContext-69c9649a.js.map → UserProfileContext-21660049.js.map} +1 -1
- package/cjs/__bundle-0dad34cd-794417d3.js +33 -0
- package/cjs/__bundle-0dad34cd-794417d3.js.map +1 -0
- package/cjs/__bundle-57e0c5af-c2950cb7.js +113 -0
- package/cjs/__bundle-57e0c5af-c2950cb7.js.map +1 -0
- package/cjs/__bundle-bd072f34-444fbfec.js +15 -0
- package/cjs/__bundle-bd072f34-444fbfec.js.map +1 -0
- package/cjs/_rollupPluginBabelHelpers-17f5a2c8.js +45 -0
- package/cjs/_rollupPluginBabelHelpers-17f5a2c8.js.map +1 -0
- package/cjs/actionTypes-76c446b3.js +10 -0
- package/cjs/{actionTypes-17aa0989.js.map → actionTypes-76c446b3.js.map} +1 -1
- package/cjs/{color-9e293baf.js → color-1ec1269a.js} +2 -2
- package/cjs/color-1ec1269a.js.map +1 -0
- package/cjs/compareIds-52f07bab.js +18 -0
- package/cjs/compareIds-52f07bab.js.map +1 -0
- package/cjs/{const-17108318.js → const-00ec2acd.js} +1 -1
- package/cjs/const-00ec2acd.js.map +1 -0
- package/cjs/{const-955190c4.js → const-b94ba65d.js} +1 -1
- package/cjs/{const-955190c4.js.map → const-b94ba65d.js.map} +1 -1
- package/cjs/{context-e041c8e0.js → context-3df5068b.js} +2 -2
- package/cjs/{context-e041c8e0.js.map → context-3df5068b.js.map} +1 -1
- package/cjs/dist/index.css +4657 -3676
- package/cjs/dist/index.css.map +1 -1
- package/cjs/groupChannel-da9ec10a.js +11 -0
- package/cjs/groupChannel-da9ec10a.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/SessionHandler.js +4 -2
- package/cjs/handlers/SessionHandler.js.map +1 -1
- package/cjs/handlers/UserEventHandler.js +4 -2
- package/cjs/handlers/UserEventHandler.js.map +1 -1
- package/cjs/{index-c1697faa.js → index-06b2ea54.js} +299 -319
- package/cjs/index-06b2ea54.js.map +1 -0
- package/cjs/{index-9ce5e5a9.js → index-0c20bfa0.js} +18 -37
- package/cjs/index-0c20bfa0.js.map +1 -0
- package/cjs/{index-550f5039.js → index-216e0934.js} +2 -2
- package/cjs/{index-550f5039.js.map → index-216e0934.js.map} +1 -1
- package/cjs/{index-b9b8972b.js → index-339b2871.js} +14 -13
- package/cjs/{index-b9b8972b.js.map → index-339b2871.js.map} +1 -1
- package/cjs/{index-025aa556.js → index-386d6cc6.js} +13 -13
- package/cjs/{index-025aa556.js.map → index-386d6cc6.js.map} +1 -1
- package/cjs/{index-1512514f.js → index-4fedaa1a.js} +16 -14
- package/cjs/index-4fedaa1a.js.map +1 -0
- package/cjs/{index-5166a415.js → index-50fc77e8.js} +69 -80
- package/cjs/index-50fc77e8.js.map +1 -0
- package/cjs/{index-e9d96b00.js → index-66b53d56.js} +4 -4
- package/cjs/{index-e9d96b00.js.map → index-66b53d56.js.map} +1 -1
- package/cjs/{index-5e2b8c03.js → index-9daabdb8.js} +30 -30
- package/cjs/{index-5e2b8c03.js.map → index-9daabdb8.js.map} +1 -1
- package/cjs/{index-18b120dc.js → index-e4245c04.js} +51 -51
- package/cjs/index-e4245c04.js.map +1 -0
- package/cjs/index.js +39 -36
- package/cjs/index.js.map +1 -1
- package/cjs/openChannel-d4ad53b7.js +10 -0
- package/cjs/openChannel-d4ad53b7.js.map +1 -0
- package/cjs/{openChannelUtils-cffba1c0.js → openChannelUtils-b74500ad.js} +11 -11
- package/cjs/openChannelUtils-b74500ad.js.map +1 -0
- package/cjs/sendbird-cd9bbca0.js +12 -0
- package/cjs/sendbird-cd9bbca0.js.map +1 -0
- package/cjs/sendbirdSelectors.js +22 -22
- package/cjs/sendbirdSelectors.js.map +1 -1
- package/cjs/{stringSet-be457fd7.js → stringSet-edbf423b.js} +4 -4
- package/cjs/{stringSet-be457fd7.js.map → stringSet-edbf423b.js.map} +1 -1
- package/cjs/topics-c5662b44.js +22 -0
- package/cjs/{topics-58ec1c61.js.map → topics-c5662b44.js.map} +1 -1
- package/cjs/{tslib.es6-36205d81.js → tslib.es6-8c7aa47e.js} +2 -2
- package/cjs/tslib.es6-8c7aa47e.js.map +1 -0
- package/cjs/ui/Accordion.js +4 -5
- package/cjs/ui/Accordion.js.map +1 -1
- package/cjs/ui/AccordionGroup.js +2 -2
- package/cjs/ui/AccordionGroup.js.map +1 -1
- package/cjs/ui/AdminMessage.js +3 -4
- package/cjs/ui/AdminMessage.js.map +1 -1
- package/cjs/ui/Avatar.js +6 -7
- package/cjs/ui/Avatar.js.map +1 -1
- package/cjs/ui/Badge.js +5 -6
- package/cjs/ui/Badge.js.map +1 -1
- package/cjs/ui/Button.js +3 -4
- package/cjs/ui/Button.js.map +1 -1
- package/cjs/ui/ChannelAvatar.js +3 -4
- package/cjs/ui/ChannelAvatar.js.map +1 -1
- package/cjs/ui/Checkbox.js +1 -1
- package/cjs/ui/Checkbox.js.map +1 -1
- package/cjs/ui/ConnectionStatus.js +4 -5
- package/cjs/ui/ConnectionStatus.js.map +1 -1
- package/cjs/ui/ContextMenu.js +14 -15
- package/cjs/ui/ContextMenu.js.map +1 -1
- package/cjs/ui/DateSeparator.js +5 -6
- package/cjs/ui/DateSeparator.js.map +1 -1
- package/cjs/ui/EmojiReactions.js +13 -14
- package/cjs/ui/EmojiReactions.js.map +1 -1
- package/cjs/ui/FileMessageItemBody.js +6 -7
- package/cjs/ui/FileMessageItemBody.js.map +1 -1
- package/cjs/ui/FileViewer.js +11 -12
- package/cjs/ui/FileViewer.js.map +1 -1
- package/cjs/ui/Icon.js +74 -73
- package/cjs/ui/Icon.js.map +1 -1
- package/cjs/ui/IconButton.js +7 -7
- package/cjs/ui/IconButton.js.map +1 -1
- package/cjs/ui/ImageRenderer.js +8 -10
- package/cjs/ui/ImageRenderer.js.map +1 -1
- package/cjs/ui/Input.js +4 -5
- package/cjs/ui/Input.js.map +1 -1
- package/cjs/ui/Label.js +2 -3
- package/cjs/ui/Label.js.map +1 -1
- package/cjs/ui/LinkLabel.js +14 -13
- package/cjs/ui/LinkLabel.js.map +1 -1
- package/cjs/ui/Loader.js +1 -2
- package/cjs/ui/Loader.js.map +1 -1
- package/cjs/ui/MentionLabel.js +13 -13
- package/cjs/ui/MentionLabel.js.map +1 -1
- package/cjs/ui/MentionUserLabel.js.map +1 -1
- package/cjs/ui/MessageContent.js +19 -19
- package/cjs/ui/MessageContent.js.map +1 -1
- package/cjs/ui/MessageInput.js +178 -19889
- package/cjs/ui/MessageInput.js.map +1 -1
- package/cjs/ui/MessageItemMenu.js +17 -18
- package/cjs/ui/MessageItemMenu.js.map +1 -1
- package/cjs/ui/MessageItemReactionMenu.js +12 -13
- package/cjs/ui/MessageItemReactionMenu.js.map +1 -1
- package/cjs/ui/MessageSearchFileItem.js +13 -24
- package/cjs/ui/MessageSearchFileItem.js.map +1 -1
- package/cjs/ui/MessageSearchItem.js +12 -14
- package/cjs/ui/MessageSearchItem.js.map +1 -1
- package/cjs/ui/MessageStatus.js +7 -8
- package/cjs/ui/MessageStatus.js.map +1 -1
- package/cjs/ui/Modal.js +9 -10
- package/cjs/ui/Modal.js.map +1 -1
- package/cjs/ui/MutedAvatarOverlay.js +0 -1
- package/cjs/ui/MutedAvatarOverlay.js.map +1 -1
- package/cjs/ui/OGMessageItemBody.js +11 -11
- package/cjs/ui/OGMessageItemBody.js.map +1 -1
- package/cjs/ui/OpenChannelAdminMessage.js +3 -4
- package/cjs/ui/OpenChannelAdminMessage.js.map +1 -1
- package/cjs/ui/OpenChannelAvatar.js +6 -7
- package/cjs/ui/OpenChannelAvatar.js.map +1 -1
- package/cjs/ui/OpenchannelConversationHeader.js +6 -7
- package/cjs/ui/OpenchannelConversationHeader.js.map +1 -1
- package/cjs/ui/OpenchannelFileMessage.js +24 -24
- package/cjs/ui/OpenchannelFileMessage.js.map +1 -1
- package/cjs/ui/OpenchannelOGMessage.js +26 -26
- package/cjs/ui/OpenchannelOGMessage.js.map +1 -1
- package/cjs/ui/OpenchannelThumbnailMessage.js +26 -26
- package/cjs/ui/OpenchannelThumbnailMessage.js.map +1 -1
- package/cjs/ui/OpenchannelUserMessage.js +24 -24
- package/cjs/ui/OpenchannelUserMessage.js.map +1 -1
- package/cjs/ui/PlaceHolder.js +6 -7
- package/cjs/ui/PlaceHolder.js.map +1 -1
- package/cjs/ui/QuoteMessage.js +10 -11
- package/cjs/ui/QuoteMessage.js.map +1 -1
- package/cjs/ui/QuoteMessageInput.js +7 -8
- package/cjs/ui/QuoteMessageInput.js.map +1 -1
- package/cjs/ui/ReactionBadge.js +4 -5
- package/cjs/ui/ReactionBadge.js.map +1 -1
- package/cjs/ui/ReactionButton.js +6 -6
- package/cjs/ui/ReactionButton.js.map +1 -1
- package/cjs/ui/SortByRow.js +2 -2
- package/cjs/ui/SortByRow.js.map +1 -1
- package/cjs/ui/TextButton.js +8 -9
- package/cjs/ui/TextButton.js.map +1 -1
- package/cjs/ui/TextMessageItemBody.js +10 -10
- package/cjs/ui/TextMessageItemBody.js.map +1 -1
- package/cjs/ui/ThumbnailMessageItemBody.js +5 -6
- package/cjs/ui/ThumbnailMessageItemBody.js.map +1 -1
- package/cjs/ui/Tooltip.js +3 -4
- package/cjs/ui/Tooltip.js.map +1 -1
- package/cjs/ui/TooltipWrapper.js +5 -5
- package/cjs/ui/TooltipWrapper.js.map +1 -1
- package/cjs/ui/UnknownMessageItemBody.js +6 -7
- package/cjs/ui/UnknownMessageItemBody.js.map +1 -1
- package/cjs/ui/UserListItem.js +17 -17
- package/cjs/ui/UserListItem.js.map +1 -1
- package/cjs/ui/UserProfile.js +11 -11
- package/cjs/ui/UserProfile.js.map +1 -1
- package/cjs/ui/Word.js +15 -10
- package/cjs/ui/Word.js.map +1 -1
- package/cjs/useSendbirdStateContext.js +1 -1
- package/cjs/useSendbirdStateContext.js.map +1 -1
- package/cjs/utils-01f53796.js +6 -0
- package/cjs/{utils-09738454.js.map → utils-01f53796.js.map} +1 -1
- package/cjs/{utils-40fab371.js → utils-1dafbcbf.js} +2 -2
- package/cjs/{utils-40fab371.js.map → utils-1dafbcbf.js.map} +1 -1
- package/cjs/{utils-9419225c.js → utils-b6394fc0.js} +4 -4
- package/cjs/utils-b6394fc0.js.map +1 -0
- package/cjs/{uuid-edc908ea.js → uuid-0e8b271a.js} +2 -2
- package/cjs/{uuid-edc908ea.js.map → uuid-0e8b271a.js.map} +1 -1
- package/cjs/withSendbird.js +13 -15
- package/cjs/withSendbird.js.map +1 -1
- package/{color-402a36fd.js → color-25be65f3.js} +2 -2
- package/{color-402a36fd.js.map → color-25be65f3.js.map} +1 -1
- package/compareIds-3fb63c4f.js +16 -0
- package/compareIds-3fb63c4f.js.map +1 -0
- package/{const-768ef60e.js → const-32a10da6.js} +1 -1
- package/const-32a10da6.js.map +1 -0
- package/{const-6b428cb8.js → const-82d4c478.js} +1 -1
- package/{const-6b428cb8.js.map → const-82d4c478.js.map} +1 -1
- package/{context-bd92675f.js → context-352b7bd9.js} +2 -2
- package/{context-bd92675f.js.map → context-352b7bd9.js.map} +1 -1
- package/dist/index.css +4657 -3676
- package/dist/index.css.map +1 -1
- package/groupChannel-28860f2b.js +8 -0
- package/groupChannel-28860f2b.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/SessionHandler.js +4 -2
- package/handlers/SessionHandler.js.map +1 -1
- package/handlers/UserEventHandler.js +4 -2
- package/handlers/UserEventHandler.js.map +1 -1
- package/{index-3249f6b5.js → index-26e371a5.js} +2 -2
- package/{index-3249f6b5.js.map → index-26e371a5.js.map} +1 -1
- package/{index-3699f160.js → index-31d409a0.js} +18 -37
- package/index-31d409a0.js.map +1 -0
- package/{index-6b896cd8.js → index-327e2586.js} +14 -13
- package/{index-6b896cd8.js.map → index-327e2586.js.map} +1 -1
- package/{index-726a5475.js → index-730972e8.js} +30 -30
- package/{index-726a5475.js.map → index-730972e8.js.map} +1 -1
- package/{index-7fa0a721.js → index-8095ffa6.js} +299 -320
- package/index-8095ffa6.js.map +1 -0
- package/{index-598898d3.js → index-9a33f2b0.js} +16 -14
- package/index-9a33f2b0.js.map +1 -0
- package/{index-176e9ad4.js → index-ab443960.js} +69 -80
- package/index-ab443960.js.map +1 -0
- package/{index-b79c5b07.js → index-be836db2.js} +13 -13
- package/{index-b79c5b07.js.map → index-be836db2.js.map} +1 -1
- package/{index-f59cf800.js → index-eeb90f55.js} +51 -51
- package/index-eeb90f55.js.map +1 -0
- package/{index-a98bd600.js → index-f767d8bd.js} +4 -4
- package/{index-a98bd600.js.map → index-f767d8bd.js.map} +1 -1
- package/index.d.ts +1 -1
- package/index.js +39 -36
- package/index.js.map +1 -1
- package/{openChannel-8c75e1a4.js → openChannel-c1a271aa.js} +3 -2
- package/openChannel-c1a271aa.js.map +1 -0
- package/{openChannelUtils-ecaeb7d7.js → openChannelUtils-a028985c.js} +11 -11
- package/openChannelUtils-a028985c.js.map +1 -0
- package/package.json +2 -3
- package/sendbird-8f18cf5b.js +7 -0
- package/sendbird-8f18cf5b.js.map +1 -0
- package/sendbirdSelectors.js +22 -22
- package/sendbirdSelectors.js.map +1 -1
- package/{stringSet-dc330bcf.js → stringSet-6e7f0195.js} +4 -4
- package/{stringSet-dc330bcf.js.map → stringSet-6e7f0195.js.map} +1 -1
- package/topics-13d4b72d.js +13 -0
- package/{topics-c5198349.js.map → topics-13d4b72d.js.map} +1 -1
- package/{tslib.es6-cb5d77bf.js → tslib.es6-c49bbc0a.js} +2 -2
- package/tslib.es6-c49bbc0a.js.map +1 -0
- package/ui/Accordion.js +4 -5
- package/ui/Accordion.js.map +1 -1
- package/ui/AccordionGroup.js +2 -2
- package/ui/AccordionGroup.js.map +1 -1
- package/ui/AdminMessage.js +3 -4
- package/ui/AdminMessage.js.map +1 -1
- package/ui/Avatar.js +6 -7
- package/ui/Avatar.js.map +1 -1
- package/ui/Badge.js +5 -6
- package/ui/Badge.js.map +1 -1
- package/ui/Button.js +3 -4
- package/ui/Button.js.map +1 -1
- package/ui/ChannelAvatar.js +3 -4
- package/ui/ChannelAvatar.js.map +1 -1
- package/ui/Checkbox.js +1 -1
- package/ui/Checkbox.js.map +1 -1
- package/ui/ConnectionStatus.js +4 -5
- package/ui/ConnectionStatus.js.map +1 -1
- package/ui/ContextMenu.js +14 -15
- package/ui/ContextMenu.js.map +1 -1
- package/ui/DateSeparator.js +5 -6
- package/ui/DateSeparator.js.map +1 -1
- package/ui/EmojiReactions.js +13 -14
- package/ui/EmojiReactions.js.map +1 -1
- package/ui/FileMessageItemBody.js +6 -7
- package/ui/FileMessageItemBody.js.map +1 -1
- package/ui/FileViewer.js +11 -12
- package/ui/FileViewer.js.map +1 -1
- package/ui/Icon.js +74 -73
- package/ui/Icon.js.map +1 -1
- package/ui/IconButton.js +7 -7
- package/ui/IconButton.js.map +1 -1
- package/ui/ImageRenderer.js +8 -10
- package/ui/ImageRenderer.js.map +1 -1
- package/ui/Input.js +4 -5
- package/ui/Input.js.map +1 -1
- package/ui/Label.js +2 -3
- package/ui/Label.js.map +1 -1
- package/ui/LinkLabel.js +14 -13
- package/ui/LinkLabel.js.map +1 -1
- package/ui/Loader.js +1 -2
- package/ui/Loader.js.map +1 -1
- package/ui/MentionLabel.js +13 -13
- package/ui/MentionLabel.js.map +1 -1
- package/ui/MentionUserLabel.js.map +1 -1
- package/ui/MessageContent.js +19 -19
- package/ui/MessageContent.js.map +1 -1
- package/ui/MessageInput.js +178 -19889
- package/ui/MessageInput.js.map +1 -1
- package/ui/MessageItemMenu.js +17 -18
- package/ui/MessageItemMenu.js.map +1 -1
- package/ui/MessageItemReactionMenu.js +12 -13
- package/ui/MessageItemReactionMenu.js.map +1 -1
- package/ui/MessageSearchFileItem.js +13 -24
- package/ui/MessageSearchFileItem.js.map +1 -1
- package/ui/MessageSearchItem.js +12 -14
- package/ui/MessageSearchItem.js.map +1 -1
- package/ui/MessageStatus.js +7 -8
- package/ui/MessageStatus.js.map +1 -1
- package/ui/Modal.js +9 -10
- package/ui/Modal.js.map +1 -1
- package/ui/MutedAvatarOverlay.js +0 -1
- package/ui/MutedAvatarOverlay.js.map +1 -1
- package/ui/OGMessageItemBody.js +11 -11
- package/ui/OGMessageItemBody.js.map +1 -1
- package/ui/OpenChannelAdminMessage.js +3 -4
- package/ui/OpenChannelAdminMessage.js.map +1 -1
- package/ui/OpenChannelAvatar.js +6 -7
- package/ui/OpenChannelAvatar.js.map +1 -1
- package/ui/OpenchannelConversationHeader.js +6 -7
- package/ui/OpenchannelConversationHeader.js.map +1 -1
- package/ui/OpenchannelFileMessage.js +24 -24
- package/ui/OpenchannelFileMessage.js.map +1 -1
- package/ui/OpenchannelOGMessage.js +26 -26
- package/ui/OpenchannelOGMessage.js.map +1 -1
- package/ui/OpenchannelThumbnailMessage.js +26 -26
- package/ui/OpenchannelThumbnailMessage.js.map +1 -1
- package/ui/OpenchannelUserMessage.js +24 -24
- package/ui/OpenchannelUserMessage.js.map +1 -1
- package/ui/PlaceHolder.js +6 -7
- package/ui/PlaceHolder.js.map +1 -1
- package/ui/QuoteMessage.js +10 -11
- package/ui/QuoteMessage.js.map +1 -1
- package/ui/QuoteMessageInput.js +7 -8
- package/ui/QuoteMessageInput.js.map +1 -1
- package/ui/ReactionBadge.js +4 -5
- package/ui/ReactionBadge.js.map +1 -1
- package/ui/ReactionButton.js +6 -6
- package/ui/ReactionButton.js.map +1 -1
- package/ui/SortByRow.js +2 -2
- package/ui/SortByRow.js.map +1 -1
- package/ui/TextButton.js +8 -9
- package/ui/TextButton.js.map +1 -1
- package/ui/TextMessageItemBody.js +10 -10
- package/ui/TextMessageItemBody.js.map +1 -1
- package/ui/ThumbnailMessageItemBody.js +5 -6
- package/ui/ThumbnailMessageItemBody.js.map +1 -1
- package/ui/Tooltip.js +3 -4
- package/ui/Tooltip.js.map +1 -1
- package/ui/TooltipWrapper.js +5 -5
- package/ui/TooltipWrapper.js.map +1 -1
- package/ui/UnknownMessageItemBody.js +6 -7
- package/ui/UnknownMessageItemBody.js.map +1 -1
- package/ui/UserListItem.js +17 -17
- package/ui/UserListItem.js.map +1 -1
- package/ui/UserProfile.js +11 -11
- package/ui/UserProfile.js.map +1 -1
- package/ui/Word.js +15 -10
- package/ui/Word.js.map +1 -1
- package/useSendbirdStateContext.js +1 -1
- package/useSendbirdStateContext.js.map +1 -1
- package/{utils-330ed0b1.js → utils-9e478f2a.js} +2 -2
- package/{utils-330ed0b1.js.map → utils-9e478f2a.js.map} +1 -1
- package/{utils-8fb72715.js → utils-c3865334.js} +4 -4
- package/utils-c3865334.js.map +1 -0
- package/utils-e3b472fd.js +4 -0
- package/{utils-629876b9.js.map → utils-e3b472fd.js.map} +1 -1
- package/{uuid-180d497e.js → uuid-741c039a.js} +2 -2
- package/{uuid-180d497e.js.map → uuid-741c039a.js.map} +1 -1
- package/withSendbird.js +13 -15
- package/withSendbird.js.map +1 -1
- package/ChannelListProvider-6e3b8f43.js.map +0 -1
- package/__bundle-bd072f34-95f6bf17.js +0 -8
- package/__bundle-bd072f34-95f6bf17.js.map +0 -1
- package/_rollupPluginBabelHelpers-4527872e.js +0 -130
- package/_rollupPluginBabelHelpers-4527872e.js.map +0 -1
- package/actionTypes-517789b8.js +0 -6
- package/cjs/ChannelListProvider-781aa186.js.map +0 -1
- package/cjs/__bundle-bd072f34-57bee5af.js +0 -106
- package/cjs/__bundle-bd072f34-57bee5af.js.map +0 -1
- package/cjs/_rollupPluginBabelHelpers-f9e4bb55.js +0 -134
- package/cjs/_rollupPluginBabelHelpers-f9e4bb55.js.map +0 -1
- package/cjs/actionTypes-17aa0989.js +0 -10
- package/cjs/color-9e293baf.js.map +0 -1
- package/cjs/compareIds-cf626c9f.js +0 -20
- package/cjs/compareIds-cf626c9f.js.map +0 -1
- package/cjs/const-17108318.js.map +0 -1
- package/cjs/groupChannel-6d56c155.js +0 -11
- package/cjs/groupChannel-6d56c155.js.map +0 -1
- package/cjs/index-1512514f.js.map +0 -1
- package/cjs/index-18b120dc.js.map +0 -1
- package/cjs/index-5166a415.js.map +0 -1
- package/cjs/index-9ce5e5a9.js.map +0 -1
- package/cjs/index-c1697faa.js.map +0 -1
- package/cjs/openChannel-8aabbf3c.js +0 -9
- package/cjs/openChannel-8aabbf3c.js.map +0 -1
- package/cjs/openChannelUtils-cffba1c0.js.map +0 -1
- package/cjs/topics-58ec1c61.js +0 -22
- package/cjs/tslib.es6-36205d81.js.map +0 -1
- package/cjs/utils-09738454.js +0 -6
- package/cjs/utils-9419225c.js.map +0 -1
- package/compareIds-31e2f55c.js +0 -18
- package/compareIds-31e2f55c.js.map +0 -1
- package/const-768ef60e.js.map +0 -1
- package/groupChannel-e2a071e1.js +0 -8
- package/groupChannel-e2a071e1.js.map +0 -1
- package/index-176e9ad4.js.map +0 -1
- package/index-3699f160.js.map +0 -1
- package/index-598898d3.js.map +0 -1
- package/index-7fa0a721.js.map +0 -1
- package/index-f59cf800.js.map +0 -1
- package/openChannel-8c75e1a4.js.map +0 -1
- package/openChannelUtils-ecaeb7d7.js.map +0 -1
- package/package-lock.json +0 -25501
- package/topics-c5198349.js +0 -13
- package/tslib.es6-cb5d77bf.js.map +0 -1
- package/utils-629876b9.js +0 -4
- package/utils-8fb72715.js.map +0 -1
|
@@ -1 +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.ReactElement;\n renderIconButton?: (props: void) => React.ReactElement;\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":";;;;;;;;;;;;;;;;
|
|
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.ReactElement;\n renderIconButton?: (props: void) => React.ReactElement;\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","_b","stores","userStore","stringSet","useContext","LocalizationContext","React","join","profileUrl","nickname","LabelTypography","SUBTITLE_2","LabelColors","ONBACKGROUND_1","NO_NAME","BODY_2","ONBACKGROUND_2","userId"],"mappings":";;;;;;;;;;;;;;;;AAiBA,IAAMA,iBAAiB,GAA0C,UAACC,EAAD,EAKpC;;;MAJ3BC,YAAY,GAAAD,EAAA,CAAAC;MACZC,gBAAgB,GAAAF,EAAA,CAAAE;MAChBC,MAAM,GAAAH,EAAA,CAAAG;MACNC,gBAAgB,GAAAJ,EAAA,CAAAI;EAEhB,IAAMC,OAAO,GAAGC,uBAAuB,EAAvC,CAAA;AACQ,EAAA,IAAAC,IAAI,GAAK,CAAA,CAAAC,EAAA,GAAAH,OAAO,KAAP,IAAA,IAAAA,OAAO,KAAP,KAAA,CAAA,GAAA,KAAA,CAAA,GAAAA,OAAO,CAAEI,MAAT,MAAe,IAAf,IAAeD,EAAA,KAAA,KAAA,CAAf,GAAe,KAAA,CAAf,GAAeA,EAAA,CAAEE,SAAjB,MAAT,CAAA;AAEA,EAAA,IAAAC,SAAS,GAAKC,UAAU,CAACC,mBAAD,CAAV,UAAd,CAAA;EACR,oBACEC,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AACE,IAAA,SAAS,EAAE,CACT,yBADS,EAETV,gBAAgB,GAAG,qCAAH,GAA2C,EAFlD,CAAA,CAGTW,IAHS,CAGJ,GAHI,CAAA;AADb,GAAA,EAOId,YAAY,GACRA,YAAY,EADJ,gBAGRa,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AACE,IAAA,SAAS,EAAC,gCADZ;AAEE,IAAA,IAAI,EAAC,QAFP;AAGE,IAAA,OAAO,EAAE,YAAA;MAAQX,MAAM,EAAA,CAAA;KAHzB;AAIE,IAAA,SAAS,EAAE,YAAA;MAAQA,MAAM,EAAA,CAAA;KAJ3B;AAKE,IAAA,QAAQ,EAAE,CAAA;GAEV,eAAAW,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAAK,IAAA,SAAS,EAAC,sCAAA;AAAf,GAAA,eACEA,6BAAC,MAAD,EAAA;AACE,IAAA,KAAK,EAAC,MADR;AAEE,IAAA,MAAM,EAAC,MAFT;IAGE,GAAG,EAAEP,IAAI,CAACS,UAHZ;IAIE,GAAG,EAAET,IAAI,CAACU,QAAAA;AAJZ,GAAA,CADF,CAPF,eAeEH,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAAK,IAAA,SAAS,EAAC,uCAAA;AAAf,GAAA,eACEA,6BAAC,KAAD,EAAA;AACE,IAAA,SAAS,EAAC,6CADZ;IAEE,IAAI,EAAEI,eAAe,CAACC,UAFxB;IAGE,KAAK,EAAEC,WAAW,CAACC,cAAAA;GAElBd,EAAAA,IAAI,CAACU,QAAL,IAAiBN,SAAS,CAACW,OAL9B,CADF,eAQER,cAAA,CAAA,aAAA,CAAC,KAAD,EAAA;AACE,IAAA,SAAS,EAAC,gDADZ;IAEE,IAAI,EAAEI,eAAe,CAACK,MAFxB;IAGE,KAAK,EAAEH,WAAW,CAACI,cAAAA;AAHrB,GAAA,EAKGjB,IAAI,CAACkB,MALR,CARF,CAfF,CAVR,eA4CEX,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAAK,IAAA,SAAS,EAAC,qCAAA;AAAf,GAAA,EACGZ,gBAAgB,EAAM,iBAAAY,cAAA,CAAA,aAAA,CAAC,UAAD,EAAA,IAAA,CADzB,CA5CF,CADF,CAAA;AAkDD;;;;"}
|
|
@@ -3,68 +3,70 @@ import ChannelListHeader from './ChannelListHeader.js';
|
|
|
3
3
|
import { AddChannel } from './AddChannel.js';
|
|
4
4
|
import ChannelPreview from './ChannelPreview.js';
|
|
5
5
|
import ChannelPreviewAction from './ChannelPreviewAction.js';
|
|
6
|
-
import { u as useChannelListContext, F as FETCH_CHANNELS_START, a as FETCH_CHANNELS_SUCCESS, b as FETCH_CHANNELS_FAILURE, L as LEAVE_CHANNEL_SUCCESS, S as SET_CURRENT_CHANNEL } from '../../ChannelListProvider-
|
|
6
|
+
import { u as useChannelListContext, F as FETCH_CHANNELS_START, a as FETCH_CHANNELS_SUCCESS, b as FETCH_CHANNELS_FAILURE, L as LEAVE_CHANNEL_SUCCESS, S as SET_CURRENT_CHANNEL } from '../../ChannelListProvider-1a22e404.js';
|
|
7
7
|
import useSendbirdStateContext from '../../useSendbirdStateContext.js';
|
|
8
8
|
import EditProfile from '../../EditUserProfile.js';
|
|
9
|
-
import { P as PlaceHolder, a as PlaceHolderTypes } from '../../index-
|
|
10
|
-
import '../../LocalizationContext-
|
|
11
|
-
import '../../stringSet-
|
|
12
|
-
import '../../index-
|
|
13
|
-
import '../../index-
|
|
14
|
-
import '../../_rollupPluginBabelHelpers-4527872e.js';
|
|
9
|
+
import { P as PlaceHolder, a as PlaceHolderTypes } from '../../index-f767d8bd.js';
|
|
10
|
+
import '../../LocalizationContext-78d3faa4.js';
|
|
11
|
+
import '../../stringSet-6e7f0195.js';
|
|
12
|
+
import '../../index-ab443960.js';
|
|
13
|
+
import '../../index-327e2586.js';
|
|
15
14
|
import 'prop-types';
|
|
16
15
|
import '../../ui/IconButton.js';
|
|
17
|
-
import '../../tslib.es6-
|
|
16
|
+
import '../../tslib.es6-c49bbc0a.js';
|
|
18
17
|
import '../../ui/Avatar.js';
|
|
19
18
|
import '../../ui/ImageRenderer.js';
|
|
20
19
|
import '../../ui/Icon.js';
|
|
21
|
-
import '../../uuid-
|
|
20
|
+
import '../../uuid-741c039a.js';
|
|
22
21
|
import '../../CreateChannel.js';
|
|
23
22
|
import '../../CreateChannel/components/CreateChannelUI.js';
|
|
24
|
-
import '../../CreateChannelProvider-
|
|
23
|
+
import '../../CreateChannelProvider-f740e1f0.js';
|
|
25
24
|
import '../../sendbirdSelectors.js';
|
|
26
|
-
import '../../topics-
|
|
27
|
-
import '../../utils-
|
|
25
|
+
import '../../topics-13d4b72d.js';
|
|
26
|
+
import '../../utils-e3b472fd.js';
|
|
28
27
|
import '../../CreateChannel/components/InviteUsers.js';
|
|
29
28
|
import '../../ui/Modal.js';
|
|
30
29
|
import 'react-dom';
|
|
31
|
-
import '../../index-
|
|
30
|
+
import '../../index-26e371a5.js';
|
|
32
31
|
import '../../ui/Button.js';
|
|
33
32
|
import '../../ui/UserListItem.js';
|
|
34
|
-
import '../../UserProfileContext-
|
|
33
|
+
import '../../UserProfileContext-bc040e78.js';
|
|
35
34
|
import '../../ui/MutedAvatarOverlay.js';
|
|
36
35
|
import '../../ui/Checkbox.js';
|
|
37
36
|
import '../../ui/UserProfile.js';
|
|
38
37
|
import '../../withSendbird.js';
|
|
38
|
+
import '../../_rollupPluginBabelHelpers-64f3f48c.js';
|
|
39
39
|
import '../../ui/ContextMenu.js';
|
|
40
40
|
import '../../ui/SortByRow.js';
|
|
41
|
-
import '../../index-
|
|
41
|
+
import '../../index-eeb90f55.js';
|
|
42
42
|
import '../../CreateChannel/components/SelectChannelType.js';
|
|
43
43
|
import '../../ui/ChannelAvatar.js';
|
|
44
|
-
import '../../utils-
|
|
44
|
+
import '../../utils-c3865334.js';
|
|
45
45
|
import '../../ui/Badge.js';
|
|
46
|
-
import '../../index-
|
|
47
|
-
import '../../index-
|
|
48
|
-
import '../../index-
|
|
46
|
+
import '../../index-31d409a0.js';
|
|
47
|
+
import '../../index-9a33f2b0.js';
|
|
48
|
+
import '../../index-8095ffa6.js';
|
|
49
49
|
import '../../ui/MentionUserLabel.js';
|
|
50
50
|
import '../../Channel/components/TypingIndicator.js';
|
|
51
|
-
import '../../groupChannel-
|
|
52
|
-
import '../../__bundle-
|
|
53
|
-
import '../../
|
|
54
|
-
import '../../
|
|
55
|
-
import '../../
|
|
51
|
+
import '../../groupChannel-28860f2b.js';
|
|
52
|
+
import '../../__bundle-57e0c5af-dff5d7e0.js';
|
|
53
|
+
import '../../__bundle-0dad34cd-6408fa97.js';
|
|
54
|
+
import '../../__bundle-bd072f34-80eb9bbc.js';
|
|
55
|
+
import '../../ChannelProvider-e38bb434.js';
|
|
56
|
+
import '../../compareIds-3fb63c4f.js';
|
|
57
|
+
import '../../const-82d4c478.js';
|
|
56
58
|
import '../../ui/ReactionButton.js';
|
|
57
59
|
import '../../ui/MessageStatus.js';
|
|
58
60
|
import '../../ui/Loader.js';
|
|
59
|
-
import '../../index-
|
|
61
|
+
import '../../index-be836db2.js';
|
|
60
62
|
import '../../ui/Input.js';
|
|
61
63
|
import '../../ui/TextButton.js';
|
|
62
|
-
import '../../color-
|
|
63
|
-
import '../../actionTypes-
|
|
64
|
+
import '../../color-25be65f3.js';
|
|
65
|
+
import '../../actionTypes-fb6947e7.js';
|
|
64
66
|
|
|
65
67
|
var DELIVERY_RECIPT = 'delivery_receipt';
|
|
66
68
|
|
|
67
|
-
var ChannelListUI = function
|
|
69
|
+
var ChannelListUI = function (props) {
|
|
68
70
|
var _a, _b;
|
|
69
71
|
|
|
70
72
|
var renderHeader = props.renderHeader,
|
|
@@ -123,26 +125,26 @@ var ChannelListUI = function ChannelListUI(props) {
|
|
|
123
125
|
className: "sendbird-channel-list__header"
|
|
124
126
|
}, /*#__PURE__*/React__default.createElement(ChannelListHeader, {
|
|
125
127
|
renderHeader: renderHeader,
|
|
126
|
-
onEdit: function
|
|
128
|
+
onEdit: function () {
|
|
127
129
|
if (allowProfileEdit) {
|
|
128
130
|
setShowProfileEdit(true);
|
|
129
131
|
}
|
|
130
132
|
},
|
|
131
133
|
allowProfileEdit: allowProfileEdit,
|
|
132
|
-
renderIconButton: function
|
|
134
|
+
renderIconButton: function () {
|
|
133
135
|
return /*#__PURE__*/React__default.createElement(AddChannel, null);
|
|
134
136
|
}
|
|
135
137
|
})), showProfileEdit && /*#__PURE__*/React__default.createElement(EditProfile, {
|
|
136
138
|
onThemeChange: onThemeChange,
|
|
137
|
-
onCancel: function
|
|
139
|
+
onCancel: function () {
|
|
138
140
|
setShowProfileEdit(false);
|
|
139
141
|
},
|
|
140
|
-
onEditProfile: function
|
|
142
|
+
onEditProfile: function () {
|
|
141
143
|
setShowProfileEdit(false);
|
|
142
144
|
}
|
|
143
145
|
}), /*#__PURE__*/React__default.createElement("div", {
|
|
144
146
|
className: "sendbird-channel-list__body",
|
|
145
|
-
onScroll: function
|
|
147
|
+
onScroll: function (e) {
|
|
146
148
|
var target = e === null || e === void 0 ? void 0 : e.target;
|
|
147
149
|
var fetchMore = target.clientHeight + target.scrollTop === target.scrollHeight;
|
|
148
150
|
|
|
@@ -181,7 +183,7 @@ var ChannelListUI = function ChannelListUI(props) {
|
|
|
181
183
|
}, sdkError && (renderPlaceHolderError && typeof renderPlaceHolderError === 'function' ? renderPlaceHolderError === null || renderPlaceHolderError === void 0 ? void 0 : renderPlaceHolderError() : /*#__PURE__*/React__default.createElement(PlaceHolder, {
|
|
182
184
|
type: PlaceHolderTypes.WRONG
|
|
183
185
|
})), /*#__PURE__*/React__default.createElement("div", null, allChannels && allChannels.map(function (channel, idx) {
|
|
184
|
-
var
|
|
186
|
+
var onLeaveChannel = function (c, cb) {
|
|
185
187
|
logger.info('ChannelList: Leaving channel', c);
|
|
186
188
|
c.leave().then(function (res) {
|
|
187
189
|
logger.info('ChannelList: Leaving channel success', res);
|
|
@@ -203,7 +205,7 @@ var ChannelListUI = function ChannelListUI(props) {
|
|
|
203
205
|
});
|
|
204
206
|
};
|
|
205
207
|
|
|
206
|
-
var onClick = function
|
|
208
|
+
var onClick = function () {
|
|
207
209
|
if (!isOnline) {
|
|
208
210
|
return;
|
|
209
211
|
}
|
|
@@ -223,7 +225,7 @@ var ChannelListUI = function ChannelListUI(props) {
|
|
|
223
225
|
onClick: onClick
|
|
224
226
|
}, renderChannelPreview({
|
|
225
227
|
channel: channel,
|
|
226
|
-
onLeaveChannel:
|
|
228
|
+
onLeaveChannel: onLeaveChannel
|
|
227
229
|
})) : /*#__PURE__*/React__default.createElement(ChannelPreview, {
|
|
228
230
|
key: channel === null || channel === void 0 ? void 0 : channel.url,
|
|
229
231
|
tabIndex: idx,
|
|
@@ -234,11 +236,11 @@ var ChannelListUI = function ChannelListUI(props) {
|
|
|
234
236
|
var url = _a.url;
|
|
235
237
|
return url === (channel === null || channel === void 0 ? void 0 : channel.url);
|
|
236
238
|
}),
|
|
237
|
-
renderChannelAction: function
|
|
239
|
+
renderChannelAction: function () {
|
|
238
240
|
return /*#__PURE__*/React__default.createElement(ChannelPreviewAction, {
|
|
239
241
|
disabled: !isOnline,
|
|
240
|
-
onLeaveChannel: function
|
|
241
|
-
return
|
|
242
|
+
onLeaveChannel: function () {
|
|
243
|
+
return onLeaveChannel(channel, null);
|
|
242
244
|
}
|
|
243
245
|
});
|
|
244
246
|
}
|
|
@@ -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.ReactElement;\n renderUserProfile?: (props: RenderUserProfileProps) => React.ReactElement;\n renderHeader?: (props: void) => React.ReactElement;\n renderPlaceHolderError?: (props: void) => React.ReactElement;\n renderPlaceHolderLoading?: (props: void) => React.ReactElement;\n renderPlaceHolderEmptyList?: (props: void) => React.ReactElement;\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.ReactElement;\n renderUserProfile?: (props: RenderUserProfileProps) => React.ReactElement;\n renderHeader?: (props: void) => React.ReactElement;\n renderPlaceHolderError?: (props: void) => React.ReactElement;\n renderPlaceHolderLoading?: (props: void) => React.ReactElement;\n renderPlaceHolderEmptyList?: (props: void) => React.ReactElement;\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","_a","stores","config","isOnline","_b","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","LOADING","NO_CHANNELS"],"mappings":"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"}
|
|
@@ -2,47 +2,49 @@ 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-327e2586.js';
|
|
6
|
+
import { i as isToday, a as isYesterday, f as formatRelative } from '../../index-31d409a0.js';
|
|
7
|
+
import { f as format } from '../../index-8095ffa6.js';
|
|
8
|
+
import { t as truncateString, e as isEditedMessage } from '../../index-eeb90f55.js';
|
|
9
9
|
import useSendbirdStateContext from '../../useSendbirdStateContext.js';
|
|
10
|
-
import { u as useLocalization } from '../../LocalizationContext-
|
|
10
|
+
import { u as useLocalization } from '../../LocalizationContext-78d3faa4.js';
|
|
11
11
|
import MentionUserLabel from '../../ui/MentionUserLabel.js';
|
|
12
|
-
import { u as useChannelListContext } from '../../ChannelListProvider-
|
|
12
|
+
import { u as useChannelListContext } from '../../ChannelListProvider-1a22e404.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-c49bbc0a.js';
|
|
17
17
|
import '../../ui/ImageRenderer.js';
|
|
18
|
-
import '../../uuid-
|
|
19
|
-
import '../../utils-
|
|
20
|
-
import '../../_rollupPluginBabelHelpers-4527872e.js';
|
|
18
|
+
import '../../uuid-741c039a.js';
|
|
19
|
+
import '../../utils-c3865334.js';
|
|
21
20
|
import 'prop-types';
|
|
22
|
-
import '../../stringSet-
|
|
23
|
-
import '../../index-
|
|
24
|
-
import '../../index-
|
|
21
|
+
import '../../stringSet-6e7f0195.js';
|
|
22
|
+
import '../../index-9a33f2b0.js';
|
|
23
|
+
import '../../index-ab443960.js';
|
|
25
24
|
import '../../withSendbird.js';
|
|
26
|
-
import '../../
|
|
27
|
-
import '../../
|
|
28
|
-
import '../../
|
|
29
|
-
import '../../
|
|
30
|
-
import '../../
|
|
31
|
-
import '../../
|
|
32
|
-
import '../../
|
|
33
|
-
import '../../
|
|
25
|
+
import '../../_rollupPluginBabelHelpers-64f3f48c.js';
|
|
26
|
+
import '../../groupChannel-28860f2b.js';
|
|
27
|
+
import '../../__bundle-57e0c5af-dff5d7e0.js';
|
|
28
|
+
import '../../__bundle-0dad34cd-6408fa97.js';
|
|
29
|
+
import '../../__bundle-bd072f34-80eb9bbc.js';
|
|
30
|
+
import '../../topics-13d4b72d.js';
|
|
31
|
+
import '../../utils-e3b472fd.js';
|
|
32
|
+
import '../../UserProfileContext-bc040e78.js';
|
|
33
|
+
import '../../ChannelProvider-e38bb434.js';
|
|
34
|
+
import '../../compareIds-3fb63c4f.js';
|
|
35
|
+
import '../../const-82d4c478.js';
|
|
34
36
|
import '../../ui/ContextMenu.js';
|
|
35
37
|
import 'react-dom';
|
|
36
38
|
import '../../ui/SortByRow.js';
|
|
37
39
|
import '../../ui/ReactionButton.js';
|
|
38
40
|
import '../../ui/Loader.js';
|
|
39
41
|
|
|
40
|
-
|
|
42
|
+
const getChannelTitle = function () {
|
|
41
43
|
var _channel$members;
|
|
42
44
|
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
45
|
+
let channel = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
46
|
+
let currentUserId = arguments.length > 1 ? arguments[1] : undefined;
|
|
47
|
+
let stringSet = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : LabelStringSet;
|
|
46
48
|
|
|
47
49
|
if (!(channel !== null && channel !== void 0 && channel.name) && !(channel !== null && channel !== void 0 && channel.members)) {
|
|
48
50
|
return stringSet.NO_TITLE;
|
|
@@ -56,20 +58,24 @@ var getChannelTitle = function getChannelTitle() {
|
|
|
56
58
|
return stringSet.NO_MEMBERS;
|
|
57
59
|
}
|
|
58
60
|
|
|
59
|
-
return ((channel === null || channel === void 0 ? void 0 : channel.members) || []).filter(
|
|
60
|
-
|
|
61
|
+
return ((channel === null || channel === void 0 ? void 0 : channel.members) || []).filter(_ref => {
|
|
62
|
+
let {
|
|
63
|
+
userId
|
|
64
|
+
} = _ref;
|
|
61
65
|
return userId !== currentUserId;
|
|
62
|
-
}).map(
|
|
63
|
-
|
|
66
|
+
}).map(_ref2 => {
|
|
67
|
+
let {
|
|
68
|
+
nickname
|
|
69
|
+
} = _ref2;
|
|
64
70
|
return nickname || stringSet.NO_NAME;
|
|
65
71
|
}).join(', ');
|
|
66
72
|
};
|
|
67
|
-
|
|
73
|
+
const getLastMessageCreatedAt = (channel, locale) => {
|
|
68
74
|
var _channel$lastMessage;
|
|
69
75
|
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
locale
|
|
76
|
+
const createdAt = channel === null || channel === void 0 ? void 0 : (_channel$lastMessage = channel.lastMessage) === null || _channel$lastMessage === void 0 ? void 0 : _channel$lastMessage.createdAt;
|
|
77
|
+
const optionalParam = locale ? {
|
|
78
|
+
locale
|
|
73
79
|
} : null;
|
|
74
80
|
|
|
75
81
|
if (!createdAt) {
|
|
@@ -86,15 +92,15 @@ var getLastMessageCreatedAt = function getLastMessageCreatedAt(channel, locale)
|
|
|
86
92
|
|
|
87
93
|
return format(createdAt, 'MMM dd', optionalParam);
|
|
88
94
|
};
|
|
89
|
-
|
|
90
|
-
return channel !== null && channel !== void 0 && channel.memberCount ? channel.memberCount : 0;
|
|
91
|
-
};
|
|
95
|
+
const getTotalMembers = channel => channel !== null && channel !== void 0 && channel.memberCount ? channel.memberCount : 0;
|
|
92
96
|
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
97
|
+
const getPrettyLastMessage = function () {
|
|
98
|
+
let message = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
99
|
+
const MAXLEN = 30;
|
|
100
|
+
const {
|
|
101
|
+
messageType,
|
|
102
|
+
name
|
|
103
|
+
} = message;
|
|
98
104
|
|
|
99
105
|
if (messageType === 'file') {
|
|
100
106
|
return truncateString(name, MAXLEN);
|
|
@@ -103,14 +109,10 @@ var getPrettyLastMessage = function getPrettyLastMessage() {
|
|
|
103
109
|
return message.message;
|
|
104
110
|
};
|
|
105
111
|
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
};
|
|
109
|
-
var getChannelUnreadMessageCount = function getChannelUnreadMessageCount(channel) {
|
|
110
|
-
return channel !== null && channel !== void 0 && channel.unreadMessageCount ? channel.unreadMessageCount : 0;
|
|
111
|
-
};
|
|
112
|
+
const getLastMessage = channel => channel !== null && channel !== void 0 && channel.lastMessage ? getPrettyLastMessage(channel.lastMessage) : '';
|
|
113
|
+
const getChannelUnreadMessageCount = channel => channel !== null && channel !== void 0 && channel.unreadMessageCount ? channel.unreadMessageCount : 0;
|
|
112
114
|
|
|
113
|
-
var ChannelPreview = function
|
|
115
|
+
var ChannelPreview = function (_a) {
|
|
114
116
|
var _b, _c, _d, _e, _f, _g, _h, _j, _k;
|
|
115
117
|
|
|
116
118
|
var channel = _a.channel,
|
|
@@ -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.ReactElement;\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.ReactElement;\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","_d","_b","stores","userStore","user","theme","_e","config","isMentionEnabled","_f","isFrozen","isBroadcast","isChannelTyping","isMessageStatusEnabled","_g","_h","_k","_j","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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"}
|