@sendbird/uikit-react 3.5.0-rc.1 → 3.5.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/App.js +323 -238
- package/App.js.map +1 -1
- package/CHANGELOG.md +556 -0
- package/Channel/components/ChannelHeader.js +46 -41
- package/Channel/components/ChannelHeader.js.map +1 -1
- package/Channel/components/ChannelUI.js +104 -131
- package/Channel/components/ChannelUI.js.map +1 -1
- package/Channel/components/FileViewer.js +56 -52
- package/Channel/components/FileViewer.js.map +1 -1
- package/Channel/components/FrozenNotification.js +12 -7
- package/Channel/components/FrozenNotification.js.map +1 -1
- package/Channel/components/Message.js +240 -230
- package/Channel/components/Message.js.map +1 -1
- package/Channel/components/MessageInput.js +152 -129
- package/Channel/components/MessageInput.js.map +1 -1
- package/Channel/components/MessageList.js +270 -175
- package/Channel/components/MessageList.js.map +1 -1
- package/Channel/components/RemoveMessageModal.js +34 -30
- package/Channel/components/RemoveMessageModal.js.map +1 -1
- package/Channel/components/SuggestedMentionList.js +139 -193
- package/Channel/components/SuggestedMentionList.js.map +1 -1
- package/Channel/components/TypingIndicator.js +44 -61
- package/Channel/components/TypingIndicator.js.map +1 -1
- package/Channel/components/UnreadCount.js +18 -20
- package/Channel/components/UnreadCount.js.map +1 -1
- package/Channel/context.js +12 -19
- package/Channel/context.js.map +1 -1
- package/Channel.js +69 -44
- package/Channel.js.map +1 -1
- package/ChannelList/components/AddChannel.js +29 -30
- package/ChannelList/components/AddChannel.js.map +1 -1
- package/ChannelList/components/ChannelListHeader.js +32 -28
- package/ChannelList/components/ChannelListHeader.js.map +1 -1
- package/ChannelList/components/ChannelListUI.js +101 -142
- package/ChannelList/components/ChannelListUI.js.map +1 -1
- package/ChannelList/components/ChannelPreview.js +72 -82
- package/ChannelList/components/ChannelPreview.js.map +1 -1
- package/ChannelList/components/ChannelPreviewAction.js +36 -36
- package/ChannelList/components/ChannelPreviewAction.js.map +1 -1
- package/ChannelList/context.js +7 -8
- package/ChannelList/context.js.map +1 -1
- package/ChannelList.js +32 -31
- package/ChannelList.js.map +1 -1
- package/{ChannelListProvider-1d36e2e9.js → ChannelListProvider-643a2b47.js} +234 -286
- package/ChannelListProvider-643a2b47.js.map +1 -0
- package/{ChannelProvider-289cd35f.js → ChannelProvider-33559192.js} +661 -727
- package/ChannelProvider-33559192.js.map +1 -0
- package/ChannelSettings/components/ChannelProfile.js +33 -46
- package/ChannelSettings/components/ChannelProfile.js.map +1 -1
- package/ChannelSettings/components/ChannelSettingsUI.js +45 -48
- package/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
- package/ChannelSettings/components/EditDetailsModal.js +47 -58
- package/ChannelSettings/components/EditDetailsModal.js.map +1 -1
- package/ChannelSettings/components/LeaveChannel.js +40 -46
- package/ChannelSettings/components/LeaveChannel.js.map +1 -1
- package/ChannelSettings/components/ModerationPanel.js +522 -605
- package/ChannelSettings/components/ModerationPanel.js.map +1 -1
- package/ChannelSettings/components/UserListItem.js +71 -72
- package/ChannelSettings/components/UserListItem.js.map +1 -1
- package/ChannelSettings/components/UserPanel.js +29 -32
- package/ChannelSettings/components/UserPanel.js.map +1 -1
- package/ChannelSettings/context.js +55 -58
- package/ChannelSettings/context.js.map +1 -1
- package/ChannelSettings.js +20 -20
- package/ChannelSettings.js.map +1 -1
- package/CreateChannel/components/CreateChannelUI.js +24 -24
- package/CreateChannel/components/CreateChannelUI.js.map +1 -1
- package/CreateChannel/components/InviteUsers.js +102 -124
- package/CreateChannel/components/InviteUsers.js.map +1 -1
- package/CreateChannel/components/SelectChannelType.js +41 -42
- package/CreateChannel/components/SelectChannelType.js.map +1 -1
- package/CreateChannel/context.js +4 -4
- package/CreateChannel.js +22 -21
- package/CreateChannel.js.map +1 -1
- package/CreateChannelProvider-5b006b58.js +44 -0
- package/CreateChannelProvider-5b006b58.js.map +1 -0
- package/CreateOpenChannel/components/CreateOpenChannelUI.js +33 -43
- package/CreateOpenChannel/components/CreateOpenChannelUI.js.map +1 -1
- package/CreateOpenChannel/context.js +33 -33
- package/CreateOpenChannel/context.js.map +1 -1
- package/CreateOpenChannel.js +18 -17
- package/CreateOpenChannel.js.map +1 -1
- package/EditUserProfile/components/EditUserProfileUI.js +12 -13
- package/EditUserProfile/components/EditUserProfileUI.js.map +1 -1
- package/EditUserProfile/context.js +0 -2
- package/EditUserProfile/context.js.map +1 -1
- package/EditUserProfile.js +18 -17
- package/EditUserProfile.js.map +1 -1
- package/LocalizationContext-25d6694d.js +20 -0
- package/{LocalizationContext-289c1917.js.map → LocalizationContext-25d6694d.js.map} +1 -1
- package/MediaQueryContext-94c9086a.js +87 -0
- package/MediaQueryContext-94c9086a.js.map +1 -0
- package/MemberList-9f8950db.js +403 -0
- package/MemberList-9f8950db.js.map +1 -0
- package/Message/context.js +31 -0
- package/Message/context.js.map +1 -0
- package/MessageSearch/components/MessageSearchUI.js +62 -71
- package/MessageSearch/components/MessageSearchUI.js.map +1 -1
- package/MessageSearch/context.js +201 -224
- package/MessageSearch/context.js.map +1 -1
- package/MessageSearch.js +46 -58
- package/MessageSearch.js.map +1 -1
- package/OpenChannel/components/FrozenChannelNotification.js +8 -6
- package/OpenChannel/components/FrozenChannelNotification.js.map +1 -1
- package/OpenChannel/components/OpenChannelHeader.js +27 -25
- package/OpenChannel/components/OpenChannelHeader.js.map +1 -1
- package/OpenChannel/components/OpenChannelInput.js +50 -35
- package/OpenChannel/components/OpenChannelInput.js.map +1 -1
- package/OpenChannel/components/OpenChannelMessage.js +174 -191
- package/OpenChannel/components/OpenChannelMessage.js.map +1 -1
- package/OpenChannel/components/OpenChannelMessageList.js +72 -92
- package/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
- package/OpenChannel/components/OpenChannelUI.js +52 -49
- package/OpenChannel/components/OpenChannelUI.js.map +1 -1
- package/OpenChannel/context.js +8 -9
- package/OpenChannel/context.js.map +1 -1
- package/OpenChannel.js +36 -30
- package/OpenChannel.js.map +1 -1
- package/OpenChannelList/components/OpenChannelListUI.js +61 -76
- package/OpenChannelList/components/OpenChannelListUI.js.map +1 -1
- package/OpenChannelList/components/OpenChannelPreview.js +21 -22
- package/OpenChannelList/components/OpenChannelPreview.js.map +1 -1
- package/OpenChannelList/context.js +3 -4
- package/OpenChannelList/context.js.map +1 -1
- package/OpenChannelList.js +26 -24
- package/OpenChannelList.js.map +1 -1
- package/OpenChannelListProvider-7c6b2f84.js +429 -0
- package/OpenChannelListProvider-7c6b2f84.js.map +1 -0
- package/OpenChannelProvider-18fa6128.js +1885 -0
- package/OpenChannelProvider-18fa6128.js.map +1 -0
- package/OpenChannelSettings/components/EditDetailsModal.js +47 -56
- package/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
- package/OpenChannelSettings/components/OpenChannelProfile.js +26 -31
- package/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
- package/OpenChannelSettings/components/OpenChannelSettingsUI.js +45 -43
- package/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
- package/OpenChannelSettings/components/OperatorUI.js +516 -586
- package/OpenChannelSettings/components/OperatorUI.js.map +1 -1
- package/OpenChannelSettings/components/ParticipantUI.js +15 -16
- package/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
- package/OpenChannelSettings/context.js +57 -70
- package/OpenChannelSettings/context.js.map +1 -1
- package/OpenChannelSettings.js +19 -20
- package/OpenChannelSettings.js.map +1 -1
- package/README.md +62 -13
- package/RemoveMessageModal-9c0350c0.js +36 -0
- package/RemoveMessageModal-9c0350c0.js.map +1 -0
- package/SendbirdProvider.js +749 -408
- package/SendbirdProvider.js.map +1 -1
- package/Thread/components/ParentMessageInfo.js +238 -217
- package/Thread/components/ParentMessageInfo.js.map +1 -1
- package/Thread/components/ParentMessageInfoItem.js +112 -89
- package/Thread/components/ParentMessageInfoItem.js.map +1 -1
- package/Thread/components/ThreadHeader.js +22 -23
- package/Thread/components/ThreadHeader.js.map +1 -1
- package/Thread/components/ThreadList.js +108 -83
- package/Thread/components/ThreadList.js.map +1 -1
- package/Thread/components/ThreadListItem.js +306 -276
- package/Thread/components/ThreadListItem.js.map +1 -1
- package/Thread/components/ThreadMessageInput.js +146 -113
- package/Thread/components/ThreadMessageInput.js.map +1 -1
- package/Thread/components/ThreadUI.js +169 -138
- package/Thread/components/ThreadUI.js.map +1 -1
- package/Thread/context/types.js +9 -14
- package/Thread/context/types.js.map +1 -1
- package/Thread/context.js +8 -8
- package/Thread.js +87 -57
- package/Thread.js.map +1 -1
- package/ThreadProvider-6ae0b041.js +1695 -0
- package/ThreadProvider-6ae0b041.js.map +1 -0
- package/{UserProfileContext-e3530842.js → UserProfileContext-a56cc682.js} +1 -4
- package/{UserProfileContext-e3530842.js.map → UserProfileContext-a56cc682.js.map} +1 -1
- package/VoiceMessageInputWrapper-69ac1f5a.js +170 -0
- package/VoiceMessageInputWrapper-69ac1f5a.js.map +1 -0
- package/VoicePlayer/context.js +7 -0
- package/{NotificationChannel → VoicePlayer}/context.js.map +1 -1
- package/VoicePlayer/useVoicePlayer.js +84 -0
- package/VoicePlayer/useVoicePlayer.js.map +1 -0
- package/VoiceRecorder/context.js +156 -0
- package/VoiceRecorder/context.js.map +1 -0
- package/VoiceRecorder/useVoiceRecorder.js +121 -0
- package/VoiceRecorder/useVoiceRecorder.js.map +1 -0
- package/WebAudioUtils-16540f03.js +123 -0
- package/WebAudioUtils-16540f03.js.map +1 -0
- package/{_rollupPluginBabelHelpers-519f674b.js → _rollupPluginBabelHelpers-1be219c2.js} +17 -11
- package/_rollupPluginBabelHelpers-1be219c2.js.map +1 -0
- package/actionTypes-a8140d53.js +8 -0
- package/actionTypes-a8140d53.js.map +1 -0
- package/cjs/App.js +324 -239
- package/cjs/App.js.map +1 -1
- package/cjs/Channel/components/ChannelHeader.js +46 -41
- package/cjs/Channel/components/ChannelHeader.js.map +1 -1
- package/cjs/Channel/components/ChannelUI.js +102 -129
- package/cjs/Channel/components/ChannelUI.js.map +1 -1
- package/cjs/Channel/components/FileViewer.js +56 -52
- package/cjs/Channel/components/FileViewer.js.map +1 -1
- package/cjs/Channel/components/FrozenNotification.js +12 -7
- package/cjs/Channel/components/FrozenNotification.js.map +1 -1
- package/cjs/Channel/components/Message.js +243 -233
- package/cjs/Channel/components/Message.js.map +1 -1
- package/cjs/Channel/components/MessageInput.js +151 -128
- package/cjs/Channel/components/MessageInput.js.map +1 -1
- package/cjs/Channel/components/MessageList.js +270 -175
- package/cjs/Channel/components/MessageList.js.map +1 -1
- package/cjs/Channel/components/RemoveMessageModal.js +34 -30
- package/cjs/Channel/components/RemoveMessageModal.js.map +1 -1
- package/cjs/Channel/components/SuggestedMentionList.js +139 -193
- package/cjs/Channel/components/SuggestedMentionList.js.map +1 -1
- package/cjs/Channel/components/TypingIndicator.js +44 -61
- package/cjs/Channel/components/TypingIndicator.js.map +1 -1
- package/cjs/Channel/components/UnreadCount.js +18 -20
- package/cjs/Channel/components/UnreadCount.js.map +1 -1
- package/cjs/Channel/context.js +12 -23
- package/cjs/Channel/context.js.map +1 -1
- package/cjs/Channel.js +69 -44
- package/cjs/Channel.js.map +1 -1
- package/cjs/ChannelList/components/AddChannel.js +29 -30
- package/cjs/ChannelList/components/AddChannel.js.map +1 -1
- package/cjs/ChannelList/components/ChannelListHeader.js +32 -28
- package/cjs/ChannelList/components/ChannelListHeader.js.map +1 -1
- package/cjs/ChannelList/components/ChannelListUI.js +100 -141
- package/cjs/ChannelList/components/ChannelListUI.js.map +1 -1
- package/cjs/ChannelList/components/ChannelPreview.js +72 -82
- package/cjs/ChannelList/components/ChannelPreview.js.map +1 -1
- package/cjs/ChannelList/components/ChannelPreviewAction.js +36 -36
- package/cjs/ChannelList/components/ChannelPreviewAction.js.map +1 -1
- package/cjs/ChannelList/context.js +7 -8
- package/cjs/ChannelList/context.js.map +1 -1
- package/cjs/ChannelList.js +32 -31
- package/cjs/ChannelList.js.map +1 -1
- package/cjs/{ChannelListProvider-0de52d2b.js → ChannelListProvider-1d4a8060.js} +233 -285
- package/cjs/ChannelListProvider-1d4a8060.js.map +1 -0
- package/cjs/{ChannelProvider-fc58e60e.js → ChannelProvider-2c7ec64b.js} +659 -725
- package/cjs/ChannelProvider-2c7ec64b.js.map +1 -0
- package/cjs/ChannelSettings/components/ChannelProfile.js +33 -46
- package/cjs/ChannelSettings/components/ChannelProfile.js.map +1 -1
- package/cjs/ChannelSettings/components/ChannelSettingsUI.js +45 -48
- package/cjs/ChannelSettings/components/ChannelSettingsUI.js.map +1 -1
- package/cjs/ChannelSettings/components/EditDetailsModal.js +47 -58
- package/cjs/ChannelSettings/components/EditDetailsModal.js.map +1 -1
- package/cjs/ChannelSettings/components/LeaveChannel.js +40 -46
- package/cjs/ChannelSettings/components/LeaveChannel.js.map +1 -1
- package/cjs/ChannelSettings/components/ModerationPanel.js +522 -605
- package/cjs/ChannelSettings/components/ModerationPanel.js.map +1 -1
- package/cjs/ChannelSettings/components/UserListItem.js +71 -72
- package/cjs/ChannelSettings/components/UserListItem.js.map +1 -1
- package/cjs/ChannelSettings/components/UserPanel.js +29 -32
- package/cjs/ChannelSettings/components/UserPanel.js.map +1 -1
- package/cjs/ChannelSettings/context.js +57 -60
- package/cjs/ChannelSettings/context.js.map +1 -1
- package/cjs/ChannelSettings.js +20 -20
- package/cjs/ChannelSettings.js.map +1 -1
- package/cjs/CreateChannel/components/CreateChannelUI.js +24 -24
- package/cjs/CreateChannel/components/CreateChannelUI.js.map +1 -1
- package/cjs/CreateChannel/components/InviteUsers.js +102 -124
- package/cjs/CreateChannel/components/InviteUsers.js.map +1 -1
- package/cjs/CreateChannel/components/SelectChannelType.js +41 -42
- package/cjs/CreateChannel/components/SelectChannelType.js.map +1 -1
- package/cjs/CreateChannel/context.js +4 -4
- package/cjs/CreateChannel.js +22 -21
- package/cjs/CreateChannel.js.map +1 -1
- package/cjs/CreateChannelProvider-f7d36126.js +52 -0
- package/cjs/CreateChannelProvider-f7d36126.js.map +1 -0
- package/cjs/CreateOpenChannel/components/CreateOpenChannelUI.js +33 -43
- package/cjs/CreateOpenChannel/components/CreateOpenChannelUI.js.map +1 -1
- package/cjs/CreateOpenChannel/context.js +33 -33
- package/cjs/CreateOpenChannel/context.js.map +1 -1
- package/cjs/CreateOpenChannel.js +18 -17
- package/cjs/CreateOpenChannel.js.map +1 -1
- package/cjs/EditUserProfile/components/EditUserProfileUI.js +12 -13
- package/cjs/EditUserProfile/components/EditUserProfileUI.js.map +1 -1
- package/cjs/EditUserProfile/context.js +0 -2
- package/cjs/EditUserProfile/context.js.map +1 -1
- package/cjs/EditUserProfile.js +18 -17
- package/cjs/EditUserProfile.js.map +1 -1
- package/cjs/{LocalizationContext-bddc5c2b.js → LocalizationContext-bd54275c.js} +9 -11
- package/cjs/{LocalizationContext-bddc5c2b.js.map → LocalizationContext-bd54275c.js.map} +1 -1
- package/cjs/MediaQueryContext-ebcb159a.js +94 -0
- package/cjs/MediaQueryContext-ebcb159a.js.map +1 -0
- package/cjs/MemberList-2204c0b1.js +409 -0
- package/cjs/MemberList-2204c0b1.js.map +1 -0
- package/cjs/Message/context.js +40 -0
- package/cjs/Message/context.js.map +1 -0
- package/cjs/MessageSearch/components/MessageSearchUI.js +61 -70
- package/cjs/MessageSearch/components/MessageSearchUI.js.map +1 -1
- package/cjs/MessageSearch/context.js +201 -224
- package/cjs/MessageSearch/context.js.map +1 -1
- package/cjs/MessageSearch.js +46 -58
- package/cjs/MessageSearch.js.map +1 -1
- package/cjs/OpenChannel/components/FrozenChannelNotification.js +8 -6
- package/cjs/OpenChannel/components/FrozenChannelNotification.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelHeader.js +27 -25
- package/cjs/OpenChannel/components/OpenChannelHeader.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelInput.js +50 -35
- package/cjs/OpenChannel/components/OpenChannelInput.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelMessage.js +174 -191
- package/cjs/OpenChannel/components/OpenChannelMessage.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelMessageList.js +72 -92
- package/cjs/OpenChannel/components/OpenChannelMessageList.js.map +1 -1
- package/cjs/OpenChannel/components/OpenChannelUI.js +52 -49
- package/cjs/OpenChannel/components/OpenChannelUI.js.map +1 -1
- package/cjs/OpenChannel/context.js +8 -9
- package/cjs/OpenChannel/context.js.map +1 -1
- package/cjs/OpenChannel.js +36 -30
- package/cjs/OpenChannel.js.map +1 -1
- package/cjs/OpenChannelList/components/OpenChannelListUI.js +61 -76
- package/cjs/OpenChannelList/components/OpenChannelListUI.js.map +1 -1
- package/cjs/OpenChannelList/components/OpenChannelPreview.js +21 -22
- package/cjs/OpenChannelList/components/OpenChannelPreview.js.map +1 -1
- package/cjs/OpenChannelList/context.js +3 -4
- package/cjs/OpenChannelList/context.js.map +1 -1
- package/cjs/OpenChannelList.js +26 -24
- package/cjs/OpenChannelList.js.map +1 -1
- package/cjs/OpenChannelListProvider-865700d5.js +439 -0
- package/cjs/OpenChannelListProvider-865700d5.js.map +1 -0
- package/cjs/OpenChannelProvider-083e5628.js +1894 -0
- package/cjs/OpenChannelProvider-083e5628.js.map +1 -0
- package/cjs/OpenChannelSettings/components/EditDetailsModal.js +47 -56
- package/cjs/OpenChannelSettings/components/EditDetailsModal.js.map +1 -1
- package/cjs/OpenChannelSettings/components/OpenChannelProfile.js +26 -31
- package/cjs/OpenChannelSettings/components/OpenChannelProfile.js.map +1 -1
- package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js +45 -43
- package/cjs/OpenChannelSettings/components/OpenChannelSettingsUI.js.map +1 -1
- package/cjs/OpenChannelSettings/components/OperatorUI.js +516 -586
- package/cjs/OpenChannelSettings/components/OperatorUI.js.map +1 -1
- package/cjs/OpenChannelSettings/components/ParticipantUI.js +15 -16
- package/cjs/OpenChannelSettings/components/ParticipantUI.js.map +1 -1
- package/cjs/OpenChannelSettings/context.js +58 -71
- package/cjs/OpenChannelSettings/context.js.map +1 -1
- package/cjs/OpenChannelSettings.js +19 -20
- package/cjs/OpenChannelSettings.js.map +1 -1
- package/cjs/{RemoveMessageModal-9169766a.js → RemoveMessageModal-822e0fac.js} +19 -14
- package/cjs/RemoveMessageModal-822e0fac.js.map +1 -0
- package/cjs/SendbirdProvider.js +748 -408
- package/cjs/SendbirdProvider.js.map +1 -1
- package/cjs/Thread/components/ParentMessageInfo.js +237 -216
- package/cjs/Thread/components/ParentMessageInfo.js.map +1 -1
- package/cjs/Thread/components/ParentMessageInfoItem.js +111 -88
- package/cjs/Thread/components/ParentMessageInfoItem.js.map +1 -1
- package/cjs/Thread/components/ThreadHeader.js +22 -23
- package/cjs/Thread/components/ThreadHeader.js.map +1 -1
- package/cjs/Thread/components/ThreadList.js +108 -83
- package/cjs/Thread/components/ThreadList.js.map +1 -1
- package/cjs/Thread/components/ThreadListItem.js +305 -275
- package/cjs/Thread/components/ThreadListItem.js.map +1 -1
- package/cjs/Thread/components/ThreadMessageInput.js +146 -113
- package/cjs/Thread/components/ThreadMessageInput.js.map +1 -1
- package/cjs/Thread/components/ThreadUI.js +170 -139
- package/cjs/Thread/components/ThreadUI.js.map +1 -1
- package/cjs/Thread/context/types.js +13 -14
- package/cjs/Thread/context/types.js.map +1 -1
- package/cjs/Thread/context.js +8 -8
- package/cjs/Thread.js +87 -57
- package/cjs/Thread.js.map +1 -1
- package/cjs/ThreadProvider-09392c06.js +1704 -0
- package/cjs/ThreadProvider-09392c06.js.map +1 -0
- package/cjs/{UserProfileContext-8d0dee57.js → UserProfileContext-10e1ac24.js} +1 -4
- package/cjs/{UserProfileContext-8d0dee57.js.map → UserProfileContext-10e1ac24.js.map} +1 -1
- package/cjs/VoiceMessageInputWrapper-fee2ede6.js +176 -0
- package/cjs/VoiceMessageInputWrapper-fee2ede6.js.map +1 -0
- package/cjs/VoicePlayer/context.js +17 -0
- package/cjs/{NotificationChannel → VoicePlayer}/context.js.map +1 -1
- package/cjs/VoicePlayer/useVoicePlayer.js +88 -0
- package/cjs/VoicePlayer/useVoicePlayer.js.map +1 -0
- package/cjs/VoiceRecorder/context.js +166 -0
- package/cjs/VoiceRecorder/context.js.map +1 -0
- package/cjs/VoiceRecorder/useVoiceRecorder.js +126 -0
- package/cjs/VoiceRecorder/useVoiceRecorder.js.map +1 -0
- package/cjs/WebAudioUtils-9dfbd5a9.js +126 -0
- package/cjs/WebAudioUtils-9dfbd5a9.js.map +1 -0
- package/cjs/{_rollupPluginBabelHelpers-fed1e122.js → _rollupPluginBabelHelpers-53e83515.js} +17 -10
- package/cjs/_rollupPluginBabelHelpers-53e83515.js.map +1 -0
- package/cjs/actionTypes-b1275c7f.js +10 -0
- package/cjs/actionTypes-b1275c7f.js.map +1 -0
- package/cjs/{color-f47044b3.js → color-e7fbb496.js} +13 -21
- package/cjs/color-e7fbb496.js.map +1 -0
- package/cjs/{compareIds-4124b297.js → compareIds-03cd7437.js} +5 -6
- package/cjs/compareIds-03cd7437.js.map +1 -0
- package/cjs/{const-fd64914b.js → const-8728e4b6.js} +4 -4
- package/cjs/const-8728e4b6.js.map +1 -0
- package/cjs/const-b3585ae0.js +20 -0
- package/cjs/const-b3585ae0.js.map +1 -0
- package/cjs/consts-6bd1cfe3.js +6 -0
- package/cjs/consts-6bd1cfe3.js.map +1 -0
- package/cjs/consts-a006bc78.js +6 -0
- package/cjs/consts-a006bc78.js.map +1 -0
- package/cjs/consts-a0e35044.js +6 -0
- package/cjs/consts-a0e35044.js.map +1 -0
- package/cjs/consts-aa056322.js +41 -0
- package/cjs/consts-aa056322.js.map +1 -0
- package/cjs/{context-7a0e057b.js → context-ad45a982.js} +6 -5
- package/cjs/{context-7a0e057b.js.map → context-ad45a982.js.map} +1 -1
- package/cjs/dist/index.css +1847 -1394
- package/cjs/dist/index.css.map +1 -1
- package/cjs/handlers/OpenChannelHandler.js.map +1 -1
- package/cjs/handlers/SessionHandler.js.map +1 -1
- package/cjs/{index-343cd84a.js → index-165d52b7.js} +2 -2
- package/cjs/{index-343cd84a.js.map → index-165d52b7.js.map} +1 -1
- package/cjs/index-288afd10.js +367 -0
- package/cjs/index-288afd10.js.map +1 -0
- package/cjs/{index-9ca07037.js → index-2f206bb6.js} +29 -37
- package/cjs/index-2f206bb6.js.map +1 -0
- package/cjs/index-32244c73.js +585 -0
- package/cjs/index-32244c73.js.map +1 -0
- package/cjs/index-35d641f7.js +202 -0
- package/cjs/index-35d641f7.js.map +1 -0
- package/cjs/{index-c475c3c8.js → index-3e924a85.js} +55 -63
- package/cjs/index-3e924a85.js.map +1 -0
- package/cjs/index-4a2ec2ae.js +456 -0
- package/cjs/index-4a2ec2ae.js.map +1 -0
- package/cjs/{index-d14a43c4.js → index-745c9ce1.js} +1 -1
- package/cjs/{index-d14a43c4.js.map → index-745c9ce1.js.map} +1 -1
- package/cjs/index-7bd7f678.js +79 -0
- package/cjs/index-7bd7f678.js.map +1 -0
- package/cjs/index-7d2d89a2.js +330 -0
- package/cjs/index-7d2d89a2.js.map +1 -0
- package/cjs/{index-c5cd589d.js → index-8ada6055.js} +1 -1
- package/cjs/index-8ada6055.js.map +1 -0
- package/cjs/{index-3a4f8219.js → index-9a94e768.js} +42 -51
- package/cjs/index-9a94e768.js.map +1 -0
- package/cjs/index-9f2a1c52.js +161 -0
- package/cjs/index-9f2a1c52.js.map +1 -0
- package/cjs/{index-abbc8024.js → index-9feae73e.js} +57 -3
- package/cjs/index-9feae73e.js.map +1 -0
- package/cjs/{index-8de8f28a.js → index-a01673e9.js} +2 -2
- package/cjs/{index-8de8f28a.js.map → index-a01673e9.js.map} +1 -1
- package/cjs/index-d0b4f3c0.js +57 -0
- package/cjs/index-d0b4f3c0.js.map +1 -0
- package/cjs/{index-5d5497c2.js → index-f6621210.js} +11 -25
- package/cjs/index-f6621210.js.map +1 -0
- package/cjs/index.js +84 -63
- package/cjs/index.js.map +1 -1
- package/cjs/index.module-02ae6df9.js +6 -0
- package/cjs/index.module-02ae6df9.js.map +1 -0
- package/cjs/lame.all.js +2541 -0
- package/cjs/lame.all.js.map +1 -0
- package/cjs/resolvedReplyType-da86056c.js +32 -0
- package/cjs/resolvedReplyType-da86056c.js.map +1 -0
- package/cjs/sendbirdSelectors.js +307 -417
- package/cjs/sendbirdSelectors.js.map +1 -1
- package/cjs/{stringSet-3e6167ef.js → stringSet-d212a015.js} +112 -90
- package/cjs/stringSet-d212a015.js.map +1 -0
- package/cjs/tokenize-b019fb84.js +164 -0
- package/cjs/tokenize-b019fb84.js.map +1 -0
- package/cjs/topics-77576a9c.js +18 -0
- package/cjs/topics-77576a9c.js.map +1 -0
- package/cjs/types-36ee2d00.js +17 -0
- package/cjs/types-36ee2d00.js.map +1 -0
- package/cjs/ui/Accordion.js +21 -24
- package/cjs/ui/Accordion.js.map +1 -1
- package/cjs/ui/AccordionGroup.js +10 -13
- package/cjs/ui/AccordionGroup.js.map +1 -1
- package/cjs/ui/AdminMessage.js +10 -13
- package/cjs/ui/AdminMessage.js.map +1 -1
- package/cjs/ui/Avatar.js +57 -79
- package/cjs/ui/Avatar.js.map +1 -1
- package/cjs/ui/Badge.js +16 -15
- package/cjs/ui/Badge.js.map +1 -1
- package/cjs/ui/BottomSheet.js +14 -12
- package/cjs/ui/BottomSheet.js.map +1 -1
- package/cjs/ui/Button.js +20 -35
- package/cjs/ui/Button.js.map +1 -1
- package/cjs/ui/ChannelAvatar.js +38 -41
- package/cjs/ui/ChannelAvatar.js.map +1 -1
- package/cjs/ui/Checkbox.js +11 -13
- package/cjs/ui/Checkbox.js.map +1 -1
- package/cjs/ui/ConnectionStatus.js +7 -5
- package/cjs/ui/ConnectionStatus.js.map +1 -1
- package/cjs/ui/ContextMenu.js +175 -199
- package/cjs/ui/ContextMenu.js.map +1 -1
- package/cjs/ui/DateSeparator.js +12 -14
- package/cjs/ui/DateSeparator.js.map +1 -1
- package/cjs/ui/EmojiReactions.js +299 -107
- package/cjs/ui/EmojiReactions.js.map +1 -1
- package/cjs/ui/FileMessageItemBody.js +22 -23
- package/cjs/ui/FileMessageItemBody.js.map +1 -1
- package/cjs/ui/FileViewer.js +36 -36
- package/cjs/ui/FileViewer.js.map +1 -1
- package/cjs/ui/Icon.js +447 -623
- package/cjs/ui/Icon.js.map +1 -1
- package/cjs/ui/IconButton.js +20 -31
- package/cjs/ui/IconButton.js.map +1 -1
- package/cjs/ui/ImageRenderer.js +34 -43
- package/cjs/ui/ImageRenderer.js.map +1 -1
- package/cjs/ui/Input.js +16 -16
- package/cjs/ui/Input.js.map +1 -1
- package/cjs/ui/Label.js +2 -2
- package/cjs/ui/LinkLabel.js +4 -3
- package/cjs/ui/LinkLabel.js.map +1 -1
- package/cjs/ui/Loader.js +10 -12
- package/cjs/ui/Loader.js.map +1 -1
- package/cjs/ui/MentionLabel.js +58 -65
- package/cjs/ui/MentionLabel.js.map +1 -1
- package/cjs/ui/MentionUserLabel.js +12 -10
- package/cjs/ui/MentionUserLabel.js.map +1 -1
- package/cjs/ui/MessageContent.js +216 -550
- package/cjs/ui/MessageContent.js.map +1 -1
- package/cjs/ui/MessageInput.js +392 -119
- package/cjs/ui/MessageInput.js.map +1 -1
- package/cjs/ui/MessageItemMenu.js +83 -83
- package/cjs/ui/MessageItemMenu.js.map +1 -1
- package/cjs/ui/MessageItemReactionMenu.js +58 -62
- package/cjs/ui/MessageItemReactionMenu.js.map +1 -1
- package/cjs/ui/MessageSearchFileItem.js +56 -51
- package/cjs/ui/MessageSearchFileItem.js.map +1 -1
- package/cjs/ui/MessageSearchItem.js +42 -41
- package/cjs/ui/MessageSearchItem.js.map +1 -1
- package/cjs/ui/MessageStatus.js +10 -11
- package/cjs/ui/MessageStatus.js.map +1 -1
- package/cjs/ui/Modal.js +52 -46
- package/cjs/ui/Modal.js.map +1 -1
- package/cjs/ui/MutedAvatarOverlay.js +10 -10
- package/cjs/ui/MutedAvatarOverlay.js.map +1 -1
- package/cjs/ui/OGMessageItemBody.js +67 -63
- package/cjs/ui/OGMessageItemBody.js.map +1 -1
- package/cjs/ui/OpenChannelAdminMessage.js +8 -7
- package/cjs/ui/OpenChannelAdminMessage.js.map +1 -1
- package/cjs/ui/OpenChannelAvatar.js +18 -17
- package/cjs/ui/OpenChannelAvatar.js.map +1 -1
- package/cjs/ui/OpenchannelConversationHeader.js +17 -13
- package/cjs/ui/OpenchannelConversationHeader.js.map +1 -1
- package/cjs/ui/OpenchannelFileMessage.js +140 -151
- package/cjs/ui/OpenchannelFileMessage.js.map +1 -1
- package/cjs/ui/OpenchannelOGMessage.js +204 -233
- package/cjs/ui/OpenchannelOGMessage.js.map +1 -1
- package/cjs/ui/OpenchannelThumbnailMessage.js +215 -222
- package/cjs/ui/OpenchannelThumbnailMessage.js.map +1 -1
- package/cjs/ui/OpenchannelUserMessage.js +168 -178
- package/cjs/ui/OpenchannelUserMessage.js.map +1 -1
- package/cjs/ui/PlaceHolder.js +5 -6
- package/cjs/ui/PlaceHolder.js.map +1 -1
- package/cjs/ui/PlaybackTime.js +35 -0
- package/cjs/ui/PlaybackTime.js.map +1 -0
- package/cjs/ui/ProgressBar.js +40 -0
- package/cjs/ui/ProgressBar.js.map +1 -0
- package/cjs/ui/QuoteMessage.js +50 -44
- package/cjs/ui/QuoteMessage.js.map +1 -1
- package/cjs/ui/QuoteMessageInput.js +31 -29
- package/cjs/ui/QuoteMessageInput.js.map +1 -1
- package/cjs/ui/ReactionBadge.js +13 -21
- package/cjs/ui/ReactionBadge.js.map +1 -1
- package/cjs/ui/ReactionButton.js +30 -27
- package/cjs/ui/ReactionButton.js.map +1 -1
- package/cjs/ui/SortByRow.js +14 -18
- package/cjs/ui/SortByRow.js.map +1 -1
- package/cjs/ui/TextButton.js +13 -21
- package/cjs/ui/TextButton.js.map +1 -1
- package/cjs/ui/TextMessageItemBody.js +41 -48
- package/cjs/ui/TextMessageItemBody.js.map +1 -1
- package/cjs/ui/ThreadReplies.js +25 -22
- package/cjs/ui/ThreadReplies.js.map +1 -1
- package/cjs/ui/ThumbnailMessageItemBody.js +36 -45
- package/cjs/ui/ThumbnailMessageItemBody.js.map +1 -1
- package/cjs/ui/Toggle.js +202 -0
- package/cjs/ui/Toggle.js.map +1 -0
- package/cjs/ui/Tooltip.js +8 -9
- package/cjs/ui/Tooltip.js.map +1 -1
- package/cjs/ui/TooltipWrapper.js +17 -20
- package/cjs/ui/TooltipWrapper.js.map +1 -1
- package/cjs/ui/UnknownMessageItemBody.js +21 -22
- package/cjs/ui/UnknownMessageItemBody.js.map +1 -1
- package/cjs/ui/UserListItem.js +76 -76
- package/cjs/ui/UserListItem.js.map +1 -1
- package/cjs/ui/UserProfile.js +31 -29
- package/cjs/ui/UserProfile.js.map +1 -1
- package/cjs/ui/VoiceMessageItemBody.js +119 -0
- package/cjs/ui/VoiceMessageItemBody.js.map +1 -0
- package/cjs/ui/VoiceMessgeInput.js +22 -0
- package/cjs/ui/VoiceMessgeInput.js.map +1 -0
- package/cjs/ui/Word.js +31 -39
- package/cjs/ui/Word.js.map +1 -1
- package/cjs/useDirtyGetMentions-792a65af.js +77 -0
- package/cjs/useDirtyGetMentions-792a65af.js.map +1 -0
- package/cjs/useLongPress-50d2028a.js +87 -0
- package/cjs/useLongPress-50d2028a.js.map +1 -0
- package/cjs/useSendbirdStateContext.js +2 -3
- package/cjs/useSendbirdStateContext.js.map +1 -1
- package/cjs/utils/message/getOutgoingMessageState.js +16 -21
- package/cjs/utils/message/getOutgoingMessageState.js.map +1 -1
- package/cjs/utils/message/isVoiceMessage.js +12 -0
- package/cjs/utils/message/isVoiceMessage.js.map +1 -0
- package/cjs/{utils-374d57b4.js → utils-85ff9137.js} +1 -1
- package/cjs/{utils-374d57b4.js.map → utils-85ff9137.js.map} +1 -1
- package/cjs/{utils-5f86a394.js → utils-8ce3a247.js} +3 -7
- package/cjs/{utils-5f86a394.js.map → utils-8ce3a247.js.map} +1 -1
- package/cjs/utils-c2543c4d.js +31 -0
- package/cjs/utils-c2543c4d.js.map +1 -0
- package/cjs/utils-d2648e7d.js +35 -0
- package/cjs/utils-d2648e7d.js.map +1 -0
- package/cjs/uuid-97ce2508.js +15 -0
- package/cjs/{uuid-2475ef6c.js.map → uuid-97ce2508.js.map} +1 -1
- package/cjs/withSendbird.js +5 -6
- package/cjs/withSendbird.js.map +1 -1
- package/{color-163ba24d.js → color-04427a41.js} +5 -14
- package/{color-163ba24d.js.map → color-04427a41.js.map} +1 -1
- package/{compareIds-ef41eb2c.js → compareIds-e75af4f9.js} +5 -6
- package/compareIds-e75af4f9.js.map +1 -0
- package/{const-76d87f47.js → const-8d418b81.js} +4 -4
- package/const-8d418b81.js.map +1 -0
- package/const-ec18f7f8.js +13 -0
- package/const-ec18f7f8.js.map +1 -0
- package/consts-01a1e3c0.js +4 -0
- package/consts-01a1e3c0.js.map +1 -0
- package/consts-4d93ce13.js +4 -0
- package/consts-4d93ce13.js.map +1 -0
- package/consts-a5106683.js +4 -0
- package/consts-a5106683.js.map +1 -0
- package/consts-e6fdc559.js +27 -0
- package/consts-e6fdc559.js.map +1 -0
- package/context-6272efa3.js +13 -0
- package/{context-10475c77.js.map → context-6272efa3.js.map} +1 -1
- package/dist/index.css +1847 -1394
- package/dist/index.css.map +1 -1
- package/handlers/OpenChannelHandler.js.map +1 -1
- package/handlers/SessionHandler.js.map +1 -1
- package/{index-12754b45.js → index-19daf00f.js} +55 -63
- package/index-19daf00f.js.map +1 -0
- package/index-24f4354d.js +450 -0
- package/index-24f4354d.js.map +1 -0
- package/index-2d858f6d.js +187 -0
- package/index-2d858f6d.js.map +1 -0
- package/{index-232388fa.js → index-32a56033.js} +29 -37
- package/index-32a56033.js.map +1 -0
- package/index-36d49e08.js +154 -0
- package/index-36d49e08.js.map +1 -0
- package/{index-2f346069.js → index-5819e39d.js} +1 -1
- package/index-5819e39d.js.map +1 -0
- package/index-7ff2c073.js +360 -0
- package/index-7ff2c073.js.map +1 -0
- package/index-9a62272f.js +51 -0
- package/index-9a62272f.js.map +1 -0
- package/{index-4ebfc7a7.js → index-a4552c13.js} +1 -1
- package/{index-4ebfc7a7.js.map → index-a4552c13.js.map} +1 -1
- package/index-b3c3e1aa.js +76 -0
- package/index-b3c3e1aa.js.map +1 -0
- package/index-c589f349.js +540 -0
- package/index-c589f349.js.map +1 -0
- package/{index-2784bdd8.js → index-d88e3ef9.js} +11 -25
- package/index-d88e3ef9.js.map +1 -0
- package/{index-751f97ce.js → index-dcaf3cb8.js} +57 -4
- package/index-dcaf3cb8.js.map +1 -0
- package/{index-a02da5bd.js → index-dd8e8ea1.js} +2 -2
- package/{index-a02da5bd.js.map → index-dd8e8ea1.js.map} +1 -1
- package/index-f4374646.js +320 -0
- package/index-f4374646.js.map +1 -0
- package/{index-aea7b7d6.js → index-fe7ed4c0.js} +39 -48
- package/index-fe7ed4c0.js.map +1 -0
- package/{index-3c013a28.js → index-fea4f7d3.js} +2 -2
- package/{index-3c013a28.js.map → index-fea4f7d3.js.map} +1 -1
- package/index.d.ts +176 -124
- package/index.js +84 -63
- package/index.js.map +1 -1
- package/index.module-1ba8586e.js +4 -0
- package/index.module-1ba8586e.js.map +1 -0
- package/lame.all.js +2537 -0
- package/lame.all.js.map +1 -0
- package/package.json +62 -41
- package/resolvedReplyType-94a089b3.js +29 -0
- package/resolvedReplyType-94a089b3.js.map +1 -0
- package/sendbirdSelectors.js +307 -417
- package/sendbirdSelectors.js.map +1 -1
- package/{stringSet-9ae71b7d.js → stringSet-3649b375.js} +112 -90
- package/stringSet-3649b375.js.map +1 -0
- package/tokenize-053e921e.js +159 -0
- package/tokenize-053e921e.js.map +1 -0
- package/topics-d0dcd2f2.js +16 -0
- package/topics-d0dcd2f2.js.map +1 -0
- package/types-54edb45d.js +15 -0
- package/types-54edb45d.js.map +1 -0
- package/ui/Accordion.js +21 -24
- package/ui/Accordion.js.map +1 -1
- package/ui/AccordionGroup.js +10 -13
- package/ui/AccordionGroup.js.map +1 -1
- package/ui/AdminMessage.js +10 -13
- package/ui/AdminMessage.js.map +1 -1
- package/ui/Avatar.js +57 -79
- package/ui/Avatar.js.map +1 -1
- package/ui/Badge.js +16 -15
- package/ui/Badge.js.map +1 -1
- package/ui/BottomSheet.js +14 -12
- package/ui/BottomSheet.js.map +1 -1
- package/ui/Button.js +20 -35
- package/ui/Button.js.map +1 -1
- package/ui/ChannelAvatar.js +38 -41
- package/ui/ChannelAvatar.js.map +1 -1
- package/ui/Checkbox.js +11 -13
- package/ui/Checkbox.js.map +1 -1
- package/ui/ConnectionStatus.js +7 -5
- package/ui/ConnectionStatus.js.map +1 -1
- package/ui/ContextMenu.js +176 -200
- package/ui/ContextMenu.js.map +1 -1
- package/ui/DateSeparator.js +12 -14
- package/ui/DateSeparator.js.map +1 -1
- package/ui/EmojiReactions.js +300 -108
- package/ui/EmojiReactions.js.map +1 -1
- package/ui/FileMessageItemBody.js +22 -23
- package/ui/FileMessageItemBody.js.map +1 -1
- package/ui/FileViewer.js +36 -36
- package/ui/FileViewer.js.map +1 -1
- package/ui/Icon.js +448 -622
- package/ui/Icon.js.map +1 -1
- package/ui/IconButton.js +20 -31
- package/ui/IconButton.js.map +1 -1
- package/ui/ImageRenderer.js +34 -43
- package/ui/ImageRenderer.js.map +1 -1
- package/ui/Input.js +16 -16
- package/ui/Input.js.map +1 -1
- package/ui/Label.js +2 -2
- package/ui/LinkLabel.js +4 -3
- package/ui/LinkLabel.js.map +1 -1
- package/ui/Loader.js +10 -12
- package/ui/Loader.js.map +1 -1
- package/ui/MentionLabel.js +58 -65
- package/ui/MentionLabel.js.map +1 -1
- package/ui/MentionUserLabel.js +12 -10
- package/ui/MentionUserLabel.js.map +1 -1
- package/ui/MessageContent.js +219 -553
- package/ui/MessageContent.js.map +1 -1
- package/ui/MessageInput.js +392 -120
- package/ui/MessageInput.js.map +1 -1
- package/ui/MessageItemMenu.js +83 -83
- package/ui/MessageItemMenu.js.map +1 -1
- package/ui/MessageItemReactionMenu.js +58 -62
- package/ui/MessageItemReactionMenu.js.map +1 -1
- package/ui/MessageSearchFileItem.js +55 -50
- package/ui/MessageSearchFileItem.js.map +1 -1
- package/ui/MessageSearchItem.js +41 -40
- package/ui/MessageSearchItem.js.map +1 -1
- package/ui/MessageStatus.js +10 -11
- package/ui/MessageStatus.js.map +1 -1
- package/ui/Modal.js +52 -46
- package/ui/Modal.js.map +1 -1
- package/ui/MutedAvatarOverlay.js +10 -10
- package/ui/MutedAvatarOverlay.js.map +1 -1
- package/ui/OGMessageItemBody.js +68 -64
- package/ui/OGMessageItemBody.js.map +1 -1
- package/ui/OpenChannelAdminMessage.js +8 -7
- package/ui/OpenChannelAdminMessage.js.map +1 -1
- package/ui/OpenChannelAvatar.js +18 -17
- package/ui/OpenChannelAvatar.js.map +1 -1
- package/ui/OpenchannelConversationHeader.js +17 -13
- package/ui/OpenchannelConversationHeader.js.map +1 -1
- package/ui/OpenchannelFileMessage.js +140 -151
- package/ui/OpenchannelFileMessage.js.map +1 -1
- package/ui/OpenchannelOGMessage.js +204 -233
- package/ui/OpenchannelOGMessage.js.map +1 -1
- package/ui/OpenchannelThumbnailMessage.js +215 -222
- package/ui/OpenchannelThumbnailMessage.js.map +1 -1
- package/ui/OpenchannelUserMessage.js +168 -178
- package/ui/OpenchannelUserMessage.js.map +1 -1
- package/ui/PlaceHolder.js +5 -6
- package/ui/PlaceHolder.js.map +1 -1
- package/ui/PlaybackTime.js +26 -0
- package/ui/PlaybackTime.js.map +1 -0
- package/ui/ProgressBar.js +30 -0
- package/ui/ProgressBar.js.map +1 -0
- package/ui/QuoteMessage.js +50 -44
- package/ui/QuoteMessage.js.map +1 -1
- package/ui/QuoteMessageInput.js +31 -29
- package/ui/QuoteMessageInput.js.map +1 -1
- package/ui/ReactionBadge.js +13 -21
- package/ui/ReactionBadge.js.map +1 -1
- package/ui/ReactionButton.js +30 -27
- package/ui/ReactionButton.js.map +1 -1
- package/ui/SortByRow.js +14 -18
- package/ui/SortByRow.js.map +1 -1
- package/ui/TextButton.js +13 -21
- package/ui/TextButton.js.map +1 -1
- package/ui/TextMessageItemBody.js +41 -48
- package/ui/TextMessageItemBody.js.map +1 -1
- package/ui/ThreadReplies.js +25 -22
- package/ui/ThreadReplies.js.map +1 -1
- package/ui/ThumbnailMessageItemBody.js +36 -45
- package/ui/ThumbnailMessageItemBody.js.map +1 -1
- package/ui/Toggle.js +191 -0
- package/ui/Toggle.js.map +1 -0
- package/ui/Tooltip.js +8 -9
- package/ui/Tooltip.js.map +1 -1
- package/ui/TooltipWrapper.js +17 -20
- package/ui/TooltipWrapper.js.map +1 -1
- package/ui/UnknownMessageItemBody.js +21 -22
- package/ui/UnknownMessageItemBody.js.map +1 -1
- package/ui/UserListItem.js +76 -76
- package/ui/UserListItem.js.map +1 -1
- package/ui/UserProfile.js +31 -29
- package/ui/UserProfile.js.map +1 -1
- package/ui/VoiceMessageItemBody.js +110 -0
- package/ui/VoiceMessageItemBody.js.map +1 -0
- package/ui/VoiceMessgeInput.js +14 -0
- package/ui/VoiceMessgeInput.js.map +1 -0
- package/ui/Word.js +31 -39
- package/ui/Word.js.map +1 -1
- package/useDirtyGetMentions-b9a9c21b.js +75 -0
- package/useDirtyGetMentions-b9a9c21b.js.map +1 -0
- package/useLongPress-5e28b292.js +85 -0
- package/useLongPress-5e28b292.js.map +1 -0
- package/useSendbirdStateContext.js +2 -3
- package/useSendbirdStateContext.js.map +1 -1
- package/utils/message/getOutgoingMessageState.js +9 -15
- package/utils/message/getOutgoingMessageState.js.map +1 -1
- package/utils/message/isVoiceMessage.js +8 -0
- package/utils/message/isVoiceMessage.js.map +1 -0
- package/utils-1f5c8b6c.js +29 -0
- package/utils-1f5c8b6c.js.map +1 -0
- package/{utils-ddb0df4c.js → utils-712b81f7.js} +3 -7
- package/{utils-ddb0df4c.js.map → utils-712b81f7.js.map} +1 -1
- package/{utils-ea66f822.js → utils-a1f2aa01.js} +1 -1
- package/{utils-ea66f822.js.map → utils-a1f2aa01.js.map} +1 -1
- package/utils-cbae9afc.js +31 -0
- package/utils-cbae9afc.js.map +1 -0
- package/uuid-8c96bee0.js +13 -0
- package/{uuid-7e004f47.js.map → uuid-8c96bee0.js.map} +1 -1
- package/withSendbird.js +5 -6
- package/withSendbird.js.map +1 -1
- package/ChannelListProvider-1d36e2e9.js.map +0 -1
- package/ChannelProvider-289cd35f.js.map +0 -1
- package/CreateChannelProvider-72b655e9.js +0 -55
- package/CreateChannelProvider-72b655e9.js.map +0 -1
- package/LocalizationContext-289c1917.js +0 -22
- package/MediaQueryContext-273d29f6.js +0 -90
- package/MediaQueryContext-273d29f6.js.map +0 -1
- package/MemberList-7ad0fa0b.js +0 -435
- package/MemberList-7ad0fa0b.js.map +0 -1
- package/NotificationChannel/components/NotificationChannelUI.js +0 -119
- package/NotificationChannel/components/NotificationChannelUI.js.map +0 -1
- package/NotificationChannel/components/NotificationList.js +0 -111
- package/NotificationChannel/components/NotificationList.js.map +0 -1
- package/NotificationChannel/components/NotificationMessageWrap.js +0 -136
- package/NotificationChannel/components/NotificationMessageWrap.js.map +0 -1
- package/NotificationChannel/context.js +0 -12
- package/NotificationChannel.js +0 -58
- package/NotificationChannel.js.map +0 -1
- package/NotificationChannelProvider-ad556c64.js +0 -535
- package/NotificationChannelProvider-ad556c64.js.map +0 -1
- package/OpenChannelListProvider-0febf8b2.js +0 -434
- package/OpenChannelListProvider-0febf8b2.js.map +0 -1
- package/OpenChannelProvider-c254c663.js +0 -2000
- package/OpenChannelProvider-c254c663.js.map +0 -1
- package/RemoveMessageModal-d6cbf9fa.js +0 -31
- package/RemoveMessageModal-d6cbf9fa.js.map +0 -1
- package/ThreadProvider-8696ef31.js +0 -1644
- package/ThreadProvider-8696ef31.js.map +0 -1
- package/_rollupPluginBabelHelpers-519f674b.js.map +0 -1
- package/actionTypes-9f87e87f.js +0 -6
- package/actionTypes-9f87e87f.js.map +0 -1
- package/cjs/ChannelListProvider-0de52d2b.js.map +0 -1
- package/cjs/ChannelProvider-fc58e60e.js.map +0 -1
- package/cjs/CreateChannelProvider-a82d20f4.js +0 -62
- package/cjs/CreateChannelProvider-a82d20f4.js.map +0 -1
- package/cjs/MediaQueryContext-4711a81f.js +0 -97
- package/cjs/MediaQueryContext-4711a81f.js.map +0 -1
- package/cjs/MemberList-b2623166.js +0 -441
- package/cjs/MemberList-b2623166.js.map +0 -1
- package/cjs/NotificationChannel/components/NotificationChannelUI.js +0 -125
- package/cjs/NotificationChannel/components/NotificationChannelUI.js.map +0 -1
- package/cjs/NotificationChannel/components/NotificationList.js +0 -117
- package/cjs/NotificationChannel/components/NotificationList.js.map +0 -1
- package/cjs/NotificationChannel/components/NotificationMessageWrap.js +0 -142
- package/cjs/NotificationChannel/components/NotificationMessageWrap.js.map +0 -1
- package/cjs/NotificationChannel/context.js +0 -21
- package/cjs/NotificationChannel.js +0 -64
- package/cjs/NotificationChannel.js.map +0 -1
- package/cjs/NotificationChannelProvider-2cdc7ff4.js +0 -543
- package/cjs/NotificationChannelProvider-2cdc7ff4.js.map +0 -1
- package/cjs/OpenChannelListProvider-60bc3c69.js +0 -443
- package/cjs/OpenChannelListProvider-60bc3c69.js.map +0 -1
- package/cjs/OpenChannelProvider-3ed4eb6e.js +0 -2009
- package/cjs/OpenChannelProvider-3ed4eb6e.js.map +0 -1
- package/cjs/RemoveMessageModal-9169766a.js.map +0 -1
- package/cjs/ThreadProvider-389f5031.js +0 -1653
- package/cjs/ThreadProvider-389f5031.js.map +0 -1
- package/cjs/_rollupPluginBabelHelpers-fed1e122.js.map +0 -1
- package/cjs/actionTypes-2f90e726.js +0 -10
- package/cjs/actionTypes-2f90e726.js.map +0 -1
- package/cjs/color-f47044b3.js.map +0 -1
- package/cjs/compareIds-4124b297.js.map +0 -1
- package/cjs/const-015e5589.js +0 -20
- package/cjs/const-015e5589.js.map +0 -1
- package/cjs/const-fd64914b.js.map +0 -1
- package/cjs/index-30c97863.js +0 -194
- package/cjs/index-30c97863.js.map +0 -1
- package/cjs/index-3a4f8219.js.map +0 -1
- package/cjs/index-40e4653a.js +0 -59
- package/cjs/index-40e4653a.js.map +0 -1
- package/cjs/index-5d5497c2.js.map +0 -1
- package/cjs/index-62c1bdfc.js +0 -701
- package/cjs/index-62c1bdfc.js.map +0 -1
- package/cjs/index-9ca07037.js.map +0 -1
- package/cjs/index-9f3670d0.js +0 -360
- package/cjs/index-9f3670d0.js.map +0 -1
- package/cjs/index-abbc8024.js.map +0 -1
- package/cjs/index-c475c3c8.js.map +0 -1
- package/cjs/index-c5cd589d.js.map +0 -1
- package/cjs/stringSet-3e6167ef.js.map +0 -1
- package/cjs/topics-56842e14.js +0 -22
- package/cjs/topics-56842e14.js.map +0 -1
- package/cjs/tslib.es6-b8ba50ef.js +0 -110
- package/cjs/tslib.es6-b8ba50ef.js.map +0 -1
- package/cjs/useLongPress-99c66f7f.js +0 -118
- package/cjs/useLongPress-99c66f7f.js.map +0 -1
- package/cjs/utils-9adfd244.js +0 -38
- package/cjs/utils-9adfd244.js.map +0 -1
- package/cjs/utils-f6a96ebf.js +0 -32
- package/cjs/utils-f6a96ebf.js.map +0 -1
- package/cjs/uuid-2475ef6c.js +0 -19
- package/compareIds-ef41eb2c.js.map +0 -1
- package/const-76d87f47.js.map +0 -1
- package/const-da6f3d34.js +0 -14
- package/const-da6f3d34.js.map +0 -1
- package/context-10475c77.js +0 -12
- package/index-12754b45.js.map +0 -1
- package/index-1e46e582.js +0 -179
- package/index-1e46e582.js.map +0 -1
- package/index-232388fa.js.map +0 -1
- package/index-2784bdd8.js.map +0 -1
- package/index-2f346069.js.map +0 -1
- package/index-4637b0de.js +0 -57
- package/index-4637b0de.js.map +0 -1
- package/index-4900e890.js +0 -353
- package/index-4900e890.js.map +0 -1
- package/index-751f97ce.js.map +0 -1
- package/index-855ef33d.js +0 -662
- package/index-855ef33d.js.map +0 -1
- package/index-aea7b7d6.js.map +0 -1
- package/stringSet-9ae71b7d.js.map +0 -1
- package/topics-e2963bba.js +0 -13
- package/topics-e2963bba.js.map +0 -1
- package/tslib.es6-72df3331.js +0 -104
- package/tslib.es6-72df3331.js.map +0 -1
- package/useLongPress-1a777e9e.js +0 -116
- package/useLongPress-1a777e9e.js.map +0 -1
- package/utils-2976f2c1.js +0 -30
- package/utils-2976f2c1.js.map +0 -1
- package/utils-6b69fb18.js +0 -34
- package/utils-6b69fb18.js.map +0 -1
- package/uuid-7e004f47.js +0 -17
|
@@ -1,230 +1,267 @@
|
|
|
1
|
-
import React__default, { useState,
|
|
2
|
-
import { i as
|
|
3
|
-
import {
|
|
4
|
-
import { P as PlaceHolder, a as PlaceHolderTypes } from '../../index-232388fa.js';
|
|
1
|
+
import React__default, { useState, useEffect } from 'react';
|
|
2
|
+
import { c as compareMessagesForGrouping, u as useChannelContext, i as isAboutSame } from '../../ChannelProvider-33559192.js';
|
|
3
|
+
import { P as PlaceHolder, a as PlaceHolderTypes } from '../../index-32a56033.js';
|
|
5
4
|
import Icon, { IconTypes, IconColors } from '../../ui/Icon.js';
|
|
6
5
|
import Message from './Message.js';
|
|
7
|
-
import {
|
|
8
|
-
import '
|
|
9
|
-
import '
|
|
10
|
-
import '../../
|
|
6
|
+
import { i as isSameDay } from '../../index-dd8e8ea1.js';
|
|
7
|
+
import UnreadCount from './UnreadCount.js';
|
|
8
|
+
import FrozenNotification from './FrozenNotification.js';
|
|
9
|
+
import { S as SCROLL_BUFFER } from '../../consts-e6fdc559.js';
|
|
10
|
+
import useSendbirdStateContext from '../../useSendbirdStateContext.js';
|
|
11
|
+
import { MessageProvider } from '../../Message/context.js';
|
|
12
|
+
import { u as useDebounce, a as useHandleOnScrollCallback } from '../../index-b3c3e1aa.js';
|
|
13
|
+
import '../../UserProfileContext-a56cc682.js';
|
|
11
14
|
import 'prop-types';
|
|
12
|
-
import '../../
|
|
13
|
-
import '../../
|
|
14
|
-
import '../../
|
|
15
|
-
import '../../topics-
|
|
16
|
-
import '../../index-
|
|
17
|
-
import '../../
|
|
15
|
+
import '../../const-ec18f7f8.js';
|
|
16
|
+
import '../../index-fea4f7d3.js';
|
|
17
|
+
import '../../index-a4552c13.js';
|
|
18
|
+
import '../../topics-d0dcd2f2.js';
|
|
19
|
+
import '../../index-c589f349.js';
|
|
20
|
+
import '../../_rollupPluginBabelHelpers-1be219c2.js';
|
|
18
21
|
import '../../utils/message/getOutgoingMessageState.js';
|
|
19
|
-
import '../../compareIds-
|
|
20
|
-
import '../../const-da6f3d34.js';
|
|
22
|
+
import '../../compareIds-e75af4f9.js';
|
|
21
23
|
import '@sendbird/chat/groupChannel';
|
|
24
|
+
import '../../uuid-8c96bee0.js';
|
|
22
25
|
import '@sendbird/chat/message';
|
|
23
|
-
import '../../
|
|
24
|
-
import '
|
|
25
|
-
import '../../
|
|
26
|
-
import '../../index-
|
|
27
|
-
import '../../stringSet-9ae71b7d.js';
|
|
28
|
-
import '../../ui/ReactionButton.js';
|
|
29
|
-
import '../../ui/ImageRenderer.js';
|
|
30
|
-
import '../../LocalizationContext-289c1917.js';
|
|
26
|
+
import '../../resolvedReplyType-94a089b3.js';
|
|
27
|
+
import '../../LocalizationContext-25d6694d.js';
|
|
28
|
+
import '../../stringSet-3649b375.js';
|
|
29
|
+
import '../../index-d88e3ef9.js';
|
|
31
30
|
import '../../ui/Loader.js';
|
|
32
31
|
import './SuggestedMentionList.js';
|
|
33
32
|
import '../../ui/Avatar.js';
|
|
34
|
-
import '../../
|
|
35
|
-
import '../../
|
|
33
|
+
import '../../ui/ImageRenderer.js';
|
|
34
|
+
import '../../const-8d418b81.js';
|
|
35
|
+
import '../../ThreadProvider-6ae0b041.js';
|
|
36
36
|
import '../../Thread/context/types.js';
|
|
37
37
|
import '@sendbird/chat';
|
|
38
38
|
import '../../ui/DateSeparator.js';
|
|
39
|
-
import '../../color-
|
|
39
|
+
import '../../color-04427a41.js';
|
|
40
40
|
import '../../ui/MessageInput.js';
|
|
41
|
-
import 'react-dom/server';
|
|
42
41
|
import '../../ui/IconButton.js';
|
|
43
42
|
import '../../ui/Button.js';
|
|
44
|
-
import '
|
|
43
|
+
import 'dompurify';
|
|
44
|
+
import '../../consts-4d93ce13.js';
|
|
45
|
+
import '../../consts-a5106683.js';
|
|
46
|
+
import '../../consts-01a1e3c0.js';
|
|
47
|
+
import '../../tokenize-053e921e.js';
|
|
48
|
+
import '../../index.module-1ba8586e.js';
|
|
45
49
|
import '../../ui/MessageContent.js';
|
|
46
50
|
import '../../ui/UserProfile.js';
|
|
47
51
|
import '../../sendbirdSelectors.js';
|
|
48
|
-
import '../../utils-
|
|
49
|
-
import '../../index-
|
|
50
|
-
import '../../index-
|
|
51
|
-
import '../../index-4637b0de.js';
|
|
52
|
+
import '../../utils-a1f2aa01.js';
|
|
53
|
+
import '../../index-fe7ed4c0.js';
|
|
54
|
+
import '../../index-dcaf3cb8.js';
|
|
52
55
|
import '../../ui/MessageItemMenu.js';
|
|
56
|
+
import '../../ui/ContextMenu.js';
|
|
57
|
+
import 'react-dom';
|
|
58
|
+
import '../../ui/SortByRow.js';
|
|
59
|
+
import '../../types-54edb45d.js';
|
|
53
60
|
import '../../ui/MessageItemReactionMenu.js';
|
|
61
|
+
import '../../ui/ReactionButton.js';
|
|
62
|
+
import '../../useLongPress-5e28b292.js';
|
|
63
|
+
import '../../MediaQueryContext-94c9086a.js';
|
|
54
64
|
import '../../ui/EmojiReactions.js';
|
|
65
|
+
import '../../ui/ReactionBadge.js';
|
|
66
|
+
import '../../ui/BottomSheet.js';
|
|
67
|
+
import '../../index-5819e39d.js';
|
|
68
|
+
import '../../ui/UserListItem.js';
|
|
69
|
+
import '../../ui/MutedAvatarOverlay.js';
|
|
70
|
+
import '../../ui/Checkbox.js';
|
|
55
71
|
import '../../ui/Tooltip.js';
|
|
56
72
|
import '../../ui/TooltipWrapper.js';
|
|
57
|
-
import '../../ui/ReactionBadge.js';
|
|
58
73
|
import '../../ui/AdminMessage.js';
|
|
59
74
|
import '../../ui/TextMessageItemBody.js';
|
|
60
|
-
import '../../
|
|
61
|
-
import '../../ui/LinkLabel.js';
|
|
75
|
+
import '../../index-9a62272f.js';
|
|
62
76
|
import '../../ui/MentionLabel.js';
|
|
77
|
+
import '../../ui/LinkLabel.js';
|
|
63
78
|
import '../../ui/FileMessageItemBody.js';
|
|
64
79
|
import '../../ui/TextButton.js';
|
|
65
|
-
import '../../MediaQueryContext-273d29f6.js';
|
|
66
80
|
import '../../ui/ThumbnailMessageItemBody.js';
|
|
67
81
|
import '../../ui/OGMessageItemBody.js';
|
|
68
82
|
import '../../ui/UnknownMessageItemBody.js';
|
|
69
83
|
import '../../ui/QuoteMessage.js';
|
|
70
|
-
import '../../
|
|
71
|
-
import '../../ui/BottomSheet.js';
|
|
72
|
-
import '../../index-2f346069.js';
|
|
84
|
+
import '../../index-24f4354d.js';
|
|
73
85
|
import '../../ui/ThreadReplies.js';
|
|
86
|
+
import '../../ui/VoiceMessageItemBody.js';
|
|
87
|
+
import '../../ui/ProgressBar.js';
|
|
88
|
+
import '../../VoicePlayer/useVoicePlayer.js';
|
|
89
|
+
import '../../index-f4374646.js';
|
|
90
|
+
import '../../VoiceRecorder/context.js';
|
|
91
|
+
import '../../ui/Modal.js';
|
|
92
|
+
import '../../withSendbird.js';
|
|
93
|
+
import '../../ui/PlaybackTime.js';
|
|
74
94
|
import './FileViewer.js';
|
|
75
95
|
import './RemoveMessageModal.js';
|
|
76
|
-
import '../../
|
|
77
|
-
|
|
78
|
-
var SCROLL_REF_CLASS_NAME = '.sendbird-msg--scroll-ref';
|
|
79
|
-
|
|
80
|
-
var MessageList = function (props) {
|
|
81
|
-
var renderMessage = props.renderMessage,
|
|
82
|
-
renderPlaceholderEmpty = props.renderPlaceholderEmpty,
|
|
83
|
-
renderCustomSeparator = props.renderCustomSeparator;
|
|
96
|
+
import '../../useDirtyGetMentions-b9a9c21b.js';
|
|
84
97
|
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
var scrollTop = element.scrollTop,
|
|
108
|
-
clientHeight = element.clientHeight,
|
|
109
|
-
scrollHeight = element.scrollHeight;
|
|
110
|
-
|
|
111
|
-
if (scrollTop === 0) {
|
|
112
|
-
if (!hasMorePrev) {
|
|
113
|
-
return;
|
|
114
|
-
}
|
|
98
|
+
const getMessagePartsInfo = _ref => {
|
|
99
|
+
let {
|
|
100
|
+
allMessages = [],
|
|
101
|
+
isMessageGroupingEnabled = true,
|
|
102
|
+
currentIndex = 0,
|
|
103
|
+
currentMessage = null,
|
|
104
|
+
currentChannel = null,
|
|
105
|
+
replyType = ''
|
|
106
|
+
} = _ref;
|
|
107
|
+
const previousMessage = allMessages[currentIndex - 1];
|
|
108
|
+
const nextMessage = allMessages[currentIndex + 1];
|
|
109
|
+
const [chainTop, chainBottom] = isMessageGroupingEnabled ? compareMessagesForGrouping(previousMessage, currentMessage, nextMessage, currentChannel, replyType) : [false, false];
|
|
110
|
+
const previousMessageCreatedAt = previousMessage === null || previousMessage === void 0 ? void 0 : previousMessage.createdAt;
|
|
111
|
+
const currentCreatedAt = currentMessage.createdAt;
|
|
112
|
+
// https://stackoverflow.com/a/41855608
|
|
113
|
+
const hasSeparator = !(previousMessageCreatedAt && isSameDay(currentCreatedAt, previousMessageCreatedAt));
|
|
114
|
+
return {
|
|
115
|
+
chainTop,
|
|
116
|
+
chainBottom,
|
|
117
|
+
hasSeparator
|
|
118
|
+
};
|
|
119
|
+
};
|
|
115
120
|
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
121
|
+
const DELAY = 500;
|
|
122
|
+
function useSetScrollToBottom(_ref) {
|
|
123
|
+
let {
|
|
124
|
+
loading
|
|
125
|
+
} = _ref;
|
|
126
|
+
const [scrollBottom, setScrollBottom] = useState(0);
|
|
127
|
+
useEffect(() => {
|
|
128
|
+
if (loading) {
|
|
129
|
+
setScrollBottom(0);
|
|
130
|
+
}
|
|
131
|
+
}, [loading]);
|
|
132
|
+
const scrollCb = e => {
|
|
133
|
+
const element = e.target;
|
|
134
|
+
try {
|
|
135
|
+
setScrollBottom(element.scrollHeight - element.scrollTop - element.offsetHeight);
|
|
136
|
+
} catch (_unused) {
|
|
137
|
+
//
|
|
138
|
+
}
|
|
139
|
+
};
|
|
140
|
+
return {
|
|
141
|
+
scrollBottom,
|
|
142
|
+
scrollToBottomHandler: useDebounce(scrollCb, DELAY)
|
|
143
|
+
};
|
|
144
|
+
}
|
|
120
145
|
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
146
|
+
const SCROLL_BOTTOM_PADDING = 50;
|
|
147
|
+
const MessageList = _ref => {
|
|
148
|
+
let {
|
|
149
|
+
className = '',
|
|
150
|
+
renderMessage,
|
|
151
|
+
renderPlaceholderEmpty,
|
|
152
|
+
renderCustomSeparator,
|
|
153
|
+
renderPlaceholderLoader
|
|
154
|
+
} = _ref;
|
|
155
|
+
const {
|
|
156
|
+
allMessages,
|
|
157
|
+
hasMorePrev,
|
|
158
|
+
hasMoreNext,
|
|
159
|
+
setInitialTimeStamp,
|
|
160
|
+
setAnimatedMessageId,
|
|
161
|
+
setHighLightedMessageId,
|
|
162
|
+
isMessageGroupingEnabled,
|
|
163
|
+
scrollRef,
|
|
164
|
+
onScrollCallback,
|
|
165
|
+
onScrollDownCallback,
|
|
166
|
+
messagesDispatcher,
|
|
167
|
+
messageActionTypes,
|
|
168
|
+
currentGroupChannel,
|
|
169
|
+
disableMarkAsRead,
|
|
170
|
+
filterMessageList,
|
|
171
|
+
replyType,
|
|
172
|
+
loading,
|
|
173
|
+
unreadSince
|
|
174
|
+
} = useChannelContext();
|
|
175
|
+
const store = useSendbirdStateContext();
|
|
176
|
+
const allMessagesFiltered = typeof filterMessageList === 'function' ? allMessages.filter(filterMessageList) : allMessages;
|
|
177
|
+
const markAsReadScheduler = store.config.markAsReadScheduler;
|
|
178
|
+
const onScroll = () => {
|
|
179
|
+
const element = scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current;
|
|
180
|
+
if (element == null) {
|
|
181
|
+
return;
|
|
182
|
+
}
|
|
183
|
+
const {
|
|
184
|
+
scrollTop,
|
|
185
|
+
clientHeight,
|
|
186
|
+
scrollHeight
|
|
187
|
+
} = element;
|
|
188
|
+
if (isAboutSame(scrollTop, 0, SCROLL_BUFFER)) {
|
|
189
|
+
onScrollCallback(messages => {
|
|
132
190
|
});
|
|
133
191
|
}
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
onScrollDownCallback(function (_a) {
|
|
137
|
-
_a[0];
|
|
192
|
+
if (isAboutSame(clientHeight + scrollTop, scrollHeight, SCROLL_BUFFER) && hasMoreNext) {
|
|
193
|
+
onScrollDownCallback(_ref2 => {
|
|
138
194
|
});
|
|
139
|
-
} // Save the lastest scroll bottom value
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
if (scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current) {
|
|
143
|
-
var current = scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current;
|
|
144
|
-
setScrollBottom(current.scrollHeight - current.scrollTop - current.offsetHeight);
|
|
145
195
|
}
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
messagesDispatcher({
|
|
153
|
-
type: messageActionTypes.MARK_AS_READ,
|
|
154
|
-
payload: {
|
|
155
|
-
channel: currentGroupChannel
|
|
156
|
-
}
|
|
157
|
-
});
|
|
158
|
-
|
|
159
|
-
try {
|
|
160
|
-
(_a = currentGroupChannel === null || currentGroupChannel === void 0 ? void 0 : currentGroupChannel.markAsRead) === null || _a === void 0 ? void 0 : _a.call(currentGroupChannel);
|
|
161
|
-
} catch (_b) {//
|
|
196
|
+
if (!disableMarkAsRead && isAboutSame(clientHeight + scrollTop, scrollHeight, SCROLL_BUFFER) && !!currentGroupChannel) {
|
|
197
|
+
messagesDispatcher({
|
|
198
|
+
type: messageActionTypes.MARK_AS_READ,
|
|
199
|
+
payload: {
|
|
200
|
+
channel: currentGroupChannel
|
|
162
201
|
}
|
|
163
|
-
}
|
|
202
|
+
});
|
|
203
|
+
markAsReadScheduler.push(currentGroupChannel);
|
|
164
204
|
}
|
|
165
205
|
};
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
var _a, _b, _c;
|
|
169
|
-
|
|
206
|
+
const onClickScrollBot = () => {
|
|
207
|
+
var _scrollRef$current;
|
|
170
208
|
setInitialTimeStamp === null || setInitialTimeStamp === void 0 ? void 0 : setInitialTimeStamp(null);
|
|
171
209
|
setAnimatedMessageId === null || setAnimatedMessageId === void 0 ? void 0 : setAnimatedMessageId(null);
|
|
172
210
|
setHighLightedMessageId === null || setHighLightedMessageId === void 0 ? void 0 : setHighLightedMessageId(null);
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
scrollRef.current.scrollTop = ((
|
|
211
|
+
if ((scrollRef === null || scrollRef === void 0 ? void 0 : (_scrollRef$current = scrollRef.current) === null || _scrollRef$current === void 0 ? void 0 : _scrollRef$current.scrollTop) > -1) {
|
|
212
|
+
var _scrollRef$current$sc, _scrollRef$current2, _scrollRef$current$of, _scrollRef$current3;
|
|
213
|
+
scrollRef.current.scrollTop = ((_scrollRef$current$sc = scrollRef === null || scrollRef === void 0 ? void 0 : (_scrollRef$current2 = scrollRef.current) === null || _scrollRef$current2 === void 0 ? void 0 : _scrollRef$current2.scrollHeight) !== null && _scrollRef$current$sc !== void 0 ? _scrollRef$current$sc : 0) - ((_scrollRef$current$of = scrollRef === null || scrollRef === void 0 ? void 0 : (_scrollRef$current3 = scrollRef.current) === null || _scrollRef$current3 === void 0 ? void 0 : _scrollRef$current3.offsetHeight) !== null && _scrollRef$current$of !== void 0 ? _scrollRef$current$of : 0);
|
|
176
214
|
}
|
|
177
|
-
};
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
var memoizedAllMessages = useMemo(function () {
|
|
181
|
-
return allMessages.map(function (m, idx) {
|
|
182
|
-
var previousMessage = allMessages[idx - 1];
|
|
183
|
-
var nextMessage = allMessages[idx + 1];
|
|
184
|
-
|
|
185
|
-
var _a = isMessageGroupingEnabled ? compareMessagesForGrouping(previousMessage, m, nextMessage, currentGroupChannel, replyType) : [false, false],
|
|
186
|
-
chainTop = _a[0],
|
|
187
|
-
chainBottom = _a[1];
|
|
188
|
-
|
|
189
|
-
var previousMessageCreatedAt = previousMessage === null || previousMessage === void 0 ? void 0 : previousMessage.createdAt;
|
|
190
|
-
var currentCreatedAt = m.createdAt; // https://stackoverflow.com/a/41855608
|
|
191
|
-
|
|
192
|
-
var hasSeparator = !(previousMessageCreatedAt && isSameDay(currentCreatedAt, previousMessageCreatedAt));
|
|
193
|
-
|
|
194
|
-
var handleScroll = function () {
|
|
195
|
-
var current = scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current;
|
|
196
|
-
|
|
197
|
-
if (current) {
|
|
198
|
-
var bottom = current.scrollHeight - current.scrollTop - current.offsetHeight;
|
|
199
|
-
|
|
200
|
-
if (scrollBottom < bottom) {
|
|
201
|
-
current.scrollTop += bottom - scrollBottom;
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
};
|
|
215
|
+
};
|
|
205
216
|
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
217
|
+
// Move the messsage list scroll when the last message's height is changed by reactions
|
|
218
|
+
const handleMessageHeightChange = () => {
|
|
219
|
+
const current = scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current;
|
|
220
|
+
if (current) {
|
|
221
|
+
const bottom = current.scrollHeight - current.scrollTop - current.offsetHeight;
|
|
222
|
+
if (scrollBottom < bottom && scrollBottom <= SCROLL_BUFFER) {
|
|
223
|
+
current.scrollTop += bottom - scrollBottom;
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
};
|
|
227
|
+
// Keep the scrollBottom value after fetching new message list
|
|
228
|
+
const handleMessageListHeightChange = () => {
|
|
229
|
+
const current = scrollRef === null || scrollRef === void 0 ? void 0 : scrollRef.current;
|
|
230
|
+
if (current) {
|
|
231
|
+
const bottom = current.scrollHeight - current.scrollTop - current.offsetHeight;
|
|
232
|
+
if (scrollBottom < bottom) {
|
|
233
|
+
current.scrollTop += bottom - scrollBottom;
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
};
|
|
237
|
+
const handleOnScroll = useHandleOnScrollCallback({
|
|
238
|
+
hasMore: hasMorePrev,
|
|
239
|
+
hasNext: hasMoreNext,
|
|
240
|
+
onScroll,
|
|
241
|
+
scrollRef
|
|
242
|
+
});
|
|
243
|
+
const {
|
|
244
|
+
scrollToBottomHandler,
|
|
245
|
+
scrollBottom
|
|
246
|
+
} = useSetScrollToBottom({
|
|
247
|
+
loading
|
|
248
|
+
});
|
|
249
|
+
if (loading) {
|
|
250
|
+
return typeof renderPlaceholderLoader === 'function' ? renderPlaceholderLoader() : /*#__PURE__*/React__default.createElement(PlaceHolder, {
|
|
251
|
+
type: PlaceHolderTypes.LOADING
|
|
216
252
|
});
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
253
|
+
}
|
|
254
|
+
if (allMessagesFiltered.length < 1) {
|
|
255
|
+
if (renderPlaceholderEmpty && typeof renderPlaceholderEmpty === 'function') {
|
|
256
|
+
return renderPlaceholderEmpty();
|
|
257
|
+
}
|
|
258
|
+
return /*#__PURE__*/React__default.createElement(PlaceHolder, {
|
|
221
259
|
className: "sendbird-conversation__no-messages",
|
|
222
260
|
type: PlaceHolderTypes.NO_MESSAGES
|
|
223
|
-
})
|
|
261
|
+
});
|
|
224
262
|
}
|
|
225
|
-
|
|
226
263
|
return /*#__PURE__*/React__default.createElement("div", {
|
|
227
|
-
className:
|
|
264
|
+
className: `sendbird-conversation__messages ${className}`
|
|
228
265
|
}, /*#__PURE__*/React__default.createElement("div", {
|
|
229
266
|
className: "sendbird-conversation__scroll-container"
|
|
230
267
|
}, /*#__PURE__*/React__default.createElement("div", {
|
|
@@ -232,9 +269,67 @@ var MessageList = function (props) {
|
|
|
232
269
|
}), /*#__PURE__*/React__default.createElement("div", {
|
|
233
270
|
className: "sendbird-conversation__messages-padding",
|
|
234
271
|
ref: scrollRef,
|
|
235
|
-
onScroll:
|
|
236
|
-
|
|
237
|
-
|
|
272
|
+
onScroll: e => {
|
|
273
|
+
handleOnScroll();
|
|
274
|
+
scrollToBottomHandler(e);
|
|
275
|
+
}
|
|
276
|
+
}, allMessagesFiltered.map((m, idx) => {
|
|
277
|
+
var _sender, _store$config;
|
|
278
|
+
const {
|
|
279
|
+
chainTop,
|
|
280
|
+
chainBottom,
|
|
281
|
+
hasSeparator
|
|
282
|
+
} = getMessagePartsInfo({
|
|
283
|
+
allMessages: allMessagesFiltered,
|
|
284
|
+
replyType,
|
|
285
|
+
isMessageGroupingEnabled,
|
|
286
|
+
currentIndex: idx,
|
|
287
|
+
currentMessage: m,
|
|
288
|
+
currentChannel: currentGroupChannel
|
|
289
|
+
});
|
|
290
|
+
const isByMe = (m === null || m === void 0 ? void 0 : (_sender = m.sender) === null || _sender === void 0 ? void 0 : _sender.userId) === (store === null || store === void 0 ? void 0 : (_store$config = store.config) === null || _store$config === void 0 ? void 0 : _store$config.userId);
|
|
291
|
+
return /*#__PURE__*/React__default.createElement(MessageProvider, {
|
|
292
|
+
message: m,
|
|
293
|
+
key: m === null || m === void 0 ? void 0 : m.messageId,
|
|
294
|
+
isByMe: isByMe
|
|
295
|
+
}, /*#__PURE__*/React__default.createElement(Message, {
|
|
296
|
+
handleScroll: handleMessageHeightChange,
|
|
297
|
+
handleMessageListHeightChange: handleMessageListHeightChange,
|
|
298
|
+
renderMessage: renderMessage,
|
|
299
|
+
message: m,
|
|
300
|
+
hasSeparator: hasSeparator,
|
|
301
|
+
chainTop: chainTop,
|
|
302
|
+
chainBottom: chainBottom,
|
|
303
|
+
renderCustomSeparator: renderCustomSeparator
|
|
304
|
+
}));
|
|
305
|
+
}))), (currentGroupChannel === null || currentGroupChannel === void 0 ? void 0 : currentGroupChannel.isFrozen) && /*#__PURE__*/React__default.createElement(FrozenNotification, {
|
|
306
|
+
className: "sendbird-conversation__messages__notification"
|
|
307
|
+
}), /*#__PURE__*/React__default.createElement(UnreadCount, {
|
|
308
|
+
className: "sendbird-conversation__messages__notification",
|
|
309
|
+
count: currentGroupChannel === null || currentGroupChannel === void 0 ? void 0 : currentGroupChannel.unreadMessageCount,
|
|
310
|
+
time: unreadSince,
|
|
311
|
+
onClick: () => {
|
|
312
|
+
var _scrollRef$current4;
|
|
313
|
+
if (scrollRef !== null && scrollRef !== void 0 && (_scrollRef$current4 = scrollRef.current) !== null && _scrollRef$current4 !== void 0 && _scrollRef$current4.scrollTop) {
|
|
314
|
+
var _scrollRef$current$sc2, _scrollRef$current5, _scrollRef$current$of2, _scrollRef$current6;
|
|
315
|
+
scrollRef.current.scrollTop = ((_scrollRef$current$sc2 = scrollRef === null || scrollRef === void 0 ? void 0 : (_scrollRef$current5 = scrollRef.current) === null || _scrollRef$current5 === void 0 ? void 0 : _scrollRef$current5.scrollHeight) !== null && _scrollRef$current$sc2 !== void 0 ? _scrollRef$current$sc2 : 0) - ((_scrollRef$current$of2 = scrollRef === null || scrollRef === void 0 ? void 0 : (_scrollRef$current6 = scrollRef.current) === null || _scrollRef$current6 === void 0 ? void 0 : _scrollRef$current6.offsetHeight) !== null && _scrollRef$current$of2 !== void 0 ? _scrollRef$current$of2 : 0);
|
|
316
|
+
}
|
|
317
|
+
if (!disableMarkAsRead && !!currentGroupChannel) {
|
|
318
|
+
markAsReadScheduler.push(currentGroupChannel);
|
|
319
|
+
messagesDispatcher({
|
|
320
|
+
type: messageActionTypes.MARK_AS_READ,
|
|
321
|
+
payload: {
|
|
322
|
+
channel: currentGroupChannel
|
|
323
|
+
}
|
|
324
|
+
});
|
|
325
|
+
}
|
|
326
|
+
setInitialTimeStamp(null);
|
|
327
|
+
setAnimatedMessageId(null);
|
|
328
|
+
setHighLightedMessageId(null);
|
|
329
|
+
}
|
|
330
|
+
}),
|
|
331
|
+
// This flag is an unmatched variable
|
|
332
|
+
scrollBottom > SCROLL_BOTTOM_PADDING && /*#__PURE__*/React__default.createElement("div", {
|
|
238
333
|
className: "sendbird-conversation__scroll-bottom-button",
|
|
239
334
|
onClick: onClickScrollBot,
|
|
240
335
|
onKeyDown: onClickScrollBot,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MessageList.js","sources":["../../../src/smart-components/Channel/components/MessageList/index.tsx"],"sourcesContent":["import './message-list.scss';\n\nimport React, { useState, useMemo } from 'react';\nimport isSameDay from 'date-fns/isSameDay';\n\nimport { useChannelContext } from '../../context/ChannelProvider';\nimport PlaceHolder, { PlaceHolderTypes } from '../../../../ui/PlaceHolder';\nimport Icon, { IconTypes, IconColors } from '../../../../ui/Icon';\nimport { compareMessagesForGrouping } from '../../context/utils';\nimport Message from '../Message';\nimport { RenderCustomSeparatorProps, RenderMessageProps } from '../../../../types';\nimport { isAboutSame } from '../../context/utils';\nimport uuidv4 from '../../../../utils/uuid';\n\nexport type MessageListProps = {\n renderMessage?: (props: RenderMessageProps) => React.ReactElement;\n renderPlaceholderEmpty?: () => React.ReactElement;\n renderCustomSeparator?: (props: RenderCustomSeparatorProps) => React.ReactElement;\n};\n\nconst SCROLL_REF_CLASS_NAME = '.sendbird-msg--scroll-ref';\n\nconst MessageList: React.FC<MessageListProps> = (props: MessageListProps) => {\n const {\n renderMessage,\n renderPlaceholderEmpty,\n renderCustomSeparator,\n } = props;\n const {\n allMessages,\n hasMorePrev,\n setInitialTimeStamp,\n setAnimatedMessageId,\n setHighLightedMessageId,\n isMessageGroupingEnabled,\n scrollRef,\n onScrollCallback,\n onScrollDownCallback,\n messagesDispatcher,\n messageActionTypes,\n currentGroupChannel,\n disableMarkAsRead,\n replyType,\n } = useChannelContext();\n const [scrollBottom, setScrollBottom] = useState(0);\n\n const onScroll = (e) => {\n const element = e.target;\n const {\n scrollTop,\n clientHeight,\n scrollHeight,\n } = element;\n\n if (scrollTop === 0) {\n if (!hasMorePrev) {\n return;\n }\n const nodes = scrollRef.current.querySelectorAll(SCROLL_REF_CLASS_NAME);\n const first = nodes && nodes[0];\n onScrollCallback(([messages]) => {\n if (messages) {\n // https://github.com/scabbiaza/react-scroll-position-on-updating-dom\n // Set block to nearest to prevent unexpected scrolling from outer components\n try {\n first.scrollIntoView({ block: \"start\", inline: \"nearest\" });\n } catch (error) {\n //\n }\n }\n });\n }\n\n if (isAboutSame(clientHeight + scrollTop, scrollHeight, 10)) {\n onScrollDownCallback(([messages]) => {\n if (messages) {\n try {\n // element.scrollTop = scrollHeight - clientHeight;\n // scrollRef.current.scrollTop = scrollHeight - clientHeight;\n } catch (error) {\n //\n }\n }\n });\n }\n\n // Save the lastest scroll bottom value\n if (scrollRef?.current) {\n const current = scrollRef?.current;\n setScrollBottom(current.scrollHeight - current.scrollTop - current.offsetHeight)\n }\n\n if (!disableMarkAsRead && isAboutSame(clientHeight + scrollTop, scrollHeight, 10)) {\n // Mark as read if scroll is at end\n setTimeout(() => {\n messagesDispatcher({\n type: messageActionTypes.MARK_AS_READ,\n payload: { channel: currentGroupChannel },\n });\n try {\n currentGroupChannel?.markAsRead?.();\n } catch {\n //\n }\n }, 500);\n }\n };\n\n const onClickScrollBot = () => {\n setInitialTimeStamp?.(null);\n setAnimatedMessageId?.(null);\n setHighLightedMessageId?.(null);\n if (scrollRef?.current?.scrollTop > -1) {\n scrollRef.current.scrollTop = scrollRef?.current?.scrollHeight - scrollRef?.current?.offsetHeight;\n }\n };\n\n // Because every message components are re-rendered everytime by every scroll events\n const memoizedAllMessages = useMemo(() => {\n return (\n allMessages.map((m, idx) => {\n const previousMessage = allMessages[idx - 1];\n const nextMessage = allMessages[idx + 1];\n const [chainTop, chainBottom] = isMessageGroupingEnabled\n ? compareMessagesForGrouping(previousMessage, m, nextMessage, currentGroupChannel, replyType)\n : [false, false];\n const previousMessageCreatedAt = previousMessage?.createdAt;\n const currentCreatedAt = m.createdAt;\n // https://stackoverflow.com/a/41855608\n const hasSeparator = !(previousMessageCreatedAt && (\n isSameDay(currentCreatedAt, previousMessageCreatedAt)\n ));\n\n const handleScroll = () => {\n const current = scrollRef?.current;\n if (current) {\n const bottom = current.scrollHeight - current.scrollTop - current.offsetHeight;\n if (scrollBottom < bottom) {\n current.scrollTop += bottom - scrollBottom;\n }\n }\n };\n\n return (\n <Message\n handleScroll={handleScroll}\n renderMessage={renderMessage}\n message={m}\n hasSeparator={hasSeparator}\n chainTop={chainTop}\n chainBottom={chainBottom}\n renderCustomSeparator={renderCustomSeparator}\n key={m.messageId + uuidv4()}\n />\n );\n })\n );\n }, [allMessages]);\n\n if (allMessages.length < 1) {\n return (\n <>\n {\n renderPlaceholderEmpty?.() || (\n <PlaceHolder\n className=\"sendbird-conversation__no-messages\"\n type={PlaceHolderTypes.NO_MESSAGES}\n />)\n }\n </>\n );\n }\n return (\n <div className=\"sendbird-conversation__messages\">\n <div className=\"sendbird-conversation__scroll-container\">\n <div className=\"sendbird-conversation__padding\" />\n <div\n className=\"sendbird-conversation__messages-padding\"\n ref={scrollRef}\n onScroll={onScroll}\n >\n {memoizedAllMessages}\n </div>\n </div>\n {\n // This flag is an unmatched variable\n (scrollBottom > 1) && (\n <div\n className=\"sendbird-conversation__scroll-bottom-button\"\n onClick={onClickScrollBot}\n onKeyDown={onClickScrollBot}\n tabIndex={0}\n role=\"button\"\n >\n <Icon\n width=\"24px\"\n height=\"24px\"\n type={IconTypes.CHEVRON_DOWN}\n fillColor={IconColors.PRIMARY}\n />\n </div>\n )\n }\n </div>\n );\n};\n\nexport default MessageList;\n"],"names":["SCROLL_REF_CLASS_NAME","MessageList","props","renderMessage","renderPlaceholderEmpty","renderCustomSeparator","_a","useChannelContext","allMessages","hasMorePrev","setInitialTimeStamp","setAnimatedMessageId","setHighLightedMessageId","isMessageGroupingEnabled","scrollRef","onScrollCallback","onScrollDownCallback","messagesDispatcher","messageActionTypes","currentGroupChannel","disableMarkAsRead","replyType","_b","useState","scrollBottom","setScrollBottom","onScroll","e","element","target","scrollTop","clientHeight","scrollHeight","nodes","current","querySelectorAll","first_1","messages","scrollIntoView","block","inline","error","isAboutSame","offsetHeight","setTimeout","type","MARK_AS_READ","payload","channel","markAsRead","onClickScrollBot","_c","memoizedAllMessages","useMemo","map","m","idx","previousMessage","nextMessage","compareMessagesForGrouping","chainTop","chainBottom","previousMessageCreatedAt","createdAt","currentCreatedAt","hasSeparator","isSameDay","handleScroll","bottom","React","messageId","uuidv4","length","PlaceHolderTypes","NO_MESSAGES","IconTypes","CHEVRON_DOWN","IconColors","PRIMARY"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAoBA,IAAMA,qBAAqB,GAAG,2BAA9B,CAAA;;AAEA,IAAMC,WAAW,GAA+B,UAACC,KAAD,EAAwB;AAEpE,EAAA,IAAAC,aAAa,GAGXD,KAAK,CAAAC,aAHP;AAAA,MACAC,sBAAsB,GAEpBF,KAAK,CAAAE,sBAHP;AAAA,MAEAC,qBAAqB,GACnBH,KAAK,sBAHP,CAAA;;EAII,IAAAI,EAAA,GAeFC,iBAAiB,EAff;AAAA,MACJC,WAAW,GAAAF,EAAA,CAAAE,WADP;AAAA,MAEJC,WAAW,GAAAH,EAAA,CAAAG,WAFP;AAAA,MAGJC,mBAAmB,GAAAJ,EAAA,CAAAI,mBAHf;AAAA,MAIJC,oBAAoB,GAAAL,EAAA,CAAAK,oBAJhB;AAAA,MAKJC,uBAAuB,GAAAN,EAAA,CAAAM,uBALnB;AAAA,MAMJC,wBAAwB,GAAAP,EAAA,CAAAO,wBANpB;AAAA,MAOJC,SAAS,GAAAR,EAAA,CAAAQ,SAPL;AAAA,MAQJC,gBAAgB,GAAAT,EAAA,CAAAS,gBARZ;AAAA,MASJC,oBAAoB,GAAAV,EAAA,CAAAU,oBAThB;AAAA,MAUJC,kBAAkB,GAAAX,EAAA,CAAAW,kBAVd;AAAA,MAWJC,kBAAkB,GAAAZ,EAAA,CAAAY,kBAXd;AAAA,MAYJC,mBAAmB,GAAAb,EAAA,CAAAa,mBAZf;AAAA,MAaJC,iBAAiB,GAAAd,EAAA,CAAAc,iBAbb;AAAA,MAcJC,SAAS,GAAAf,EAAA,CAAAe,SAdL,CAAA;;AAgBA,EAAA,IAAAC,EAAA,GAAkCC,QAAQ,CAAC,CAAD,CAA1C;AAAA,MAACC,YAAY,GAAAF,EAAA,CAAA,CAAA,CAAb;AAAA,MAAeG,eAAe,GAAAH,EAAA,CAAA,CAAA,CAA9B,CAAA;;AAEN,EAAA,IAAMI,QAAQ,GAAG,UAACC,CAAD,EAAE;AACjB,IAAA,IAAMC,OAAO,GAAGD,CAAC,CAACE,MAAlB,CAAA;AAEE,IAAA,IAAAC,SAAS,GAGPF,OAAO,CAAAE,SAHT;AAAA,QACAC,YAAY,GAEVH,OAAO,CAAAG,YAHT;AAAA,QAEAC,YAAY,GACVJ,OAAO,aAHT,CAAA;;IAKF,IAAIE,SAAS,KAAK,CAAlB,EAAqB;MACnB,IAAI,CAACrB,WAAL,EAAkB;AAChB,QAAA,OAAA;AACD,OAAA;;MACD,IAAMwB,KAAK,GAAGnB,SAAS,CAACoB,OAAV,CAAkBC,gBAAlB,CAAmCnC,qBAAnC,CAAd,CAAA;AACA,MAAA,IAAMoC,OAAK,GAAGH,KAAK,IAAIA,KAAK,CAAC,CAAD,CAA5B,CAAA;MACAlB,gBAAgB,CAAC,UAACT,EAAD,EAAW;AAAT,QAAA,IAAA+B,QAAQ,GAAA/B,EAAA,CAAA,CAAA,CAAR,CAAA;;AACjB,QAAA,IAAI+B,QAAJ,EAAc;AACZ;AACA;UACA,IAAI;YACFD,OAAK,CAACE,cAAN,CAAqB;AAAEC,cAAAA,KAAK,EAAE,OAAT;AAAkBC,cAAAA,MAAM,EAAE,SAAA;aAA/C,CAAA,CAAA;AACD,WAFD,CAEE,OAAOC,KAAP,EAAc;AAEf,WAAA;AACF,SAAA;AACF,OAVe,CAAhB,CAAA;AAWD,KAAA;;IAED,IAAIC,WAAW,CAACX,YAAY,GAAGD,SAAhB,EAA2BE,YAA3B,EAAyC,EAAzC,CAAf,EAA6D;MAC3DhB,oBAAoB,CAAC,UAACV,EAAD,EAAW;AAAT,QAAQA,EAAA,CAAA,CAAA,EAAR;AAStB,OATmB,CAApB,CAAA;AAUD,KAtCgB;;;AAyCjB,IAAA,IAAIQ,SAAS,KAAT,IAAA,IAAAA,SAAS,WAAT,SAAA,GAAAA,SAAS,CAAEoB,OAAf,EAAwB;AACtB,MAAA,IAAMA,OAAO,GAAGpB,SAAS,KAAA,IAAT,IAAAA,SAAS,KAAT,KAAA,CAAA,GAAA,KAAA,CAAA,GAAAA,SAAS,CAAEoB,OAA3B,CAAA;AACAT,MAAAA,eAAe,CAACS,OAAO,CAACF,YAAR,GAAuBE,OAAO,CAACJ,SAA/B,GAA2CI,OAAO,CAACS,YAApD,CAAf,CAAA;AACD,KAAA;;AAED,IAAA,IAAI,CAACvB,iBAAD,IAAsBsB,WAAW,CAACX,YAAY,GAAGD,SAAhB,EAA2BE,YAA3B,EAAyC,EAAzC,CAArC,EAAmF;AACjF;AACAY,MAAAA,UAAU,CAAC,YAAA;;;AACT3B,QAAAA,kBAAkB,CAAC;UACjB4B,IAAI,EAAE3B,kBAAkB,CAAC4B,YADR;AAEjBC,UAAAA,OAAO,EAAE;AAAEC,YAAAA,OAAO,EAAE7B,mBAAAA;AAAX,WAAA;AAFQ,SAAD,CAAlB,CAAA;;QAIA,IAAI;AACF,UAAA,CAAAb,EAAA,GAAAa,mBAAmB,SAAnB,IAAAA,mBAAmB,KAAA,KAAA,CAAnB,GAAmB,KAAA,CAAnB,GAAAA,mBAAmB,CAAE8B,UAArB,UAAA,iBAAA,SAAA,+BAAA,CAAA;AACD,SAFD,CAEE,OAAM3B,EAAN,EAAM;AAEP,SAAA;OATO,EAUP,GAVO,CAAV,CAAA;AAWD,KAAA;GA3DH,CAAA;;EA8DA,IAAM4B,gBAAgB,GAAG,YAAA;;;AACvBxC,IAAAA,mBAAmB,SAAnB,IAAAA,mBAAmB,KAAA,KAAA,CAAnB,GAAmB,KAAA,CAAnB,GAAAA,mBAAmB,CAAG,IAAH,CAAnB,CAAA;AACAC,IAAAA,oBAAoB,SAApB,IAAAA,oBAAoB,KAAA,KAAA,CAApB,GAAoB,KAAA,CAApB,GAAAA,oBAAoB,CAAG,IAAH,CAApB,CAAA;AACAC,IAAAA,uBAAuB,SAAvB,IAAAA,uBAAuB,KAAA,KAAA,CAAvB,GAAuB,KAAA,CAAvB,GAAAA,uBAAuB,CAAG,IAAH,CAAvB,CAAA;;AACA,IAAA,IAAI,CAAA,CAAAN,EAAA,GAAAQ,SAAS,KAAA,IAAT,IAAAA,SAAS,KAAT,KAAA,CAAA,GAAA,KAAA,CAAA,GAAAA,SAAS,CAAEoB,OAAX,MAAoB,IAApB,IAAoB5B,EAAA,KAAA,KAAA,CAApB,GAAoB,KAAA,CAApB,GAAoBA,EAAA,CAAAwB,SAApB,IAAgC,CAAC,CAArC,EAAwC;AACtChB,MAAAA,SAAS,CAACoB,OAAV,CAAkBJ,SAAlB,GAA8B,CAAA,CAAAR,EAAA,GAAAR,SAAS,KAAT,IAAA,IAAAA,SAAS,KAAT,KAAA,CAAA,GAAA,KAAA,CAAA,GAAAA,SAAS,CAAEoB,OAAX,MAAoB,IAApB,IAAoBZ,EAAA,KAAA,KAAA,CAApB,GAAoB,KAAA,CAApB,GAAoBA,EAAA,CAAAU,YAApB,KAAmC,CAAAmB,EAAA,GAAArC,SAAS,KAAA,IAAT,IAAAA,SAAS,KAAA,KAAA,CAAT,GAAS,KAAA,CAAT,GAAAA,SAAS,CAAEoB,OAAX,MAAkB,IAAlB,IAAkBiB,EAAA,KAAA,KAAA,CAAlB,GAAkB,KAAA,CAAlB,GAAkBA,EAAA,CAAER,YAAvD,CAA9B,CAAA;AACD,KAAA;AACF,GAPD,CAtFsE;;;AAgGtE,EAAA,IAAMS,mBAAmB,GAAGC,OAAO,CAAC,YAAA;IAClC,OACE7C,WAAW,CAAC8C,GAAZ,CAAgB,UAACC,CAAD,EAAIC,GAAJ,EAAO;AACrB,MAAA,IAAMC,eAAe,GAAGjD,WAAW,CAACgD,GAAG,GAAG,CAAP,CAAnC,CAAA;AACA,MAAA,IAAME,WAAW,GAAGlD,WAAW,CAACgD,GAAG,GAAG,CAAP,CAA/B,CAAA;;MACM,IAAAlD,KAA0BO,wBAAwB,GACpD8C,0BAA0B,CAACF,eAAD,EAAkBF,CAAlB,EAAqBG,WAArB,EAAkCvC,mBAAlC,EAAuDE,SAAvD,CAD0B,GAEpD,CAAC,KAAD,EAAQ,KAAR,CAFE;AAAA,UAACuC,QAAQ,GAAAtD,EAAA,CAAA,CAAA,CAAT;AAAA,UAAWuD,WAAW,GAAAvD,EAAA,CAAA,CAAA,CAAtB,CAAA;;AAGN,MAAA,IAAMwD,wBAAwB,GAAGL,eAAe,KAAA,IAAf,IAAAA,eAAe,KAAf,KAAA,CAAA,GAAA,KAAA,CAAA,GAAAA,eAAe,CAAEM,SAAlD,CAAA;AACA,MAAA,IAAMC,gBAAgB,GAAGT,CAAC,CAACQ,SAA3B,CAPqB;;MASrB,IAAME,YAAY,GAAG,EAAEH,wBAAwB,IAC7CI,SAAS,CAACF,gBAAD,EAAmBF,wBAAnB,CADU,CAArB,CAAA;;MAIA,IAAMK,YAAY,GAAG,YAAA;AACnB,QAAA,IAAMjC,OAAO,GAAGpB,SAAS,KAAA,IAAT,IAAAA,SAAS,KAAT,KAAA,CAAA,GAAA,KAAA,CAAA,GAAAA,SAAS,CAAEoB,OAA3B,CAAA;;AACA,QAAA,IAAIA,OAAJ,EAAa;AACX,UAAA,IAAMkC,MAAM,GAAGlC,OAAO,CAACF,YAAR,GAAuBE,OAAO,CAACJ,SAA/B,GAA2CI,OAAO,CAACS,YAAlE,CAAA;;UACA,IAAInB,YAAY,GAAG4C,MAAnB,EAA2B;AACzBlC,YAAAA,OAAO,CAACJ,SAAR,IAAqBsC,MAAM,GAAG5C,YAA9B,CAAA;AACD,WAAA;AACF,SAAA;OAPH,CAAA;;AAUA,MAAA,oBACE6C,6BAAC,OAAD,EAAA;AACE,QAAA,YAAY,EAAEF,YADhB;AAEE,QAAA,aAAa,EAAEhE,aAFjB;AAGE,QAAA,OAAO,EAAEoD,CAHX;AAIE,QAAA,YAAY,EAAEU,YAJhB;AAKE,QAAA,QAAQ,EAAEL,QALZ;AAME,QAAA,WAAW,EAAEC,WANf;AAOE,QAAA,qBAAqB,EAAExD,qBAPzB;AAQE,QAAA,GAAG,EAAEkD,CAAC,CAACe,SAAF,GAAcC,MAAM,EAAA;OAT7B,CAAA,CAAA;AAYD,KAnCD,CADF,CAAA;AAsCD,GAvCkC,EAuChC,CAAC/D,WAAD,CAvCgC,CAAnC,CAAA;;AAyCA,EAAA,IAAIA,WAAW,CAACgE,MAAZ,GAAqB,CAAzB,EAA4B;AAC1B,IAAA,oBACEH,4DAEI,CAAAjE,sBAAsB,KAAA,IAAtB,IAAAA,sBAAsB,KAAA,KAAA,CAAtB,GAAsB,KAAA,CAAtB,GAAAA,sBAAsB,EAAtB,kBACEiE,6BAAC,WAAD,EAAA;AACE,MAAA,SAAS,EAAC,oCADZ;MAEE,IAAI,EAAEI,gBAAgB,CAACC,WAAAA;AAFzB,KAAA,CAHN,CADF,CAAA;AAWD,GAAA;;EACD,oBACEL,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAAK,IAAA,SAAS,EAAC,iCAAA;GACb,eAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAAK,IAAA,SAAS,EAAC,yCAAA;GACb,eAAAA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AAAK,IAAA,SAAS,EAAC,gCAAA;AAAf,GAAA,CADF,eAEEA,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AACE,IAAA,SAAS,EAAC,yCADZ;AAEE,IAAA,GAAG,EAAEvD,SAFP;AAGE,IAAA,QAAQ,EAAEY,QAAAA;GAET0B,EAAAA,mBALH,CAFF,CADF;EAaK5B,YAAY,GAAG,CAAhB,iBACE6C,cAAA,CAAA,aAAA,CAAA,KAAA,EAAA;AACE,IAAA,SAAS,EAAC,6CADZ;AAEE,IAAA,OAAO,EAAEnB,gBAFX;AAGE,IAAA,SAAS,EAAEA,gBAHb;AAIE,IAAA,QAAQ,EAAE,CAJZ;AAKE,IAAA,IAAI,EAAC,QAAA;AALP,GAAA,eAOEmB,6BAAC,IAAD,EAAA;AACE,IAAA,KAAK,EAAC,MADR;AAEE,IAAA,MAAM,EAAC,MAFT;IAGE,IAAI,EAAEM,SAAS,CAACC,YAHlB;IAIE,SAAS,EAAEC,UAAU,CAACC,OAAAA;AAJxB,GAAA,CAPF,CAdN,CADF,CAAA;AAiCD;;;;"}
|
|
1
|
+
{"version":3,"file":"MessageList.js","sources":["../../../src/modules/Channel/components/MessageList/getMessagePartsInfo.ts","../../../src/modules/Channel/components/MessageList/hooks/useSetScrollToBottom.ts","../../../src/modules/Channel/components/MessageList/index.tsx"],"sourcesContent":["import { GroupChannel } from '@sendbird/chat/groupChannel';\nimport { AdminMessage, FileMessage, UserMessage } from '@sendbird/chat/message';\nimport isSameDay from 'date-fns/isSameDay';\n\nimport { compareMessagesForGrouping } from '../../context/utils';\n\nexport interface GetMessagePartsInfoProps {\n allMessages: Array<UserMessage | FileMessage | AdminMessage>;\n isMessageGroupingEnabled: boolean;\n currentIndex: number;\n currentMessage: UserMessage | FileMessage | AdminMessage;\n currentChannel: GroupChannel;\n replyType: string;\n}\n\ninterface OutPuts {\n chainTop: boolean,\n chainBottom: boolean,\n hasSeparator: boolean,\n}\n\nexport const getMessagePartsInfo = ({\n allMessages = [],\n isMessageGroupingEnabled = true,\n currentIndex = 0,\n currentMessage = null,\n currentChannel = null,\n replyType = '',\n}: GetMessagePartsInfoProps): OutPuts => {\n const previousMessage = allMessages[currentIndex - 1];\n const nextMessage = allMessages[currentIndex + 1];\n const [chainTop, chainBottom] = isMessageGroupingEnabled\n ? compareMessagesForGrouping(previousMessage, currentMessage, nextMessage, currentChannel, replyType)\n : [false, false];\n const previousMessageCreatedAt = previousMessage?.createdAt;\n const currentCreatedAt = currentMessage.createdAt;\n // https://stackoverflow.com/a/41855608\n const hasSeparator = !(previousMessageCreatedAt && (\n isSameDay(currentCreatedAt, previousMessageCreatedAt)\n ));\n return {\n chainTop,\n chainBottom,\n hasSeparator,\n };\n};\n","import React, { useEffect, useState } from 'react';\nimport { useDebounce } from '../../../../../hooks/useDebounce';\n\nconst DELAY = 500;\n\nexport function useSetScrollToBottom({\n loading,\n}: {\n loading: boolean;\n}): ({\n scrollBottom: number;\n scrollToBottomHandler: (e: React.UIEvent<HTMLDivElement, UIEvent>) => void;\n}) {\n const [scrollBottom, setScrollBottom] = useState(0);\n useEffect(() => {\n if (loading) {\n setScrollBottom(0);\n }\n }, [loading]);\n const scrollCb = (e: React.UIEvent<HTMLDivElement, UIEvent>) => {\n const element = e.target as HTMLDivElement;\n try {\n setScrollBottom(element.scrollHeight - element.scrollTop - element.offsetHeight);\n } catch {\n //\n }\n };\n return {\n scrollBottom,\n scrollToBottomHandler: useDebounce(scrollCb, DELAY),\n };\n}\n","import './message-list.scss';\n\nimport React from 'react';\n\nimport { useChannelContext } from '../../context/ChannelProvider';\nimport PlaceHolder, { PlaceHolderTypes } from '../../../../ui/PlaceHolder';\nimport Icon, { IconTypes, IconColors } from '../../../../ui/Icon';\nimport Message from '../Message';\nimport { EveryMessage, RenderCustomSeparatorProps, RenderMessageProps } from '../../../../types';\nimport { isAboutSame } from '../../context/utils';\nimport { getMessagePartsInfo } from './getMessagePartsInfo';\nimport UnreadCount from '../UnreadCount';\nimport FrozenNotification from '../FrozenNotification';\nimport { SCROLL_BUFFER } from '../../../../utils/consts';\nimport useSendbirdStateContext from '../../../../hooks/useSendbirdStateContext';\nimport { UserMessage } from '@sendbird/chat/message';\nimport { MessageProvider } from '../../../Message/context/MessageProvider';\nimport { useHandleOnScrollCallback } from '../../../../hooks/useHandleOnScrollCallback';\nimport { useSetScrollToBottom } from './hooks/useSetScrollToBottom';\n\nconst SCROLL_BOTTOM_PADDING = 50;\n\nexport interface MessageListProps {\n className?: string;\n renderMessage?: (props: RenderMessageProps) => React.ReactElement;\n renderPlaceholderEmpty?: () => React.ReactElement;\n renderCustomSeparator?: (props: RenderCustomSeparatorProps) => React.ReactElement;\n renderPlaceholderLoader?: () => React.ReactElement;\n}\n\nconst MessageList: React.FC<MessageListProps> = ({\n className = '',\n renderMessage,\n renderPlaceholderEmpty,\n renderCustomSeparator,\n renderPlaceholderLoader,\n}) => {\n const {\n allMessages,\n hasMorePrev,\n hasMoreNext,\n setInitialTimeStamp,\n setAnimatedMessageId,\n setHighLightedMessageId,\n isMessageGroupingEnabled,\n scrollRef,\n onScrollCallback,\n onScrollDownCallback,\n messagesDispatcher,\n messageActionTypes,\n currentGroupChannel,\n disableMarkAsRead,\n filterMessageList,\n replyType,\n loading,\n unreadSince,\n } = useChannelContext();\n const store = useSendbirdStateContext();\n const allMessagesFiltered = (typeof filterMessageList === 'function')\n ? allMessages.filter((filterMessageList as (message: EveryMessage) => boolean))\n : allMessages;\n const markAsReadScheduler = store.config.markAsReadScheduler;\n\n const onScroll = () => {\n const element = scrollRef?.current;\n if (element == null) {\n return;\n }\n\n const {\n scrollTop,\n clientHeight,\n scrollHeight,\n } = element;\n\n if (isAboutSame(scrollTop, 0, SCROLL_BUFFER)) {\n onScrollCallback((messages) => {\n if (messages) {\n try {\n //\n } catch (error) {\n //\n }\n }\n });\n }\n\n if (isAboutSame(clientHeight + scrollTop, scrollHeight, SCROLL_BUFFER) && hasMoreNext) {\n onScrollDownCallback(([messages]) => {\n if (messages) {\n try {\n // element.scrollTop = scrollHeight - clientHeight;\n // scrollRef.current.scrollTop = scrollHeight - clientHeight;\n } catch (error) {\n //\n }\n }\n });\n }\n\n if (!disableMarkAsRead\n && isAboutSame(clientHeight + scrollTop, scrollHeight, SCROLL_BUFFER)\n && !!currentGroupChannel\n ) {\n messagesDispatcher({\n type: messageActionTypes.MARK_AS_READ,\n payload: { channel: currentGroupChannel },\n });\n markAsReadScheduler.push(currentGroupChannel);\n }\n };\n\n const onClickScrollBot = () => {\n setInitialTimeStamp?.(null);\n setAnimatedMessageId?.(null);\n setHighLightedMessageId?.(null);\n if (scrollRef?.current?.scrollTop > -1) {\n scrollRef.current.scrollTop = (scrollRef?.current?.scrollHeight ?? 0) - (scrollRef?.current?.offsetHeight ?? 0);\n }\n };\n\n // Move the messsage list scroll when the last message's height is changed by reactions\n const handleMessageHeightChange = () => {\n const current = scrollRef?.current;\n if (current) {\n const bottom = current.scrollHeight - current.scrollTop - current.offsetHeight;\n if (scrollBottom < bottom && scrollBottom <= SCROLL_BUFFER) {\n current.scrollTop += bottom - scrollBottom;\n }\n }\n };\n // Keep the scrollBottom value after fetching new message list\n const handleMessageListHeightChange = () => {\n const current = scrollRef?.current;\n if (current) {\n const bottom = current.scrollHeight - current.scrollTop - current.offsetHeight;\n if (scrollBottom < bottom) {\n current.scrollTop += bottom - scrollBottom;\n }\n }\n };\n\n const handleOnScroll = useHandleOnScrollCallback({\n hasMore: hasMorePrev,\n hasNext: hasMoreNext,\n onScroll,\n scrollRef,\n });\n\n const { scrollToBottomHandler, scrollBottom } = useSetScrollToBottom({ loading });\n\n if (loading) {\n return (typeof renderPlaceholderLoader === 'function')\n ? renderPlaceholderLoader()\n : <PlaceHolder type={PlaceHolderTypes.LOADING} />;\n }\n if (allMessagesFiltered.length < 1) {\n if (renderPlaceholderEmpty && typeof renderPlaceholderEmpty === 'function') {\n return renderPlaceholderEmpty();\n }\n return <PlaceHolder className=\"sendbird-conversation__no-messages\" type={PlaceHolderTypes.NO_MESSAGES} />;\n }\n return (\n <div className={`sendbird-conversation__messages ${className}`}>\n <div className=\"sendbird-conversation__scroll-container\">\n <div className=\"sendbird-conversation__padding\" />\n <div\n className=\"sendbird-conversation__messages-padding\"\n ref={scrollRef}\n onScroll={(e) => {\n handleOnScroll();\n scrollToBottomHandler(e);\n }}\n >\n {allMessagesFiltered.map((m, idx) => {\n const {\n chainTop,\n chainBottom,\n hasSeparator,\n } = getMessagePartsInfo({\n allMessages: allMessagesFiltered,\n replyType,\n isMessageGroupingEnabled,\n currentIndex: idx,\n currentMessage: m,\n currentChannel: currentGroupChannel,\n });\n const isByMe = (m as UserMessage)?.sender?.userId === store?.config?.userId;\n return (\n <MessageProvider message={m} key={m?.messageId} isByMe={isByMe}>\n <Message\n handleScroll={handleMessageHeightChange}\n handleMessageListHeightChange={handleMessageListHeightChange}\n renderMessage={renderMessage}\n message={m}\n hasSeparator={hasSeparator}\n chainTop={chainTop}\n chainBottom={chainBottom}\n renderCustomSeparator={renderCustomSeparator}\n />\n </MessageProvider>\n );\n })}\n {/* show frozen notifications */}\n {/* show new message notifications */}\n </div>\n </div>\n {currentGroupChannel?.isFrozen && (\n <FrozenNotification className=\"sendbird-conversation__messages__notification\" />\n )}\n <UnreadCount\n className=\"sendbird-conversation__messages__notification\"\n count={currentGroupChannel?.unreadMessageCount}\n time={unreadSince}\n onClick={() => {\n if (scrollRef?.current?.scrollTop) {\n scrollRef.current.scrollTop = (scrollRef?.current?.scrollHeight ?? 0) - (scrollRef?.current?.offsetHeight ?? 0);\n }\n if (!disableMarkAsRead && !!currentGroupChannel) {\n markAsReadScheduler.push(currentGroupChannel);\n messagesDispatcher({\n type: messageActionTypes.MARK_AS_READ,\n payload: { channel: currentGroupChannel },\n });\n }\n setInitialTimeStamp(null);\n setAnimatedMessageId(null);\n setHighLightedMessageId(null);\n }}\n />\n {\n // This flag is an unmatched variable\n scrollBottom > SCROLL_BOTTOM_PADDING && (\n <div\n className=\"sendbird-conversation__scroll-bottom-button\"\n onClick={onClickScrollBot}\n onKeyDown={onClickScrollBot}\n tabIndex={0}\n role=\"button\"\n >\n <Icon\n width=\"24px\"\n height=\"24px\"\n type={IconTypes.CHEVRON_DOWN}\n fillColor={IconColors.PRIMARY}\n />\n </div>\n )\n }\n </div>\n );\n};\n\nexport default MessageList;\n"],"names":["getMessagePartsInfo","_ref","allMessages","isMessageGroupingEnabled","currentIndex","currentMessage","currentChannel","replyType","previousMessage","nextMessage","chainTop","chainBottom","compareMessagesForGrouping","previousMessageCreatedAt","createdAt","currentCreatedAt","hasSeparator","isSameDay","DELAY","useSetScrollToBottom","loading","scrollBottom","setScrollBottom","useState","useEffect","scrollCb","e","element","target","scrollHeight","scrollTop","offsetHeight","_unused","scrollToBottomHandler","useDebounce","SCROLL_BOTTOM_PADDING","MessageList","className","renderMessage","renderPlaceholderEmpty","renderCustomSeparator","renderPlaceholderLoader","hasMorePrev","hasMoreNext","setInitialTimeStamp","setAnimatedMessageId","setHighLightedMessageId","scrollRef","onScrollCallback","onScrollDownCallback","messagesDispatcher","messageActionTypes","currentGroupChannel","disableMarkAsRead","filterMessageList","unreadSince","useChannelContext","store","useSendbirdStateContext","allMessagesFiltered","filter","markAsReadScheduler","config","onScroll","current","clientHeight","isAboutSame","SCROLL_BUFFER","messages","_ref2","type","MARK_AS_READ","payload","channel","push","onClickScrollBot","_scrollRef$current","_scrollRef$current$sc","_scrollRef$current2","_scrollRef$current$of","_scrollRef$current3","handleMessageHeightChange","bottom","handleMessageListHeightChange","handleOnScroll","useHandleOnScrollCallback","hasMore","hasNext","React","createElement","PlaceHolder","PlaceHolderTypes","LOADING","length","NO_MESSAGES","ref","map","m","idx","_sender","_store$config","isByMe","sender","userId","MessageProvider","message","key","messageId","Message","handleScroll","isFrozen","FrozenNotification","UnreadCount","count","unreadMessageCount","time","onClick","_scrollRef$current4","_scrollRef$current$sc2","_scrollRef$current5","_scrollRef$current$of2","_scrollRef$current6","onKeyDown","tabIndex","role","Icon","width","height","IconTypes","CHEVRON_DOWN","fillColor","IconColors","PRIMARY"],"mappings":"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"}
|