@sendbird/uikit-react-native 2.0.3 → 2.2.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/README.md +2 -2
- package/lib/commonjs/components/ChannelCover.js +22 -1
- package/lib/commonjs/components/ChannelCover.js.map +1 -1
- package/lib/commonjs/components/ChatFlatList.js +2 -1
- package/lib/commonjs/components/ChatFlatList.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/FileMessage/BaseFileMessage.js +11 -6
- package/lib/commonjs/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/FileMessage/ImageFileMessage.js +12 -2
- package/lib/commonjs/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/FileMessage/VideoFileMessage.js +25 -10
- package/lib/commonjs/components/MessageRenderer/FileMessage/VideoFileMessage.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/MessageIncomingAvatar.js +9 -2
- package/lib/commonjs/components/MessageRenderer/MessageIncomingAvatar.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/UserMessage/BaseUserMessage.js +86 -10
- package/lib/commonjs/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js +99 -14
- package/lib/commonjs/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/UserMessage/index.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/index.js +23 -4
- package/lib/commonjs/components/MessageRenderer/index.js.map +1 -1
- package/lib/commonjs/components/ReactionAddons/BottomSheetReactionAddon.js +150 -0
- package/lib/commonjs/components/ReactionAddons/BottomSheetReactionAddon.js.map +1 -0
- package/lib/commonjs/components/ReactionAddons/MessageReactionAddon.js +135 -0
- package/lib/commonjs/components/ReactionAddons/MessageReactionAddon.js.map +1 -0
- package/lib/commonjs/components/ReactionAddons/ReactionRoundedButton.js +87 -0
- package/lib/commonjs/components/ReactionAddons/ReactionRoundedButton.js.map +1 -0
- package/lib/commonjs/components/ReactionAddons/index.js +19 -0
- package/lib/commonjs/components/ReactionAddons/index.js.map +1 -0
- package/lib/commonjs/components/ReactionBottomSheets/ReactionListBottomSheet.js +150 -0
- package/lib/commonjs/components/ReactionBottomSheets/ReactionListBottomSheet.js.map +1 -0
- package/lib/commonjs/components/ReactionBottomSheets/ReactionUserListBottomSheet.js +276 -0
- package/lib/commonjs/components/ReactionBottomSheets/ReactionUserListBottomSheet.js.map +1 -0
- package/lib/commonjs/components/ReactionBottomSheets/index.js +19 -0
- package/lib/commonjs/components/ReactionBottomSheets/index.js.map +1 -0
- package/lib/commonjs/components/TypedPlaceholder.js +2 -2
- package/lib/commonjs/components/TypedPlaceholder.js.map +1 -1
- package/lib/commonjs/components/UserActionBar.js +7 -4
- package/lib/commonjs/components/UserActionBar.js.map +1 -1
- package/lib/commonjs/constants.js +3 -1
- package/lib/commonjs/constants.js.map +1 -1
- package/lib/commonjs/containers/GroupChannelPreviewContainer.js +9 -1
- package/lib/commonjs/containers/GroupChannelPreviewContainer.js.map +1 -1
- package/lib/commonjs/containers/SendbirdUIKitContainer.js +130 -83
- package/lib/commonjs/containers/SendbirdUIKitContainer.js.map +1 -1
- package/lib/commonjs/contexts/{Localization.js → LocalizationCtx.js} +1 -1
- package/lib/commonjs/contexts/LocalizationCtx.js.map +1 -0
- package/lib/commonjs/contexts/{PlatformService.js → PlatformServiceCtx.js} +1 -1
- package/lib/commonjs/contexts/PlatformServiceCtx.js.map +1 -0
- package/lib/commonjs/contexts/ReactionCtx.js +107 -0
- package/lib/commonjs/contexts/ReactionCtx.js.map +1 -0
- package/lib/commonjs/contexts/{SendbirdChat.js → SendbirdChatCtx.js} +21 -7
- package/lib/commonjs/contexts/SendbirdChatCtx.js.map +1 -0
- package/lib/commonjs/contexts/UserProfileCtx.js +125 -0
- package/lib/commonjs/contexts/UserProfileCtx.js.map +1 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js +34 -36
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -1
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js +31 -12
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -1
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js +129 -35
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -1
- package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js +31 -12
- package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
- package/lib/commonjs/domain/groupChannel/component/GroupChannelSuggestedMentionList.js +210 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelSuggestedMentionList.js.map +1 -0
- package/lib/commonjs/domain/groupChannel/index.js +8 -0
- package/lib/commonjs/domain/groupChannel/index.js.map +1 -1
- package/lib/commonjs/domain/groupChannel/module/createGroupChannelModule.js +4 -0
- package/lib/commonjs/domain/groupChannel/module/createGroupChannelModule.js.map +1 -1
- package/lib/commonjs/domain/groupChannel/module/moduleContext.js +4 -4
- package/lib/commonjs/domain/groupChannel/module/moduleContext.js.map +1 -1
- package/lib/commonjs/domain/groupChannel/types.js.map +1 -1
- package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js +39 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js.map +1 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js +54 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js.map +1 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js +34 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js.map +1 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js +38 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js.map +1 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js +34 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js.map +1 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/index.js +62 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/index.js.map +1 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js +45 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js.map +1 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/module/moduleContext.js +45 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/module/moduleContext.js.map +1 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/types.js +6 -0
- package/lib/commonjs/domain/groupChannelBannedUsers/types.js.map +1 -0
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js +2 -1
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListTypeSelector.js +32 -30
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListTypeSelector.js.map +1 -1
- package/lib/commonjs/domain/groupChannelList/types.js.map +1 -1
- package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationHeader.js +39 -0
- package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationHeader.js.map +1 -0
- package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationMenu.js +103 -0
- package/lib/commonjs/domain/groupChannelModeration/component/GroupChannelModerationMenu.js.map +1 -0
- package/lib/commonjs/domain/groupChannelModeration/index.js +46 -0
- package/lib/commonjs/domain/groupChannelModeration/index.js.map +1 -0
- package/lib/commonjs/domain/groupChannelModeration/module/createGroupChannelModerationModule.js +33 -0
- package/lib/commonjs/domain/groupChannelModeration/module/createGroupChannelModerationModule.js.map +1 -0
- package/lib/commonjs/domain/groupChannelModeration/module/moduleContext.js +46 -0
- package/lib/commonjs/domain/groupChannelModeration/module/moduleContext.js.map +1 -0
- package/lib/commonjs/domain/groupChannelModeration/types.js +6 -0
- package/lib/commonjs/domain/groupChannelModeration/types.js.map +1 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js +39 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js.map +1 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +52 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js +34 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js.map +1 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js +38 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js.map +1 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js +34 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js.map +1 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/index.js +70 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/index.js.map +1 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js +45 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js.map +1 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/module/moduleContext.js +45 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/module/moduleContext.js.map +1 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/types.js +6 -0
- package/lib/commonjs/domain/groupChannelMutedMembers/types.js.map +1 -0
- package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js +39 -0
- package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js.map +1 -0
- package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js +140 -0
- package/lib/commonjs/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js.map +1 -0
- package/lib/commonjs/domain/groupChannelNotifications/index.js +46 -0
- package/lib/commonjs/domain/groupChannelNotifications/index.js.map +1 -0
- package/lib/commonjs/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js +33 -0
- package/lib/commonjs/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js.map +1 -0
- package/lib/commonjs/domain/groupChannelNotifications/module/moduleContext.js +45 -0
- package/lib/commonjs/domain/groupChannelNotifications/module/moduleContext.js.map +1 -0
- package/lib/commonjs/domain/groupChannelNotifications/types.js +6 -0
- package/lib/commonjs/domain/groupChannelNotifications/types.js.map +1 -0
- package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js +44 -0
- package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js.map +1 -0
- package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +52 -0
- package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -0
- package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js +34 -0
- package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js.map +1 -0
- package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js +38 -0
- package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js.map +1 -0
- package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js +34 -0
- package/lib/commonjs/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js.map +1 -0
- package/lib/commonjs/domain/groupChannelOperators/index.js +70 -0
- package/lib/commonjs/domain/groupChannelOperators/index.js.map +1 -0
- package/lib/commonjs/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js +45 -0
- package/lib/commonjs/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js.map +1 -0
- package/lib/commonjs/domain/groupChannelOperators/module/moduleContext.js +45 -0
- package/lib/commonjs/domain/groupChannelOperators/module/moduleContext.js.map +1 -0
- package/lib/commonjs/domain/groupChannelOperators/types.js +6 -0
- package/lib/commonjs/domain/groupChannelOperators/types.js.map +1 -0
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js +1 -8
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -1
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +60 -6
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
- package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js +9 -14
- package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js.map +1 -1
- package/lib/commonjs/domain/groupChannelSettings/types.js.map +1 -1
- package/lib/commonjs/domain/groupChannelUserList/types.js.map +1 -1
- package/lib/commonjs/domain/userList/component/UserListList.js +4 -1
- package/lib/commonjs/domain/userList/component/UserListList.js.map +1 -1
- package/lib/commonjs/domain/userList/component/UserListStatusError.js +2 -2
- package/lib/commonjs/domain/userList/component/UserListStatusError.js.map +1 -1
- package/lib/commonjs/domain/userList/module/createUserListModule.js.map +1 -1
- package/lib/commonjs/domain/userList/types.js.map +1 -1
- package/lib/commonjs/fragments/createGroupChannelBannedUsersFragment.js +101 -0
- package/lib/commonjs/fragments/createGroupChannelBannedUsersFragment.js.map +1 -0
- package/lib/commonjs/fragments/createGroupChannelCreateFragment.js +9 -25
- package/lib/commonjs/fragments/createGroupChannelCreateFragment.js.map +1 -1
- package/lib/commonjs/fragments/createGroupChannelFragment.js +22 -8
- package/lib/commonjs/fragments/createGroupChannelFragment.js.map +1 -1
- package/lib/commonjs/fragments/createGroupChannelInviteFragment.js +21 -37
- package/lib/commonjs/fragments/createGroupChannelInviteFragment.js.map +1 -1
- package/lib/commonjs/fragments/createGroupChannelListFragment.js +3 -11
- package/lib/commonjs/fragments/createGroupChannelListFragment.js.map +1 -1
- package/lib/commonjs/fragments/createGroupChannelMembersFragment.js +95 -51
- package/lib/commonjs/fragments/createGroupChannelMembersFragment.js.map +1 -1
- package/lib/commonjs/fragments/createGroupChannelModerationFragment.js +68 -0
- package/lib/commonjs/fragments/createGroupChannelModerationFragment.js.map +1 -0
- package/lib/commonjs/fragments/createGroupChannelMutedMembersFragment.js +116 -0
- package/lib/commonjs/fragments/createGroupChannelMutedMembersFragment.js.map +1 -0
- package/lib/commonjs/fragments/createGroupChannelNotificationsFragment.js +34 -0
- package/lib/commonjs/fragments/createGroupChannelNotificationsFragment.js.map +1 -0
- package/lib/commonjs/fragments/createGroupChannelOperatorsFragment.js +129 -0
- package/lib/commonjs/fragments/createGroupChannelOperatorsFragment.js.map +1 -0
- package/lib/commonjs/fragments/createGroupChannelRegisterOperatorFragment.js +114 -0
- package/lib/commonjs/fragments/createGroupChannelRegisterOperatorFragment.js.map +1 -0
- package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js +5 -1
- package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js.map +1 -1
- package/lib/commonjs/hooks/useConnection.js +7 -0
- package/lib/commonjs/hooks/useConnection.js.map +1 -1
- package/lib/commonjs/hooks/useContext.js +27 -7
- package/lib/commonjs/hooks/useContext.js.map +1 -1
- package/lib/commonjs/hooks/useKeyboardStatus.js +93 -0
- package/lib/commonjs/hooks/useKeyboardStatus.js.map +1 -0
- package/lib/commonjs/hooks/useMentionSuggestion.js +110 -0
- package/lib/commonjs/hooks/useMentionSuggestion.js.map +1 -0
- package/lib/commonjs/hooks/useMentionTextInput.js +139 -0
- package/lib/commonjs/hooks/useMentionTextInput.js.map +1 -0
- package/lib/commonjs/index.js +165 -42
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/libs/EmojiManager.js +100 -0
- package/lib/commonjs/libs/EmojiManager.js.map +1 -0
- package/lib/commonjs/libs/MentionConfig.js +47 -0
- package/lib/commonjs/libs/MentionConfig.js.map +1 -0
- package/lib/commonjs/libs/MentionManager.js +235 -0
- package/lib/commonjs/libs/MentionManager.js.map +1 -0
- package/lib/commonjs/localization/StringSet.type.js +77 -16
- package/lib/commonjs/localization/StringSet.type.js.map +1 -1
- package/lib/commonjs/platform/createFileService.native.js.map +1 -1
- package/lib/commonjs/types.js.map +1 -1
- package/lib/commonjs/utils/common.js +19 -0
- package/lib/commonjs/utils/common.js.map +1 -0
- package/lib/commonjs/version.js +1 -1
- package/lib/commonjs/version.js.map +1 -1
- package/lib/module/components/ChannelCover.js +22 -2
- package/lib/module/components/ChannelCover.js.map +1 -1
- package/lib/module/components/ChatFlatList.js +3 -2
- package/lib/module/components/ChatFlatList.js.map +1 -1
- package/lib/module/components/MessageRenderer/FileMessage/BaseFileMessage.js +11 -6
- package/lib/module/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -1
- package/lib/module/components/MessageRenderer/FileMessage/ImageFileMessage.js +12 -2
- package/lib/module/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -1
- package/lib/module/components/MessageRenderer/FileMessage/VideoFileMessage.js +25 -10
- package/lib/module/components/MessageRenderer/FileMessage/VideoFileMessage.js.map +1 -1
- package/lib/module/components/MessageRenderer/MessageIncomingAvatar.js +9 -3
- package/lib/module/components/MessageRenderer/MessageIncomingAvatar.js.map +1 -1
- package/lib/module/components/MessageRenderer/UserMessage/BaseUserMessage.js +86 -12
- package/lib/module/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -1
- package/lib/module/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js +101 -17
- package/lib/module/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js.map +1 -1
- package/lib/module/components/MessageRenderer/UserMessage/index.js.map +1 -1
- package/lib/module/components/MessageRenderer/index.js +22 -5
- package/lib/module/components/MessageRenderer/index.js.map +1 -1
- package/lib/module/components/ReactionAddons/BottomSheetReactionAddon.js +132 -0
- package/lib/module/components/ReactionAddons/BottomSheetReactionAddon.js.map +1 -0
- package/lib/module/components/ReactionAddons/MessageReactionAddon.js +118 -0
- package/lib/module/components/ReactionAddons/MessageReactionAddon.js.map +1 -0
- package/lib/module/components/ReactionAddons/ReactionRoundedButton.js +74 -0
- package/lib/module/components/ReactionAddons/ReactionRoundedButton.js.map +1 -0
- package/lib/module/components/ReactionAddons/index.js +7 -0
- package/lib/module/components/ReactionAddons/index.js.map +1 -0
- package/lib/module/components/ReactionBottomSheets/ReactionListBottomSheet.js +135 -0
- package/lib/module/components/ReactionBottomSheets/ReactionListBottomSheet.js.map +1 -0
- package/lib/module/components/ReactionBottomSheets/ReactionUserListBottomSheet.js +259 -0
- package/lib/module/components/ReactionBottomSheets/ReactionUserListBottomSheet.js.map +1 -0
- package/lib/module/components/ReactionBottomSheets/index.js +7 -0
- package/lib/module/components/ReactionBottomSheets/index.js.map +1 -0
- package/lib/module/components/TypedPlaceholder.js +2 -2
- package/lib/module/components/TypedPlaceholder.js.map +1 -1
- package/lib/module/components/UserActionBar.js +8 -5
- package/lib/module/components/UserActionBar.js.map +1 -1
- package/lib/module/constants.js +1 -0
- package/lib/module/constants.js.map +1 -1
- package/lib/module/containers/GroupChannelPreviewContainer.js +9 -1
- package/lib/module/containers/GroupChannelPreviewContainer.js.map +1 -1
- package/lib/module/containers/SendbirdUIKitContainer.js +123 -81
- package/lib/module/containers/SendbirdUIKitContainer.js.map +1 -1
- package/lib/module/contexts/{Localization.js → LocalizationCtx.js} +1 -1
- package/lib/module/contexts/LocalizationCtx.js.map +1 -0
- package/lib/module/contexts/{PlatformService.js → PlatformServiceCtx.js} +1 -1
- package/lib/module/contexts/PlatformServiceCtx.js.map +1 -0
- package/lib/module/contexts/ReactionCtx.js +85 -0
- package/lib/module/contexts/ReactionCtx.js.map +1 -0
- package/lib/module/contexts/{SendbirdChat.js → SendbirdChatCtx.js} +21 -7
- package/lib/module/contexts/SendbirdChatCtx.js.map +1 -0
- package/lib/module/contexts/UserProfileCtx.js +101 -0
- package/lib/module/contexts/UserProfileCtx.js.map +1 -0
- package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js +35 -38
- package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -1
- package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js +27 -14
- package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -1
- package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js +126 -37
- package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -1
- package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js +32 -14
- package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
- package/lib/module/domain/groupChannel/component/GroupChannelSuggestedMentionList.js +188 -0
- package/lib/module/domain/groupChannel/component/GroupChannelSuggestedMentionList.js.map +1 -0
- package/lib/module/domain/groupChannel/index.js +1 -0
- package/lib/module/domain/groupChannel/index.js.map +1 -1
- package/lib/module/domain/groupChannel/module/createGroupChannelModule.js +3 -0
- package/lib/module/domain/groupChannel/module/createGroupChannelModule.js.map +1 -1
- package/lib/module/domain/groupChannel/module/moduleContext.js +4 -4
- package/lib/module/domain/groupChannel/module/moduleContext.js.map +1 -1
- package/lib/module/domain/groupChannel/types.js.map +1 -1
- package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js +25 -0
- package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.js.map +1 -0
- package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js +41 -0
- package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.js.map +1 -0
- package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js +21 -0
- package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.js.map +1 -0
- package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js +25 -0
- package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.js.map +1 -0
- package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js +21 -0
- package/lib/module/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.js.map +1 -0
- package/lib/module/domain/groupChannelBannedUsers/index.js +7 -0
- package/lib/module/domain/groupChannelBannedUsers/index.js.map +1 -0
- package/lib/module/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js +30 -0
- package/lib/module/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.js.map +1 -0
- package/lib/module/domain/groupChannelBannedUsers/module/moduleContext.js +25 -0
- package/lib/module/domain/groupChannelBannedUsers/module/moduleContext.js.map +1 -0
- package/lib/module/domain/groupChannelBannedUsers/types.js +2 -0
- package/lib/module/domain/groupChannelBannedUsers/types.js.map +1 -0
- package/lib/module/domain/groupChannelList/component/GroupChannelListList.js +3 -2
- package/lib/module/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
- package/lib/module/domain/groupChannelList/component/GroupChannelListTypeSelector.js +34 -33
- package/lib/module/domain/groupChannelList/component/GroupChannelListTypeSelector.js.map +1 -1
- package/lib/module/domain/groupChannelList/types.js.map +1 -1
- package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationHeader.js +25 -0
- package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationHeader.js.map +1 -0
- package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationMenu.js +87 -0
- package/lib/module/domain/groupChannelModeration/component/GroupChannelModerationMenu.js.map +1 -0
- package/lib/module/domain/groupChannelModeration/index.js +5 -0
- package/lib/module/domain/groupChannelModeration/index.js.map +1 -0
- package/lib/module/domain/groupChannelModeration/module/createGroupChannelModerationModule.js +21 -0
- package/lib/module/domain/groupChannelModeration/module/createGroupChannelModerationModule.js.map +1 -0
- package/lib/module/domain/groupChannelModeration/module/moduleContext.js +26 -0
- package/lib/module/domain/groupChannelModeration/module/moduleContext.js.map +1 -0
- package/lib/module/domain/groupChannelModeration/types.js +2 -0
- package/lib/module/domain/groupChannelModeration/types.js.map +1 -0
- package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js +25 -0
- package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.js.map +1 -0
- package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js +39 -0
- package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.js.map +1 -0
- package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js +21 -0
- package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.js.map +1 -0
- package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js +25 -0
- package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.js.map +1 -0
- package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js +21 -0
- package/lib/module/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.js.map +1 -0
- package/lib/module/domain/groupChannelMutedMembers/index.js +8 -0
- package/lib/module/domain/groupChannelMutedMembers/index.js.map +1 -0
- package/lib/module/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js +30 -0
- package/lib/module/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.js.map +1 -0
- package/lib/module/domain/groupChannelMutedMembers/module/moduleContext.js +25 -0
- package/lib/module/domain/groupChannelMutedMembers/module/moduleContext.js.map +1 -0
- package/lib/module/domain/groupChannelMutedMembers/types.js +2 -0
- package/lib/module/domain/groupChannelMutedMembers/types.js.map +1 -0
- package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js +25 -0
- package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.js.map +1 -0
- package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js +122 -0
- package/lib/module/domain/groupChannelNotifications/component/GroupChannelNotificationsView.js.map +1 -0
- package/lib/module/domain/groupChannelNotifications/index.js +5 -0
- package/lib/module/domain/groupChannelNotifications/index.js.map +1 -0
- package/lib/module/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js +21 -0
- package/lib/module/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.js.map +1 -0
- package/lib/module/domain/groupChannelNotifications/module/moduleContext.js +25 -0
- package/lib/module/domain/groupChannelNotifications/module/moduleContext.js.map +1 -0
- package/lib/module/domain/groupChannelNotifications/types.js +2 -0
- package/lib/module/domain/groupChannelNotifications/types.js.map +1 -0
- package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js +30 -0
- package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.js.map +1 -0
- package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js +39 -0
- package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsList.js.map +1 -0
- package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js +21 -0
- package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.js.map +1 -0
- package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js +25 -0
- package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.js.map +1 -0
- package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js +21 -0
- package/lib/module/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.js.map +1 -0
- package/lib/module/domain/groupChannelOperators/index.js +8 -0
- package/lib/module/domain/groupChannelOperators/index.js.map +1 -0
- package/lib/module/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js +30 -0
- package/lib/module/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.js.map +1 -0
- package/lib/module/domain/groupChannelOperators/module/moduleContext.js +25 -0
- package/lib/module/domain/groupChannelOperators/module/moduleContext.js.map +1 -0
- package/lib/module/domain/groupChannelOperators/types.js +2 -0
- package/lib/module/domain/groupChannelOperators/types.js.map +1 -0
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js +2 -8
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -1
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +57 -6
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
- package/lib/module/domain/groupChannelSettings/module/moduleContext.js +10 -15
- package/lib/module/domain/groupChannelSettings/module/moduleContext.js.map +1 -1
- package/lib/module/domain/groupChannelSettings/types.js.map +1 -1
- package/lib/module/domain/groupChannelUserList/types.js.map +1 -1
- package/lib/module/domain/userList/component/UserListList.js +3 -1
- package/lib/module/domain/userList/component/UserListList.js.map +1 -1
- package/lib/module/domain/userList/component/UserListStatusError.js +2 -2
- package/lib/module/domain/userList/component/UserListStatusError.js.map +1 -1
- package/lib/module/domain/userList/module/createUserListModule.js.map +1 -1
- package/lib/module/domain/userList/types.js.map +1 -1
- package/lib/module/fragments/createGroupChannelBannedUsersFragment.js +84 -0
- package/lib/module/fragments/createGroupChannelBannedUsersFragment.js.map +1 -0
- package/lib/module/fragments/createGroupChannelCreateFragment.js +10 -26
- package/lib/module/fragments/createGroupChannelCreateFragment.js.map +1 -1
- package/lib/module/fragments/createGroupChannelFragment.js +22 -8
- package/lib/module/fragments/createGroupChannelFragment.js.map +1 -1
- package/lib/module/fragments/createGroupChannelInviteFragment.js +22 -37
- package/lib/module/fragments/createGroupChannelInviteFragment.js.map +1 -1
- package/lib/module/fragments/createGroupChannelListFragment.js +4 -11
- package/lib/module/fragments/createGroupChannelListFragment.js.map +1 -1
- package/lib/module/fragments/createGroupChannelMembersFragment.js +99 -56
- package/lib/module/fragments/createGroupChannelMembersFragment.js.map +1 -1
- package/lib/module/fragments/createGroupChannelModerationFragment.js +53 -0
- package/lib/module/fragments/createGroupChannelModerationFragment.js.map +1 -0
- package/lib/module/fragments/createGroupChannelMutedMembersFragment.js +98 -0
- package/lib/module/fragments/createGroupChannelMutedMembersFragment.js.map +1 -0
- package/lib/module/fragments/createGroupChannelNotificationsFragment.js +22 -0
- package/lib/module/fragments/createGroupChannelNotificationsFragment.js.map +1 -0
- package/lib/module/fragments/createGroupChannelOperatorsFragment.js +111 -0
- package/lib/module/fragments/createGroupChannelOperatorsFragment.js.map +1 -0
- package/lib/module/fragments/createGroupChannelRegisterOperatorFragment.js +94 -0
- package/lib/module/fragments/createGroupChannelRegisterOperatorFragment.js.map +1 -0
- package/lib/module/fragments/createGroupChannelSettingsFragment.js +5 -1
- package/lib/module/fragments/createGroupChannelSettingsFragment.js.map +1 -1
- package/lib/module/hooks/useConnection.js +7 -0
- package/lib/module/hooks/useConnection.js.map +1 -1
- package/lib/module/hooks/useContext.js +15 -3
- package/lib/module/hooks/useContext.js.map +1 -1
- package/lib/module/hooks/useKeyboardStatus.js +75 -0
- package/lib/module/hooks/useKeyboardStatus.js.map +1 -0
- package/lib/module/hooks/useMentionSuggestion.js +100 -0
- package/lib/module/hooks/useMentionSuggestion.js.map +1 -0
- package/lib/module/hooks/useMentionTextInput.js +128 -0
- package/lib/module/hooks/useMentionTextInput.js.map +1 -0
- package/lib/module/index.js +17 -6
- package/lib/module/index.js.map +1 -1
- package/lib/module/libs/EmojiManager.js +90 -0
- package/lib/module/libs/EmojiManager.js.map +1 -0
- package/lib/module/libs/MentionConfig.js +39 -0
- package/lib/module/libs/MentionConfig.js.map +1 -0
- package/lib/module/libs/MentionManager.js +223 -0
- package/lib/module/libs/MentionManager.js.map +1 -0
- package/lib/module/localization/StringSet.type.js +78 -17
- package/lib/module/localization/StringSet.type.js.map +1 -1
- package/lib/module/platform/createFileService.native.js.map +1 -1
- package/lib/module/types.js.map +1 -1
- package/lib/module/utils/common.js +7 -0
- package/lib/module/utils/common.js.map +1 -0
- package/lib/module/version.js +1 -1
- package/lib/module/version.js.map +1 -1
- package/lib/typescript/__template__/types.d.ts +3 -3
- package/lib/typescript/src/components/ChannelCover.d.ts +2 -2
- package/lib/typescript/src/components/ChatFlatList.d.ts +1 -1
- package/lib/typescript/src/components/FileViewer.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/AdminMessage/index.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/FileMessage/BaseFileMessage.d.ts +2 -2
- package/lib/typescript/src/components/MessageRenderer/FileMessage/ImageFileMessage.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/FileMessage/VideoFileMessage.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/FileMessage/index.d.ts +11 -2
- package/lib/typescript/src/components/MessageRenderer/MessageDateSeparator.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/MessageIncomingAvatar.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/MessageIncomingSenderName.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/MessageOutgoingStatus.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/MessageTime.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/UnknownMessage/index.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/UserMessage/BaseUserMessage.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/UserMessage/OpenGraphUserMessage.d.ts +2 -2
- package/lib/typescript/src/components/MessageRenderer/UserMessage/index.d.ts +4 -1
- package/lib/typescript/src/components/MessageRenderer/index.d.ts +4 -3
- package/lib/typescript/src/components/NewMessagesButton.d.ts +1 -1
- package/lib/typescript/src/components/ReactionAddons/BottomSheetReactionAddon.d.ts +8 -0
- package/lib/typescript/src/components/ReactionAddons/MessageReactionAddon.d.ts +6 -0
- package/lib/typescript/src/components/ReactionAddons/ReactionRoundedButton.d.ts +14 -0
- package/lib/typescript/src/components/ReactionAddons/index.d.ts +11 -0
- package/lib/typescript/src/components/ReactionBottomSheets/ReactionListBottomSheet.d.ts +3 -0
- package/lib/typescript/src/components/ReactionBottomSheets/ReactionUserListBottomSheet.d.ts +3 -0
- package/lib/typescript/src/components/ReactionBottomSheets/index.d.ts +20 -0
- package/lib/typescript/src/components/ScrollToBottomButton.d.ts +1 -1
- package/lib/typescript/src/components/StatusComposition.d.ts +1 -1
- package/lib/typescript/src/components/TypedPlaceholder.d.ts +2 -2
- package/lib/typescript/src/components/UserActionBar.d.ts +5 -3
- package/lib/typescript/src/components/UserSelectableBar.d.ts +1 -1
- package/lib/typescript/src/constants.d.ts +1 -0
- package/lib/typescript/src/containers/GroupChannelPreviewContainer.d.ts +1 -1
- package/lib/typescript/src/containers/SendbirdUIKitContainer.d.ts +19 -8
- package/lib/typescript/src/contexts/{Localization.d.ts → LocalizationCtx.d.ts} +2 -2
- package/lib/typescript/src/contexts/{PlatformService.d.ts → PlatformServiceCtx.d.ts} +1 -1
- package/lib/typescript/src/contexts/ReactionCtx.d.ts +18 -0
- package/lib/typescript/src/contexts/{SendbirdChat.d.ts → SendbirdChatCtx.d.ts} +17 -5
- package/lib/typescript/src/contexts/UserProfileCtx.d.ts +15 -0
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/EditInput.d.ts +36 -7
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/SendInput.d.ts +34 -5
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/index.d.ts +20 -3
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelSuggestedMentionList.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannel/index.d.ts +1 -0
- package/lib/typescript/src/domain/groupChannel/module/createGroupChannelModule.d.ts +1 -1
- package/lib/typescript/src/domain/groupChannel/types.d.ts +25 -8
- package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.d.ts +2 -0
- package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.d.ts +2 -0
- package/lib/typescript/src/domain/groupChannelBannedUsers/index.d.ts +6 -0
- package/lib/typescript/src/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelBannedUsers/module/moduleContext.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelBannedUsers/types.d.ts +47 -0
- package/lib/typescript/src/domain/groupChannelList/component/GroupChannelListTypeSelector.d.ts +1 -1
- package/lib/typescript/src/domain/groupChannelList/types.d.ts +5 -11
- package/lib/typescript/src/domain/groupChannelModeration/component/GroupChannelModerationHeader.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelModeration/component/GroupChannelModerationMenu.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelModeration/index.d.ts +4 -0
- package/lib/typescript/src/domain/groupChannelModeration/module/createGroupChannelModerationModule.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelModeration/module/moduleContext.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelModeration/types.d.ts +43 -0
- package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.d.ts +2 -0
- package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.d.ts +2 -0
- package/lib/typescript/src/domain/groupChannelMutedMembers/index.d.ts +7 -0
- package/lib/typescript/src/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelMutedMembers/module/moduleContext.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelMutedMembers/types.d.ts +47 -0
- package/lib/typescript/src/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelNotifications/component/GroupChannelNotificationsView.d.ts +2 -0
- package/lib/typescript/src/domain/groupChannelNotifications/index.d.ts +4 -0
- package/lib/typescript/src/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelNotifications/module/moduleContext.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelNotifications/types.d.ts +33 -0
- package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsList.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.d.ts +2 -0
- package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.d.ts +2 -0
- package/lib/typescript/src/domain/groupChannelOperators/index.d.ts +7 -0
- package/lib/typescript/src/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelOperators/module/moduleContext.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelOperators/types.d.ts +49 -0
- package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsInfo.d.ts +1 -1
- package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.d.ts +1 -1
- package/lib/typescript/src/domain/groupChannelSettings/types.d.ts +5 -1
- package/lib/typescript/src/domain/groupChannelUserList/types.d.ts +17 -11
- package/lib/typescript/src/domain/userList/component/UserListList.d.ts +2 -1
- package/lib/typescript/src/domain/userList/component/UserListStatusError.d.ts +2 -2
- package/lib/typescript/src/domain/userList/module/createUserListModule.d.ts +2 -1
- package/lib/typescript/src/domain/userList/types.d.ts +4 -3
- package/lib/typescript/src/fragments/createGroupChannelBannedUsersFragment.d.ts +3 -0
- package/lib/typescript/src/fragments/createGroupChannelCreateFragment.d.ts +2 -1
- package/lib/typescript/src/fragments/createGroupChannelInviteFragment.d.ts +2 -1
- package/lib/typescript/src/fragments/createGroupChannelModerationFragment.d.ts +3 -0
- package/lib/typescript/src/fragments/createGroupChannelMutedMembersFragment.d.ts +3 -0
- package/lib/typescript/src/fragments/createGroupChannelNotificationsFragment.d.ts +3 -0
- package/lib/typescript/src/fragments/createGroupChannelOperatorsFragment.d.ts +3 -0
- package/lib/typescript/src/fragments/createGroupChannelRegisterOperatorFragment.d.ts +5 -0
- package/lib/typescript/src/hooks/useConnection.d.ts +1 -1
- package/lib/typescript/src/hooks/useContext.d.ts +7 -1
- package/lib/typescript/src/hooks/useKeyboardStatus.d.ts +6 -0
- package/lib/typescript/src/hooks/useMentionSuggestion.d.ts +17 -0
- package/lib/typescript/src/hooks/useMentionTextInput.d.ts +18 -0
- package/lib/typescript/src/index.d.ts +16 -5
- package/lib/typescript/src/libs/EmojiManager.d.ts +16 -0
- package/lib/typescript/src/libs/MentionConfig.d.ts +24 -0
- package/lib/typescript/src/libs/MentionManager.d.ts +61 -0
- package/lib/typescript/src/localization/StringSet.type.d.ts +63 -9
- package/lib/typescript/src/platform/createFileService.native.d.ts +1 -1
- package/lib/typescript/src/platform/createMediaService.expo.d.ts +1 -1
- package/lib/typescript/src/platform/createMediaService.native.d.ts +1 -1
- package/lib/typescript/src/platform/dynamicModule.d.ts +1 -1
- package/lib/typescript/src/platform/types.d.ts +5 -5
- package/lib/typescript/src/types.d.ts +13 -4
- package/lib/typescript/src/utils/common.d.ts +1 -0
- package/lib/typescript/src/version.d.ts +1 -1
- package/package.json +11 -11
- package/src/components/ChannelCover.tsx +23 -3
- package/src/components/ChatFlatList.tsx +2 -1
- package/src/components/MessageRenderer/FileMessage/BaseFileMessage.tsx +17 -12
- package/src/components/MessageRenderer/FileMessage/ImageFileMessage.tsx +25 -18
- package/src/components/MessageRenderer/FileMessage/VideoFileMessage.tsx +20 -10
- package/src/components/MessageRenderer/MessageIncomingAvatar.tsx +9 -2
- package/src/components/MessageRenderer/UserMessage/BaseUserMessage.tsx +82 -14
- package/src/components/MessageRenderer/UserMessage/OpenGraphUserMessage.tsx +135 -61
- package/src/components/MessageRenderer/UserMessage/index.tsx +8 -1
- package/src/components/MessageRenderer/index.tsx +40 -8
- package/src/components/ReactionAddons/BottomSheetReactionAddon.tsx +106 -0
- package/src/components/ReactionAddons/MessageReactionAddon.tsx +123 -0
- package/src/components/ReactionAddons/ReactionRoundedButton.tsx +71 -0
- package/src/components/ReactionAddons/index.tsx +7 -0
- package/src/components/ReactionBottomSheets/ReactionListBottomSheet.tsx +113 -0
- package/src/components/ReactionBottomSheets/ReactionUserListBottomSheet.tsx +249 -0
- package/src/components/ReactionBottomSheets/index.tsx +24 -0
- package/src/components/TypedPlaceholder.tsx +4 -4
- package/src/components/UserActionBar.tsx +10 -4
- package/src/constants.ts +2 -0
- package/src/containers/GroupChannelPreviewContainer.tsx +8 -1
- package/src/containers/SendbirdUIKitContainer.tsx +161 -84
- package/src/contexts/{Localization.tsx → LocalizationCtx.tsx} +0 -0
- package/src/contexts/{PlatformService.tsx → PlatformServiceCtx.tsx} +0 -0
- package/src/contexts/ReactionCtx.tsx +102 -0
- package/src/contexts/{SendbirdChat.tsx → SendbirdChatCtx.tsx} +34 -6
- package/src/contexts/UserProfileCtx.tsx +135 -0
- package/src/domain/groupChannel/component/GroupChannelInput/EditInput.tsx +57 -29
- package/src/domain/groupChannel/component/GroupChannelInput/SendInput.tsx +56 -13
- package/src/domain/groupChannel/component/GroupChannelInput/index.tsx +138 -41
- package/src/domain/groupChannel/component/GroupChannelMessageList.tsx +27 -10
- package/src/domain/groupChannel/component/GroupChannelSuggestedMentionList.tsx +173 -0
- package/src/domain/groupChannel/index.ts +1 -0
- package/src/domain/groupChannel/module/createGroupChannelModule.tsx +12 -1
- package/src/domain/groupChannel/module/moduleContext.tsx +4 -4
- package/src/domain/groupChannel/types.ts +29 -6
- package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersHeader.tsx +14 -0
- package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersList.tsx +33 -0
- package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusEmpty.tsx +18 -0
- package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusError.tsx +19 -0
- package/src/domain/groupChannelBannedUsers/component/GroupChannelBannedUsersStatusLoading.tsx +18 -0
- package/src/domain/groupChannelBannedUsers/index.ts +6 -0
- package/src/domain/groupChannelBannedUsers/module/createGroupChannelBannedUsersModule.tsx +21 -0
- package/src/domain/groupChannelBannedUsers/module/moduleContext.tsx +30 -0
- package/src/domain/groupChannelBannedUsers/types.ts +50 -0
- package/src/domain/groupChannelList/component/GroupChannelListList.tsx +2 -1
- package/src/domain/groupChannelList/component/GroupChannelListTypeSelector.tsx +37 -43
- package/src/domain/groupChannelList/types.ts +3 -9
- package/src/domain/groupChannelModeration/component/GroupChannelModerationHeader.tsx +14 -0
- package/src/domain/groupChannelModeration/component/GroupChannelModerationMenu.tsx +84 -0
- package/src/domain/groupChannelModeration/index.ts +4 -0
- package/src/domain/groupChannelModeration/module/createGroupChannelModerationModule.tsx +15 -0
- package/src/domain/groupChannelModeration/module/moduleContext.tsx +33 -0
- package/src/domain/groupChannelModeration/types.ts +48 -0
- package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersHeader.tsx +14 -0
- package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersList.tsx +31 -0
- package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusEmpty.tsx +18 -0
- package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusError.tsx +19 -0
- package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.tsx +18 -0
- package/src/domain/groupChannelMutedMembers/index.ts +7 -0
- package/src/domain/groupChannelMutedMembers/module/createGroupChannelMutedMembersModule.tsx +21 -0
- package/src/domain/groupChannelMutedMembers/module/moduleContext.tsx +30 -0
- package/src/domain/groupChannelMutedMembers/types.ts +50 -0
- package/src/domain/groupChannelNotifications/component/GroupChannelNotificationsHeader.tsx +14 -0
- package/src/domain/groupChannelNotifications/component/GroupChannelNotificationsView.tsx +128 -0
- package/src/domain/groupChannelNotifications/index.ts +4 -0
- package/src/domain/groupChannelNotifications/module/createGroupChannelNotificationsModule.tsx +15 -0
- package/src/domain/groupChannelNotifications/module/moduleContext.tsx +31 -0
- package/src/domain/groupChannelNotifications/types.ts +38 -0
- package/src/domain/groupChannelOperators/component/GroupChannelOperatorsHeader.tsx +25 -0
- package/src/domain/groupChannelOperators/component/GroupChannelOperatorsList.tsx +30 -0
- package/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusEmpty.tsx +18 -0
- package/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusError.tsx +19 -0
- package/src/domain/groupChannelOperators/component/GroupChannelOperatorsStatusLoading.tsx +18 -0
- package/src/domain/groupChannelOperators/index.ts +7 -0
- package/src/domain/groupChannelOperators/module/createGroupChannelOperatorsModule.tsx +21 -0
- package/src/domain/groupChannelOperators/module/moduleContext.tsx +30 -0
- package/src/domain/groupChannelOperators/types.ts +52 -0
- package/src/domain/groupChannelSettings/component/GroupChannelSettingsInfo.tsx +2 -7
- package/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.tsx +51 -3
- package/src/domain/groupChannelSettings/module/moduleContext.tsx +9 -12
- package/src/domain/groupChannelSettings/types.ts +4 -0
- package/src/domain/groupChannelUserList/types.ts +31 -11
- package/src/domain/userList/component/UserListList.tsx +5 -1
- package/src/domain/userList/component/UserListStatusError.tsx +2 -2
- package/src/domain/userList/module/createUserListModule.tsx +3 -1
- package/src/domain/userList/types.ts +4 -1
- package/src/fragments/createGroupChannelBannedUsersFragment.tsx +80 -0
- package/src/fragments/createGroupChannelCreateFragment.tsx +18 -32
- package/src/fragments/createGroupChannelFragment.tsx +31 -11
- package/src/fragments/createGroupChannelInviteFragment.tsx +28 -50
- package/src/fragments/createGroupChannelListFragment.tsx +4 -10
- package/src/fragments/createGroupChannelMembersFragment.tsx +110 -67
- package/src/fragments/createGroupChannelModerationFragment.tsx +57 -0
- package/src/fragments/createGroupChannelMutedMembersFragment.tsx +93 -0
- package/src/fragments/createGroupChannelNotificationsFragment.tsx +27 -0
- package/src/fragments/createGroupChannelOperatorsFragment.tsx +101 -0
- package/src/fragments/createGroupChannelRegisterOperatorFragment.tsx +94 -0
- package/src/fragments/createGroupChannelSettingsFragment.tsx +11 -1
- package/src/hooks/useConnection.ts +5 -1
- package/src/hooks/useContext.ts +17 -3
- package/src/hooks/useKeyboardStatus.ts +54 -0
- package/src/hooks/useMentionSuggestion.ts +106 -0
- package/src/hooks/useMentionTextInput.ts +139 -0
- package/src/index.ts +22 -5
- package/src/libs/EmojiManager.ts +80 -0
- package/src/libs/MentionConfig.ts +40 -0
- package/src/libs/MentionManager.tsx +240 -0
- package/src/localization/StringSet.type.ts +137 -22
- package/src/platform/createFileService.native.ts +1 -1
- package/src/types.ts +12 -0
- package/src/utils/common.ts +8 -0
- package/src/version.ts +1 -1
- package/lib/commonjs/contexts/Localization.js.map +0 -1
- package/lib/commonjs/contexts/PlatformService.js.map +0 -1
- package/lib/commonjs/contexts/SendbirdChat.js.map +0 -1
- package/lib/module/contexts/Localization.js.map +0 -1
- package/lib/module/contexts/PlatformService.js.map +0 -1
- package/lib/module/contexts/SendbirdChat.js.map +0 -1
|
@@ -2,7 +2,7 @@ import type React from 'react';
|
|
|
2
2
|
import type { FlatListProps } from 'react-native';
|
|
3
3
|
|
|
4
4
|
import type { UseGroupChannelListOptions } from '@sendbird/uikit-chat-hooks';
|
|
5
|
-
import type { ActionMenuItem
|
|
5
|
+
import type { ActionMenuItem } from '@sendbird/uikit-react-native-foundation';
|
|
6
6
|
import type { SendbirdGroupChannel } from '@sendbird/uikit-utils';
|
|
7
7
|
|
|
8
8
|
import type { CommonComponent } from '../../types';
|
|
@@ -14,17 +14,13 @@ export interface GroupChannelListProps {
|
|
|
14
14
|
onPressChannel: (channel: SendbirdGroupChannel) => void;
|
|
15
15
|
/** Navigate to GroupChannelCreateFragment **/
|
|
16
16
|
onPressCreateChannel: (channelType: GroupChannelType) => void;
|
|
17
|
-
/** Custom Header for TypeSelector, Only replace header component not a module **/
|
|
18
|
-
TypeSelectorHeader?: null | CommonComponent<
|
|
19
|
-
BaseHeaderProps<{ title: string; right: React.ReactElement; onPressRight: () => void }>
|
|
20
|
-
>;
|
|
21
17
|
/** Method to render GroupChannel preview **/
|
|
22
18
|
renderGroupChannelPreview?: (
|
|
23
19
|
channel: SendbirdGroupChannel,
|
|
24
20
|
onLongPressChannel: () => void,
|
|
25
21
|
) => React.ReactElement | null;
|
|
26
|
-
|
|
27
|
-
|
|
22
|
+
/** Skip type selection, When this is set to true 'channelType' only receive 'GROUP' type **/
|
|
23
|
+
skipTypeSelection?: boolean;
|
|
28
24
|
/** Custom Query creator for channels query **/
|
|
29
25
|
queryCreator?: UseGroupChannelListOptions['queryCreator'];
|
|
30
26
|
/** Custom Collection creator for group channel collection **/
|
|
@@ -55,8 +51,6 @@ export interface GroupChannelListProps {
|
|
|
55
51
|
};
|
|
56
52
|
/** Props for `GroupChannelListModule.TypeSelector` **/
|
|
57
53
|
TypeSelector: {
|
|
58
|
-
/** Prop from Fragment `Fragment.TypeSelectorHeader` **/
|
|
59
|
-
Header: GroupChannelListProps['Fragment']['TypeSelectorHeader'];
|
|
60
54
|
/** Prop from Fragment `Fragment.skipTypeSelection` **/
|
|
61
55
|
skipTypeSelection: boolean;
|
|
62
56
|
/** Method called when type is selected, call `Fragment.onPressCreateChannel` **/
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import React, { useContext } from 'react';
|
|
2
|
+
|
|
3
|
+
import { Icon, useHeaderStyle } from '@sendbird/uikit-react-native-foundation';
|
|
4
|
+
|
|
5
|
+
import { GroupChannelModerationContexts } from '../module/moduleContext';
|
|
6
|
+
import type { GroupChannelModerationProps } from '../types';
|
|
7
|
+
|
|
8
|
+
const GroupChannelModerationHeader = ({ onPressHeaderLeft }: GroupChannelModerationProps['Header']) => {
|
|
9
|
+
const { headerTitle } = useContext(GroupChannelModerationContexts.Fragment);
|
|
10
|
+
const { HeaderComponent } = useHeaderStyle();
|
|
11
|
+
return <HeaderComponent title={headerTitle} left={<Icon icon={'arrow-left'} />} onPressLeft={onPressHeaderLeft} />;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export default GroupChannelModerationHeader;
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import React, { useContext, useState } from 'react';
|
|
2
|
+
import { View } from 'react-native';
|
|
3
|
+
|
|
4
|
+
import type { MenuBarProps } from '@sendbird/uikit-react-native-foundation';
|
|
5
|
+
import { Icon, MenuBar, Switch, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
|
|
6
|
+
|
|
7
|
+
import { useLocalization } from '../../../hooks/useContext';
|
|
8
|
+
import { GroupChannelModerationContexts } from '../module/moduleContext';
|
|
9
|
+
import type { GroupChannelModerationProps } from '../types';
|
|
10
|
+
|
|
11
|
+
const GroupChannelModerationMenu = ({
|
|
12
|
+
onPressMenuBannedUsers,
|
|
13
|
+
onPressMenuMutedMembers,
|
|
14
|
+
onPressMenuOperators,
|
|
15
|
+
menuItemsCreator = (menu) => menu,
|
|
16
|
+
}: GroupChannelModerationProps['Menu']) => {
|
|
17
|
+
const { channel } = useContext(GroupChannelModerationContexts.Fragment);
|
|
18
|
+
const { STRINGS } = useLocalization();
|
|
19
|
+
const { colors } = useUIKitTheme();
|
|
20
|
+
|
|
21
|
+
const [isFrozen, setIsFrozen] = useState(() => channel.isFrozen);
|
|
22
|
+
|
|
23
|
+
const toggleFreeze = async () => {
|
|
24
|
+
if (channel.isFrozen) {
|
|
25
|
+
await channel.unfreeze();
|
|
26
|
+
} else {
|
|
27
|
+
await channel.freeze();
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
setIsFrozen(channel.isFrozen);
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
const menuItems: MenuBarProps[] = menuItemsCreator([
|
|
34
|
+
{
|
|
35
|
+
icon: 'operator',
|
|
36
|
+
name: STRINGS.GROUP_CHANNEL_MODERATION.MENU_OPERATORS,
|
|
37
|
+
onPress: () => onPressMenuOperators(),
|
|
38
|
+
actionItem: <Icon icon={'chevron-right'} color={colors.onBackground01} />,
|
|
39
|
+
},
|
|
40
|
+
{
|
|
41
|
+
icon: 'mute',
|
|
42
|
+
visible: !channel.isBroadcast,
|
|
43
|
+
name: STRINGS.GROUP_CHANNEL_MODERATION.MENU_MUTED_MEMBERS,
|
|
44
|
+
onPress: () => onPressMenuMutedMembers(),
|
|
45
|
+
actionItem: <Icon icon={'chevron-right'} color={colors.onBackground01} />,
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
icon: 'ban',
|
|
49
|
+
name: STRINGS.GROUP_CHANNEL_MODERATION.MENU_BANNED_USERS,
|
|
50
|
+
onPress: () => onPressMenuBannedUsers(),
|
|
51
|
+
actionItem: <Icon icon={'chevron-right'} color={colors.onBackground01} />,
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
icon: 'freeze',
|
|
55
|
+
visible: !channel.isBroadcast,
|
|
56
|
+
name: STRINGS.GROUP_CHANNEL_MODERATION.MENU_FREEZE_CHANNEL,
|
|
57
|
+
actionItem: <Switch value={isFrozen} onChangeValue={toggleFreeze} />,
|
|
58
|
+
onPress: toggleFreeze,
|
|
59
|
+
},
|
|
60
|
+
]);
|
|
61
|
+
|
|
62
|
+
return (
|
|
63
|
+
<View>
|
|
64
|
+
{menuItems.map((menu) => {
|
|
65
|
+
return (
|
|
66
|
+
<MenuBar
|
|
67
|
+
key={menu.name}
|
|
68
|
+
onPress={menu.onPress}
|
|
69
|
+
name={menu.name}
|
|
70
|
+
disabled={menu.disabled}
|
|
71
|
+
visible={menu.visible}
|
|
72
|
+
icon={menu.icon}
|
|
73
|
+
iconColor={menu.iconColor}
|
|
74
|
+
iconBackgroundColor={menu.iconBackgroundColor}
|
|
75
|
+
actionLabel={menu.actionLabel}
|
|
76
|
+
actionItem={menu.actionItem}
|
|
77
|
+
/>
|
|
78
|
+
);
|
|
79
|
+
})}
|
|
80
|
+
</View>
|
|
81
|
+
);
|
|
82
|
+
};
|
|
83
|
+
|
|
84
|
+
export default GroupChannelModerationMenu;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { default as GroupChannelModerationHeader } from './component/GroupChannelModerationHeader';
|
|
2
|
+
export { default as GroupChannelModerationMenu } from './component/GroupChannelModerationMenu';
|
|
3
|
+
export { default as createGroupChannelModerationModule } from './module/createGroupChannelModerationModule';
|
|
4
|
+
export { GroupChannelModerationContextsProvider, GroupChannelModerationContexts } from './module/moduleContext';
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import GroupChannelModerationHeader from '../component/GroupChannelModerationHeader';
|
|
2
|
+
import GroupChannelModerationMenu from '../component/GroupChannelModerationMenu';
|
|
3
|
+
import type { GroupChannelModerationModule } from '../types';
|
|
4
|
+
import { GroupChannelModerationContextsProvider } from './moduleContext';
|
|
5
|
+
|
|
6
|
+
const createGroupChannelModerationModule = ({
|
|
7
|
+
Header = GroupChannelModerationHeader,
|
|
8
|
+
Menu = GroupChannelModerationMenu,
|
|
9
|
+
Provider = GroupChannelModerationContextsProvider,
|
|
10
|
+
...module
|
|
11
|
+
}: Partial<GroupChannelModerationModule> = {}): GroupChannelModerationModule => {
|
|
12
|
+
return { Header, Menu, Provider, ...module };
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
export default createGroupChannelModerationModule;
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import React, { createContext } from 'react';
|
|
2
|
+
|
|
3
|
+
import type { SendbirdGroupChannel } from '@sendbird/uikit-utils';
|
|
4
|
+
|
|
5
|
+
import ProviderLayout from '../../../components/ProviderLayout';
|
|
6
|
+
import { useLocalization } from '../../../hooks/useContext';
|
|
7
|
+
import type { GroupChannelModerationContextsType, GroupChannelModerationModule } from '../types';
|
|
8
|
+
|
|
9
|
+
export const GroupChannelModerationContexts: GroupChannelModerationContextsType = {
|
|
10
|
+
Fragment: createContext({
|
|
11
|
+
headerTitle: '',
|
|
12
|
+
channel: {} as SendbirdGroupChannel,
|
|
13
|
+
}),
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
export const GroupChannelModerationContextsProvider: GroupChannelModerationModule['Provider'] = ({
|
|
17
|
+
children,
|
|
18
|
+
channel,
|
|
19
|
+
}) => {
|
|
20
|
+
// const [visible, setVisible] = useState(false);
|
|
21
|
+
|
|
22
|
+
const { STRINGS } = useLocalization();
|
|
23
|
+
|
|
24
|
+
return (
|
|
25
|
+
<ProviderLayout>
|
|
26
|
+
<GroupChannelModerationContexts.Fragment.Provider
|
|
27
|
+
value={{ headerTitle: STRINGS.GROUP_CHANNEL_MODERATION.HEADER_TITLE, channel }}
|
|
28
|
+
>
|
|
29
|
+
{children}
|
|
30
|
+
</GroupChannelModerationContexts.Fragment.Provider>
|
|
31
|
+
</ProviderLayout>
|
|
32
|
+
);
|
|
33
|
+
};
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import type React from 'react';
|
|
2
|
+
|
|
3
|
+
import type { MenuBarProps } from '@sendbird/uikit-react-native-foundation';
|
|
4
|
+
import type { SendbirdGroupChannel } from '@sendbird/uikit-utils';
|
|
5
|
+
|
|
6
|
+
import type { CommonComponent } from '../../types';
|
|
7
|
+
|
|
8
|
+
export type GroupChannelModerationProps = {
|
|
9
|
+
Fragment: {
|
|
10
|
+
channel: SendbirdGroupChannel;
|
|
11
|
+
onPressHeaderLeft: GroupChannelModerationProps['Header']['onPressHeaderLeft'];
|
|
12
|
+
onPressMenuOperators: GroupChannelModerationProps['Menu']['onPressMenuOperators'];
|
|
13
|
+
onPressMenuMutedMembers: GroupChannelModerationProps['Menu']['onPressMenuMutedMembers'];
|
|
14
|
+
onPressMenuBannedUsers: GroupChannelModerationProps['Menu']['onPressMenuBannedUsers'];
|
|
15
|
+
menuItemsCreator?: (defaultMenuItems: MenuBarProps[]) => MenuBarProps[];
|
|
16
|
+
};
|
|
17
|
+
Header: {
|
|
18
|
+
onPressHeaderLeft: () => void;
|
|
19
|
+
};
|
|
20
|
+
Menu: {
|
|
21
|
+
onPressMenuOperators: () => void;
|
|
22
|
+
onPressMenuMutedMembers: () => void;
|
|
23
|
+
onPressMenuBannedUsers: () => void;
|
|
24
|
+
menuItemsCreator?: (defaultMenuItems: MenuBarProps[]) => MenuBarProps[];
|
|
25
|
+
};
|
|
26
|
+
Provider: {
|
|
27
|
+
channel: SendbirdGroupChannel;
|
|
28
|
+
};
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* Internal context for GroupChannelModeration
|
|
33
|
+
* For example, the developer can create a custom header
|
|
34
|
+
* with getting data from the domain context
|
|
35
|
+
* */
|
|
36
|
+
export type GroupChannelModerationContextsType = {
|
|
37
|
+
Fragment: React.Context<{
|
|
38
|
+
headerTitle: string;
|
|
39
|
+
channel: SendbirdGroupChannel;
|
|
40
|
+
}>;
|
|
41
|
+
};
|
|
42
|
+
export interface GroupChannelModerationModule {
|
|
43
|
+
Provider: CommonComponent<GroupChannelModerationProps['Provider']>;
|
|
44
|
+
Header: CommonComponent<GroupChannelModerationProps['Header']>;
|
|
45
|
+
Menu: CommonComponent<GroupChannelModerationProps['Menu']>;
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
export type GroupChannelModerationFragment = CommonComponent<GroupChannelModerationProps['Fragment']>;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import React, { useContext } from 'react';
|
|
2
|
+
|
|
3
|
+
import { Icon, useHeaderStyle } from '@sendbird/uikit-react-native-foundation';
|
|
4
|
+
|
|
5
|
+
import { GroupChannelMutedMembersContexts } from '../module/moduleContext';
|
|
6
|
+
import type { GroupChannelMutedMembersProps } from '../types';
|
|
7
|
+
|
|
8
|
+
const GroupChannelMutedMembersHeader = ({ onPressHeaderLeft }: GroupChannelMutedMembersProps['Header']) => {
|
|
9
|
+
const { headerTitle } = useContext(GroupChannelMutedMembersContexts.Fragment);
|
|
10
|
+
const { HeaderComponent } = useHeaderStyle();
|
|
11
|
+
return <HeaderComponent title={headerTitle} left={<Icon icon={'arrow-left'} />} onPressLeft={onPressHeaderLeft} />;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export default GroupChannelMutedMembersHeader;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { FlatList, ListRenderItem } from 'react-native';
|
|
3
|
+
import { useSafeAreaInsets } from 'react-native-safe-area-context';
|
|
4
|
+
|
|
5
|
+
import { SendbirdRestrictedUser, getUserUniqId, useFreshCallback } from '@sendbird/uikit-utils';
|
|
6
|
+
|
|
7
|
+
import type { GroupChannelMutedMembersProps } from '../types';
|
|
8
|
+
|
|
9
|
+
const GroupChannelMutedMembersList = ({
|
|
10
|
+
renderUser,
|
|
11
|
+
mutedMembers,
|
|
12
|
+
ListEmptyComponent,
|
|
13
|
+
}: GroupChannelMutedMembersProps['List']) => {
|
|
14
|
+
const renderItem: ListRenderItem<SendbirdRestrictedUser> = useFreshCallback(({ item }) =>
|
|
15
|
+
renderUser?.({ user: item }),
|
|
16
|
+
);
|
|
17
|
+
const { left, right } = useSafeAreaInsets();
|
|
18
|
+
|
|
19
|
+
return (
|
|
20
|
+
<FlatList
|
|
21
|
+
data={mutedMembers}
|
|
22
|
+
renderItem={renderItem}
|
|
23
|
+
contentContainerStyle={{ paddingLeft: left, paddingRight: right, flexGrow: 1 }}
|
|
24
|
+
ListEmptyComponent={ListEmptyComponent}
|
|
25
|
+
bounces={false}
|
|
26
|
+
keyExtractor={getUserUniqId}
|
|
27
|
+
/>
|
|
28
|
+
);
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
export default GroupChannelMutedMembersList;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { StyleSheet, View } from 'react-native';
|
|
3
|
+
|
|
4
|
+
import TypedPlaceholder from '../../../components/TypedPlaceholder';
|
|
5
|
+
|
|
6
|
+
const GroupChannelMutedMembersStatusEmpty = () => {
|
|
7
|
+
return (
|
|
8
|
+
<View style={styles.container}>
|
|
9
|
+
<TypedPlaceholder type={'no-muted-members'} />
|
|
10
|
+
</View>
|
|
11
|
+
);
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
const styles = StyleSheet.create({
|
|
15
|
+
container: { flex: 1, justifyContent: 'center', alignItems: 'center' },
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
export default GroupChannelMutedMembersStatusEmpty;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { StyleSheet, View } from 'react-native';
|
|
3
|
+
|
|
4
|
+
import TypedPlaceholder from '../../../components/TypedPlaceholder';
|
|
5
|
+
import type { GroupChannelMutedMembersModule } from '../types';
|
|
6
|
+
|
|
7
|
+
const GroupChannelMutedMembersStatusError: GroupChannelMutedMembersModule['StatusError'] = ({ onPressRetry }) => {
|
|
8
|
+
return (
|
|
9
|
+
<View style={styles.container}>
|
|
10
|
+
<TypedPlaceholder type={'error-wrong'} onPressRetry={onPressRetry} />
|
|
11
|
+
</View>
|
|
12
|
+
);
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
const styles = StyleSheet.create({
|
|
16
|
+
container: { flex: 1, justifyContent: 'center', alignItems: 'center' },
|
|
17
|
+
});
|
|
18
|
+
|
|
19
|
+
export default GroupChannelMutedMembersStatusError;
|
package/src/domain/groupChannelMutedMembers/component/GroupChannelMutedMembersStatusLoading.tsx
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { StyleSheet, View } from 'react-native';
|
|
3
|
+
|
|
4
|
+
import TypedPlaceholder from '../../../components/TypedPlaceholder';
|
|
5
|
+
|
|
6
|
+
const GroupChannelMutedMembersStatusLoading = () => {
|
|
7
|
+
return (
|
|
8
|
+
<View style={styles.container}>
|
|
9
|
+
<TypedPlaceholder type={'loading'} />
|
|
10
|
+
</View>
|
|
11
|
+
);
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
const styles = StyleSheet.create({
|
|
15
|
+
container: { flex: 1, justifyContent: 'center', alignItems: 'center' },
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
export default GroupChannelMutedMembersStatusLoading;
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { default as GroupChannelMutedMembersList } from './component/GroupChannelMutedMembersList';
|
|
2
|
+
export { default as GroupChannelMutedMembersHeader } from './component/GroupChannelMutedMembersHeader';
|
|
3
|
+
export { default as GroupChannelMutedMembersStatusEmpty } from './component/GroupChannelMutedMembersStatusEmpty';
|
|
4
|
+
export { default as GroupChannelMutedMembersStatusError } from './component/GroupChannelMutedMembersStatusError';
|
|
5
|
+
export { default as GroupChannelMutedMembersStatusLoading } from './component/GroupChannelMutedMembersStatusLoading';
|
|
6
|
+
export { default as createGroupChannelMutedMembersModule } from './module/createGroupChannelMutedMembersModule';
|
|
7
|
+
export { GroupChannelMutedMembersContextsProvider, GroupChannelMutedMembersContexts } from './module/moduleContext';
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import GroupChannelMutedMembersHeader from '../component/GroupChannelMutedMembersHeader';
|
|
2
|
+
import GroupChannelMutedMembersList from '../component/GroupChannelMutedMembersList';
|
|
3
|
+
import GroupChannelMutedMembersStatusEmpty from '../component/GroupChannelMutedMembersStatusEmpty';
|
|
4
|
+
import GroupChannelMutedMembersStatusError from '../component/GroupChannelMutedMembersStatusError';
|
|
5
|
+
import GroupChannelMutedMembersStatusLoading from '../component/GroupChannelMutedMembersStatusLoading';
|
|
6
|
+
import type { GroupChannelMutedMembersModule } from '../types';
|
|
7
|
+
import { GroupChannelMutedMembersContextsProvider } from './moduleContext';
|
|
8
|
+
|
|
9
|
+
const createGroupChannelMutedMembersModule = ({
|
|
10
|
+
Header = GroupChannelMutedMembersHeader,
|
|
11
|
+
List = GroupChannelMutedMembersList,
|
|
12
|
+
StatusEmpty = GroupChannelMutedMembersStatusEmpty,
|
|
13
|
+
StatusError = GroupChannelMutedMembersStatusError,
|
|
14
|
+
StatusLoading = GroupChannelMutedMembersStatusLoading,
|
|
15
|
+
Provider = GroupChannelMutedMembersContextsProvider,
|
|
16
|
+
...module
|
|
17
|
+
}: Partial<GroupChannelMutedMembersModule> = {}): GroupChannelMutedMembersModule => {
|
|
18
|
+
return { Header, List, Provider, StatusEmpty, StatusError, StatusLoading, ...module };
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
export default createGroupChannelMutedMembersModule;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import React, { createContext } from 'react';
|
|
2
|
+
|
|
3
|
+
import type { SendbirdGroupChannel } from '@sendbird/uikit-utils';
|
|
4
|
+
|
|
5
|
+
import ProviderLayout from '../../../components/ProviderLayout';
|
|
6
|
+
import { useLocalization } from '../../../hooks/useContext';
|
|
7
|
+
import type { GroupChannelMutedMembersContextsType, GroupChannelMutedMembersModule } from '../types';
|
|
8
|
+
|
|
9
|
+
export const GroupChannelMutedMembersContexts: GroupChannelMutedMembersContextsType = {
|
|
10
|
+
Fragment: createContext({
|
|
11
|
+
headerTitle: '',
|
|
12
|
+
channel: {} as SendbirdGroupChannel,
|
|
13
|
+
}),
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
export const GroupChannelMutedMembersContextsProvider: GroupChannelMutedMembersModule['Provider'] = ({
|
|
17
|
+
channel,
|
|
18
|
+
children,
|
|
19
|
+
}) => {
|
|
20
|
+
const { STRINGS } = useLocalization();
|
|
21
|
+
return (
|
|
22
|
+
<ProviderLayout>
|
|
23
|
+
<GroupChannelMutedMembersContexts.Fragment.Provider
|
|
24
|
+
value={{ headerTitle: STRINGS.GROUP_CHANNEL_MUTED_MEMBERS.HEADER_TITLE, channel }}
|
|
25
|
+
>
|
|
26
|
+
{children}
|
|
27
|
+
</GroupChannelMutedMembersContexts.Fragment.Provider>
|
|
28
|
+
</ProviderLayout>
|
|
29
|
+
);
|
|
30
|
+
};
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import type React from 'react';
|
|
2
|
+
|
|
3
|
+
import type { SendbirdGroupChannel, SendbirdRestrictedUser } from '@sendbird/uikit-utils';
|
|
4
|
+
|
|
5
|
+
import type { CommonComponent } from '../../types';
|
|
6
|
+
|
|
7
|
+
export type GroupChannelMutedMembersProps = {
|
|
8
|
+
Fragment: {
|
|
9
|
+
channel: SendbirdGroupChannel;
|
|
10
|
+
onPressHeaderLeft: GroupChannelMutedMembersProps['Header']['onPressHeaderLeft'];
|
|
11
|
+
renderUser?: GroupChannelMutedMembersProps['List']['renderUser'];
|
|
12
|
+
};
|
|
13
|
+
Header: {
|
|
14
|
+
onPressHeaderLeft: () => void;
|
|
15
|
+
};
|
|
16
|
+
List: {
|
|
17
|
+
renderUser: (props: { user: SendbirdRestrictedUser }) => React.ReactElement | null;
|
|
18
|
+
onLoadNext: () => void;
|
|
19
|
+
mutedMembers: SendbirdRestrictedUser[];
|
|
20
|
+
ListEmptyComponent?: React.ReactElement;
|
|
21
|
+
};
|
|
22
|
+
StatusError: {
|
|
23
|
+
onPressRetry: () => void;
|
|
24
|
+
};
|
|
25
|
+
Provider: {
|
|
26
|
+
channel: SendbirdGroupChannel;
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
|
|
30
|
+
/**
|
|
31
|
+
* Internal context for GroupChannelMutedMembers
|
|
32
|
+
* For example, the developer can create a custom header
|
|
33
|
+
* with getting data from the domain context
|
|
34
|
+
* */
|
|
35
|
+
export type GroupChannelMutedMembersContextsType = {
|
|
36
|
+
Fragment: React.Context<{
|
|
37
|
+
headerTitle: string;
|
|
38
|
+
channel: SendbirdGroupChannel;
|
|
39
|
+
}>;
|
|
40
|
+
};
|
|
41
|
+
export interface GroupChannelMutedMembersModule {
|
|
42
|
+
Provider: CommonComponent<GroupChannelMutedMembersProps['Provider']>;
|
|
43
|
+
Header: CommonComponent<GroupChannelMutedMembersProps['Header']>;
|
|
44
|
+
List: CommonComponent<GroupChannelMutedMembersProps['List']>;
|
|
45
|
+
StatusEmpty: CommonComponent;
|
|
46
|
+
StatusLoading: CommonComponent;
|
|
47
|
+
StatusError: CommonComponent<GroupChannelMutedMembersProps['StatusError']>;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
export type GroupChannelMutedMembersFragment = CommonComponent<GroupChannelMutedMembersProps['Fragment']>;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import React, { useContext } from 'react';
|
|
2
|
+
|
|
3
|
+
import { Icon, useHeaderStyle } from '@sendbird/uikit-react-native-foundation';
|
|
4
|
+
|
|
5
|
+
import { GroupChannelNotificationsContexts } from '../module/moduleContext';
|
|
6
|
+
import type { GroupChannelNotificationsProps } from '../types';
|
|
7
|
+
|
|
8
|
+
const GroupChannelNotificationsHeader = ({ onPressHeaderLeft }: GroupChannelNotificationsProps['Header']) => {
|
|
9
|
+
const { headerTitle } = useContext(GroupChannelNotificationsContexts.Fragment);
|
|
10
|
+
const { HeaderComponent } = useHeaderStyle();
|
|
11
|
+
return <HeaderComponent title={headerTitle} left={<Icon icon={'arrow-left'} />} onPressLeft={onPressHeaderLeft} />;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export default GroupChannelNotificationsHeader;
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
import React, { useContext } from 'react';
|
|
2
|
+
import { Pressable, ScrollView, View } from 'react-native';
|
|
3
|
+
|
|
4
|
+
import { PushTriggerOption } from '@sendbird/chat';
|
|
5
|
+
import { Divider, Icon, Switch, Text, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
|
|
6
|
+
import { useForceUpdate } from '@sendbird/uikit-utils';
|
|
7
|
+
|
|
8
|
+
import { useLocalization } from '../../../hooks/useContext';
|
|
9
|
+
import { GroupChannelNotificationsContexts } from '../module/moduleContext';
|
|
10
|
+
|
|
11
|
+
const GroupChannelNotificationsView = () => {
|
|
12
|
+
const { channel } = useContext(GroupChannelNotificationsContexts.Fragment);
|
|
13
|
+
const { STRINGS } = useLocalization();
|
|
14
|
+
const { colors } = useUIKitTheme();
|
|
15
|
+
const forceUpdate = useForceUpdate();
|
|
16
|
+
|
|
17
|
+
const turnedOnNotifications = channel.myPushTriggerOption !== PushTriggerOption.OFF;
|
|
18
|
+
const turnedOnNotificationsOptionAll = [PushTriggerOption.ALL, PushTriggerOption.DEFAULT].some(
|
|
19
|
+
(it) => it === channel.myPushTriggerOption,
|
|
20
|
+
);
|
|
21
|
+
const turnedOnNotificationsOptionMentionsOnly = channel.myPushTriggerOption === PushTriggerOption.MENTION_ONLY;
|
|
22
|
+
|
|
23
|
+
const toggleNotificationSwitch = async (val: boolean) => {
|
|
24
|
+
if (val) {
|
|
25
|
+
await channel.setMyPushTriggerOption(PushTriggerOption.ALL);
|
|
26
|
+
} else {
|
|
27
|
+
await channel.setMyPushTriggerOption(PushTriggerOption.OFF);
|
|
28
|
+
}
|
|
29
|
+
forceUpdate();
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
const onPressNotificationsOption = async (option: PushTriggerOption.ALL | PushTriggerOption.MENTION_ONLY) => {
|
|
33
|
+
await channel.setMyPushTriggerOption(option);
|
|
34
|
+
forceUpdate();
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
return (
|
|
38
|
+
<ScrollView bounces={false} contentContainerStyle={styles.container}>
|
|
39
|
+
<Bar
|
|
40
|
+
subtitle2
|
|
41
|
+
title={STRINGS.GROUP_CHANNEL_NOTIFICATIONS.MENU_NOTIFICATIONS}
|
|
42
|
+
description={STRINGS.GROUP_CHANNEL_NOTIFICATIONS.MENU_NOTIFICATIONS_DESC}
|
|
43
|
+
component={<Switch value={turnedOnNotifications} onChangeValue={toggleNotificationSwitch} />}
|
|
44
|
+
/>
|
|
45
|
+
<Divider />
|
|
46
|
+
{turnedOnNotifications && (
|
|
47
|
+
<>
|
|
48
|
+
<Bar
|
|
49
|
+
body3
|
|
50
|
+
onPress={() => onPressNotificationsOption(PushTriggerOption.ALL)}
|
|
51
|
+
title={STRINGS.GROUP_CHANNEL_NOTIFICATIONS.MENU_NOTIFICATIONS_OPTION_ALL}
|
|
52
|
+
component={
|
|
53
|
+
<Icon
|
|
54
|
+
color={turnedOnNotificationsOptionAll ? colors.primary : colors.onBackground03}
|
|
55
|
+
icon={turnedOnNotificationsOptionAll ? 'radio-on' : 'radio-off'}
|
|
56
|
+
size={24}
|
|
57
|
+
/>
|
|
58
|
+
}
|
|
59
|
+
/>
|
|
60
|
+
<Divider />
|
|
61
|
+
<Bar
|
|
62
|
+
body3
|
|
63
|
+
onPress={() => onPressNotificationsOption(PushTriggerOption.MENTION_ONLY)}
|
|
64
|
+
title={STRINGS.GROUP_CHANNEL_NOTIFICATIONS.MENU_NOTIFICATIONS_OPTION_MENTION_ONLY}
|
|
65
|
+
component={
|
|
66
|
+
<Icon
|
|
67
|
+
color={turnedOnNotificationsOptionMentionsOnly ? colors.primary : colors.onBackground03}
|
|
68
|
+
icon={turnedOnNotificationsOptionMentionsOnly ? 'radio-on' : 'radio-off'}
|
|
69
|
+
size={24}
|
|
70
|
+
/>
|
|
71
|
+
}
|
|
72
|
+
/>
|
|
73
|
+
<Divider />
|
|
74
|
+
</>
|
|
75
|
+
)}
|
|
76
|
+
</ScrollView>
|
|
77
|
+
);
|
|
78
|
+
};
|
|
79
|
+
|
|
80
|
+
type BarProps = {
|
|
81
|
+
title: string;
|
|
82
|
+
onPress?: () => void;
|
|
83
|
+
description?: string;
|
|
84
|
+
component: React.ReactNode;
|
|
85
|
+
subtitle2?: boolean;
|
|
86
|
+
body3?: boolean;
|
|
87
|
+
};
|
|
88
|
+
const Bar = ({ title, onPress, description, component, subtitle2, body3 }: BarProps) => {
|
|
89
|
+
const { colors } = useUIKitTheme();
|
|
90
|
+
return (
|
|
91
|
+
<Pressable onPress={onPress} style={styles.barContainer}>
|
|
92
|
+
<View style={styles.titleContainer}>
|
|
93
|
+
<Text body3={body3} subtitle2={subtitle2} numberOfLines={1} color={colors.onBackground01} style={styles.title}>
|
|
94
|
+
{title}
|
|
95
|
+
</Text>
|
|
96
|
+
<View>{component}</View>
|
|
97
|
+
</View>
|
|
98
|
+
{Boolean(description) && (
|
|
99
|
+
<Text body3 color={colors.onBackground02} style={styles.desc}>
|
|
100
|
+
{description}
|
|
101
|
+
</Text>
|
|
102
|
+
)}
|
|
103
|
+
</Pressable>
|
|
104
|
+
);
|
|
105
|
+
};
|
|
106
|
+
|
|
107
|
+
const styles = createStyleSheet({
|
|
108
|
+
container: {
|
|
109
|
+
paddingHorizontal: 16,
|
|
110
|
+
},
|
|
111
|
+
barContainer: {
|
|
112
|
+
paddingVertical: 16,
|
|
113
|
+
},
|
|
114
|
+
titleContainer: {
|
|
115
|
+
flexDirection: 'row',
|
|
116
|
+
alignItems: 'center',
|
|
117
|
+
},
|
|
118
|
+
title: {
|
|
119
|
+
flex: 1,
|
|
120
|
+
marginRight: 8,
|
|
121
|
+
},
|
|
122
|
+
desc: {
|
|
123
|
+
marginTop: 8,
|
|
124
|
+
flex: 1,
|
|
125
|
+
},
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
export default GroupChannelNotificationsView;
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export { default as GroupChannelNotificationsView } from './component/GroupChannelNotificationsView';
|
|
2
|
+
export { default as GroupChannelNotificationsHeader } from './component/GroupChannelNotificationsHeader';
|
|
3
|
+
export { default as createGroupChannelNotificationsModule } from './module/createGroupChannelNotificationsModule';
|
|
4
|
+
export { GroupChannelNotificationsContextsProvider, GroupChannelNotificationsContexts } from './module/moduleContext';
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import GroupChannelNotificationsHeader from '../component/GroupChannelNotificationsHeader';
|
|
2
|
+
import GroupChannelNotificationsView from '../component/GroupChannelNotificationsView';
|
|
3
|
+
import type { GroupChannelNotificationsModule } from '../types';
|
|
4
|
+
import { GroupChannelNotificationsContextsProvider } from './moduleContext';
|
|
5
|
+
|
|
6
|
+
const createGroupChannelNotificationsModule = ({
|
|
7
|
+
Header = GroupChannelNotificationsHeader,
|
|
8
|
+
View = GroupChannelNotificationsView,
|
|
9
|
+
Provider = GroupChannelNotificationsContextsProvider,
|
|
10
|
+
...module
|
|
11
|
+
}: Partial<GroupChannelNotificationsModule> = {}): GroupChannelNotificationsModule => {
|
|
12
|
+
return { Header, View, Provider, ...module };
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
export default createGroupChannelNotificationsModule;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import React, { createContext } from 'react';
|
|
2
|
+
|
|
3
|
+
import type { SendbirdGroupChannel } from '@sendbird/uikit-utils';
|
|
4
|
+
|
|
5
|
+
import ProviderLayout from '../../../components/ProviderLayout';
|
|
6
|
+
import { useLocalization } from '../../../hooks/useContext';
|
|
7
|
+
import type { GroupChannelNotificationsContextsType, GroupChannelNotificationsModule } from '../types';
|
|
8
|
+
|
|
9
|
+
export const GroupChannelNotificationsContexts: GroupChannelNotificationsContextsType = {
|
|
10
|
+
Fragment: createContext({
|
|
11
|
+
headerTitle: '',
|
|
12
|
+
channel: {} as SendbirdGroupChannel,
|
|
13
|
+
}),
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
export const GroupChannelNotificationsContextsProvider: GroupChannelNotificationsModule['Provider'] = ({
|
|
17
|
+
children,
|
|
18
|
+
channel,
|
|
19
|
+
}) => {
|
|
20
|
+
const { STRINGS } = useLocalization();
|
|
21
|
+
|
|
22
|
+
return (
|
|
23
|
+
<ProviderLayout>
|
|
24
|
+
<GroupChannelNotificationsContexts.Fragment.Provider
|
|
25
|
+
value={{ channel, headerTitle: STRINGS.GROUP_CHANNEL_NOTIFICATIONS.HEADER_TITLE }}
|
|
26
|
+
>
|
|
27
|
+
{children}
|
|
28
|
+
</GroupChannelNotificationsContexts.Fragment.Provider>
|
|
29
|
+
</ProviderLayout>
|
|
30
|
+
);
|
|
31
|
+
};
|