@sendbird/uikit-react-native 1.0.0 → 1.1.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 +7 -7
- package/lib/commonjs/InternalErrorBoundary.js.map +1 -1
- package/lib/commonjs/SendbirdUIKitContainer.js +6 -3
- package/lib/commonjs/SendbirdUIKitContainer.js.map +1 -1
- package/lib/commonjs/components/ChannelCover.js.map +1 -1
- package/lib/commonjs/components/ChatFlatList.js.map +1 -1
- package/lib/commonjs/components/FileViewer.js +326 -0
- package/lib/commonjs/components/FileViewer.js.map +1 -0
- package/lib/commonjs/components/GroupChannelPreviewContainer.js +180 -0
- package/lib/commonjs/components/GroupChannelPreviewContainer.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/AdminMessage/index.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/FileMessage/VideoFileMessage.js +116 -0
- package/lib/commonjs/components/MessageRenderer/FileMessage/VideoFileMessage.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/FileMessage/index.js +8 -0
- package/lib/commonjs/components/MessageRenderer/FileMessage/index.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/MessageContainer.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/MessageDateSeparator.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/MessageIncomingAvatar.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/MessageIncomingSenderName.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/MessageOutgoingStatus.js +15 -24
- package/lib/commonjs/components/MessageRenderer/MessageOutgoingStatus.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/MessageTime.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/UnknownMessage/index.js.map +1 -1
- package/lib/commonjs/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -1
- 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/NewMessagesButton.js.map +1 -1
- package/lib/commonjs/components/ProviderLayout.js.map +1 -1
- package/lib/commonjs/components/SBUPressable.js +45 -0
- package/lib/commonjs/components/SBUPressable.js.map +1 -0
- package/lib/commonjs/components/ScrollToBottomButton.js.map +1 -1
- package/lib/commonjs/components/TypedPlaceholder.js.map +1 -1
- package/lib/commonjs/components/UserActionBar.js +1 -3
- package/lib/commonjs/components/UserActionBar.js.map +1 -1
- package/lib/commonjs/components/UserSelectableBar.js +1 -3
- package/lib/commonjs/components/UserSelectableBar.js.map +1 -1
- package/lib/commonjs/constants.js +7 -1
- package/lib/commonjs/constants.js.map +1 -1
- package/lib/commonjs/contexts/Localization.js.map +1 -1
- package/lib/commonjs/contexts/PlatformService.js +4 -2
- package/lib/commonjs/contexts/PlatformService.js.map +1 -1
- package/lib/commonjs/contexts/SendbirdChat.js +6 -2
- package/lib/commonjs/contexts/SendbirdChat.js.map +1 -1
- package/lib/commonjs/domain/groupChannel/component/GroupChannelHeader.js.map +1 -1
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -1
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js +1 -1
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -1
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -1
- package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js +30 -7
- package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
- package/lib/commonjs/domain/groupChannel/module/moduleContext.js +2 -3
- 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/groupChannelList/component/GroupChannelListHeader.js +2 -5
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListHeader.js.map +1 -1
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListTypeSelector.js.map +1 -1
- package/lib/commonjs/domain/groupChannelList/module/moduleContext.js.map +1 -1
- package/lib/commonjs/domain/groupChannelList/types.js.map +1 -1
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsHeader.js.map +1 -1
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js +1 -1
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -1
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
- package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js +1 -1
- 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/module/moduleContext.js +2 -2
- package/lib/commonjs/domain/userList/module/moduleContext.js.map +1 -1
- package/lib/commonjs/domain/userList/types.js.map +1 -1
- package/lib/commonjs/fragments/createGroupChannelCreateFragment.js +3 -7
- package/lib/commonjs/fragments/createGroupChannelCreateFragment.js.map +1 -1
- package/lib/commonjs/fragments/createGroupChannelFragment.js +13 -11
- package/lib/commonjs/fragments/createGroupChannelFragment.js.map +1 -1
- package/lib/commonjs/fragments/createGroupChannelListFragment.js +7 -37
- package/lib/commonjs/fragments/createGroupChannelListFragment.js.map +1 -1
- package/lib/commonjs/fragments/createGroupChannelMembersFragment.js +1 -1
- package/lib/commonjs/fragments/createGroupChannelMembersFragment.js.map +1 -1
- package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js +2 -3
- package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js.map +1 -1
- package/lib/commonjs/hooks/useContext.js.map +1 -1
- package/lib/commonjs/index.js +29 -2
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/localization/StringSet.type.js +8 -0
- package/lib/commonjs/localization/StringSet.type.js.map +1 -1
- package/lib/commonjs/platform/createFileService.expo.js +38 -20
- package/lib/commonjs/platform/createFileService.expo.js.map +1 -1
- package/lib/commonjs/platform/createFileService.native.js +20 -3
- package/lib/commonjs/platform/createFileService.native.js.map +1 -1
- package/lib/commonjs/platform/createMediaService.expo.js +64 -0
- package/lib/commonjs/platform/createMediaService.expo.js.map +1 -0
- package/lib/commonjs/platform/createMediaService.native.js +67 -0
- package/lib/commonjs/platform/createMediaService.native.js.map +1 -0
- package/lib/commonjs/platform/createNotificationService.expo.js.map +1 -1
- package/lib/commonjs/platform/types.js.map +1 -1
- package/lib/commonjs/version.js +1 -1
- package/lib/commonjs/version.js.map +1 -1
- package/lib/module/InternalErrorBoundary.js.map +1 -1
- package/lib/module/SendbirdUIKitContainer.js +7 -4
- package/lib/module/SendbirdUIKitContainer.js.map +1 -1
- package/lib/module/components/ChannelCover.js.map +1 -1
- package/lib/module/components/ChatFlatList.js.map +1 -1
- package/lib/module/components/FileViewer.js +304 -0
- package/lib/module/components/FileViewer.js.map +1 -0
- package/lib/module/components/GroupChannelPreviewContainer.js +158 -0
- package/lib/module/components/GroupChannelPreviewContainer.js.map +1 -0
- package/lib/module/components/MessageRenderer/AdminMessage/index.js.map +1 -1
- package/lib/module/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -1
- package/lib/module/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -1
- package/lib/module/components/MessageRenderer/FileMessage/VideoFileMessage.js +100 -0
- package/lib/module/components/MessageRenderer/FileMessage/VideoFileMessage.js.map +1 -0
- package/lib/module/components/MessageRenderer/FileMessage/index.js +6 -0
- package/lib/module/components/MessageRenderer/FileMessage/index.js.map +1 -1
- package/lib/module/components/MessageRenderer/MessageContainer.js.map +1 -1
- package/lib/module/components/MessageRenderer/MessageDateSeparator.js.map +1 -1
- package/lib/module/components/MessageRenderer/MessageIncomingAvatar.js.map +1 -1
- package/lib/module/components/MessageRenderer/MessageIncomingSenderName.js.map +1 -1
- package/lib/module/components/MessageRenderer/MessageOutgoingStatus.js +17 -26
- package/lib/module/components/MessageRenderer/MessageOutgoingStatus.js.map +1 -1
- package/lib/module/components/MessageRenderer/MessageTime.js.map +1 -1
- package/lib/module/components/MessageRenderer/UnknownMessage/index.js.map +1 -1
- package/lib/module/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -1
- 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/NewMessagesButton.js.map +1 -1
- package/lib/module/components/ProviderLayout.js.map +1 -1
- package/lib/module/components/SBUPressable.js +33 -0
- package/lib/module/components/SBUPressable.js.map +1 -0
- package/lib/module/components/ScrollToBottomButton.js.map +1 -1
- package/lib/module/components/TypedPlaceholder.js.map +1 -1
- package/lib/module/components/UserActionBar.js +1 -1
- package/lib/module/components/UserActionBar.js.map +1 -1
- package/lib/module/components/UserSelectableBar.js +1 -1
- package/lib/module/components/UserSelectableBar.js.map +1 -1
- package/lib/module/constants.js +5 -0
- package/lib/module/constants.js.map +1 -1
- package/lib/module/contexts/Localization.js.map +1 -1
- package/lib/module/contexts/PlatformService.js +4 -2
- package/lib/module/contexts/PlatformService.js.map +1 -1
- package/lib/module/contexts/SendbirdChat.js +6 -2
- package/lib/module/contexts/SendbirdChat.js.map +1 -1
- package/lib/module/domain/groupChannel/component/GroupChannelHeader.js.map +1 -1
- package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -1
- package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js +1 -1
- package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -1
- package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -1
- package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js +28 -7
- package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -1
- package/lib/module/domain/groupChannel/module/moduleContext.js +2 -3
- 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/groupChannelList/component/GroupChannelListHeader.js +2 -5
- package/lib/module/domain/groupChannelList/component/GroupChannelListHeader.js.map +1 -1
- package/lib/module/domain/groupChannelList/component/GroupChannelListList.js.map +1 -1
- package/lib/module/domain/groupChannelList/component/GroupChannelListTypeSelector.js.map +1 -1
- package/lib/module/domain/groupChannelList/module/moduleContext.js.map +1 -1
- package/lib/module/domain/groupChannelList/types.js.map +1 -1
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsHeader.js.map +1 -1
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js +1 -1
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -1
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -1
- package/lib/module/domain/groupChannelSettings/module/moduleContext.js +1 -1
- 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/module/moduleContext.js +2 -2
- package/lib/module/domain/userList/module/moduleContext.js.map +1 -1
- package/lib/module/domain/userList/types.js.map +1 -1
- package/lib/module/fragments/createGroupChannelCreateFragment.js +4 -4
- package/lib/module/fragments/createGroupChannelCreateFragment.js.map +1 -1
- package/lib/module/fragments/createGroupChannelFragment.js +15 -13
- package/lib/module/fragments/createGroupChannelFragment.js.map +1 -1
- package/lib/module/fragments/createGroupChannelListFragment.js +11 -38
- package/lib/module/fragments/createGroupChannelListFragment.js.map +1 -1
- package/lib/module/fragments/createGroupChannelMembersFragment.js +1 -1
- package/lib/module/fragments/createGroupChannelMembersFragment.js.map +1 -1
- package/lib/module/fragments/createGroupChannelSettingsFragment.js +2 -3
- package/lib/module/fragments/createGroupChannelSettingsFragment.js.map +1 -1
- package/lib/module/hooks/useContext.js.map +1 -1
- package/lib/module/index.js +4 -1
- package/lib/module/index.js.map +1 -1
- package/lib/module/localization/StringSet.type.js +8 -0
- package/lib/module/localization/StringSet.type.js.map +1 -1
- package/lib/module/platform/createFileService.expo.js +38 -20
- package/lib/module/platform/createFileService.expo.js.map +1 -1
- package/lib/module/platform/createFileService.native.js +20 -3
- package/lib/module/platform/createFileService.native.js.map +1 -1
- package/lib/module/platform/createMediaService.expo.js +54 -0
- package/lib/module/platform/createMediaService.expo.js.map +1 -0
- package/lib/module/platform/createMediaService.native.js +57 -0
- package/lib/module/platform/createMediaService.native.js.map +1 -0
- package/lib/module/platform/createNotificationService.expo.js.map +1 -1
- package/lib/module/platform/types.js.map +1 -1
- package/lib/module/version.js +1 -1
- package/lib/module/version.js.map +1 -1
- package/lib/typescript/__template__/component/__domain__Header.d.ts +1 -2
- package/lib/typescript/__template__/component/__domain__StatusEmpty.d.ts +0 -1
- package/lib/typescript/__template__/component/__domain__StatusLoading.d.ts +0 -1
- package/lib/typescript/__template__/component/__domain__View.d.ts +1 -2
- package/lib/typescript/__template__/module/moduleContext.d.ts +2 -3
- package/lib/typescript/__template__/types.d.ts +2 -2
- package/lib/typescript/src/InternalErrorBoundary.d.ts +1 -0
- package/lib/typescript/src/SendbirdUIKitContainer.d.ts +9 -6
- package/lib/typescript/src/components/ChannelCover.d.ts +1 -2
- package/lib/typescript/src/components/FileViewer.d.ts +12 -0
- package/lib/typescript/src/components/GroupChannelPreviewContainer.d.ts +8 -0
- package/lib/typescript/src/components/MessageRenderer/AdminMessage/index.d.ts +1 -2
- package/lib/typescript/src/components/MessageRenderer/FileMessage/BaseFileMessage.d.ts +3 -3
- package/lib/typescript/src/components/MessageRenderer/FileMessage/ImageFileMessage.d.ts +1 -2
- package/lib/typescript/src/components/MessageRenderer/FileMessage/VideoFileMessage.d.ts +3 -0
- package/lib/typescript/src/components/MessageRenderer/FileMessage/index.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/MessageContainer.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/MessageDateSeparator.d.ts +1 -2
- package/lib/typescript/src/components/MessageRenderer/MessageIncomingAvatar.d.ts +1 -2
- package/lib/typescript/src/components/MessageRenderer/MessageIncomingSenderName.d.ts +1 -2
- package/lib/typescript/src/components/MessageRenderer/MessageOutgoingStatus.d.ts +1 -1
- package/lib/typescript/src/components/MessageRenderer/MessageTime.d.ts +1 -2
- package/lib/typescript/src/components/MessageRenderer/UnknownMessage/index.d.ts +1 -2
- package/lib/typescript/src/components/MessageRenderer/UserMessage/BaseUserMessage.d.ts +1 -2
- package/lib/typescript/src/components/MessageRenderer/UserMessage/OpenGraphUserMessage.d.ts +1 -2
- package/lib/typescript/src/components/MessageRenderer/UserMessage/index.d.ts +1 -1
- package/lib/typescript/src/components/NewMessagesButton.d.ts +1 -1
- package/lib/typescript/src/components/ProviderLayout.d.ts +1 -1
- package/lib/typescript/src/components/SBUPressable.d.ts +18 -0
- package/lib/typescript/src/components/ScrollToBottomButton.d.ts +1 -1
- package/lib/typescript/src/components/TypedPlaceholder.d.ts +1 -2
- package/lib/typescript/src/components/UserActionBar.d.ts +2 -3
- package/lib/typescript/src/components/UserSelectableBar.d.ts +2 -3
- package/lib/typescript/src/constants.d.ts +5 -0
- package/lib/typescript/src/contexts/Localization.d.ts +2 -3
- package/lib/typescript/src/contexts/PlatformService.d.ts +5 -4
- package/lib/typescript/src/contexts/SendbirdChat.d.ts +7 -3
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelHeader.d.ts +1 -2
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/EditInput.d.ts +1 -2
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/SendInput.d.ts +1 -2
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/index.d.ts +2 -2
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelMessageList.d.ts +4 -3
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelStatusEmpty.d.ts +0 -1
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelStatusLoading.d.ts +0 -1
- package/lib/typescript/src/domain/groupChannel/types.d.ts +8 -4
- package/lib/typescript/src/domain/groupChannelList/component/GroupChannelListHeader.d.ts +1 -2
- package/lib/typescript/src/domain/groupChannelList/component/GroupChannelListList.d.ts +1 -2
- package/lib/typescript/src/domain/groupChannelList/component/GroupChannelListStatusEmpty.d.ts +0 -1
- package/lib/typescript/src/domain/groupChannelList/component/GroupChannelListStatusLoading.d.ts +0 -1
- package/lib/typescript/src/domain/groupChannelList/component/GroupChannelListTypeSelector.d.ts +1 -2
- package/lib/typescript/src/domain/groupChannelList/module/moduleContext.d.ts +2 -3
- package/lib/typescript/src/domain/groupChannelList/types.d.ts +2 -2
- package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsHeader.d.ts +1 -2
- package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsInfo.d.ts +1 -2
- package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.d.ts +1 -2
- package/lib/typescript/src/domain/groupChannelSettings/module/moduleContext.d.ts +2 -3
- package/lib/typescript/src/domain/groupChannelSettings/types.d.ts +2 -2
- package/lib/typescript/src/domain/groupChannelUserList/types.d.ts +4 -4
- package/lib/typescript/src/domain/userList/component/UserListStatusEmpty.d.ts +0 -1
- package/lib/typescript/src/domain/userList/component/UserListStatusLoading.d.ts +0 -1
- package/lib/typescript/src/domain/userList/module/moduleContext.d.ts +2 -3
- package/lib/typescript/src/domain/userList/types.d.ts +1 -1
- package/lib/typescript/src/hooks/useContext.d.ts +8 -4
- package/lib/typescript/src/index.d.ts +3 -0
- package/lib/typescript/src/localization/StringSet.type.d.ts +4 -0
- package/lib/typescript/src/platform/createFileService.expo.d.ts +4 -4
- package/lib/typescript/src/platform/createMediaService.expo.d.ts +9 -0
- package/lib/typescript/src/platform/createMediaService.native.d.ts +9 -0
- package/lib/typescript/src/platform/createNotificationService.expo.d.ts +1 -1
- package/lib/typescript/src/platform/types.d.ts +20 -1
- package/lib/typescript/src/version.d.ts +1 -1
- package/package.json +16 -7
- package/src/InternalErrorBoundary.tsx +1 -0
- package/src/SendbirdUIKitContainer.tsx +17 -6
- package/src/components/ChannelCover.tsx +1 -1
- package/src/components/ChatFlatList.tsx +1 -1
- package/src/components/FileViewer.tsx +284 -0
- package/src/components/GroupChannelPreviewContainer.tsx +134 -0
- package/src/components/MessageRenderer/AdminMessage/index.tsx +1 -1
- package/src/components/MessageRenderer/FileMessage/BaseFileMessage.tsx +4 -6
- package/src/components/MessageRenderer/FileMessage/ImageFileMessage.tsx +1 -1
- package/src/components/MessageRenderer/FileMessage/VideoFileMessage.tsx +91 -0
- package/src/components/MessageRenderer/FileMessage/index.tsx +7 -1
- package/src/components/MessageRenderer/MessageContainer.tsx +1 -1
- package/src/components/MessageRenderer/MessageDateSeparator.tsx +1 -1
- package/src/components/MessageRenderer/MessageIncomingAvatar.tsx +5 -2
- package/src/components/MessageRenderer/MessageIncomingSenderName.tsx +5 -2
- package/src/components/MessageRenderer/MessageOutgoingStatus.tsx +26 -33
- package/src/components/MessageRenderer/MessageTime.tsx +6 -2
- package/src/components/MessageRenderer/UnknownMessage/index.tsx +1 -1
- package/src/components/MessageRenderer/UserMessage/BaseUserMessage.tsx +1 -1
- package/src/components/MessageRenderer/UserMessage/OpenGraphUserMessage.tsx +4 -2
- package/src/components/MessageRenderer/UserMessage/index.tsx +1 -1
- package/src/components/NewMessagesButton.tsx +1 -1
- package/src/components/ProviderLayout.tsx +1 -1
- package/src/components/SBUPressable.tsx +40 -0
- package/src/components/ScrollToBottomButton.tsx +1 -1
- package/src/components/TypedPlaceholder.tsx +1 -1
- package/src/components/UserActionBar.tsx +2 -2
- package/src/components/UserSelectableBar.tsx +2 -2
- package/src/constants.ts +5 -0
- package/src/contexts/Localization.tsx +2 -3
- package/src/contexts/PlatformService.tsx +13 -6
- package/src/contexts/SendbirdChat.tsx +15 -7
- package/src/domain/groupChannel/component/GroupChannelHeader.tsx +1 -1
- package/src/domain/groupChannel/component/GroupChannelInput/EditInput.tsx +1 -1
- package/src/domain/groupChannel/component/GroupChannelInput/SendInput.tsx +2 -2
- package/src/domain/groupChannel/component/GroupChannelInput/index.tsx +2 -2
- package/src/domain/groupChannel/component/GroupChannelMessageList.tsx +25 -8
- package/src/domain/groupChannel/module/moduleContext.tsx +6 -13
- package/src/domain/groupChannel/types.ts +10 -4
- package/src/domain/groupChannelList/component/GroupChannelListHeader.tsx +2 -4
- package/src/domain/groupChannelList/component/GroupChannelListList.tsx +2 -2
- package/src/domain/groupChannelList/component/GroupChannelListTypeSelector.tsx +4 -4
- package/src/domain/groupChannelList/module/moduleContext.tsx +2 -2
- package/src/domain/groupChannelList/types.ts +3 -2
- package/src/domain/groupChannelSettings/component/GroupChannelSettingsHeader.tsx +1 -1
- package/src/domain/groupChannelSettings/component/GroupChannelSettingsInfo.tsx +1 -1
- package/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.tsx +2 -2
- package/src/domain/groupChannelSettings/module/moduleContext.tsx +7 -15
- package/src/domain/groupChannelSettings/types.ts +2 -2
- package/src/domain/groupChannelUserList/types.ts +4 -5
- package/src/domain/userList/module/moduleContext.tsx +3 -7
- package/src/domain/userList/types.ts +1 -1
- package/src/fragments/createGroupChannelCreateFragment.tsx +38 -41
- package/src/fragments/createGroupChannelFragment.tsx +23 -33
- package/src/fragments/createGroupChannelListFragment.tsx +10 -32
- package/src/fragments/createGroupChannelMembersFragment.tsx +34 -39
- package/src/fragments/createGroupChannelSettingsFragment.tsx +1 -9
- package/src/hooks/useContext.ts +3 -5
- package/src/index.ts +5 -1
- package/src/localization/StringSet.type.ts +8 -0
- package/src/platform/createFileService.expo.ts +29 -16
- package/src/platform/createFileService.native.ts +16 -3
- package/src/platform/createMediaService.expo.tsx +30 -0
- package/src/platform/createMediaService.native.tsx +37 -0
- package/src/platform/createNotificationService.expo.ts +1 -1
- package/src/platform/types.ts +26 -1
- package/src/version.ts +1 -1
|
@@ -1,59 +1,52 @@
|
|
|
1
|
-
import React, { useEffect
|
|
1
|
+
import React, { useEffect } from 'react';
|
|
2
2
|
|
|
3
3
|
import { Icon, LoadingSpinner, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
|
|
4
|
-
import type {
|
|
5
|
-
|
|
6
|
-
SendbirdGroupChannel,
|
|
7
|
-
SendbirdMessage,
|
|
8
|
-
SendbirdUserMessage,
|
|
9
|
-
} from '@sendbird/uikit-utils';
|
|
10
|
-
import { useUniqId } from '@sendbird/uikit-utils';
|
|
4
|
+
import type { SendbirdGroupChannel, SendbirdMessage } from '@sendbird/uikit-utils';
|
|
5
|
+
import { isDifferentChannel, useForceUpdate, useUniqId } from '@sendbird/uikit-utils';
|
|
11
6
|
|
|
12
7
|
import { useSendbirdChat } from '../../hooks/useContext';
|
|
13
8
|
|
|
14
9
|
const SIZE = 16;
|
|
15
10
|
|
|
16
11
|
type Props = { channel: SendbirdGroupChannel; message: SendbirdMessage };
|
|
17
|
-
const MessageOutgoingStatus
|
|
12
|
+
const MessageOutgoingStatus = ({ channel, message }: Props) => {
|
|
18
13
|
if (!message.isUserMessage() && !message.isFileMessage()) return null;
|
|
19
14
|
|
|
20
|
-
const handlerId = useUniqId('MessageOutgoingStatus');
|
|
21
|
-
|
|
22
15
|
const { sdk, features } = useSendbirdChat();
|
|
23
16
|
const { colors } = useUIKitTheme();
|
|
24
17
|
|
|
25
|
-
const
|
|
26
|
-
|
|
27
|
-
undeliveredCount: channel.getUndeliveredMemberCount(message),
|
|
28
|
-
}));
|
|
29
|
-
|
|
30
|
-
const getCounts = (channel: SendbirdGroupChannel, message: SendbirdUserMessage | SendbirdFileMessage) => {
|
|
31
|
-
return {
|
|
32
|
-
unreadCount: channel.getUnreadMemberCount(message),
|
|
33
|
-
undeliveredCount: channel.getUndeliveredMemberCount(message),
|
|
34
|
-
};
|
|
35
|
-
};
|
|
18
|
+
const uniqId = useUniqId('MessageOutgoingStatus');
|
|
19
|
+
const forceUpdate = useForceUpdate();
|
|
36
20
|
|
|
37
21
|
useEffect(() => {
|
|
38
|
-
const
|
|
39
|
-
|
|
40
|
-
|
|
22
|
+
const handlerId = `MessageOutgoingStatus_${uniqId}`;
|
|
23
|
+
|
|
24
|
+
if (
|
|
25
|
+
message.sendingStatus === 'succeeded' &&
|
|
26
|
+
channel.getUnreadMemberCount(message) === 0 &&
|
|
27
|
+
channel.getUndeliveredMemberCount(message) === 0
|
|
28
|
+
) {
|
|
29
|
+
sdk.removeChannelHandler(handlerId);
|
|
41
30
|
} else {
|
|
42
31
|
const handler = new sdk.ChannelHandler();
|
|
43
|
-
|
|
44
|
-
|
|
32
|
+
|
|
33
|
+
handler.onReadReceiptUpdated = (eventChannel) => {
|
|
34
|
+
if (isDifferentChannel(channel, eventChannel)) return;
|
|
35
|
+
forceUpdate();
|
|
45
36
|
};
|
|
46
37
|
|
|
47
38
|
if (features.deliveryReceiptEnabled) {
|
|
48
|
-
handler.onDeliveryReceiptUpdated = (
|
|
49
|
-
if (
|
|
39
|
+
handler.onDeliveryReceiptUpdated = (eventChannel) => {
|
|
40
|
+
if (isDifferentChannel(channel, eventChannel)) return;
|
|
41
|
+
forceUpdate();
|
|
50
42
|
};
|
|
51
43
|
}
|
|
52
|
-
|
|
44
|
+
|
|
45
|
+
sdk.addChannelHandler(handlerId, handler);
|
|
53
46
|
}
|
|
54
47
|
|
|
55
48
|
return () => {
|
|
56
|
-
sdk.removeChannelHandler(
|
|
49
|
+
sdk.removeChannelHandler(handlerId);
|
|
57
50
|
};
|
|
58
51
|
}, [message.sendingStatus]);
|
|
59
52
|
|
|
@@ -65,12 +58,12 @@ const MessageOutgoingStatus: React.FC<Props> = ({ channel, message }) => {
|
|
|
65
58
|
return <Icon icon={'error'} size={SIZE} color={colors.error} style={styles.container} />;
|
|
66
59
|
}
|
|
67
60
|
|
|
68
|
-
if (
|
|
61
|
+
if (channel.getUnreadMemberCount(message) === 0) {
|
|
69
62
|
return <Icon icon={'done-all'} size={SIZE} color={colors.secondary} style={styles.container} />;
|
|
70
63
|
}
|
|
71
64
|
|
|
72
65
|
if (features.deliveryReceiptEnabled) {
|
|
73
|
-
if (
|
|
66
|
+
if (channel.getUndeliveredMemberCount(message) === 0) {
|
|
74
67
|
return <Icon icon={'done-all'} size={SIZE} color={colors.onBackground03} style={styles.container} />;
|
|
75
68
|
}
|
|
76
69
|
return <Icon icon={'done'} size={SIZE} color={colors.onBackground03} style={styles.container} />;
|
|
@@ -6,8 +6,12 @@ import type { SendbirdMessage } from '@sendbird/uikit-utils';
|
|
|
6
6
|
|
|
7
7
|
import { useLocalization } from '../../hooks/useContext';
|
|
8
8
|
|
|
9
|
-
type Props = {
|
|
10
|
-
|
|
9
|
+
type Props = {
|
|
10
|
+
message: SendbirdMessage;
|
|
11
|
+
grouping: boolean;
|
|
12
|
+
style?: StyleProp<ViewStyle>;
|
|
13
|
+
};
|
|
14
|
+
const MessageTime = ({ message, grouping, style }: Props) => {
|
|
11
15
|
const { STRINGS } = useLocalization();
|
|
12
16
|
const { colors } = useUIKitTheme();
|
|
13
17
|
if (grouping) return null;
|
|
@@ -7,7 +7,7 @@ import { useLocalization } from '../../../hooks/useContext';
|
|
|
7
7
|
import type { MessageRendererInterface } from '../index';
|
|
8
8
|
|
|
9
9
|
export type UnknownMessageProps = MessageRendererInterface;
|
|
10
|
-
const UnknownMessage
|
|
10
|
+
const UnknownMessage = ({ message, variant, pressed }: UnknownMessageProps) => {
|
|
11
11
|
const { STRINGS } = useLocalization();
|
|
12
12
|
const { colors } = useUIKitTheme();
|
|
13
13
|
const color = colors.ui.message[variant][pressed ? 'pressed' : 'enabled'];
|
|
@@ -6,7 +6,7 @@ import { Text, URLParsedText, createStyleSheet, useUIKitTheme } from '@sendbird/
|
|
|
6
6
|
import { useLocalization } from '../../../hooks/useContext';
|
|
7
7
|
import type { UserMessageProps } from './index';
|
|
8
8
|
|
|
9
|
-
const BaseUserMessage
|
|
9
|
+
const BaseUserMessage = ({ message, variant, pressed }: UserMessageProps) => {
|
|
10
10
|
const { colors } = useUIKitTheme();
|
|
11
11
|
const color = colors.ui.message[variant][pressed ? 'pressed' : 'enabled'];
|
|
12
12
|
const { STRINGS } = useLocalization();
|
|
@@ -15,8 +15,10 @@ import { conditionChaining } from '@sendbird/uikit-utils';
|
|
|
15
15
|
import { useLocalization } from '../../../hooks/useContext';
|
|
16
16
|
import type { UserMessageProps } from './index';
|
|
17
17
|
|
|
18
|
-
type Props = UserMessageProps & {
|
|
19
|
-
|
|
18
|
+
type Props = UserMessageProps & {
|
|
19
|
+
ogMetaData: Sendbird.OGMetaData;
|
|
20
|
+
};
|
|
21
|
+
const OpenGraphUserMessage = ({ message, variant, pressed, ogMetaData }: Props) => {
|
|
20
22
|
const { STRINGS } = useLocalization();
|
|
21
23
|
const { colors, select, palette } = useUIKitTheme();
|
|
22
24
|
const color = colors.ui.message[variant][pressed ? 'pressed' : 'enabled'];
|
|
@@ -7,7 +7,7 @@ import BaseUserMessage from './BaseUserMessage';
|
|
|
7
7
|
import OpenGraphUserMessage from './OpenGraphUserMessage';
|
|
8
8
|
|
|
9
9
|
export type UserMessageProps = MessageRendererInterface<SendbirdUserMessage>;
|
|
10
|
-
const UserMessage
|
|
10
|
+
const UserMessage = (props: UserMessageProps) => {
|
|
11
11
|
if (props.message.ogMetaData) {
|
|
12
12
|
return <OpenGraphUserMessage {...props} ogMetaData={props.message.ogMetaData} />;
|
|
13
13
|
}
|
|
@@ -11,7 +11,7 @@ type Props = {
|
|
|
11
11
|
visible: boolean;
|
|
12
12
|
onPress: () => void;
|
|
13
13
|
};
|
|
14
|
-
const NewMessagesButton
|
|
14
|
+
const NewMessagesButton = ({ newMessages, visible, onPress }: Props) => {
|
|
15
15
|
const { STRINGS } = useLocalization();
|
|
16
16
|
const { select, palette, colors } = useUIKitTheme();
|
|
17
17
|
if (newMessages.length === 0 || !visible) return null;
|
|
@@ -3,7 +3,7 @@ import { View } from 'react-native';
|
|
|
3
3
|
|
|
4
4
|
import { createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
|
|
5
5
|
|
|
6
|
-
const ProviderLayout
|
|
6
|
+
const ProviderLayout = ({ children }: React.PropsWithChildren) => {
|
|
7
7
|
const { colors } = useUIKitTheme();
|
|
8
8
|
return <View style={[styles.view, { backgroundColor: colors.background }]}>{children}</View>;
|
|
9
9
|
};
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { Pressable, PressableProps, TouchableOpacity, TouchableOpacityProps } from 'react-native';
|
|
3
|
+
|
|
4
|
+
import { DEFAULT_LONG_PRESS_DELAY } from '../constants';
|
|
5
|
+
|
|
6
|
+
type Components = 'Pressable' | 'TouchableOpacity';
|
|
7
|
+
type Props<T extends Components = 'Pressable'> = {
|
|
8
|
+
as?: T;
|
|
9
|
+
} & ExtractProps<T, AsProps>;
|
|
10
|
+
|
|
11
|
+
type AsProps =
|
|
12
|
+
| {
|
|
13
|
+
type: 'Pressable';
|
|
14
|
+
props: PressableProps;
|
|
15
|
+
}
|
|
16
|
+
| {
|
|
17
|
+
type: 'TouchableOpacity';
|
|
18
|
+
props: TouchableOpacityProps;
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
type ExtractProps<T extends Components, U extends AsProps> = U extends { type: T; props: infer P } ? P : never;
|
|
22
|
+
|
|
23
|
+
function getComponent(as?: Components) {
|
|
24
|
+
switch (as) {
|
|
25
|
+
case 'Pressable':
|
|
26
|
+
return Pressable;
|
|
27
|
+
case 'TouchableOpacity':
|
|
28
|
+
return TouchableOpacity;
|
|
29
|
+
default:
|
|
30
|
+
return Pressable;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
const SBUPressable = <T extends Components>({ as, ...props }: Props<T>) => {
|
|
35
|
+
const Renderer = getComponent(as);
|
|
36
|
+
// @ts-ignore
|
|
37
|
+
return <Renderer delayLongPress={DEFAULT_LONG_PRESS_DELAY} {...props} />;
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
export default SBUPressable;
|
|
@@ -7,7 +7,7 @@ type Props = {
|
|
|
7
7
|
visible: boolean;
|
|
8
8
|
onPress: () => void;
|
|
9
9
|
};
|
|
10
|
-
const ScrollToBottomButton
|
|
10
|
+
const ScrollToBottomButton = ({ visible, onPress }: Props) => {
|
|
11
11
|
const { palette, select } = useUIKitTheme();
|
|
12
12
|
return (
|
|
13
13
|
<TouchableOpacity
|
|
@@ -16,7 +16,7 @@ type Props = {
|
|
|
16
16
|
| 'loading';
|
|
17
17
|
onPressRetry?: () => void;
|
|
18
18
|
};
|
|
19
|
-
const TypedPlaceholder
|
|
19
|
+
const TypedPlaceholder = ({ type, onPressRetry }: Props) => {
|
|
20
20
|
const { STRINGS } = useLocalization();
|
|
21
21
|
switch (type) {
|
|
22
22
|
case 'no-banned-members':
|
|
@@ -12,7 +12,7 @@ type Props = {
|
|
|
12
12
|
disabled: boolean;
|
|
13
13
|
onPressActionMenu?: () => void;
|
|
14
14
|
};
|
|
15
|
-
const UserActionBar
|
|
15
|
+
const UserActionBar = ({ muted, uri, name, disabled, onPressActionMenu, label }: Props) => {
|
|
16
16
|
const { colors } = useUIKitTheme();
|
|
17
17
|
|
|
18
18
|
const iconColor = conditionChaining([disabled], [colors.onBackground04, colors.onBackground01]);
|
|
@@ -70,4 +70,4 @@ const styles = createStyleSheet({
|
|
|
70
70
|
},
|
|
71
71
|
});
|
|
72
72
|
|
|
73
|
-
export default
|
|
73
|
+
export default UserActionBar;
|
|
@@ -10,7 +10,7 @@ type Props = {
|
|
|
10
10
|
selected: boolean;
|
|
11
11
|
disabled: boolean;
|
|
12
12
|
};
|
|
13
|
-
const UserSelectableBar
|
|
13
|
+
const UserSelectableBar = ({ uri, name, selected, disabled }: Props) => {
|
|
14
14
|
const { colors } = useUIKitTheme();
|
|
15
15
|
|
|
16
16
|
const iconColor = conditionChaining(
|
|
@@ -55,4 +55,4 @@ const styles = createStyleSheet({
|
|
|
55
55
|
},
|
|
56
56
|
});
|
|
57
57
|
|
|
58
|
-
export default
|
|
58
|
+
export default UserSelectableBar;
|
package/src/constants.ts
CHANGED
|
@@ -2,10 +2,9 @@ import React from 'react';
|
|
|
2
2
|
|
|
3
3
|
import type { StringSet } from '../localization/StringSet.type';
|
|
4
4
|
|
|
5
|
-
type Props = {
|
|
5
|
+
type Props = React.PropsWithChildren<{
|
|
6
6
|
stringSet: StringSet;
|
|
7
|
-
|
|
8
|
-
};
|
|
7
|
+
}>;
|
|
9
8
|
|
|
10
9
|
export type LocalizationContextType = {
|
|
11
10
|
STRINGS: StringSet;
|
|
@@ -1,22 +1,29 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
|
|
3
|
-
import type {
|
|
3
|
+
import type {
|
|
4
|
+
ClipboardServiceInterface,
|
|
5
|
+
FileServiceInterface,
|
|
6
|
+
MediaServiceInterface,
|
|
7
|
+
NotificationServiceInterface,
|
|
8
|
+
} from '../platform/types';
|
|
4
9
|
|
|
5
|
-
type Props = {
|
|
10
|
+
type Props = React.PropsWithChildren<{
|
|
6
11
|
fileService: FileServiceInterface;
|
|
7
12
|
clipboardService: ClipboardServiceInterface;
|
|
8
13
|
notificationService: NotificationServiceInterface;
|
|
9
|
-
|
|
14
|
+
mediaService?: MediaServiceInterface;
|
|
15
|
+
}>;
|
|
10
16
|
|
|
11
17
|
export const PlatformServiceContext = React.createContext<Props | null>(null);
|
|
12
|
-
export const PlatformServiceProvider
|
|
18
|
+
export const PlatformServiceProvider = ({
|
|
13
19
|
children,
|
|
14
20
|
fileService,
|
|
15
21
|
clipboardService,
|
|
16
22
|
notificationService,
|
|
17
|
-
|
|
23
|
+
mediaService,
|
|
24
|
+
}: Props) => {
|
|
18
25
|
return (
|
|
19
|
-
<PlatformServiceContext.Provider value={{ fileService, clipboardService, notificationService }}>
|
|
26
|
+
<PlatformServiceContext.Provider value={{ fileService, clipboardService, notificationService, mediaService }}>
|
|
20
27
|
{children}
|
|
21
28
|
</PlatformServiceContext.Provider>
|
|
22
29
|
);
|
|
@@ -7,13 +7,13 @@ import { useForceUpdate } from '@sendbird/uikit-utils';
|
|
|
7
7
|
|
|
8
8
|
import type { FileType } from '../platform/types';
|
|
9
9
|
|
|
10
|
-
type Props = {
|
|
10
|
+
type Props = React.PropsWithChildren<{
|
|
11
11
|
sdkInstance: SendbirdChatSDK;
|
|
12
12
|
|
|
13
13
|
enableAutoPushTokenRegistration: boolean;
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
}
|
|
14
|
+
enableChannelListTypingIndicator: boolean;
|
|
15
|
+
enableChannelListMessageReceiptStatus: boolean;
|
|
16
|
+
}>;
|
|
17
17
|
|
|
18
18
|
type Context = {
|
|
19
19
|
sdk: SendbirdChatSDK;
|
|
@@ -27,8 +27,8 @@ type Context = {
|
|
|
27
27
|
features: {
|
|
28
28
|
// UIKit features
|
|
29
29
|
autoPushTokenRegistrationEnabled: boolean;
|
|
30
|
-
|
|
31
|
-
|
|
30
|
+
channelListTypingIndicatorEnabled: boolean;
|
|
31
|
+
channelListMessageReceiptStatusEnabled: boolean;
|
|
32
32
|
|
|
33
33
|
// Sendbird application features
|
|
34
34
|
deliveryReceiptEnabled: boolean;
|
|
@@ -39,7 +39,13 @@ type Context = {
|
|
|
39
39
|
};
|
|
40
40
|
|
|
41
41
|
export const SendbirdChatContext = React.createContext<Context | null>(null);
|
|
42
|
-
export const SendbirdChatProvider
|
|
42
|
+
export const SendbirdChatProvider = ({
|
|
43
|
+
children,
|
|
44
|
+
sdkInstance,
|
|
45
|
+
enableAutoPushTokenRegistration,
|
|
46
|
+
enableChannelListMessageReceiptStatus,
|
|
47
|
+
enableChannelListTypingIndicator,
|
|
48
|
+
}: Props) => {
|
|
43
49
|
const [currentUser, _setCurrentUser] = useState<SendbirdUser>();
|
|
44
50
|
const forceUpdate = useForceUpdate();
|
|
45
51
|
const appFeatures = useAppFeatures(sdkInstance);
|
|
@@ -103,6 +109,8 @@ export const SendbirdChatProvider: React.FC<Props> = ({ children, sdkInstance, e
|
|
|
103
109
|
features: {
|
|
104
110
|
...appFeatures,
|
|
105
111
|
autoPushTokenRegistrationEnabled: enableAutoPushTokenRegistration,
|
|
112
|
+
channelListTypingIndicatorEnabled: enableChannelListTypingIndicator,
|
|
113
|
+
channelListMessageReceiptStatusEnabled: enableChannelListMessageReceiptStatus,
|
|
106
114
|
},
|
|
107
115
|
};
|
|
108
116
|
|
|
@@ -8,7 +8,7 @@ import { useLocalization } from '../../../hooks/useContext';
|
|
|
8
8
|
import { GroupChannelContexts } from '../module/moduleContext';
|
|
9
9
|
import type { GroupChannelProps } from '../types';
|
|
10
10
|
|
|
11
|
-
const GroupChannelHeader
|
|
11
|
+
const GroupChannelHeader = ({ onPressHeaderLeft, onPressHeaderRight }: GroupChannelProps['Header']) => {
|
|
12
12
|
const { headerTitle, channel } = useContext(GroupChannelContexts.Fragment);
|
|
13
13
|
const { typingUsers } = useContext(GroupChannelContexts.TypingIndicator);
|
|
14
14
|
const { STRINGS } = useLocalization();
|
|
@@ -15,7 +15,7 @@ type EditInputProps = GroupChannelProps['Input'] & {
|
|
|
15
15
|
};
|
|
16
16
|
|
|
17
17
|
const AUTO_FOCUS = Platform.select({ ios: false, android: true, default: false });
|
|
18
|
-
const EditInput
|
|
18
|
+
const EditInput = ({ text, setText, editMessage, setEditMessage, onUpdateUserMessage }: EditInputProps) => {
|
|
19
19
|
const { STRINGS } = useLocalization();
|
|
20
20
|
const inputRef = useRef<RNTextInput>(null);
|
|
21
21
|
const toast = useToast();
|
|
@@ -19,7 +19,7 @@ type SendInputProps = GroupChannelProps['Input'] & {
|
|
|
19
19
|
setText: (val: string) => void;
|
|
20
20
|
disabled: boolean;
|
|
21
21
|
};
|
|
22
|
-
const SendInput
|
|
22
|
+
const SendInput = ({ onSendUserMessage, onSendFileMessage, text, setText, disabled }: SendInputProps) => {
|
|
23
23
|
const { STRINGS } = useLocalization();
|
|
24
24
|
const { openSheet } = useBottomSheet();
|
|
25
25
|
const { fileService } = usePlatformService();
|
|
@@ -38,7 +38,7 @@ const SendInput: React.FC<SendInputProps> = ({ onSendUserMessage, onSendFileMess
|
|
|
38
38
|
icon: 'camera',
|
|
39
39
|
onPress: async () => {
|
|
40
40
|
const photo = await fileService.openCamera({
|
|
41
|
-
mediaType: '
|
|
41
|
+
mediaType: 'all',
|
|
42
42
|
onOpenFailureWithToastMessage: () => toast.show(STRINGS.TOAST.OPEN_CAMERA_ERROR, 'error'),
|
|
43
43
|
});
|
|
44
44
|
|
|
@@ -11,7 +11,7 @@ import EditInput from './EditInput';
|
|
|
11
11
|
import SendInput from './SendInput';
|
|
12
12
|
|
|
13
13
|
const KEYBOARD_AVOID_VIEW_BEHAVIOR = Platform.select({ ios: 'padding' as const, default: undefined });
|
|
14
|
-
const GroupChannelInput:
|
|
14
|
+
const GroupChannelInput = (props: GroupChannelProps['Input']) => {
|
|
15
15
|
const { channel } = props;
|
|
16
16
|
|
|
17
17
|
const { left, right, bottom } = useSafeAreaInsets();
|
|
@@ -65,7 +65,7 @@ const GroupChannelInput: React.FC<GroupChannelProps['Input']> = (props) => {
|
|
|
65
65
|
</KeyboardAvoidingView>
|
|
66
66
|
);
|
|
67
67
|
};
|
|
68
|
-
const SafeAreaBottom
|
|
68
|
+
const SafeAreaBottom = ({ height }: { height: number }) => {
|
|
69
69
|
return <View style={{ height }} />;
|
|
70
70
|
};
|
|
71
71
|
|
|
@@ -19,18 +19,20 @@ import {
|
|
|
19
19
|
getFileType,
|
|
20
20
|
isMyMessage,
|
|
21
21
|
messageKeyExtractor,
|
|
22
|
+
toMegabyte,
|
|
22
23
|
useFreshCallback,
|
|
23
24
|
} from '@sendbird/uikit-utils';
|
|
24
25
|
|
|
25
26
|
import type { ChatFlatListRef } from '../../../components/ChatFlatList';
|
|
26
27
|
import ChatFlatList from '../../../components/ChatFlatList';
|
|
28
|
+
import { DEPRECATION_WARNING } from '../../../constants';
|
|
27
29
|
import { useLocalization, usePlatformService } from '../../../hooks/useContext';
|
|
28
30
|
import { GroupChannelContexts } from '../module/moduleContext';
|
|
29
31
|
import type { GroupChannelProps } from '../types';
|
|
30
32
|
|
|
31
33
|
const HANDLE_NEXT_MSG_SEPARATELY = Platform.select({ default: true });
|
|
32
34
|
|
|
33
|
-
const GroupChannelMessageList
|
|
35
|
+
const GroupChannelMessageList = ({
|
|
34
36
|
currentUserId,
|
|
35
37
|
channel,
|
|
36
38
|
messages,
|
|
@@ -44,9 +46,10 @@ const GroupChannelMessageList: React.FC<GroupChannelProps['MessageList']> = ({
|
|
|
44
46
|
onResendFailedMessage,
|
|
45
47
|
onDeleteMessage,
|
|
46
48
|
onPressImageMessage,
|
|
49
|
+
onPressMediaMessage,
|
|
47
50
|
flatListProps,
|
|
48
51
|
enableMessageGrouping,
|
|
49
|
-
}) => {
|
|
52
|
+
}: GroupChannelProps['MessageList']) => {
|
|
50
53
|
const { STRINGS } = useLocalization();
|
|
51
54
|
const { colors } = useUIKitTheme();
|
|
52
55
|
const { left, right } = useSafeAreaInsets();
|
|
@@ -56,6 +59,7 @@ const GroupChannelMessageList: React.FC<GroupChannelProps['MessageList']> = ({
|
|
|
56
59
|
const getMessagePressActions = useGetMessagePressActions({
|
|
57
60
|
onDeleteMessage,
|
|
58
61
|
onPressImageMessage,
|
|
62
|
+
onPressMediaMessage,
|
|
59
63
|
currentUserId,
|
|
60
64
|
onResendFailedMessage,
|
|
61
65
|
});
|
|
@@ -135,15 +139,15 @@ const GroupChannelMessageList: React.FC<GroupChannelProps['MessageList']> = ({
|
|
|
135
139
|
};
|
|
136
140
|
|
|
137
141
|
type HandleableMessage = SendbirdUserMessage | SendbirdFileMessage;
|
|
138
|
-
const toMegabyte = (byte: number) => byte / 1024 / 1024;
|
|
139
142
|
const useGetMessagePressActions = ({
|
|
140
143
|
onPressImageMessage,
|
|
144
|
+
onPressMediaMessage,
|
|
141
145
|
onDeleteMessage,
|
|
142
146
|
onResendFailedMessage,
|
|
143
147
|
currentUserId,
|
|
144
148
|
}: Pick<
|
|
145
149
|
GroupChannelProps['MessageList'],
|
|
146
|
-
'onDeleteMessage' | 'onResendFailedMessage' | 'onPressImageMessage' | '
|
|
150
|
+
'onDeleteMessage' | 'onResendFailedMessage' | 'currentUserId' | 'onPressImageMessage' | 'onPressMediaMessage'
|
|
147
151
|
>) => {
|
|
148
152
|
const { colors } = useUIKitTheme();
|
|
149
153
|
const { STRINGS } = useLocalization();
|
|
@@ -253,10 +257,23 @@ const useGetMessagePressActions = ({
|
|
|
253
257
|
}
|
|
254
258
|
|
|
255
259
|
const fileType = getFileType(msg.type || getFileExtension(msg.name));
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
+
switch (fileType) {
|
|
261
|
+
case 'image':
|
|
262
|
+
case 'video':
|
|
263
|
+
case 'audio': {
|
|
264
|
+
response.onPress = () => {
|
|
265
|
+
if (onPressImageMessage && fileType === 'image') {
|
|
266
|
+
Logger.warn(DEPRECATION_WARNING.GROUP_CHANNEL.ON_PRESS_IMAGE_MESSAGE);
|
|
267
|
+
onPressImageMessage(msg, getAvailableUriFromFileMessage(msg));
|
|
268
|
+
}
|
|
269
|
+
onPressMediaMessage?.(msg, () => onDeleteMessage(msg), getAvailableUriFromFileMessage(msg));
|
|
270
|
+
};
|
|
271
|
+
break;
|
|
272
|
+
}
|
|
273
|
+
default: {
|
|
274
|
+
response.onPress = () => Linking.openURL(msg.url).catch();
|
|
275
|
+
break;
|
|
276
|
+
}
|
|
260
277
|
}
|
|
261
278
|
}
|
|
262
279
|
|
|
@@ -41,20 +41,13 @@ export const GroupChannelContextsProvider: GroupChannelModule['Provider'] = ({
|
|
|
41
41
|
const [typingUsers, setTypingUsers] = useState<SendbirdUser[]>([]);
|
|
42
42
|
const [editMessage, setEditMessage] = useState<SendbirdUserMessage | SendbirdFileMessage>();
|
|
43
43
|
|
|
44
|
-
useChannelHandler(
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
if (isDifferentChannel(channel, eventChannel)) return;
|
|
50
|
-
if (!enableTypingIndicator) return;
|
|
51
|
-
|
|
52
|
-
const usersWithoutMe = eventChannel.getTypingUsers().filter((u) => u.userId !== currentUser?.userId);
|
|
53
|
-
setTypingUsers(usersWithoutMe);
|
|
54
|
-
},
|
|
44
|
+
useChannelHandler(sdk, `GroupChannelContextsProvider_${id}`, {
|
|
45
|
+
onTypingStatusUpdated(eventChannel) {
|
|
46
|
+
if (isDifferentChannel(channel, eventChannel)) return;
|
|
47
|
+
if (!enableTypingIndicator) return;
|
|
48
|
+
setTypingUsers(eventChannel.getTypingUsers());
|
|
55
49
|
},
|
|
56
|
-
|
|
57
|
-
);
|
|
50
|
+
});
|
|
58
51
|
|
|
59
52
|
return (
|
|
60
53
|
<ProviderLayout>
|
|
@@ -28,7 +28,7 @@ export interface GroupChannelProps {
|
|
|
28
28
|
onBeforeSendUserMessage?: (
|
|
29
29
|
params: SendbirdUserMessageParams,
|
|
30
30
|
) => SendbirdUserMessageParams | Promise<SendbirdUserMessageParams>;
|
|
31
|
-
|
|
31
|
+
onPressMediaMessage?: GroupChannelProps['MessageList']['onPressMediaMessage'];
|
|
32
32
|
|
|
33
33
|
renderMessage?: GroupChannelProps['MessageList']['renderMessage'];
|
|
34
34
|
renderNewMessagesButton?: GroupChannelProps['MessageList']['renderNewMessagesButton'];
|
|
@@ -42,6 +42,9 @@ export interface GroupChannelProps {
|
|
|
42
42
|
sortComparator?: UseGroupChannelMessagesOptions['sortComparator'];
|
|
43
43
|
collectionCreator?: UseGroupChannelMessagesOptions['collectionCreator'];
|
|
44
44
|
queryCreator?: UseGroupChannelMessagesOptions['queryCreator'];
|
|
45
|
+
|
|
46
|
+
/** @deprecated `onPressImageMessage` is deprecated, please use `onPressMediaMessage` instead **/
|
|
47
|
+
onPressImageMessage?: GroupChannelProps['MessageList']['onPressImageMessage'];
|
|
45
48
|
};
|
|
46
49
|
Header: {
|
|
47
50
|
onPressHeaderLeft: () => void;
|
|
@@ -59,7 +62,7 @@ export interface GroupChannelProps {
|
|
|
59
62
|
|
|
60
63
|
onResendFailedMessage: (failedMessage: SendbirdUserMessage | SendbirdFileMessage) => Promise<void>;
|
|
61
64
|
onDeleteMessage: (message: SendbirdUserMessage | SendbirdFileMessage) => Promise<void>;
|
|
62
|
-
|
|
65
|
+
onPressMediaMessage?: (message: SendbirdFileMessage, deleteMessage: () => Promise<void>, uri: string) => void;
|
|
63
66
|
|
|
64
67
|
renderMessage: (props: {
|
|
65
68
|
message: SendbirdMessage;
|
|
@@ -81,6 +84,9 @@ export interface GroupChannelProps {
|
|
|
81
84
|
onPress: () => void;
|
|
82
85
|
}>;
|
|
83
86
|
flatListProps?: Omit<FlatListProps<SendbirdMessage>, 'data' | 'renderItem'>;
|
|
87
|
+
|
|
88
|
+
/** @deprecated `onPressImageMessage` is deprecated, please use `onPressMediaMessage` instead **/
|
|
89
|
+
onPressImageMessage?: (message: SendbirdFileMessage, uri: string) => void;
|
|
84
90
|
};
|
|
85
91
|
Input: {
|
|
86
92
|
channel: SendbirdGroupChannel;
|
|
@@ -114,7 +120,7 @@ export interface GroupChannelContextsType {
|
|
|
114
120
|
}>;
|
|
115
121
|
}
|
|
116
122
|
export interface GroupChannelModule {
|
|
117
|
-
Provider:
|
|
123
|
+
Provider: CommonComponent<GroupChannelProps['Provider']>;
|
|
118
124
|
Header: CommonComponent<GroupChannelProps['Header']>;
|
|
119
125
|
MessageList: CommonComponent<GroupChannelProps['MessageList']>;
|
|
120
126
|
Input: CommonComponent<GroupChannelProps['Input']>;
|
|
@@ -122,4 +128,4 @@ export interface GroupChannelModule {
|
|
|
122
128
|
StatusLoading: CommonComponent;
|
|
123
129
|
}
|
|
124
130
|
|
|
125
|
-
export type GroupChannelFragment =
|
|
131
|
+
export type GroupChannelFragment = CommonComponent<GroupChannelProps['Fragment']>;
|
|
@@ -5,15 +5,13 @@ import { Icon, useHeaderStyle } from '@sendbird/uikit-react-native-foundation';
|
|
|
5
5
|
import { GroupChannelListContexts } from '../module/moduleContext';
|
|
6
6
|
import type { GroupChannelListProps } from '../types';
|
|
7
7
|
|
|
8
|
-
const GroupChannelListHeader:
|
|
8
|
+
const GroupChannelListHeader = (_: GroupChannelListProps['Header']) => {
|
|
9
9
|
const fragment = useContext(GroupChannelListContexts.Fragment);
|
|
10
10
|
const typeSelector = useContext(GroupChannelListContexts.TypeSelector);
|
|
11
11
|
const { HeaderComponent } = useHeaderStyle();
|
|
12
12
|
|
|
13
13
|
return (
|
|
14
|
-
<HeaderComponent title={fragment.headerTitle} right={<Icon icon={'create'} />} onPressRight={typeSelector.show}
|
|
15
|
-
{children}
|
|
16
|
-
</HeaderComponent>
|
|
14
|
+
<HeaderComponent title={fragment.headerTitle} right={<Icon icon={'create'} />} onPressRight={typeSelector.show} />
|
|
17
15
|
);
|
|
18
16
|
};
|
|
19
17
|
|
|
@@ -8,13 +8,13 @@ import { PASS, SendbirdGroupChannel, useFreshCallback } from '@sendbird/uikit-ut
|
|
|
8
8
|
import { useLocalization, useSendbirdChat } from '../../../hooks/useContext';
|
|
9
9
|
import type { GroupChannelListProps } from '../types';
|
|
10
10
|
|
|
11
|
-
const GroupChannelListList
|
|
11
|
+
const GroupChannelListList = ({
|
|
12
12
|
renderGroupChannelPreview,
|
|
13
13
|
groupChannels,
|
|
14
14
|
onLoadNext,
|
|
15
15
|
flatListProps,
|
|
16
16
|
menuItemCreator = PASS,
|
|
17
|
-
}) => {
|
|
17
|
+
}: GroupChannelListProps['List']) => {
|
|
18
18
|
const toast = useToast();
|
|
19
19
|
const { openMenu } = useActionMenu();
|
|
20
20
|
const { STRINGS } = useLocalization();
|