@sendbird/uikit-react 3.5.0-rc.0 → 3.5.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/App.js +312 -235
- package/App.js.map +1 -1
- package/CHANGELOG.md +544 -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 +260 -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-ade145a7.js → ChannelListProvider-4cf5c0f5.js} +233 -285
- package/ChannelListProvider-4cf5c0f5.js.map +1 -0
- package/{ChannelProvider-c9db10c0.js → ChannelProvider-6e8e99df.js} +659 -726
- package/ChannelProvider-6e8e99df.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 +53 -57
- 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-34603fa5.js +44 -0
- package/CreateChannelProvider-34603fa5.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-04c0c9dc.js +20 -0
- package/{LocalizationContext-60894e38.js.map → LocalizationContext-04c0c9dc.js.map} +1 -1
- package/MediaQueryContext-ff9dca2b.js +87 -0
- package/MediaQueryContext-ff9dca2b.js.map +1 -0
- package/MemberList-9bf26111.js +403 -0
- package/MemberList-9bf26111.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-d7372692.js +429 -0
- package/OpenChannelListProvider-d7372692.js.map +1 -0
- package/OpenChannelProvider-24cd68b9.js +1885 -0
- package/OpenChannelProvider-24cd68b9.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 +56 -69
- 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-94e2bf9e.js +36 -0
- package/RemoveMessageModal-94e2bf9e.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-203b94f3.js +1695 -0
- package/ThreadProvider-203b94f3.js.map +1 -0
- package/{UserProfileContext-33a26cc4.js → UserProfileContext-c776d522.js} +1 -4
- package/{UserProfileContext-33a26cc4.js.map → UserProfileContext-c776d522.js.map} +1 -1
- package/VoiceMessageInputWrapper-77d8f487.js +170 -0
- package/VoiceMessageInputWrapper-77d8f487.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-62e6d3a7.js +123 -0
- package/WebAudioUtils-62e6d3a7.js.map +1 -0
- package/{_rollupPluginBabelHelpers-ed44209e.js → _rollupPluginBabelHelpers-fb0e05a4.js} +17 -11
- package/_rollupPluginBabelHelpers-fb0e05a4.js.map +1 -0
- package/actionTypes-1db5749d.js +8 -0
- package/actionTypes-1db5749d.js.map +1 -0
- package/cjs/App.js +312 -235
- 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 +260 -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-65473831.js → ChannelListProvider-e0ce316a.js} +232 -284
- package/cjs/ChannelListProvider-e0ce316a.js.map +1 -0
- package/cjs/{ChannelProvider-1e08a7a9.js → ChannelProvider-0df75472.js} +657 -724
- package/cjs/ChannelProvider-0df75472.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 +55 -59
- 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-c0fca0a5.js +52 -0
- package/cjs/CreateChannelProvider-c0fca0a5.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-8780a64e.js → LocalizationContext-0e429c3d.js} +9 -11
- package/cjs/{LocalizationContext-8780a64e.js.map → LocalizationContext-0e429c3d.js.map} +1 -1
- package/cjs/MediaQueryContext-33fc3b17.js +94 -0
- package/cjs/MediaQueryContext-33fc3b17.js.map +1 -0
- package/cjs/MemberList-a45a51c4.js +409 -0
- package/cjs/MemberList-a45a51c4.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-fc8b53ee.js +439 -0
- package/cjs/OpenChannelListProvider-fc8b53ee.js.map +1 -0
- package/cjs/OpenChannelProvider-217a8ac2.js +1894 -0
- package/cjs/OpenChannelProvider-217a8ac2.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 +57 -70
- package/cjs/OpenChannelSettings/context.js.map +1 -1
- package/cjs/OpenChannelSettings.js +19 -20
- package/cjs/OpenChannelSettings.js.map +1 -1
- package/cjs/{RemoveMessageModal-0da4f94b.js → RemoveMessageModal-5903f232.js} +19 -14
- package/cjs/RemoveMessageModal-5903f232.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-8ee179c2.js +1704 -0
- package/cjs/ThreadProvider-8ee179c2.js.map +1 -0
- package/cjs/{UserProfileContext-0808e413.js → UserProfileContext-87580795.js} +1 -4
- package/cjs/{UserProfileContext-0808e413.js.map → UserProfileContext-87580795.js.map} +1 -1
- package/cjs/VoiceMessageInputWrapper-4fdc8ef1.js +176 -0
- package/cjs/VoiceMessageInputWrapper-4fdc8ef1.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-e226789c.js +126 -0
- package/cjs/WebAudioUtils-e226789c.js.map +1 -0
- package/cjs/{_rollupPluginBabelHelpers-bd6baf0a.js → _rollupPluginBabelHelpers-c89f311a.js} +17 -10
- package/cjs/_rollupPluginBabelHelpers-c89f311a.js.map +1 -0
- package/cjs/actionTypes-0fa2943d.js +10 -0
- package/cjs/actionTypes-0fa2943d.js.map +1 -0
- package/cjs/{color-fdbe394d.js → color-bada0fc7.js} +13 -21
- package/cjs/color-bada0fc7.js.map +1 -0
- package/cjs/{compareIds-d0c02eca.js → compareIds-ccccfe86.js} +5 -6
- package/cjs/compareIds-ccccfe86.js.map +1 -0
- package/cjs/const-a85f3364.js +20 -0
- package/cjs/const-a85f3364.js.map +1 -0
- package/cjs/{const-8785e4ad.js → const-d8cece19.js} +4 -4
- package/cjs/const-d8cece19.js.map +1 -0
- package/cjs/consts-1c3020ad.js +6 -0
- package/cjs/consts-1c3020ad.js.map +1 -0
- package/cjs/consts-1d94dc61.js +6 -0
- package/cjs/consts-1d94dc61.js.map +1 -0
- package/cjs/consts-5e0f96b3.js +41 -0
- package/cjs/consts-5e0f96b3.js.map +1 -0
- package/cjs/consts-740f60b8.js +6 -0
- package/cjs/consts-740f60b8.js.map +1 -0
- package/cjs/{context-012aecd1.js → context-8e7e8457.js} +6 -5
- package/cjs/{context-012aecd1.js.map → context-8e7e8457.js.map} +1 -1
- package/cjs/dist/index.css +1682 -1229
- 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-48d85d8f.js → index-016f7106.js} +1 -1
- package/cjs/{index-48d85d8f.js.map → index-016f7106.js.map} +1 -1
- package/cjs/{index-e8544e24.js → index-1613ae03.js} +29 -37
- package/cjs/index-1613ae03.js.map +1 -0
- package/cjs/index-2be14d85.js +57 -0
- package/cjs/index-2be14d85.js.map +1 -0
- package/cjs/index-3b30939e.js +79 -0
- package/cjs/index-3b30939e.js.map +1 -0
- package/cjs/index-5231fde8.js +585 -0
- package/cjs/index-5231fde8.js.map +1 -0
- package/cjs/index-648c06ed.js +330 -0
- package/cjs/index-648c06ed.js.map +1 -0
- package/cjs/{index-bdd889a2.js → index-6cb0d040.js} +11 -25
- package/cjs/index-6cb0d040.js.map +1 -0
- package/cjs/{index-ebb542c3.js → index-71fdaa1b.js} +55 -63
- package/cjs/index-71fdaa1b.js.map +1 -0
- package/cjs/{index-abe135e6.js → index-7d125728.js} +2 -2
- package/cjs/{index-abe135e6.js.map → index-7d125728.js.map} +1 -1
- package/cjs/{index-e191d245.js → index-7f6bbe0c.js} +42 -51
- package/cjs/index-7f6bbe0c.js.map +1 -0
- package/cjs/{index-5ea12b7a.js → index-869e9a94.js} +2 -2
- package/cjs/{index-5ea12b7a.js.map → index-869e9a94.js.map} +1 -1
- package/cjs/index-89d81dad.js +456 -0
- package/cjs/index-89d81dad.js.map +1 -0
- package/cjs/{index-c13771a7.js → index-8affdde5.js} +57 -3
- package/cjs/index-8affdde5.js.map +1 -0
- package/cjs/index-99f16473.js +202 -0
- package/cjs/index-99f16473.js.map +1 -0
- package/cjs/index-c9d348b6.js +367 -0
- package/cjs/index-c9d348b6.js.map +1 -0
- package/cjs/index-e8c0080f.js +161 -0
- package/cjs/index-e8c0080f.js.map +1 -0
- package/cjs/{index-08d232f8.js → index-f570d25c.js} +1 -1
- package/cjs/index-f570d25c.js.map +1 -0
- package/cjs/index.js +84 -63
- package/cjs/index.js.map +1 -1
- package/cjs/index.module-0585715f.js +6 -0
- package/cjs/index.module-0585715f.js.map +1 -0
- package/cjs/lame.all.js +2541 -0
- package/cjs/lame.all.js.map +1 -0
- package/cjs/resolvedReplyType-67e78c63.js +32 -0
- package/cjs/resolvedReplyType-67e78c63.js.map +1 -0
- package/cjs/sendbirdSelectors.js +307 -417
- package/cjs/sendbirdSelectors.js.map +1 -1
- package/cjs/{stringSet-60660a99.js → stringSet-106da549.js} +112 -90
- package/cjs/stringSet-106da549.js.map +1 -0
- package/cjs/tokenize-2aa0f876.js +164 -0
- package/cjs/tokenize-2aa0f876.js.map +1 -0
- package/cjs/topics-b384e6b3.js +18 -0
- package/cjs/topics-b384e6b3.js.map +1 -0
- package/cjs/types-e0b77c8c.js +17 -0
- package/cjs/types-e0b77c8c.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 +212 -548
- 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-b8ca5675.js +77 -0
- package/cjs/useDirtyGetMentions-b8ca5675.js.map +1 -0
- package/cjs/useLongPress-8037894e.js +87 -0
- package/cjs/useLongPress-8037894e.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-ba58eacf.js → utils-01ff5332.js} +3 -7
- package/cjs/{utils-ba58eacf.js.map → utils-01ff5332.js.map} +1 -1
- package/cjs/utils-2edcddc8.js +35 -0
- package/cjs/utils-2edcddc8.js.map +1 -0
- package/cjs/utils-5ac3db44.js +31 -0
- package/cjs/utils-5ac3db44.js.map +1 -0
- package/cjs/{utils-708aa730.js → utils-ad7b5b82.js} +1 -1
- package/cjs/{utils-708aa730.js.map → utils-ad7b5b82.js.map} +1 -1
- package/cjs/uuid-12b01f73.js +15 -0
- package/cjs/{uuid-a9006ea2.js.map → uuid-12b01f73.js.map} +1 -1
- package/cjs/withSendbird.js +5 -6
- package/cjs/withSendbird.js.map +1 -1
- package/{color-c39702d1.js → color-347926b6.js} +5 -14
- package/{color-c39702d1.js.map → color-347926b6.js.map} +1 -1
- package/{compareIds-063e5503.js → compareIds-3a43c11b.js} +5 -6
- package/compareIds-3a43c11b.js.map +1 -0
- package/const-18dba7a4.js +13 -0
- package/const-18dba7a4.js.map +1 -0
- package/{const-1510a671.js → const-c608f749.js} +4 -4
- package/const-c608f749.js.map +1 -0
- package/consts-6bca01c7.js +4 -0
- package/consts-6bca01c7.js.map +1 -0
- package/consts-7a169a0f.js +4 -0
- package/consts-7a169a0f.js.map +1 -0
- package/consts-c1baf70a.js +27 -0
- package/consts-c1baf70a.js.map +1 -0
- package/consts-fb4d475a.js +4 -0
- package/consts-fb4d475a.js.map +1 -0
- package/context-786ef1a2.js +13 -0
- package/{context-d5dc28c9.js.map → context-786ef1a2.js.map} +1 -1
- package/dist/index.css +1682 -1229
- package/dist/index.css.map +1 -1
- package/handlers/OpenChannelHandler.js.map +1 -1
- package/handlers/SessionHandler.js.map +1 -1
- package/{index-7c1f570b.js → index-06b854f7.js} +55 -63
- package/index-06b854f7.js.map +1 -0
- package/index-2673effb.js +360 -0
- package/index-2673effb.js.map +1 -0
- package/{index-5e776774.js → index-319984d0.js} +1 -1
- package/{index-5e776774.js.map → index-319984d0.js.map} +1 -1
- package/{index-eadca08d.js → index-4455855e.js} +2 -2
- package/{index-eadca08d.js.map → index-4455855e.js.map} +1 -1
- package/index-6663ce18.js +450 -0
- package/index-6663ce18.js.map +1 -0
- package/{index-b19486f5.js → index-6c252d25.js} +2 -2
- package/{index-b19486f5.js.map → index-6c252d25.js.map} +1 -1
- package/index-71a20863.js +320 -0
- package/index-71a20863.js.map +1 -0
- package/index-7d71b26c.js +154 -0
- package/index-7d71b26c.js.map +1 -0
- package/{index-d81c515b.js → index-9a4e0846.js} +1 -1
- package/index-9a4e0846.js.map +1 -0
- package/{index-fd15e3b0.js → index-9cd77b08.js} +29 -37
- package/index-9cd77b08.js.map +1 -0
- package/index-c149ea48.js +187 -0
- package/index-c149ea48.js.map +1 -0
- package/index-cf3939c6.js +76 -0
- package/index-cf3939c6.js.map +1 -0
- package/index-cf859f03.js +540 -0
- package/index-cf859f03.js.map +1 -0
- package/{index-95ac9232.js → index-e33f7f55.js} +11 -25
- package/index-e33f7f55.js.map +1 -0
- package/{index-b8de16d6.js → index-eabd1e7e.js} +39 -48
- package/index-eabd1e7e.js.map +1 -0
- package/index-ebb62af1.js +51 -0
- package/index-ebb62af1.js.map +1 -0
- package/{index-0fd24497.js → index-edf844f0.js} +57 -4
- package/index-edf844f0.js.map +1 -0
- package/index.d.ts +176 -124
- package/index.js +84 -63
- package/index.js.map +1 -1
- package/index.module-6b7ed635.js +4 -0
- package/index.module-6b7ed635.js.map +1 -0
- package/lame.all.js +2537 -0
- package/lame.all.js.map +1 -0
- package/package.json +62 -41
- package/resolvedReplyType-8776d777.js +29 -0
- package/resolvedReplyType-8776d777.js.map +1 -0
- package/sendbirdSelectors.js +307 -417
- package/sendbirdSelectors.js.map +1 -1
- package/{stringSet-7ace5726.js → stringSet-e0ee1265.js} +112 -90
- package/stringSet-e0ee1265.js.map +1 -0
- package/tokenize-1b053c86.js +159 -0
- package/tokenize-1b053c86.js.map +1 -0
- package/topics-70f569e9.js +16 -0
- package/topics-70f569e9.js.map +1 -0
- package/types-77bbdda6.js +15 -0
- package/types-77bbdda6.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 +215 -551
- 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-f00f1f94.js +75 -0
- package/useDirtyGetMentions-f00f1f94.js.map +1 -0
- package/useLongPress-1ab49410.js +85 -0
- package/useLongPress-1ab49410.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-30c326f7.js → utils-56cb7de5.js} +1 -1
- package/{utils-30c326f7.js.map → utils-56cb7de5.js.map} +1 -1
- package/utils-77f7e8b2.js +29 -0
- package/utils-77f7e8b2.js.map +1 -0
- package/{utils-ded73fa5.js → utils-7f3d0d8c.js} +3 -7
- package/{utils-ded73fa5.js.map → utils-7f3d0d8c.js.map} +1 -1
- package/utils-af9b1c06.js +31 -0
- package/utils-af9b1c06.js.map +1 -0
- package/uuid-92d22300.js +13 -0
- package/{uuid-968941a0.js.map → uuid-92d22300.js.map} +1 -1
- package/withSendbird.js +5 -6
- package/withSendbird.js.map +1 -1
- package/ChannelListProvider-ade145a7.js.map +0 -1
- package/ChannelProvider-c9db10c0.js.map +0 -1
- package/CreateChannelProvider-be2dfe96.js +0 -55
- package/CreateChannelProvider-be2dfe96.js.map +0 -1
- package/LocalizationContext-60894e38.js +0 -22
- package/MediaQueryContext-bcf72e28.js +0 -90
- package/MediaQueryContext-bcf72e28.js.map +0 -1
- package/MemberList-ce1fd162.js +0 -435
- package/MemberList-ce1fd162.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-2cb7ca21.js +0 -535
- package/NotificationChannelProvider-2cb7ca21.js.map +0 -1
- package/OpenChannelListProvider-0bdafda1.js +0 -434
- package/OpenChannelListProvider-0bdafda1.js.map +0 -1
- package/OpenChannelProvider-a72c6fb7.js +0 -2000
- package/OpenChannelProvider-a72c6fb7.js.map +0 -1
- package/RemoveMessageModal-b025d4a7.js +0 -31
- package/RemoveMessageModal-b025d4a7.js.map +0 -1
- package/ThreadProvider-de5a7889.js +0 -1644
- package/ThreadProvider-de5a7889.js.map +0 -1
- package/_rollupPluginBabelHelpers-ed44209e.js.map +0 -1
- package/actionTypes-aa58fd27.js +0 -6
- package/actionTypes-aa58fd27.js.map +0 -1
- package/cjs/ChannelListProvider-65473831.js.map +0 -1
- package/cjs/ChannelProvider-1e08a7a9.js.map +0 -1
- package/cjs/CreateChannelProvider-cbf490c6.js +0 -62
- package/cjs/CreateChannelProvider-cbf490c6.js.map +0 -1
- package/cjs/MediaQueryContext-e455934a.js +0 -97
- package/cjs/MediaQueryContext-e455934a.js.map +0 -1
- package/cjs/MemberList-aee91fce.js +0 -441
- package/cjs/MemberList-aee91fce.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-4cc9575f.js +0 -543
- package/cjs/NotificationChannelProvider-4cc9575f.js.map +0 -1
- package/cjs/OpenChannelListProvider-4aab4391.js +0 -443
- package/cjs/OpenChannelListProvider-4aab4391.js.map +0 -1
- package/cjs/OpenChannelProvider-a763b71c.js +0 -2009
- package/cjs/OpenChannelProvider-a763b71c.js.map +0 -1
- package/cjs/RemoveMessageModal-0da4f94b.js.map +0 -1
- package/cjs/ThreadProvider-51be09a5.js +0 -1653
- package/cjs/ThreadProvider-51be09a5.js.map +0 -1
- package/cjs/_rollupPluginBabelHelpers-bd6baf0a.js.map +0 -1
- package/cjs/actionTypes-561bdde9.js +0 -10
- package/cjs/actionTypes-561bdde9.js.map +0 -1
- package/cjs/color-fdbe394d.js.map +0 -1
- package/cjs/compareIds-d0c02eca.js.map +0 -1
- package/cjs/const-8785e4ad.js.map +0 -1
- package/cjs/const-beb25e10.js +0 -20
- package/cjs/const-beb25e10.js.map +0 -1
- package/cjs/index-08d232f8.js.map +0 -1
- package/cjs/index-8a4b2f10.js +0 -59
- package/cjs/index-8a4b2f10.js.map +0 -1
- package/cjs/index-8c350889.js +0 -194
- package/cjs/index-8c350889.js.map +0 -1
- package/cjs/index-b3371ef2.js +0 -701
- package/cjs/index-b3371ef2.js.map +0 -1
- package/cjs/index-bdd889a2.js.map +0 -1
- package/cjs/index-c13771a7.js.map +0 -1
- package/cjs/index-e191d245.js.map +0 -1
- package/cjs/index-e8544e24.js.map +0 -1
- package/cjs/index-ebb542c3.js.map +0 -1
- package/cjs/index-f032bd2c.js +0 -360
- package/cjs/index-f032bd2c.js.map +0 -1
- package/cjs/stringSet-60660a99.js.map +0 -1
- package/cjs/topics-f3f74edc.js +0 -22
- package/cjs/topics-f3f74edc.js.map +0 -1
- package/cjs/tslib.es6-5a7eb30d.js +0 -110
- package/cjs/tslib.es6-5a7eb30d.js.map +0 -1
- package/cjs/useLongPress-e7140087.js +0 -118
- package/cjs/useLongPress-e7140087.js.map +0 -1
- package/cjs/utils-693dd952.js +0 -38
- package/cjs/utils-693dd952.js.map +0 -1
- package/cjs/utils-b6001dd4.js +0 -32
- package/cjs/utils-b6001dd4.js.map +0 -1
- package/cjs/uuid-a9006ea2.js +0 -19
- package/compareIds-063e5503.js.map +0 -1
- package/const-14919575.js +0 -14
- package/const-14919575.js.map +0 -1
- package/const-1510a671.js.map +0 -1
- package/context-d5dc28c9.js +0 -12
- package/index-0fd24497.js.map +0 -1
- package/index-2561104e.js +0 -179
- package/index-2561104e.js.map +0 -1
- package/index-54843058.js +0 -57
- package/index-54843058.js.map +0 -1
- package/index-58e5d82d.js +0 -662
- package/index-58e5d82d.js.map +0 -1
- package/index-7c1f570b.js.map +0 -1
- package/index-95ac9232.js.map +0 -1
- package/index-b8de16d6.js.map +0 -1
- package/index-d07faed8.js +0 -353
- package/index-d07faed8.js.map +0 -1
- package/index-d81c515b.js.map +0 -1
- package/index-fd15e3b0.js.map +0 -1
- package/stringSet-7ace5726.js.map +0 -1
- package/topics-d390daf6.js +0 -13
- package/topics-d390daf6.js.map +0 -1
- package/tslib.es6-d9fa3716.js +0 -104
- package/tslib.es6-d9fa3716.js.map +0 -1
- package/useLongPress-7d9a5f67.js +0 -116
- package/useLongPress-7d9a5f67.js.map +0 -1
- package/utils-40ce4da5.js +0 -34
- package/utils-40ce4da5.js.map +0 -1
- package/utils-d485030c.js +0 -30
- package/utils-d485030c.js.map +0 -1
- package/uuid-968941a0.js +0 -17
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var index = require('./index-5231fde8.js');
|
|
4
|
+
|
|
5
|
+
const USER_MENTION_PREFIX = '@';
|
|
6
|
+
|
|
7
|
+
const TOKEN_TYPES = {
|
|
8
|
+
string: 'string',
|
|
9
|
+
mention: 'mention',
|
|
10
|
+
url: 'url',
|
|
11
|
+
undetermined: 'undetermined'
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
function getUserMentionRegex(mentionedUsers, templatePrefix_) {
|
|
15
|
+
const templatePrefix = templatePrefix_ || USER_MENTION_PREFIX;
|
|
16
|
+
return RegExp(`(${mentionedUsers.map(u => {
|
|
17
|
+
const userId = u.userId.replace(
|
|
18
|
+
// If user.id includes these patterns, need to convert it into an escaped one
|
|
19
|
+
/([.*+?^${}()|[\]\\])/g, '\\$1');
|
|
20
|
+
/**
|
|
21
|
+
* //{ And //} are also for escaping
|
|
22
|
+
* because curly braces `{}` are metacharacters in regular expressions used to specify repetition
|
|
23
|
+
*/
|
|
24
|
+
return `${templatePrefix}\\{${userId}\\}`;
|
|
25
|
+
}).join('|')})`, 'g');
|
|
26
|
+
}
|
|
27
|
+
function identifyMentions(_ref) {
|
|
28
|
+
let {
|
|
29
|
+
tokens,
|
|
30
|
+
mentionedUsers = [],
|
|
31
|
+
templatePrefix = USER_MENTION_PREFIX
|
|
32
|
+
} = _ref;
|
|
33
|
+
if (!(mentionedUsers !== null && mentionedUsers !== void 0 && mentionedUsers.length)) {
|
|
34
|
+
return tokens;
|
|
35
|
+
}
|
|
36
|
+
const userMentionRegex = getUserMentionRegex(mentionedUsers, templatePrefix);
|
|
37
|
+
const results = tokens.map(token => {
|
|
38
|
+
// if the token is not undetermined, return it as is
|
|
39
|
+
// is kinda unnecessary with TS, but just in case
|
|
40
|
+
if (token.type !== TOKEN_TYPES.undetermined) {
|
|
41
|
+
return token;
|
|
42
|
+
}
|
|
43
|
+
const {
|
|
44
|
+
value
|
|
45
|
+
} = token;
|
|
46
|
+
const parts = value.split(userMentionRegex);
|
|
47
|
+
const tokens = parts.map(part => {
|
|
48
|
+
if (part.match(userMentionRegex)) {
|
|
49
|
+
const matchedUser = mentionedUsers.find(user => `@{${user === null || user === void 0 ? void 0 : user.userId}}` === part);
|
|
50
|
+
const nickname = (matchedUser === null || matchedUser === void 0 ? void 0 : matchedUser.nickname) || '(No name)';
|
|
51
|
+
return {
|
|
52
|
+
value: nickname,
|
|
53
|
+
type: TOKEN_TYPES.mention,
|
|
54
|
+
userId: matchedUser === null || matchedUser === void 0 ? void 0 : matchedUser.userId
|
|
55
|
+
};
|
|
56
|
+
} else {
|
|
57
|
+
return {
|
|
58
|
+
value: part,
|
|
59
|
+
type: TOKEN_TYPES.undetermined
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
});
|
|
63
|
+
return tokens;
|
|
64
|
+
}).flat();
|
|
65
|
+
return results;
|
|
66
|
+
}
|
|
67
|
+
function identifyUrlsAndStrings(token) {
|
|
68
|
+
const results = token.map(token => {
|
|
69
|
+
if (token.type !== TOKEN_TYPES.undetermined) {
|
|
70
|
+
return token;
|
|
71
|
+
}
|
|
72
|
+
const {
|
|
73
|
+
value = ''
|
|
74
|
+
} = token;
|
|
75
|
+
const parts = value.split(' ');
|
|
76
|
+
const tokens = parts.map(part => {
|
|
77
|
+
if (index.isUrl(part)) {
|
|
78
|
+
return {
|
|
79
|
+
value: part,
|
|
80
|
+
type: TOKEN_TYPES.url
|
|
81
|
+
};
|
|
82
|
+
} else {
|
|
83
|
+
return {
|
|
84
|
+
value: part,
|
|
85
|
+
type: TOKEN_TYPES.string
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
});
|
|
89
|
+
return tokens;
|
|
90
|
+
}).flat();
|
|
91
|
+
return results;
|
|
92
|
+
}
|
|
93
|
+
function combineNearbyStrings(tokens) {
|
|
94
|
+
const results = tokens.reduce((acc, token) => {
|
|
95
|
+
const lastToken = acc[acc.length - 1];
|
|
96
|
+
if ((lastToken === null || lastToken === void 0 ? void 0 : lastToken.type) === TOKEN_TYPES.string && token.type === TOKEN_TYPES.string) {
|
|
97
|
+
lastToken.value = `${lastToken.value} ${token.value}`;
|
|
98
|
+
return acc;
|
|
99
|
+
}
|
|
100
|
+
return [...acc, token];
|
|
101
|
+
}, []);
|
|
102
|
+
return results;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
/**
|
|
106
|
+
* Converts text into set of rich tokens
|
|
107
|
+
*/
|
|
108
|
+
function tokenizeMessage(_ref2) {
|
|
109
|
+
let {
|
|
110
|
+
messageText,
|
|
111
|
+
mentionedUsers = [],
|
|
112
|
+
templatePrefix = USER_MENTION_PREFIX
|
|
113
|
+
} = _ref2;
|
|
114
|
+
// mention can be squeezed-in(no-space-between) with other mentions and urls
|
|
115
|
+
// if no users are mentioned, return the messageText as a single token
|
|
116
|
+
const partialResult = [{
|
|
117
|
+
type: TOKEN_TYPES.undetermined,
|
|
118
|
+
value: messageText
|
|
119
|
+
}];
|
|
120
|
+
|
|
121
|
+
// order is important because we want to identify mentions first
|
|
122
|
+
// identifyMentions will return a token with type mention or undetermined
|
|
123
|
+
const partialWithMentions = identifyMentions({
|
|
124
|
+
tokens: partialResult,
|
|
125
|
+
mentionedUsers,
|
|
126
|
+
templatePrefix
|
|
127
|
+
});
|
|
128
|
+
const partialsWithUrlsAndMentions = identifyUrlsAndStrings(partialWithMentions);
|
|
129
|
+
const result = combineNearbyStrings(partialsWithUrlsAndMentions);
|
|
130
|
+
return result;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
/**
|
|
134
|
+
* Don't need to use this util in DOM element since the white spaces will be kept as is,
|
|
135
|
+
* but will need if the text is wrapped \w React.Fragement or </>
|
|
136
|
+
* @link https://sendbird.slack.com/archives/GPGHESTL3/p1681180484341369
|
|
137
|
+
* Or!!! -> convert any space or tab in leading/trailing to nbsp
|
|
138
|
+
* to preserve the leading & trailing white spaces
|
|
139
|
+
*/
|
|
140
|
+
function getWhiteSpacePreservedText(text) {
|
|
141
|
+
const NON_BREAKING_SPACE = '\u00A0';
|
|
142
|
+
// Split the input string into lines
|
|
143
|
+
const lines = text.split('\n');
|
|
144
|
+
|
|
145
|
+
// Process each line and convert leading and trailing white spaces to "\u00A0"
|
|
146
|
+
const processedLines = lines.map(line => {
|
|
147
|
+
var _line$match, _line$match2;
|
|
148
|
+
const leadingWhitespace = ((_line$match = line.match(/^\s*/)) === null || _line$match === void 0 ? void 0 : _line$match[0]) || '';
|
|
149
|
+
const trailingWhitespace = ((_line$match2 = line.match(/\s*$/)) === null || _line$match2 === void 0 ? void 0 : _line$match2[0]) || '';
|
|
150
|
+
const convertedLeadingWhitespace = leadingWhitespace.replace(/ /g, NON_BREAKING_SPACE);
|
|
151
|
+
const convertedTrailingWhitespace = trailingWhitespace.replace(/ /g, NON_BREAKING_SPACE);
|
|
152
|
+
return convertedLeadingWhitespace + line.trim() + convertedTrailingWhitespace;
|
|
153
|
+
});
|
|
154
|
+
|
|
155
|
+
// Combine the processed lines into a new string with "\n"
|
|
156
|
+
const result = processedLines.join('\n');
|
|
157
|
+
return result;
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
exports.TOKEN_TYPES = TOKEN_TYPES;
|
|
161
|
+
exports.USER_MENTION_PREFIX = USER_MENTION_PREFIX;
|
|
162
|
+
exports.getWhiteSpacePreservedText = getWhiteSpacePreservedText;
|
|
163
|
+
exports.tokenizeMessage = tokenizeMessage;
|
|
164
|
+
//# sourceMappingURL=tokenize-2aa0f876.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tokenize-2aa0f876.js","sources":["../../src/modules/Message/consts.ts","../../src/modules/Message/utils/tokens/types.ts","../../src/modules/Message/utils/tokens/tokenize.ts"],"sourcesContent":["export const USER_MENTION_PREFIX = '@';\n","import { User } from '@sendbird/chat';\nimport { ObjectValues } from '../../../../utils/typeHelpers/objectValues';\n\nexport const TOKEN_TYPES = {\n string: 'string',\n mention: 'mention',\n url: 'url',\n undetermined: 'undetermined',\n} as const;\n\nexport type TokenType = ObjectValues<typeof TOKEN_TYPES>;\n\nexport type StringToken = {\n type: typeof TOKEN_TYPES.string;\n value: string;\n};\n\nexport type MentionToken = {\n type: TokenType;\n value: string;\n userId: string;\n};\n\nexport type UrlToken = {\n type: typeof TOKEN_TYPES.url;\n value: string;\n};\n\nexport type UndeterminedToken = {\n type: typeof TOKEN_TYPES.undetermined;\n value: string;\n};\n\nexport type Token = StringToken | MentionToken | UrlToken | UndeterminedToken;\n\nexport type TokenParams = {\n messageText: string;\n mentionedUsers?: User[];\n templatePrefix?: string;\n};\n\nexport type IdentifyMentionsType = {\n tokens: UndeterminedToken[];\n mentionedUsers: User[];\n templatePrefix: string;\n};\n","import { User } from '@sendbird/chat';\nimport { USER_MENTION_PREFIX } from '../../consts';\nimport { IdentifyMentionsType, MentionToken, Token, TOKEN_TYPES, TokenParams, UndeterminedToken } from './types';\nimport { isUrl } from '../../../../utils';\n\nexport function getUserMentionRegex(mentionedUsers: User[], templatePrefix_: string): RegExp {\n const templatePrefix = templatePrefix_ || USER_MENTION_PREFIX;\n\n return RegExp(`(${mentionedUsers.map(u => {\n const userId = u.userId.replace(\n // If user.id includes these patterns, need to convert it into an escaped one\n /([.*+?^${}()|[\\]\\\\])/g,\n '\\\\$1');\n /**\n * //{ And //} are also for escaping\n * because curly braces `{}` are metacharacters in regular expressions used to specify repetition\n */\n return `${templatePrefix}\\\\{${userId}\\\\}`;\n }).join('|')})`, 'g');\n}\n\nexport function identifyMentions({\n tokens,\n mentionedUsers = [],\n templatePrefix = USER_MENTION_PREFIX,\n}: IdentifyMentionsType): (MentionToken | UndeterminedToken)[] {\n if (!mentionedUsers?.length) {\n return tokens;\n }\n const userMentionRegex = getUserMentionRegex(mentionedUsers, templatePrefix);\n const results: (UndeterminedToken | MentionToken)[] = tokens.map((token) => {\n // if the token is not undetermined, return it as is\n // is kinda unnecessary with TS, but just in case\n if (token.type !== TOKEN_TYPES.undetermined) {\n return token;\n }\n const { value } = token;\n const parts = value.split(userMentionRegex);\n\n const tokens = parts.map((part) => {\n if (part.match(userMentionRegex)) {\n const matchedUser = mentionedUsers.find((user) => `@{${user?.userId}}` === part);\n const nickname = matchedUser?.nickname || '(No name)';\n return { value: nickname, type: TOKEN_TYPES.mention, userId: matchedUser?.userId };\n } else {\n return { value: part, type: TOKEN_TYPES.undetermined };\n }\n });\n return tokens;\n }).flat();\n return results;\n}\n\nexport function identifyUrlsAndStrings(token: Token[]): Token[] {\n const results: Token[] = token.map((token) => {\n if (token.type !== TOKEN_TYPES.undetermined) {\n return token;\n }\n const { value = '' } = token;\n const parts = value.split(' ');\n const tokens = parts.map((part) => {\n if (isUrl(part)) {\n return { value: part, type: TOKEN_TYPES.url };\n } else {\n return { value: part, type: TOKEN_TYPES.string };\n }\n });\n return tokens;\n }).flat();\n\n return results;\n}\n\nexport function combineNearbyStrings(tokens: Token[]): Token[] {\n const results: Token[] = tokens.reduce((acc, token) => {\n const lastToken = acc[acc.length - 1];\n if (lastToken?.type === TOKEN_TYPES.string && token.type === TOKEN_TYPES.string) {\n lastToken.value = `${lastToken.value} ${token.value}`;\n return acc;\n }\n return [...acc, token];\n }, []);\n return results;\n}\n\n/**\n * Converts text into set of rich tokens\n */\nexport function tokenizeMessage({\n messageText,\n mentionedUsers = [],\n templatePrefix = USER_MENTION_PREFIX,\n}: TokenParams): Token[] {\n // mention can be squeezed-in(no-space-between) with other mentions and urls\n // if no users are mentioned, return the messageText as a single token\n const partialResult = [{\n type: TOKEN_TYPES.undetermined,\n value: messageText,\n }];\n\n // order is important because we want to identify mentions first\n // identifyMentions will return a token with type mention or undetermined\n const partialWithMentions = identifyMentions({\n tokens: partialResult,\n mentionedUsers,\n templatePrefix,\n });\n const partialsWithUrlsAndMentions = identifyUrlsAndStrings(partialWithMentions);\n const result = combineNearbyStrings(partialsWithUrlsAndMentions);\n\n return result;\n}\n\n/**\n * Don't need to use this util in DOM element since the white spaces will be kept as is,\n * but will need if the text is wrapped \\w React.Fragement or </>\n * @link https://sendbird.slack.com/archives/GPGHESTL3/p1681180484341369\n * Or!!! -> convert any space or tab in leading/trailing to nbsp\n * to preserve the leading & trailing white spaces\n */\nexport function getWhiteSpacePreservedText(text: string): string {\n const NON_BREAKING_SPACE = '\\u00A0';\n // Split the input string into lines\n const lines = text.split('\\n');\n\n // Process each line and convert leading and trailing white spaces to \"\\u00A0\"\n const processedLines = lines.map((line) => {\n const leadingWhitespace = line.match(/^\\s*/)?.[0] || '';\n const trailingWhitespace = line.match(/\\s*$/)?.[0] || '';\n\n const convertedLeadingWhitespace = leadingWhitespace.replace(/ /g, NON_BREAKING_SPACE);\n const convertedTrailingWhitespace = trailingWhitespace.replace(/ /g, NON_BREAKING_SPACE);\n\n return convertedLeadingWhitespace + line.trim() + convertedTrailingWhitespace;\n });\n\n // Combine the processed lines into a new string with \"\\n\"\n const result = processedLines.join('\\n');\n\n return result;\n}\n"],"names":["USER_MENTION_PREFIX","TOKEN_TYPES","string","mention","url","undetermined","getUserMentionRegex","mentionedUsers","templatePrefix_","templatePrefix","RegExp","map","u","userId","replace","join","identifyMentions","_ref","tokens","length","userMentionRegex","results","token","type","value","parts","split","part","match","matchedUser","find","user","nickname","flat","identifyUrlsAndStrings","isUrl","combineNearbyStrings","reduce","acc","lastToken","tokenizeMessage","_ref2","messageText","partialResult","partialWithMentions","partialsWithUrlsAndMentions","result","getWhiteSpacePreservedText","text","NON_BREAKING_SPACE","lines","processedLines","line","_line$match","_line$match2","leadingWhitespace","trailingWhitespace","convertedLeadingWhitespace","convertedTrailingWhitespace","trim"],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
const PUBSUB_TOPICS = {
|
|
4
|
+
// Group Channel
|
|
5
|
+
USER_UPDATED: 'USER_UPDATED',
|
|
6
|
+
SEND_MESSAGE_START: 'SEND_MESSAGE_START',
|
|
7
|
+
SEND_USER_MESSAGE: 'SEND_USER_MESSAGE',
|
|
8
|
+
SEND_FILE_MESSAGE: 'SEND_FILE_MESSAGE',
|
|
9
|
+
UPDATE_USER_MESSAGE: 'UPDATE_USER_MESSAGE',
|
|
10
|
+
DELETE_MESSAGE: 'DELETE_MESSAGE',
|
|
11
|
+
LEAVE_CHANNEL: 'LEAVE_CHANNEL',
|
|
12
|
+
CREATE_CHANNEL: 'CREATE_CHANNEL',
|
|
13
|
+
// Open Channel
|
|
14
|
+
UPDATE_OPEN_CHANNEL: 'UPDATE_OPEN_CHANNEL'
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
exports.PUBSUB_TOPICS = PUBSUB_TOPICS;
|
|
18
|
+
//# sourceMappingURL=topics-b384e6b3.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"topics-b384e6b3.js","sources":["../../src/lib/pubSub/topics.ts"],"sourcesContent":["import { ObjectValues } from '../../utils/typeHelpers/objectValues';\n\nexport const PUBSUB_TOPICS = {\n // Group Channel\n USER_UPDATED: 'USER_UPDATED',\n SEND_MESSAGE_START: 'SEND_MESSAGE_START',\n SEND_USER_MESSAGE: 'SEND_USER_MESSAGE',\n SEND_FILE_MESSAGE: 'SEND_FILE_MESSAGE',\n UPDATE_USER_MESSAGE: 'UPDATE_USER_MESSAGE',\n DELETE_MESSAGE: 'DELETE_MESSAGE',\n LEAVE_CHANNEL: 'LEAVE_CHANNEL',\n CREATE_CHANNEL: 'CREATE_CHANNEL',\n // Open Channel\n UPDATE_OPEN_CHANNEL: 'UPDATE_OPEN_CHANNEL',\n} as const;\nexport type pubSubTopic = ObjectValues<typeof PUBSUB_TOPICS>;\n\nexport default PUBSUB_TOPICS;\n"],"names":["PUBSUB_TOPICS","USER_UPDATED","SEND_MESSAGE_START","SEND_USER_MESSAGE","SEND_FILE_MESSAGE","UPDATE_USER_MESSAGE","DELETE_MESSAGE","LEAVE_CHANNEL","CREATE_CHANNEL","UPDATE_OPEN_CHANNEL"],"mappings":";;AAEO,MAAMA,aAAa,GAAG;AAC3B;AACAC,EAAAA,YAAY,EAAE,cAAc;AAC5BC,EAAAA,kBAAkB,EAAE,oBAAoB;AACxCC,EAAAA,iBAAiB,EAAE,mBAAmB;AACtCC,EAAAA,iBAAiB,EAAE,mBAAmB;AACtCC,EAAAA,mBAAmB,EAAE,qBAAqB;AAC1CC,EAAAA,cAAc,EAAE,gBAAgB;AAChCC,EAAAA,aAAa,EAAE,eAAe;AAC9BC,EAAAA,cAAc,EAAE,gBAAgB;AAChC;AACAC,EAAAA,mBAAmB,EAAE,qBAAA;AACvB;;;;"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
// note to SDK team:
|
|
4
|
+
// using enum inside .d.ts won’t work for jest, but const enum will work.
|
|
5
|
+
const Role = {
|
|
6
|
+
OPERATOR: 'operator',
|
|
7
|
+
NONE: 'none'
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
// type getUpdateFileMessage = (
|
|
11
|
+
// channel: GroupChannel | OpenChannel,
|
|
12
|
+
// messageId: string | number,
|
|
13
|
+
// params: FileMessageUpdateParams,
|
|
14
|
+
// ) => Promise<FileMessage>;
|
|
15
|
+
|
|
16
|
+
exports.Role = Role;
|
|
17
|
+
//# sourceMappingURL=types-e0b77c8c.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types-e0b77c8c.js","sources":["../../src/lib/types.ts"],"sourcesContent":["import type SendbirdChat from '@sendbird/chat';\nimport type { User } from '@sendbird/chat';\nimport type {\n GroupChannel,\n GroupChannelCreateParams,\n SendbirdGroupChat,\n} from '@sendbird/chat/groupChannel';\nimport type {\n OpenChannel,\n OpenChannelCreateParams,\n SendbirdOpenChat,\n} from '@sendbird/chat/openChannel';\nimport type {\n AdminMessage,\n FileMessage,\n FileMessageCreateParams,\n UserMessage,\n UserMessageCreateParams,\n UserMessageUpdateParams,\n} from '@sendbird/chat/message';\n\nimport type SendBirdTypes from '../types';\nimport { UikitMessageHandler } from './selectors';\nimport { Logger } from './SendbirdState';\nimport { ReplyType } from 'SendbirdUIKitGlobal';\nimport { MarkAsReadSchedulerType } from './hooks/useMarkAsReadScheduler';\nimport { MarkAsDeliveredSchedulerType } from './hooks/useMarkAsDeliveredScheduler';\n\nimport { SBUConfig } from '@sendbird/uikit-tools';\n\n// note to SDK team:\n// using enum inside .d.ts won’t work for jest, but const enum will work.\nexport const Role = {\n OPERATOR: 'operator',\n NONE: 'none',\n} as const;\n\nexport interface SendBirdProviderProps {\n userId: string;\n appId: string;\n accessToken?: string;\n children?: React.ReactElement;\n theme?: 'light' | 'dark';\n nickname?: string;\n profileUrl?: string;\n dateLocale?: Locale;\n disableUserProfile?: boolean;\n disableMarkAsDelivered?: boolean;\n renderUserProfile?: (props: SendBirdTypes.RenderUserProfileProps) => React.ReactElement;\n allowProfileEdit?: boolean;\n userListQuery?(): SendBirdTypes.UserListQuery;\n config?: SendBirdTypes.SendBirdProviderConfig;\n stringSet?: Record<string, string>;\n colorSet?: Record<string, string>;\n isMentionEnabled?: boolean;\n isVoiceMessageEnabled?: boolean;\n voiceRecord?: {\n maxRecordingTime: number;\n minRecordingTime: number;\n };\n imageCompression?: {\n compressionRate?: number,\n resizingWidth?: number | string,\n resizingHeight?: number | string,\n };\n isTypingIndicatorEnabledOnChannelList?: boolean;\n isMessageReceiptStatusEnabledOnChannelList?: boolean;\n}\n\nexport interface SendBirdStateConfig {\n disableUserProfile: boolean;\n disableMarkAsDelivered: boolean;\n renderUserProfile?: (props: SendBirdTypes.RenderUserProfileProps) => React.ReactElement;\n onUserProfileMessage?: (props: GroupChannel) => void;\n allowProfileEdit: boolean;\n isOnline: boolean;\n userId: string;\n appId: string;\n accessToken: string;\n theme: string;\n pubSub: any;\n logger: Logger;\n setCurrenttheme: (theme: string) => void;\n userListQuery?(): SendBirdTypes.UserListQuery;\n isReactionEnabled: boolean;\n isMentionEnabled: boolean;\n isVoiceMessageEnabled?: boolean;\n voiceRecord?: {\n maxRecordingTime: number;\n minRecordingTime: number;\n };\n userMention: {\n maxMentionCount: number,\n maxSuggestionCount: number,\n };\n imageCompression?: {\n compressionRate?: number,\n resizingWidth?: number | string,\n resizingHeight?: number | string,\n };\n markAsReadScheduler: MarkAsReadSchedulerType;\n markAsDeliveredScheduler: MarkAsDeliveredSchedulerType;\n isTypingIndicatorEnabledOnChannelList?: boolean;\n isMessageReceiptStatusEnabledOnChannelList?: boolean;\n replyType: ReplyType;\n showSearchIcon?: boolean;\n // Remote configs set from dashboard by UIKit feature configuration\n groupChannel: {\n enableOgtag: SBUConfig['groupChannel']['channel']['enableOgtag'];\n enableTypingIndicator: SBUConfig['groupChannel']['channel']['enableTypingIndicator'];\n enableDocument: SBUConfig['groupChannel']['channel']['input']['enableDocument'];\n threadReplySelectType: SBUConfig['groupChannel']['channel']['threadReplySelectType'];\n },\n openChannel: {\n enableOgtag: SBUConfig['openChannel']['channel']['enableOgtag'];\n enableDocument: SBUConfig['openChannel']['channel']['input']['enableDocument'];\n },\n}\nexport interface SdkStore {\n error: boolean;\n initialized: boolean;\n loading: boolean;\n sdk: SendbirdChat & SendbirdGroupChat & SendbirdOpenChat;\n}\nexport interface UserStore {\n initialized: boolean;\n loading: boolean;\n user: User;\n}\nexport interface SendBirdStateStore {\n sdkStore: SdkStore;\n userStore: UserStore;\n}\n\nexport type SendBirdState = {\n config: SendBirdStateConfig;\n stores: SendBirdStateStore;\n dispatchers: {\n userDispatcher: UserDispatcher,\n },\n};\n\ntype UserDispatcherParams = {\n type: string,\n payload: User,\n};\n\ntype UserDispatcher = (params: UserDispatcherParams) => void;\n\ntype GetSdk = SendbirdChat | undefined;\ntype GetConnect = (\n userId: string,\n accessToken?: string\n) => Promise<User>;\ntype GetDisconnect = () => Promise<void>;\ntype GetUpdateUserInfo = (\n nickName: string,\n profileUrl?: string\n) => Promise<User>;\ntype GetCreateGroupChannel = (channelParams: GroupChannelCreateParams) => Promise<GroupChannel>;\ntype GetCreateOpenChannel = (channelParams: OpenChannelCreateParams) => Promise<OpenChannel>;\ntype GetGetGroupChannel = (\n channelUrl: string,\n isSelected?: boolean,\n) => Promise<GroupChannel>;\ntype GetGetOpenChannel = (\n channelUrl: string,\n) => Promise<OpenChannel>;\ntype GetLeaveGroupChannel = (channel: GroupChannel) => Promise<void>;\ntype GetEnterOpenChannel = (channel: OpenChannel) => Promise<OpenChannel>;\ntype GetExitOpenChannel = (channel: OpenChannel) => Promise<void>;\ntype GetFreezeChannel = (channel: GroupChannel | OpenChannel) => Promise<void>;\ntype GetUnFreezeChannel = (channel: GroupChannel | OpenChannel) => Promise<void>;\ntype GetSendUserMessage = (\n channel: GroupChannel | OpenChannel,\n userMessageParams: UserMessageCreateParams,\n) => UikitMessageHandler;\ntype GetSendFileMessage = (\n channel: GroupChannel | OpenChannel,\n fileMessageParams: FileMessageCreateParams\n) => UikitMessageHandler;\ntype GetUpdateUserMessage = (\n channel: GroupChannel | OpenChannel,\n messageId: string | number,\n params: UserMessageUpdateParams\n) => Promise<UserMessage>;\n// type getUpdateFileMessage = (\n// channel: GroupChannel | OpenChannel,\n// messageId: string | number,\n// params: FileMessageUpdateParams,\n// ) => Promise<FileMessage>;\ntype GetDeleteMessage = (\n channel: GroupChannel | OpenChannel,\n message: AdminMessage | UserMessage | FileMessage\n) => Promise<void>;\ntype GetResendUserMessage = (\n channel: GroupChannel | OpenChannel,\n failedMessage: UserMessage\n) => Promise<UserMessage>;\ntype GetResendFileMessage = (\n channel: GroupChannel | OpenChannel,\n failedMessage: FileMessage\n) => Promise<FileMessage>;\n\nexport interface sendbirdSelectorsInterface {\n getSdk: (store: SendBirdState) => GetSdk;\n getConnect: (store: SendBirdState) => GetConnect\n getDisconnect: (store: SendBirdState) => GetDisconnect;\n getUpdateUserInfo: (store: SendBirdState) => GetUpdateUserInfo;\n getCreateGroupChannel: (store: SendBirdState) => GetCreateGroupChannel;\n getCreateOpenChannel: (store: SendBirdState) => GetCreateOpenChannel;\n getGetGroupChannel: (store: SendBirdState) => GetGetGroupChannel;\n getGetOpenChannel: (store: SendBirdState) => GetGetOpenChannel;\n getLeaveGroupChannel: (store: SendBirdState) => GetLeaveGroupChannel;\n getEnterOpenChannel: (store: SendBirdState) => GetEnterOpenChannel;\n getExitOpenChannel: (store: SendBirdState) => GetExitOpenChannel;\n getFreezeChannel: (store: SendBirdState) => GetFreezeChannel;\n getUnFreezeChannel: (store: SendBirdState) => GetUnFreezeChannel;\n getSendUserMessage: (store: SendBirdState) => GetSendUserMessage;\n getSendFileMessage: (store: SendBirdState) => GetSendFileMessage;\n getUpdateUserMessage: (store: SendBirdState) => GetUpdateUserMessage;\n // getUpdateFileMessage: (store: SendBirdState) => GetUpdateFileMessage;\n getDeleteMessage: (store: SendBirdState) => GetDeleteMessage;\n getResendUserMessage: (store: SendBirdState) => GetResendUserMessage;\n getResendFileMessage: (store: SendBirdState) => GetResendFileMessage;\n}\n"],"names":["Role","OPERATOR","NONE"],"mappings":";;AA8BA;AACA;AACO,MAAMA,IAAI,GAAG;AAClBC,EAAAA,QAAQ,EAAE,UAAU;AACpBC,EAAAA,IAAI,EAAE,MAAA;AACR,EAAU;;AAuJV;AACA;AACA;AACA;AACA;;;;"}
|
package/cjs/ui/Accordion.js
CHANGED
|
@@ -2,50 +2,47 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
var tslib_es6 = require('../tslib.es6-5a7eb30d.js');
|
|
6
5
|
var React = require('react');
|
|
7
6
|
var ui_Icon = require('./Icon.js');
|
|
8
7
|
var ui_AccordionGroup = require('./AccordionGroup.js');
|
|
9
|
-
var context = require('../context-
|
|
8
|
+
var context = require('../context-8e7e8457.js');
|
|
10
9
|
require('prop-types');
|
|
11
|
-
require('../utils-
|
|
10
|
+
require('../utils-ad7b5b82.js');
|
|
12
11
|
|
|
13
12
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
14
13
|
|
|
15
14
|
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
16
15
|
|
|
17
|
-
function Accordion(
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
16
|
+
function Accordion(_ref) {
|
|
17
|
+
let {
|
|
18
|
+
className,
|
|
19
|
+
id,
|
|
20
|
+
renderTitle,
|
|
21
|
+
renderContent,
|
|
22
|
+
renderFooter
|
|
23
|
+
} = _ref;
|
|
24
|
+
const [showAccordion, setShowAccordion] = React.useState(false);
|
|
25
|
+
return /*#__PURE__*/React__default["default"].createElement(context.Consumer, null,
|
|
26
|
+
// Function is considered like a react component
|
|
27
|
+
value => {
|
|
28
|
+
const {
|
|
29
|
+
opened,
|
|
30
|
+
setOpened
|
|
31
|
+
} = value; // props from Provider
|
|
33
32
|
if (id === opened) {
|
|
34
33
|
setShowAccordion(true);
|
|
35
34
|
} else {
|
|
36
35
|
setShowAccordion(false);
|
|
37
36
|
}
|
|
38
|
-
|
|
39
|
-
var handleClick = function () {
|
|
37
|
+
const handleClick = () => {
|
|
40
38
|
if (showAccordion) {
|
|
41
39
|
setOpened('');
|
|
42
40
|
} else {
|
|
43
41
|
setOpened(id);
|
|
44
42
|
}
|
|
45
43
|
};
|
|
46
|
-
|
|
47
44
|
return /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
48
|
-
className:
|
|
45
|
+
className: [...(Array.isArray(className) ? className : [className]), 'sendbird-accordion__panel-header'].join(' '),
|
|
49
46
|
id: id,
|
|
50
47
|
role: "switch",
|
|
51
48
|
"aria-checked": false,
|
|
@@ -66,7 +63,7 @@ function Accordion(_a) {
|
|
|
66
63
|
}, renderFooter())));
|
|
67
64
|
});
|
|
68
65
|
}
|
|
69
|
-
|
|
66
|
+
const AccordionGroup = ui_AccordionGroup;
|
|
70
67
|
|
|
71
68
|
exports.AccordionGroup = AccordionGroup;
|
|
72
69
|
exports["default"] = Accordion;
|
package/cjs/ui/Accordion.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Accordion.js","sources":["../../../src/ui/Accordion/index.tsx"],"sourcesContent":["import React, { ReactElement, useState } from 'react';\n\nimport './index.scss';\n\nimport Icon, { IconTypes } from '../Icon';\nimport AccordionGroup_ from './AccordionGroup';\nimport { Consumer } from './context';\n\ninterface Props {\n className?: string | Array<string>;\n id: string;\n renderTitle(): ReactElement;\n renderContent(): ReactElement;\n renderFooter?(): ReactElement;\n}\n\nexport default function Accordion({\n className,\n id,\n renderTitle,\n renderContent,\n renderFooter,\n}: Props): ReactElement {\n const [showAccordion, setShowAccordion] = useState(false);\n return (\n <Consumer>\n {\n // Function is considered like a react component\n (value) => {\n const { opened, setOpened } = value; // props from Provider\n if (id === opened) {\n setShowAccordion(true);\n } else {\n setShowAccordion(false);\n }\n const handleClick = () => {\n if (showAccordion) {\n setOpened('');\n } else {\n setOpened(id);\n }\n }
|
|
1
|
+
{"version":3,"file":"Accordion.js","sources":["../../../src/ui/Accordion/index.tsx"],"sourcesContent":["import React, { ReactElement, useState } from 'react';\n\nimport './index.scss';\n\nimport Icon, { IconTypes } from '../Icon';\nimport AccordionGroup_ from './AccordionGroup';\nimport { Consumer } from './context';\n\ninterface Props {\n className?: string | Array<string>;\n id: string;\n renderTitle(): ReactElement;\n renderContent(): ReactElement;\n renderFooter?(): ReactElement;\n}\n\nexport default function Accordion({\n className,\n id,\n renderTitle,\n renderContent,\n renderFooter,\n}: Props): ReactElement {\n const [showAccordion, setShowAccordion] = useState(false);\n return (\n <Consumer>\n {\n // Function is considered like a react component\n (value) => {\n const { opened, setOpened } = value; // props from Provider\n if (id === opened) {\n setShowAccordion(true);\n } else {\n setShowAccordion(false);\n }\n const handleClick = () => {\n if (showAccordion) {\n setOpened('');\n } else {\n setOpened(id);\n }\n };\n return (\n <>\n <div\n className={[\n ...(Array.isArray(className) ? className : [className]),\n 'sendbird-accordion__panel-header',\n ].join(' ')}\n id={id}\n role=\"switch\"\n aria-checked={false}\n onClick={handleClick}\n onKeyDown={handleClick}\n tabIndex={0}\n >\n { renderTitle() }\n <Icon\n type={IconTypes.CHEVRON_RIGHT}\n className={[\n 'sendbird-accordion__panel-icon-right',\n 'sendbird-accordion__panel-icon--chevron',\n (showAccordion ? 'sendbird-accordion__panel-icon--open' : ''),\n ].join(' ')}\n height=\"24px\"\n width=\"24px\"\n />\n </div>\n {\n showAccordion && (\n <div className=\"sendbird-accordion\">\n <div className=\"sendbird-accordion__list\">\n { renderContent() }\n </div>\n {\n renderFooter && (\n <div className=\"sendbird-accordion__footer\">\n { renderFooter() }\n </div>\n )\n }\n </div>\n )\n }\n </>);\n }\n }\n </Consumer>\n );\n}\n\nexport const AccordionGroup = AccordionGroup_;\n"],"names":["Accordion","_ref","className","id","renderTitle","renderContent","renderFooter","showAccordion","setShowAccordion","useState","React","createElement","Consumer","value","opened","setOpened","handleClick","Fragment","Array","isArray","join","role","onClick","onKeyDown","tabIndex","Icon","type","IconTypes","CHEVRON_RIGHT","height","width","AccordionGroup","AccordionGroup_"],"mappings":";;;;;;;;;;;;;;;AAgBe,SAASA,SAASA,CAAAC,IAAA,EAMT;EAAA,IANU;IAChCC,SAAS;IACTC,EAAE;IACFC,WAAW;IACXC,aAAa;AACbC,IAAAA,YAAAA;AACK,GAAC,GAAAL,IAAA,CAAA;EACN,MAAM,CAACM,aAAa,EAAEC,gBAAgB,CAAC,GAAGC,cAAQ,CAAC,KAAK,CAAC,CAAA;AACzD,EAAA,oBACEC,yBAAA,CAAAC,aAAA,CAACC,gBAAQ,EAAA,IAAA;AAEL;AACCC,EAAAA,KAAK,IAAK;IACT,MAAM;MAAEC,MAAM;AAAEC,MAAAA,SAAAA;KAAW,GAAGF,KAAK,CAAC;IACpC,IAAIV,EAAE,KAAKW,MAAM,EAAE;MACjBN,gBAAgB,CAAC,IAAI,CAAC,CAAA;AACxB,KAAC,MAAM;MACLA,gBAAgB,CAAC,KAAK,CAAC,CAAA;AACzB,KAAA;IACA,MAAMQ,WAAW,GAAGA,MAAM;AACxB,MAAA,IAAIT,aAAa,EAAE;QACjBQ,SAAS,CAAC,EAAE,CAAC,CAAA;AACf,OAAC,MAAM;QACLA,SAAS,CAACZ,EAAE,CAAC,CAAA;AACf,OAAA;KACD,CAAA;IACD,oBACEO,yBAAA,CAAAC,aAAA,CAAAD,yBAAA,CAAAO,QAAA,EAAA,IAAA,eACEP,yBAAA,CAAAC,aAAA,CAAA,KAAA,EAAA;MACET,SAAS,EAAE,CACT,IAAIgB,KAAK,CAACC,OAAO,CAACjB,SAAS,CAAC,GAAGA,SAAS,GAAG,CAACA,SAAS,CAAC,CAAC,EACvD,kCAAkC,CACnC,CAACkB,IAAI,CAAC,GAAG,CAAE;AACZjB,MAAAA,EAAE,EAAEA,EAAG;AACPkB,MAAAA,IAAI,EAAC,QAAQ;AACb,MAAA,cAAA,EAAc,KAAM;AACpBC,MAAAA,OAAO,EAAEN,WAAY;AACrBO,MAAAA,SAAS,EAAEP,WAAY;AACvBQ,MAAAA,QAAQ,EAAE,CAAA;AAAE,KAAA,EAEVpB,WAAW,EAAE,eACfM,yBAAA,CAAAC,aAAA,CAACc,kBAAI,EAAA;MACHC,IAAI,EAAEC,iBAAS,CAACC,aAAc;AAC9B1B,MAAAA,SAAS,EAAE,CACT,sCAAsC,EACtC,yCAAyC,EACxCK,aAAa,GAAG,sCAAsC,GAAG,EAAE,CAC7D,CAACa,IAAI,CAAC,GAAG,CAAE;AACZS,MAAAA,MAAM,EAAC,MAAM;AACbC,MAAAA,KAAK,EAAC,MAAA;AAAM,KAAA,CACZ,CACE,EAEJvB,aAAa,iBACXG,yBAAA,CAAAC,aAAA,CAAA,KAAA,EAAA;AAAKT,MAAAA,SAAS,EAAC,oBAAA;KACbQ,eAAAA,yBAAA,CAAAC,aAAA,CAAA,KAAA,EAAA;AAAKT,MAAAA,SAAS,EAAC,0BAAA;KACXG,EAAAA,aAAa,EAAE,CACb,EAEJC,YAAY,iBACVI,yBAAA,CAAAC,aAAA,CAAA,KAAA,EAAA;AAAKT,MAAAA,SAAS,EAAC,4BAAA;AAA4B,KAAA,EACvCI,YAAY,EAAE,CAEnB,CAGN,CAEF,CAAA;AACP,GAAC,CAEM,CAAA;AAEf,CAAA;AAEO,MAAMyB,cAAc,GAAGC;;;;;"}
|
package/cjs/ui/AccordionGroup.js
CHANGED
|
@@ -1,27 +1,24 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
var React = require('react');
|
|
4
|
-
var context = require('../context-
|
|
5
|
-
require('../utils-
|
|
4
|
+
var context = require('../context-8e7e8457.js');
|
|
5
|
+
require('../utils-ad7b5b82.js');
|
|
6
6
|
|
|
7
7
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
8
8
|
|
|
9
9
|
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
10
10
|
|
|
11
11
|
// Wraps all the accordions in an accordion set
|
|
12
|
-
function AccordionGroup(
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
opened = _c[0],
|
|
19
|
-
setOpened = _c[1];
|
|
20
|
-
|
|
12
|
+
function AccordionGroup(_ref) {
|
|
13
|
+
let {
|
|
14
|
+
children,
|
|
15
|
+
className = ''
|
|
16
|
+
} = _ref;
|
|
17
|
+
const [opened, setOpened] = React.useState('');
|
|
21
18
|
return /*#__PURE__*/React__default["default"].createElement(context.Provider, {
|
|
22
19
|
value: {
|
|
23
|
-
opened
|
|
24
|
-
setOpened
|
|
20
|
+
opened,
|
|
21
|
+
setOpened
|
|
25
22
|
}
|
|
26
23
|
}, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
27
24
|
className: className
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AccordionGroup.js","sources":["../../../src/ui/Accordion/AccordionGroup.tsx"],"sourcesContent":["// Wraps all the accordions in an accordion set\n// keep one accordion open at a time\nimport React, { ReactElement, useState } from 'react';\n\nimport { Provider } from './context';\n\ninterface Props {\n children: Array<ReactElement> | ReactElement;\n className?: string;\n}\n\nexport default function AccordionGroup({\n children,\n className = '',\n}: Props): ReactElement {\n const [opened, setOpened] = useState('');\n return (\n <Provider value={{ opened, setOpened }}>\n <div className={className}>{ children }</div>\n </Provider>\n )
|
|
1
|
+
{"version":3,"file":"AccordionGroup.js","sources":["../../../src/ui/Accordion/AccordionGroup.tsx"],"sourcesContent":["// Wraps all the accordions in an accordion set\n// keep one accordion open at a time\nimport React, { ReactElement, useState } from 'react';\n\nimport { Provider } from './context';\n\ninterface Props {\n children: Array<ReactElement> | ReactElement;\n className?: string;\n}\n\nexport default function AccordionGroup({\n children,\n className = '',\n}: Props): ReactElement {\n const [opened, setOpened] = useState('');\n return (\n <Provider value={{ opened, setOpened }}>\n <div className={className}>{ children }</div>\n </Provider>\n );\n}\n"],"names":["AccordionGroup","_ref","children","className","opened","setOpened","useState","React","createElement","Provider","value"],"mappings":";;;;;;;;;;AAAA;AAWe,SAASA,cAAcA,CAAAC,IAAA,EAGd;EAAA,IAHe;IACrCC,QAAQ;AACRC,IAAAA,SAAS,GAAG,EAAA;AACP,GAAC,GAAAF,IAAA,CAAA;EACN,MAAM,CAACG,MAAM,EAAEC,SAAS,CAAC,GAAGC,cAAQ,CAAC,EAAE,CAAC,CAAA;AACxC,EAAA,oBACEC,yBAAA,CAAAC,aAAA,CAACC,gBAAQ,EAAA;AAACC,IAAAA,KAAK,EAAE;MAAEN,MAAM;AAAEC,MAAAA,SAAAA;AAAU,KAAA;GACnCE,eAAAA,yBAAA,CAAAC,aAAA,CAAA,KAAA,EAAA;AAAKL,IAAAA,SAAS,EAAEA,SAAAA;GAAaD,EAAAA,QAAQ,CAAQ,CACpC,CAAA;AAEf;;;;"}
|
package/cjs/ui/AdminMessage.js
CHANGED
|
@@ -1,28 +1,25 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
var tslib_es6 = require('../tslib.es6-5a7eb30d.js');
|
|
4
3
|
var React = require('react');
|
|
5
|
-
var ui_Label = require('../index-
|
|
4
|
+
var ui_Label = require('../index-6cb0d040.js');
|
|
6
5
|
require('prop-types');
|
|
7
|
-
require('../stringSet-
|
|
6
|
+
require('../stringSet-106da549.js');
|
|
8
7
|
|
|
9
8
|
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
10
9
|
|
|
11
10
|
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
12
11
|
|
|
13
|
-
function AdminMessage(
|
|
14
|
-
var
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
if (!((message === null || message === void 0 ? void 0 : message.isAdminMessage) || (message === null || message === void 0 ? void 0 : message.messageType)) || !((_b = message === null || message === void 0 ? void 0 : message.isAdminMessage) === null || _b === void 0 ? void 0 : _b.call(message)) || (message === null || message === void 0 ? void 0 : message.messageType) !== 'admin') {
|
|
12
|
+
function AdminMessage(_ref) {
|
|
13
|
+
var _message$isAdminMessa;
|
|
14
|
+
let {
|
|
15
|
+
className = '',
|
|
16
|
+
message
|
|
17
|
+
} = _ref;
|
|
18
|
+
if (!(message !== null && message !== void 0 && message.isAdminMessage || message !== null && message !== void 0 && message.messageType) || !(message !== null && message !== void 0 && (_message$isAdminMessa = message.isAdminMessage) !== null && _message$isAdminMessa !== void 0 && _message$isAdminMessa.call(message)) || (message === null || message === void 0 ? void 0 : message.messageType) !== 'admin') {
|
|
21
19
|
return null;
|
|
22
20
|
}
|
|
23
|
-
|
|
24
21
|
return /*#__PURE__*/React__default["default"].createElement("div", {
|
|
25
|
-
className:
|
|
22
|
+
className: [...(Array.isArray(className) ? className : [className]), 'sendbird-admin-message'].join(' ')
|
|
26
23
|
}, /*#__PURE__*/React__default["default"].createElement(ui_Label.Label, {
|
|
27
24
|
className: "sendbird-admin-message__text",
|
|
28
25
|
type: ui_Label.LabelTypography.CAPTION_2,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AdminMessage.js","sources":["../../../src/ui/AdminMessage/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\nimport { AdminMessage as AdminMessageType } from '@sendbird/chat/message';\n\nimport './index.scss';\nimport Label, { LabelColors, LabelTypography } from '../Label';\n\ninterface AdminMessageProps {\n className?: string | Array<string>;\n message: AdminMessageType;\n}\n\nexport default function AdminMessage({\n className = '',\n message,\n}: AdminMessageProps): ReactElement {\n if (!(message?.isAdminMessage || message?.messageType) || !message?.isAdminMessage?.() || message?.messageType !== 'admin') {\n return null;\n }\n return (\n <div\n className={[\n ...(Array.isArray(className) ? className : [className]),\n 'sendbird-admin-message',\n ].join(' ')}\n >\n <Label\n className=\"sendbird-admin-message__text\"\n type={LabelTypography.CAPTION_2}\n color={LabelColors.ONBACKGROUND_2}\n >\n {message?.message}\n </Label>\n </div>\n );\n}\n"],"names":["AdminMessage","
|
|
1
|
+
{"version":3,"file":"AdminMessage.js","sources":["../../../src/ui/AdminMessage/index.tsx"],"sourcesContent":["import React, { ReactElement } from 'react';\nimport { AdminMessage as AdminMessageType } from '@sendbird/chat/message';\n\nimport './index.scss';\nimport Label, { LabelColors, LabelTypography } from '../Label';\n\ninterface AdminMessageProps {\n className?: string | Array<string>;\n message: AdminMessageType;\n}\n\nexport default function AdminMessage({\n className = '',\n message,\n}: AdminMessageProps): ReactElement {\n if (!(message?.isAdminMessage || message?.messageType) || !message?.isAdminMessage?.() || message?.messageType !== 'admin') {\n return null;\n }\n return (\n <div\n className={[\n ...(Array.isArray(className) ? className : [className]),\n 'sendbird-admin-message',\n ].join(' ')}\n >\n <Label\n className=\"sendbird-admin-message__text\"\n type={LabelTypography.CAPTION_2}\n color={LabelColors.ONBACKGROUND_2}\n >\n {message?.message}\n </Label>\n </div>\n );\n}\n"],"names":["AdminMessage","_ref","_message$isAdminMessa","className","message","isAdminMessage","messageType","call","React","createElement","Array","isArray","join","Label","type","LabelTypography","CAPTION_2","color","LabelColors","ONBACKGROUND_2"],"mappings":";;;;;;;;;;;AAWe,SAASA,YAAYA,CAAAC,IAAA,EAGA;AAAA,EAAA,IAAAC,qBAAA,CAAA;EAAA,IAHC;AACnCC,IAAAA,SAAS,GAAG,EAAE;AACdC,IAAAA,OAAAA;AACiB,GAAC,GAAAH,IAAA,CAAA;EAClB,IAAI,EAAEG,OAAO,KAAPA,IAAAA,IAAAA,OAAO,eAAPA,OAAO,CAAEC,cAAc,IAAID,OAAO,KAAA,IAAA,IAAPA,OAAO,KAAPA,KAAAA,CAAAA,IAAAA,OAAO,CAAEE,WAAW,CAAC,IAAI,EAACF,OAAO,KAAPA,IAAAA,IAAAA,OAAO,KAAAF,KAAAA,CAAAA,IAAAA,CAAAA,qBAAA,GAAPE,OAAO,CAAEC,cAAc,MAAAH,IAAAA,IAAAA,qBAAA,eAAvBA,qBAAA,CAAAK,IAAA,CAAAH,OAAO,CAAoB,KAAI,CAAAA,OAAO,aAAPA,OAAO,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAPA,OAAO,CAAEE,WAAW,MAAK,OAAO,EAAE;AAC1H,IAAA,OAAO,IAAI,CAAA;AACb,GAAA;EACA,oBACEE,yBAAA,CAAAC,aAAA,CAAA,KAAA,EAAA;IACEN,SAAS,EAAE,CACT,IAAIO,KAAK,CAACC,OAAO,CAACR,SAAS,CAAC,GAAGA,SAAS,GAAG,CAACA,SAAS,CAAC,CAAC,EACvD,wBAAwB,CACzB,CAACS,IAAI,CAAC,GAAG,CAAA;AAAE,GAAA,eAEZJ,yBAAA,CAAAC,aAAA,CAACI,cAAK,EAAA;AACJV,IAAAA,SAAS,EAAC,8BAA8B;IACxCW,IAAI,EAAEC,wBAAe,CAACC,SAAU;IAChCC,KAAK,EAAEC,oBAAW,CAACC,cAAAA;GAElBf,EAAAA,OAAO,aAAPA,OAAO,KAAA,KAAA,CAAA,GAAA,KAAA,CAAA,GAAPA,OAAO,CAAEA,OAAO,CACX,CACJ,CAAA;AAEV;;;;"}
|