@sendbird/uikit-react-native 1.0.0-rc.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +410 -0
- package/lib/commonjs/InternalErrorBoundary.js +84 -0
- package/lib/commonjs/InternalErrorBoundary.js.map +1 -0
- package/lib/commonjs/InternalLocalCacheStorage.js +59 -0
- package/lib/commonjs/InternalLocalCacheStorage.js.map +1 -0
- package/lib/commonjs/SendbirdUIKitContainer.js +166 -0
- package/lib/commonjs/SendbirdUIKitContainer.js.map +1 -0
- package/lib/commonjs/components/ChannelCover.js +59 -0
- package/lib/commonjs/components/ChannelCover.js.map +1 -0
- package/lib/commonjs/components/ChatFlatList.js +118 -0
- package/lib/commonjs/components/ChatFlatList.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/AdminMessage/index.js +52 -0
- package/lib/commonjs/components/MessageRenderer/AdminMessage/index.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/FileMessage/BaseFileMessage.js +76 -0
- package/lib/commonjs/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/FileMessage/ImageFileMessage.js +61 -0
- package/lib/commonjs/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/FileMessage/index.js +31 -0
- package/lib/commonjs/components/MessageRenderer/FileMessage/index.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/MessageContainer.js +33 -0
- package/lib/commonjs/components/MessageRenderer/MessageContainer.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/MessageDateSeparator.js +58 -0
- package/lib/commonjs/components/MessageRenderer/MessageDateSeparator.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/MessageIncomingAvatar.js +42 -0
- package/lib/commonjs/components/MessageRenderer/MessageIncomingAvatar.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/MessageIncomingSenderName.js +48 -0
- package/lib/commonjs/components/MessageRenderer/MessageIncomingSenderName.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/MessageOutgoingStatus.js +134 -0
- package/lib/commonjs/components/MessageRenderer/MessageOutgoingStatus.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/MessageTime.js +41 -0
- package/lib/commonjs/components/MessageRenderer/MessageTime.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/UnknownMessage/index.js +53 -0
- package/lib/commonjs/components/MessageRenderer/UnknownMessage/index.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/UserMessage/BaseUserMessage.js +54 -0
- package/lib/commonjs/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js +131 -0
- package/lib/commonjs/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/UserMessage/index.js +31 -0
- package/lib/commonjs/components/MessageRenderer/UserMessage/index.js.map +1 -0
- package/lib/commonjs/components/MessageRenderer/index.js +189 -0
- package/lib/commonjs/components/MessageRenderer/index.js.map +1 -0
- package/lib/commonjs/components/NewMessagesButton.js +73 -0
- package/lib/commonjs/components/NewMessagesButton.js.map +1 -0
- package/lib/commonjs/components/ProviderLayout.js +37 -0
- package/lib/commonjs/components/ProviderLayout.js.map +1 -0
- package/lib/commonjs/components/ScrollToBottomButton.js +66 -0
- package/lib/commonjs/components/ScrollToBottomButton.js.map +1 -0
- package/lib/commonjs/components/StatusComposition.js +27 -0
- package/lib/commonjs/components/StatusComposition.js.map +1 -0
- package/lib/commonjs/components/TypedPlaceholder.js +80 -0
- package/lib/commonjs/components/TypedPlaceholder.js.map +1 -0
- package/lib/commonjs/components/UserActionBar.js +96 -0
- package/lib/commonjs/components/UserActionBar.js.map +1 -0
- package/lib/commonjs/components/UserSelectableBar.js +78 -0
- package/lib/commonjs/components/UserSelectableBar.js.map +1 -0
- package/lib/commonjs/constants.js +9 -0
- package/lib/commonjs/constants.js.map +1 -0
- package/lib/commonjs/contexts/Localization.js +29 -0
- package/lib/commonjs/contexts/Localization.js.map +1 -0
- package/lib/commonjs/contexts/PlatformService.js +33 -0
- package/lib/commonjs/contexts/PlatformService.js.map +1 -0
- package/lib/commonjs/contexts/SendbirdChat.js +87 -0
- package/lib/commonjs/contexts/SendbirdChat.js.map +1 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelHeader.js +88 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelHeader.js.map +1 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js +118 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js +148 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js +115 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js +343 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelStatusEmpty.js +34 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelStatusEmpty.js.map +1 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelStatusLoading.js +34 -0
- package/lib/commonjs/domain/groupChannel/component/GroupChannelStatusLoading.js.map +1 -0
- package/lib/commonjs/domain/groupChannel/index.js +70 -0
- package/lib/commonjs/domain/groupChannel/index.js.map +1 -0
- package/lib/commonjs/domain/groupChannel/module/createGroupChannelModule.js +45 -0
- package/lib/commonjs/domain/groupChannel/module/createGroupChannelModule.js.map +1 -0
- package/lib/commonjs/domain/groupChannel/module/moduleContext.js +79 -0
- package/lib/commonjs/domain/groupChannel/module/moduleContext.js.map +1 -0
- package/lib/commonjs/domain/groupChannel/types.js +6 -0
- package/lib/commonjs/domain/groupChannel/types.js.map +1 -0
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListHeader.js +38 -0
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListHeader.js.map +1 -0
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js +96 -0
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListList.js.map +1 -0
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListStatusEmpty.js +34 -0
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListStatusEmpty.js.map +1 -0
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListStatusLoading.js +34 -0
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListStatusLoading.js.map +1 -0
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListTypeSelector.js +141 -0
- package/lib/commonjs/domain/groupChannelList/component/GroupChannelListTypeSelector.js.map +1 -0
- package/lib/commonjs/domain/groupChannelList/index.js +70 -0
- package/lib/commonjs/domain/groupChannelList/index.js.map +1 -0
- package/lib/commonjs/domain/groupChannelList/module/createGroupChannelListModule.js +45 -0
- package/lib/commonjs/domain/groupChannelList/module/createGroupChannelListModule.js.map +1 -0
- package/lib/commonjs/domain/groupChannelList/module/moduleContext.js +61 -0
- package/lib/commonjs/domain/groupChannelList/module/moduleContext.js.map +1 -0
- package/lib/commonjs/domain/groupChannelList/types.js +6 -0
- package/lib/commonjs/domain/groupChannelList/types.js.map +1 -0
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsHeader.js +49 -0
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsHeader.js.map +1 -0
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js +77 -0
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -0
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +94 -0
- package/lib/commonjs/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -0
- package/lib/commonjs/domain/groupChannelSettings/index.js +54 -0
- package/lib/commonjs/domain/groupChannelSettings/index.js.map +1 -0
- package/lib/commonjs/domain/groupChannelSettings/module/createGroupChannelSettingsModule.js +37 -0
- package/lib/commonjs/domain/groupChannelSettings/module/createGroupChannelSettingsModule.js.map +1 -0
- package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js +150 -0
- package/lib/commonjs/domain/groupChannelSettings/module/moduleContext.js.map +1 -0
- package/lib/commonjs/domain/groupChannelSettings/types.js +6 -0
- package/lib/commonjs/domain/groupChannelSettings/types.js.map +1 -0
- package/lib/commonjs/domain/groupChannelUserList/types.js +6 -0
- package/lib/commonjs/domain/groupChannelUserList/types.js.map +1 -0
- package/lib/commonjs/domain/userList/component/UserListHeader.js +56 -0
- package/lib/commonjs/domain/userList/component/UserListHeader.js.map +1 -0
- package/lib/commonjs/domain/userList/component/UserListList.js +57 -0
- package/lib/commonjs/domain/userList/component/UserListList.js.map +1 -0
- package/lib/commonjs/domain/userList/component/UserListStatusEmpty.js +34 -0
- package/lib/commonjs/domain/userList/component/UserListStatusEmpty.js.map +1 -0
- package/lib/commonjs/domain/userList/component/UserListStatusError.js +38 -0
- package/lib/commonjs/domain/userList/component/UserListStatusError.js.map +1 -0
- package/lib/commonjs/domain/userList/component/UserListStatusLoading.js +34 -0
- package/lib/commonjs/domain/userList/component/UserListStatusLoading.js.map +1 -0
- package/lib/commonjs/domain/userList/index.js +70 -0
- package/lib/commonjs/domain/userList/index.js.map +1 -0
- package/lib/commonjs/domain/userList/module/createUserListModule.js +45 -0
- package/lib/commonjs/domain/userList/module/createUserListModule.js.map +1 -0
- package/lib/commonjs/domain/userList/module/moduleContext.js +54 -0
- package/lib/commonjs/domain/userList/module/moduleContext.js.map +1 -0
- package/lib/commonjs/domain/userList/types.js +6 -0
- package/lib/commonjs/domain/userList/types.js.map +1 -0
- package/lib/commonjs/fragments/createGroupChannelCreateFragment.js +145 -0
- package/lib/commonjs/fragments/createGroupChannelCreateFragment.js.map +1 -0
- package/lib/commonjs/fragments/createGroupChannelFragment.js +154 -0
- package/lib/commonjs/fragments/createGroupChannelFragment.js.map +1 -0
- package/lib/commonjs/fragments/createGroupChannelInviteFragment.js +139 -0
- package/lib/commonjs/fragments/createGroupChannelInviteFragment.js.map +1 -0
- package/lib/commonjs/fragments/createGroupChannelListFragment.js +141 -0
- package/lib/commonjs/fragments/createGroupChannelListFragment.js.map +1 -0
- package/lib/commonjs/fragments/createGroupChannelMembersFragment.js +134 -0
- package/lib/commonjs/fragments/createGroupChannelMembersFragment.js.map +1 -0
- package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js +67 -0
- package/lib/commonjs/fragments/createGroupChannelSettingsFragment.js.map +1 -0
- package/lib/commonjs/hooks/useConnection.js +102 -0
- package/lib/commonjs/hooks/useConnection.js.map +1 -0
- package/lib/commonjs/hooks/useContext.js +39 -0
- package/lib/commonjs/hooks/useContext.js.map +1 -0
- package/lib/commonjs/hooks/usePushTokenRegistration.js +83 -0
- package/lib/commonjs/hooks/usePushTokenRegistration.js.map +1 -0
- package/lib/commonjs/index.js +449 -0
- package/lib/commonjs/index.js.map +1 -0
- package/lib/commonjs/localization/StringSet.en.js +19 -0
- package/lib/commonjs/localization/StringSet.en.js.map +1 -0
- package/lib/commonjs/localization/StringSet.type.js +178 -0
- package/lib/commonjs/localization/StringSet.type.js.map +1 -0
- package/lib/commonjs/platform/createClipboardService.expo.js +23 -0
- package/lib/commonjs/platform/createClipboardService.expo.js.map +1 -0
- package/lib/commonjs/platform/createClipboardService.native.js +23 -0
- package/lib/commonjs/platform/createClipboardService.native.js.map +1 -0
- package/lib/commonjs/platform/createFileService.expo.js +176 -0
- package/lib/commonjs/platform/createFileService.expo.js.map +1 -0
- package/lib/commonjs/platform/createFileService.native.js +253 -0
- package/lib/commonjs/platform/createFileService.native.js.map +1 -0
- package/lib/commonjs/platform/createNotificationService.expo.js +50 -0
- package/lib/commonjs/platform/createNotificationService.expo.js.map +1 -0
- package/lib/commonjs/platform/createNotificationService.native.js +65 -0
- package/lib/commonjs/platform/createNotificationService.native.js.map +1 -0
- package/lib/commonjs/platform/dynamicModule.js +114 -0
- package/lib/commonjs/platform/dynamicModule.js.map +1 -0
- package/lib/commonjs/platform/types.js +2 -0
- package/lib/commonjs/platform/types.js.map +1 -0
- package/lib/commonjs/types.js +6 -0
- package/lib/commonjs/types.js.map +1 -0
- package/lib/commonjs/utils/expoPermissionGranted.js +32 -0
- package/lib/commonjs/utils/expoPermissionGranted.js.map +1 -0
- package/lib/commonjs/utils/fileTypeGuard.js +26 -0
- package/lib/commonjs/utils/fileTypeGuard.js.map +1 -0
- package/lib/commonjs/utils/nativePermissionGranted.js +23 -0
- package/lib/commonjs/utils/nativePermissionGranted.js.map +1 -0
- package/lib/commonjs/version.js +10 -0
- package/lib/commonjs/version.js.map +1 -0
- package/lib/module/InternalErrorBoundary.js +72 -0
- package/lib/module/InternalErrorBoundary.js.map +1 -0
- package/lib/module/InternalLocalCacheStorage.js +50 -0
- package/lib/module/InternalLocalCacheStorage.js.map +1 -0
- package/lib/module/SendbirdUIKitContainer.js +136 -0
- package/lib/module/SendbirdUIKitContainer.js.map +1 -0
- package/lib/module/components/ChannelCover.js +46 -0
- package/lib/module/components/ChannelCover.js.map +1 -0
- package/lib/module/components/ChatFlatList.js +102 -0
- package/lib/module/components/ChatFlatList.js.map +1 -0
- package/lib/module/components/MessageRenderer/AdminMessage/index.js +40 -0
- package/lib/module/components/MessageRenderer/AdminMessage/index.js.map +1 -0
- package/lib/module/components/MessageRenderer/FileMessage/BaseFileMessage.js +62 -0
- package/lib/module/components/MessageRenderer/FileMessage/BaseFileMessage.js.map +1 -0
- package/lib/module/components/MessageRenderer/FileMessage/ImageFileMessage.js +47 -0
- package/lib/module/components/MessageRenderer/FileMessage/ImageFileMessage.js.map +1 -0
- package/lib/module/components/MessageRenderer/FileMessage/index.js +17 -0
- package/lib/module/components/MessageRenderer/FileMessage/index.js.map +1 -0
- package/lib/module/components/MessageRenderer/MessageContainer.js +21 -0
- package/lib/module/components/MessageRenderer/MessageContainer.js.map +1 -0
- package/lib/module/components/MessageRenderer/MessageDateSeparator.js +44 -0
- package/lib/module/components/MessageRenderer/MessageDateSeparator.js.map +1 -0
- package/lib/module/components/MessageRenderer/MessageIncomingAvatar.js +30 -0
- package/lib/module/components/MessageRenderer/MessageIncomingAvatar.js.map +1 -0
- package/lib/module/components/MessageRenderer/MessageIncomingSenderName.js +35 -0
- package/lib/module/components/MessageRenderer/MessageIncomingSenderName.js.map +1 -0
- package/lib/module/components/MessageRenderer/MessageOutgoingStatus.js +116 -0
- package/lib/module/components/MessageRenderer/MessageOutgoingStatus.js.map +1 -0
- package/lib/module/components/MessageRenderer/MessageTime.js +28 -0
- package/lib/module/components/MessageRenderer/MessageTime.js.map +1 -0
- package/lib/module/components/MessageRenderer/UnknownMessage/index.js +40 -0
- package/lib/module/components/MessageRenderer/UnknownMessage/index.js.map +1 -0
- package/lib/module/components/MessageRenderer/UserMessage/BaseUserMessage.js +41 -0
- package/lib/module/components/MessageRenderer/UserMessage/BaseUserMessage.js.map +1 -0
- package/lib/module/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js +115 -0
- package/lib/module/components/MessageRenderer/UserMessage/OpenGraphUserMessage.js.map +1 -0
- package/lib/module/components/MessageRenderer/UserMessage/index.js +18 -0
- package/lib/module/components/MessageRenderer/UserMessage/index.js.map +1 -0
- package/lib/module/components/MessageRenderer/index.js +163 -0
- package/lib/module/components/MessageRenderer/index.js.map +1 -0
- package/lib/module/components/NewMessagesButton.js +58 -0
- package/lib/module/components/NewMessagesButton.js.map +1 -0
- package/lib/module/components/ProviderLayout.js +25 -0
- package/lib/module/components/ProviderLayout.js.map +1 -0
- package/lib/module/components/ScrollToBottomButton.js +52 -0
- package/lib/module/components/ScrollToBottomButton.js.map +1 -0
- package/lib/module/components/StatusComposition.js +17 -0
- package/lib/module/components/StatusComposition.js.map +1 -0
- package/lib/module/components/TypedPlaceholder.js +68 -0
- package/lib/module/components/TypedPlaceholder.js.map +1 -0
- package/lib/module/components/UserActionBar.js +81 -0
- package/lib/module/components/UserActionBar.js.map +1 -0
- package/lib/module/components/UserSelectableBar.js +63 -0
- package/lib/module/components/UserSelectableBar.js.map +1 -0
- package/lib/module/constants.js +2 -0
- package/lib/module/constants.js.map +1 -0
- package/lib/module/contexts/Localization.js +14 -0
- package/lib/module/contexts/Localization.js.map +1 -0
- package/lib/module/contexts/PlatformService.js +18 -0
- package/lib/module/contexts/PlatformService.js.map +1 -0
- package/lib/module/contexts/SendbirdChat.js +66 -0
- package/lib/module/contexts/SendbirdChat.js.map +1 -0
- package/lib/module/domain/groupChannel/component/GroupChannelHeader.js +69 -0
- package/lib/module/domain/groupChannel/component/GroupChannelHeader.js.map +1 -0
- package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js +102 -0
- package/lib/module/domain/groupChannel/component/GroupChannelInput/EditInput.js.map +1 -0
- package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js +134 -0
- package/lib/module/domain/groupChannel/component/GroupChannelInput/SendInput.js.map +1 -0
- package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js +92 -0
- package/lib/module/domain/groupChannel/component/GroupChannelInput/index.js.map +1 -0
- package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js +317 -0
- package/lib/module/domain/groupChannel/component/GroupChannelMessageList.js.map +1 -0
- package/lib/module/domain/groupChannel/component/GroupChannelStatusEmpty.js +21 -0
- package/lib/module/domain/groupChannel/component/GroupChannelStatusEmpty.js.map +1 -0
- package/lib/module/domain/groupChannel/component/GroupChannelStatusLoading.js +21 -0
- package/lib/module/domain/groupChannel/component/GroupChannelStatusLoading.js.map +1 -0
- package/lib/module/domain/groupChannel/index.js +8 -0
- package/lib/module/domain/groupChannel/index.js.map +1 -0
- package/lib/module/domain/groupChannel/module/createGroupChannelModule.js +30 -0
- package/lib/module/domain/groupChannel/module/createGroupChannelModule.js.map +1 -0
- package/lib/module/domain/groupChannel/module/moduleContext.js +57 -0
- package/lib/module/domain/groupChannel/module/moduleContext.js.map +1 -0
- package/lib/module/domain/groupChannel/types.js +2 -0
- package/lib/module/domain/groupChannel/types.js.map +1 -0
- package/lib/module/domain/groupChannelList/component/GroupChannelListHeader.js +24 -0
- package/lib/module/domain/groupChannelList/component/GroupChannelListHeader.js.map +1 -0
- package/lib/module/domain/groupChannelList/component/GroupChannelListList.js +79 -0
- package/lib/module/domain/groupChannelList/component/GroupChannelListList.js.map +1 -0
- package/lib/module/domain/groupChannelList/component/GroupChannelListStatusEmpty.js +21 -0
- package/lib/module/domain/groupChannelList/component/GroupChannelListStatusEmpty.js.map +1 -0
- package/lib/module/domain/groupChannelList/component/GroupChannelListStatusLoading.js +21 -0
- package/lib/module/domain/groupChannelList/component/GroupChannelListStatusLoading.js.map +1 -0
- package/lib/module/domain/groupChannelList/component/GroupChannelListTypeSelector.js +124 -0
- package/lib/module/domain/groupChannelList/component/GroupChannelListTypeSelector.js.map +1 -0
- package/lib/module/domain/groupChannelList/index.js +8 -0
- package/lib/module/domain/groupChannelList/index.js.map +1 -0
- package/lib/module/domain/groupChannelList/module/createGroupChannelListModule.js +30 -0
- package/lib/module/domain/groupChannelList/module/createGroupChannelListModule.js.map +1 -0
- package/lib/module/domain/groupChannelList/module/moduleContext.js +40 -0
- package/lib/module/domain/groupChannelList/module/moduleContext.js.map +1 -0
- package/lib/module/domain/groupChannelList/types.js +2 -0
- package/lib/module/domain/groupChannelList/types.js.map +1 -0
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsHeader.js +35 -0
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsHeader.js.map +1 -0
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js +56 -0
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsInfo.js.map +1 -0
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js +78 -0
- package/lib/module/domain/groupChannelSettings/component/GroupChannelSettingsMenu.js.map +1 -0
- package/lib/module/domain/groupChannelSettings/index.js +6 -0
- package/lib/module/domain/groupChannelSettings/index.js.map +1 -0
- package/lib/module/domain/groupChannelSettings/module/createGroupChannelSettingsModule.js +24 -0
- package/lib/module/domain/groupChannelSettings/module/createGroupChannelSettingsModule.js.map +1 -0
- package/lib/module/domain/groupChannelSettings/module/moduleContext.js +127 -0
- package/lib/module/domain/groupChannelSettings/module/moduleContext.js.map +1 -0
- package/lib/module/domain/groupChannelSettings/types.js +2 -0
- package/lib/module/domain/groupChannelSettings/types.js.map +1 -0
- package/lib/module/domain/groupChannelUserList/types.js +2 -0
- package/lib/module/domain/groupChannelUserList/types.js.map +1 -0
- package/lib/module/domain/userList/component/UserListHeader.js +42 -0
- package/lib/module/domain/userList/component/UserListHeader.js.map +1 -0
- package/lib/module/domain/userList/component/UserListList.js +42 -0
- package/lib/module/domain/userList/component/UserListList.js.map +1 -0
- package/lib/module/domain/userList/component/UserListStatusEmpty.js +21 -0
- package/lib/module/domain/userList/component/UserListStatusEmpty.js.map +1 -0
- package/lib/module/domain/userList/component/UserListStatusError.js +25 -0
- package/lib/module/domain/userList/component/UserListStatusError.js.map +1 -0
- package/lib/module/domain/userList/component/UserListStatusLoading.js +21 -0
- package/lib/module/domain/userList/component/UserListStatusLoading.js.map +1 -0
- package/lib/module/domain/userList/index.js +8 -0
- package/lib/module/domain/userList/index.js.map +1 -0
- package/lib/module/domain/userList/module/createUserListModule.js +30 -0
- package/lib/module/domain/userList/module/createUserListModule.js.map +1 -0
- package/lib/module/domain/userList/module/moduleContext.js +34 -0
- package/lib/module/domain/userList/module/moduleContext.js.map +1 -0
- package/lib/module/domain/userList/types.js +2 -0
- package/lib/module/domain/userList/types.js.map +1 -0
- package/lib/module/fragments/createGroupChannelCreateFragment.js +124 -0
- package/lib/module/fragments/createGroupChannelCreateFragment.js.map +1 -0
- package/lib/module/fragments/createGroupChannelFragment.js +132 -0
- package/lib/module/fragments/createGroupChannelFragment.js.map +1 -0
- package/lib/module/fragments/createGroupChannelInviteFragment.js +118 -0
- package/lib/module/fragments/createGroupChannelInviteFragment.js.map +1 -0
- package/lib/module/fragments/createGroupChannelListFragment.js +115 -0
- package/lib/module/fragments/createGroupChannelListFragment.js.map +1 -0
- package/lib/module/fragments/createGroupChannelMembersFragment.js +114 -0
- package/lib/module/fragments/createGroupChannelMembersFragment.js.map +1 -0
- package/lib/module/fragments/createGroupChannelSettingsFragment.js +52 -0
- package/lib/module/fragments/createGroupChannelSettingsFragment.js.map +1 -0
- package/lib/module/hooks/useConnection.js +79 -0
- package/lib/module/hooks/useConnection.js.map +1 -0
- package/lib/module/hooks/useContext.js +20 -0
- package/lib/module/hooks/useContext.js.map +1 -0
- package/lib/module/hooks/usePushTokenRegistration.js +69 -0
- package/lib/module/hooks/usePushTokenRegistration.js.map +1 -0
- package/lib/module/index.js +57 -0
- package/lib/module/index.js.map +1 -0
- package/lib/module/localization/StringSet.en.js +7 -0
- package/lib/module/localization/StringSet.en.js.map +1 -0
- package/lib/module/localization/StringSet.type.js +173 -0
- package/lib/module/localization/StringSet.type.js.map +1 -0
- package/lib/module/platform/createClipboardService.expo.js +15 -0
- package/lib/module/platform/createClipboardService.expo.js.map +1 -0
- package/lib/module/platform/createClipboardService.native.js +15 -0
- package/lib/module/platform/createClipboardService.native.js.map +1 -0
- package/lib/module/platform/createFileService.expo.js +164 -0
- package/lib/module/platform/createFileService.expo.js.map +1 -0
- package/lib/module/platform/createFileService.native.js +237 -0
- package/lib/module/platform/createFileService.native.js.map +1 -0
- package/lib/module/platform/createNotificationService.expo.js +42 -0
- package/lib/module/platform/createNotificationService.expo.js.map +1 -0
- package/lib/module/platform/createNotificationService.native.js +57 -0
- package/lib/module/platform/createNotificationService.native.js.map +1 -0
- package/lib/module/platform/dynamicModule.js +103 -0
- package/lib/module/platform/dynamicModule.js.map +1 -0
- package/lib/module/platform/types.js +2 -0
- package/lib/module/platform/types.js.map +1 -0
- package/lib/module/types.js +2 -0
- package/lib/module/types.js.map +1 -0
- package/lib/module/utils/expoPermissionGranted.js +24 -0
- package/lib/module/utils/expoPermissionGranted.js.map +1 -0
- package/lib/module/utils/fileTypeGuard.js +18 -0
- package/lib/module/utils/fileTypeGuard.js.map +1 -0
- package/lib/module/utils/nativePermissionGranted.js +15 -0
- package/lib/module/utils/nativePermissionGranted.js.map +1 -0
- package/lib/module/version.js +3 -0
- package/lib/module/version.js.map +1 -0
- package/lib/typescript/__template__/component/__domain__Header.d.ts +4 -0
- package/lib/typescript/__template__/component/__domain__StatusEmpty.d.ts +3 -0
- package/lib/typescript/__template__/component/__domain__StatusLoading.d.ts +3 -0
- package/lib/typescript/__template__/component/__domain__View.d.ts +4 -0
- package/lib/typescript/__template__/create__domain__Fragment.d.ts +2 -0
- package/lib/typescript/__template__/index.d.ts +6 -0
- package/lib/typescript/__template__/module/create__domain__Module.d.ts +3 -0
- package/lib/typescript/__template__/module/moduleContext.d.ts +4 -0
- package/lib/typescript/__template__/types.d.ts +31 -0
- package/lib/typescript/src/InternalErrorBoundary.d.ts +18 -0
- package/lib/typescript/src/InternalLocalCacheStorage.d.ts +12 -0
- package/lib/typescript/src/SendbirdUIKitContainer.d.ts +42 -0
- package/lib/typescript/src/components/ChannelCover.d.ts +10 -0
- package/lib/typescript/src/components/ChatFlatList.d.ts +14 -0
- package/lib/typescript/src/components/MessageRenderer/AdminMessage/index.d.ts +6 -0
- package/lib/typescript/src/components/MessageRenderer/FileMessage/BaseFileMessage.d.ts +6 -0
- package/lib/typescript/src/components/MessageRenderer/FileMessage/ImageFileMessage.d.ts +4 -0
- package/lib/typescript/src/components/MessageRenderer/FileMessage/index.d.ts +6 -0
- package/lib/typescript/src/components/MessageRenderer/MessageContainer.d.ts +3 -0
- package/lib/typescript/src/components/MessageRenderer/MessageDateSeparator.d.ts +8 -0
- package/lib/typescript/src/components/MessageRenderer/MessageIncomingAvatar.d.ts +8 -0
- package/lib/typescript/src/components/MessageRenderer/MessageIncomingSenderName.d.ts +8 -0
- package/lib/typescript/src/components/MessageRenderer/MessageOutgoingStatus.d.ts +8 -0
- package/lib/typescript/src/components/MessageRenderer/MessageTime.d.ts +10 -0
- package/lib/typescript/src/components/MessageRenderer/UnknownMessage/index.d.ts +5 -0
- package/lib/typescript/src/components/MessageRenderer/UserMessage/BaseUserMessage.d.ts +4 -0
- package/lib/typescript/src/components/MessageRenderer/UserMessage/OpenGraphUserMessage.d.ts +8 -0
- package/lib/typescript/src/components/MessageRenderer/UserMessage/index.d.ts +6 -0
- package/lib/typescript/src/components/MessageRenderer/index.d.ts +23 -0
- package/lib/typescript/src/components/NewMessagesButton.d.ts +9 -0
- package/lib/typescript/src/components/ProviderLayout.d.ts +3 -0
- package/lib/typescript/src/components/ScrollToBottomButton.d.ts +7 -0
- package/lib/typescript/src/components/StatusComposition.d.ts +10 -0
- package/lib/typescript/src/components/TypedPlaceholder.d.ts +7 -0
- package/lib/typescript/src/components/UserActionBar.d.ts +11 -0
- package/lib/typescript/src/components/UserSelectableBar.d.ts +9 -0
- package/lib/typescript/src/constants.d.ts +1 -0
- package/lib/typescript/src/contexts/Localization.d.ts +12 -0
- package/lib/typescript/src/contexts/PlatformService.d.ts +10 -0
- package/lib/typescript/src/contexts/SendbirdChat.d.ts +24 -0
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelHeader.d.ts +4 -0
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/EditInput.d.ts +11 -0
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/SendInput.d.ts +9 -0
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelInput/index.d.ts +9 -0
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelMessageList.d.ts +36 -0
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelStatusEmpty.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannel/component/GroupChannelStatusLoading.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannel/index.d.ts +7 -0
- package/lib/typescript/src/domain/groupChannel/module/createGroupChannelModule.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannel/module/moduleContext.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannel/types.d.ts +102 -0
- package/lib/typescript/src/domain/groupChannelList/component/GroupChannelListHeader.d.ts +4 -0
- package/lib/typescript/src/domain/groupChannelList/component/GroupChannelListList.d.ts +4 -0
- package/lib/typescript/src/domain/groupChannelList/component/GroupChannelListStatusEmpty.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelList/component/GroupChannelListStatusLoading.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelList/component/GroupChannelListTypeSelector.d.ts +4 -0
- package/lib/typescript/src/domain/groupChannelList/index.d.ts +7 -0
- package/lib/typescript/src/domain/groupChannelList/module/createGroupChannelListModule.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelList/module/moduleContext.d.ts +4 -0
- package/lib/typescript/src/domain/groupChannelList/types.d.ts +81 -0
- package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsHeader.d.ts +4 -0
- package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsInfo.d.ts +4 -0
- package/lib/typescript/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.d.ts +4 -0
- package/lib/typescript/src/domain/groupChannelSettings/index.d.ts +5 -0
- package/lib/typescript/src/domain/groupChannelSettings/module/createGroupChannelSettingsModule.d.ts +3 -0
- package/lib/typescript/src/domain/groupChannelSettings/module/moduleContext.d.ts +4 -0
- package/lib/typescript/src/domain/groupChannelSettings/types.d.ts +45 -0
- package/lib/typescript/src/domain/groupChannelUserList/types.d.ts +42 -0
- package/lib/typescript/src/domain/userList/component/UserListHeader.d.ts +10 -0
- package/lib/typescript/src/domain/userList/component/UserListList.d.ts +11 -0
- package/lib/typescript/src/domain/userList/component/UserListStatusEmpty.d.ts +3 -0
- package/lib/typescript/src/domain/userList/component/UserListStatusError.d.ts +3 -0
- package/lib/typescript/src/domain/userList/component/UserListStatusLoading.d.ts +3 -0
- package/lib/typescript/src/domain/userList/index.d.ts +7 -0
- package/lib/typescript/src/domain/userList/module/createUserListModule.d.ts +3 -0
- package/lib/typescript/src/domain/userList/module/moduleContext.d.ts +4 -0
- package/lib/typescript/src/domain/userList/types.d.ts +58 -0
- package/lib/typescript/src/fragments/createGroupChannelCreateFragment.d.ts +4 -0
- package/lib/typescript/src/fragments/createGroupChannelFragment.d.ts +3 -0
- package/lib/typescript/src/fragments/createGroupChannelInviteFragment.d.ts +4 -0
- package/lib/typescript/src/fragments/createGroupChannelListFragment.d.ts +3 -0
- package/lib/typescript/src/fragments/createGroupChannelMembersFragment.d.ts +5 -0
- package/lib/typescript/src/fragments/createGroupChannelSettingsFragment.d.ts +3 -0
- package/lib/typescript/src/hooks/useConnection.d.ts +11 -0
- package/lib/typescript/src/hooks/useContext.d.ts +22 -0
- package/lib/typescript/src/hooks/usePushTokenRegistration.d.ts +5 -0
- package/lib/typescript/src/index.d.ts +50 -0
- package/lib/typescript/src/localization/StringSet.en.d.ts +2 -0
- package/lib/typescript/src/localization/StringSet.type.d.ts +157 -0
- package/lib/typescript/src/platform/createClipboardService.expo.d.ts +4 -0
- package/lib/typescript/src/platform/createClipboardService.native.d.ts +4 -0
- package/lib/typescript/src/platform/createFileService.expo.d.ts +12 -0
- package/lib/typescript/src/platform/createFileService.native.d.ts +14 -0
- package/lib/typescript/src/platform/createNotificationService.expo.d.ts +4 -0
- package/lib/typescript/src/platform/createNotificationService.native.d.ts +8 -0
- package/lib/typescript/src/platform/dynamicModule.d.ts +23 -0
- package/lib/typescript/src/platform/types.d.ts +47 -0
- package/lib/typescript/src/types.d.ts +20 -0
- package/lib/typescript/src/utils/expoPermissionGranted.d.ts +13 -0
- package/lib/typescript/src/utils/fileTypeGuard.d.ts +4 -0
- package/lib/typescript/src/utils/nativePermissionGranted.d.ts +3 -0
- package/lib/typescript/src/version.d.ts +2 -0
- package/package.json +154 -0
- package/src/InternalErrorBoundary.tsx +52 -0
- package/src/InternalLocalCacheStorage.ts +45 -0
- package/src/SendbirdUIKitContainer.tsx +183 -0
- package/src/components/ChannelCover.tsx +44 -0
- package/src/components/ChatFlatList.tsx +96 -0
- package/src/components/MessageRenderer/AdminMessage/index.tsx +40 -0
- package/src/components/MessageRenderer/FileMessage/BaseFileMessage.tsx +48 -0
- package/src/components/MessageRenderer/FileMessage/ImageFileMessage.tsx +39 -0
- package/src/components/MessageRenderer/FileMessage/index.tsx +17 -0
- package/src/components/MessageRenderer/MessageContainer.tsx +17 -0
- package/src/components/MessageRenderer/MessageDateSeparator.tsx +43 -0
- package/src/components/MessageRenderer/MessageIncomingAvatar.tsx +24 -0
- package/src/components/MessageRenderer/MessageIncomingSenderName.tsx +33 -0
- package/src/components/MessageRenderer/MessageOutgoingStatus.tsx +88 -0
- package/src/components/MessageRenderer/MessageTime.tsx +24 -0
- package/src/components/MessageRenderer/UnknownMessage/index.tsx +34 -0
- package/src/components/MessageRenderer/UserMessage/BaseUserMessage.tsx +34 -0
- package/src/components/MessageRenderer/UserMessage/OpenGraphUserMessage.tsx +110 -0
- package/src/components/MessageRenderer/UserMessage/index.tsx +17 -0
- package/src/components/MessageRenderer/index.tsx +163 -0
- package/src/components/NewMessagesButton.tsx +52 -0
- package/src/components/ProviderLayout.tsx +17 -0
- package/src/components/ScrollToBottomButton.tsx +48 -0
- package/src/components/StatusComposition.tsx +16 -0
- package/src/components/TypedPlaceholder.tsx +48 -0
- package/src/components/UserActionBar.tsx +73 -0
- package/src/components/UserSelectableBar.tsx +58 -0
- package/src/constants.ts +1 -0
- package/src/contexts/Localization.tsx +17 -0
- package/src/contexts/PlatformService.tsx +23 -0
- package/src/contexts/SendbirdChat.tsx +110 -0
- package/src/domain/groupChannel/component/GroupChannelHeader.tsx +52 -0
- package/src/domain/groupChannel/component/GroupChannelInput/EditInput.tsx +92 -0
- package/src/domain/groupChannel/component/GroupChannelInput/SendInput.tsx +141 -0
- package/src/domain/groupChannel/component/GroupChannelInput/index.tsx +72 -0
- package/src/domain/groupChannel/component/GroupChannelMessageList.tsx +308 -0
- package/src/domain/groupChannel/component/GroupChannelStatusEmpty.tsx +18 -0
- package/src/domain/groupChannel/component/GroupChannelStatusLoading.tsx +18 -0
- package/src/domain/groupChannel/index.ts +7 -0
- package/src/domain/groupChannel/module/createGroupChannelModule.tsx +21 -0
- package/src/domain/groupChannel/module/moduleContext.tsx +76 -0
- package/src/domain/groupChannel/types.ts +125 -0
- package/src/domain/groupChannelList/component/GroupChannelListHeader.tsx +20 -0
- package/src/domain/groupChannelList/component/GroupChannelListList.tsx +75 -0
- package/src/domain/groupChannelList/component/GroupChannelListStatusEmpty.tsx +18 -0
- package/src/domain/groupChannelList/component/GroupChannelListStatusLoading.tsx +18 -0
- package/src/domain/groupChannelList/component/GroupChannelListTypeSelector.tsx +114 -0
- package/src/domain/groupChannelList/index.ts +7 -0
- package/src/domain/groupChannelList/module/createGroupChannelListModule.tsx +21 -0
- package/src/domain/groupChannelList/module/moduleContext.tsx +40 -0
- package/src/domain/groupChannelList/types.ts +92 -0
- package/src/domain/groupChannelSettings/component/GroupChannelSettingsHeader.tsx +29 -0
- package/src/domain/groupChannelSettings/component/GroupChannelSettingsInfo.tsx +47 -0
- package/src/domain/groupChannelSettings/component/GroupChannelSettingsMenu.tsx +77 -0
- package/src/domain/groupChannelSettings/index.ts +5 -0
- package/src/domain/groupChannelSettings/module/createGroupChannelSettingsModule.tsx +17 -0
- package/src/domain/groupChannelSettings/module/moduleContext.tsx +146 -0
- package/src/domain/groupChannelSettings/types.ts +50 -0
- package/src/domain/groupChannelUserList/types.ts +50 -0
- package/src/domain/userList/component/UserListHeader.tsx +39 -0
- package/src/domain/userList/component/UserListList.tsx +36 -0
- package/src/domain/userList/component/UserListStatusEmpty.tsx +18 -0
- package/src/domain/userList/component/UserListStatusError.tsx +19 -0
- package/src/domain/userList/component/UserListStatusLoading.tsx +18 -0
- package/src/domain/userList/index.ts +7 -0
- package/src/domain/userList/module/createUserListModule.tsx +21 -0
- package/src/domain/userList/module/moduleContext.tsx +36 -0
- package/src/domain/userList/types.ts +65 -0
- package/src/fragments/createGroupChannelCreateFragment.tsx +136 -0
- package/src/fragments/createGroupChannelFragment.tsx +153 -0
- package/src/fragments/createGroupChannelInviteFragment.tsx +127 -0
- package/src/fragments/createGroupChannelListFragment.tsx +113 -0
- package/src/fragments/createGroupChannelMembersFragment.tsx +112 -0
- package/src/fragments/createGroupChannelSettingsFragment.tsx +56 -0
- package/src/hooks/useConnection.ts +82 -0
- package/src/hooks/useContext.ts +25 -0
- package/src/hooks/usePushTokenRegistration.ts +64 -0
- package/src/index.ts +104 -0
- package/src/localization/StringSet.en.ts +7 -0
- package/src/localization/StringSet.type.ts +334 -0
- package/src/platform/createClipboardService.expo.ts +16 -0
- package/src/platform/createClipboardService.native.ts +16 -0
- package/src/platform/createFileService.expo.ts +142 -0
- package/src/platform/createFileService.native.ts +191 -0
- package/src/platform/createNotificationService.expo.ts +36 -0
- package/src/platform/createNotificationService.native.ts +60 -0
- package/src/platform/dynamicModule.ts +110 -0
- package/src/platform/types.ts +51 -0
- package/src/types.ts +18 -0
- package/src/utils/expoPermissionGranted.ts +39 -0
- package/src/utils/fileTypeGuard.ts +10 -0
- package/src/utils/nativePermissionGranted.ts +14 -0
- package/src/version.ts +2 -0
package/package.json
ADDED
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@sendbird/uikit-react-native",
|
|
3
|
+
"version": "1.0.0-rc.1",
|
|
4
|
+
"description": "react-native-uikit",
|
|
5
|
+
"main": "lib/commonjs/index",
|
|
6
|
+
"module": "lib/module/index",
|
|
7
|
+
"types": "lib/typescript/src/index.d.ts",
|
|
8
|
+
"react-native": "src/index",
|
|
9
|
+
"source": "src/index",
|
|
10
|
+
"files": [
|
|
11
|
+
"src",
|
|
12
|
+
"lib",
|
|
13
|
+
"!**/__tests__"
|
|
14
|
+
],
|
|
15
|
+
"sideEffects": false,
|
|
16
|
+
"scripts": {
|
|
17
|
+
"prepare": "yarn generate-version",
|
|
18
|
+
"test": "jest",
|
|
19
|
+
"build": "yarn generate-version && bob build",
|
|
20
|
+
"clean": "del lib",
|
|
21
|
+
"generate-version": "node scripts/generate-version.js ./src/version.ts",
|
|
22
|
+
"create-domain": "node scripts/create-core-domain"
|
|
23
|
+
},
|
|
24
|
+
"keywords": [
|
|
25
|
+
"react-native",
|
|
26
|
+
"sendbird"
|
|
27
|
+
],
|
|
28
|
+
"repository": {
|
|
29
|
+
"type": "git",
|
|
30
|
+
"url": "https://github.com/sendbird/sendbird-uikit-react-native.git",
|
|
31
|
+
"directory": "packages/uikit-react-native"
|
|
32
|
+
},
|
|
33
|
+
"author": "Sendbird <support@sendbird.com>",
|
|
34
|
+
"license": "SEE LICENSE IN LICENSE.md",
|
|
35
|
+
"bugs": {
|
|
36
|
+
"url": "https://github.com/sendbird/sendbird-uikit-react-native.git/issues"
|
|
37
|
+
},
|
|
38
|
+
"homepage": "https://github.com/sendbird/sendbird-uikit-react-native.git#readme",
|
|
39
|
+
"publishConfig": {
|
|
40
|
+
"registry": "https://registry.npmjs.org/",
|
|
41
|
+
"access": "public"
|
|
42
|
+
},
|
|
43
|
+
"dependencies": {
|
|
44
|
+
"@sendbird/uikit-chat-hooks": "1.0.0-rc.1",
|
|
45
|
+
"@sendbird/uikit-react-native-foundation": "1.0.0-rc.1",
|
|
46
|
+
"@sendbird/uikit-utils": "1.0.0-rc.1"
|
|
47
|
+
},
|
|
48
|
+
"devDependencies": {
|
|
49
|
+
"@react-native-clipboard/clipboard": "^1.8.5",
|
|
50
|
+
"@react-native-community/cameraroll": "^4.1.2",
|
|
51
|
+
"@react-native-community/netinfo": "^9.3.0",
|
|
52
|
+
"@react-native-firebase/app": "^14.4.0",
|
|
53
|
+
"@react-native-firebase/messaging": "^14.4.0",
|
|
54
|
+
"@types/react": "17.0.2",
|
|
55
|
+
"@types/react-native": "^0.66.15",
|
|
56
|
+
"date-fns": "^2.28.0",
|
|
57
|
+
"expo-clipboard": "^2.1.1",
|
|
58
|
+
"expo-document-picker": "^10.1.3",
|
|
59
|
+
"expo-file-system": "^13.1.4",
|
|
60
|
+
"expo-image-picker": "^12.0.2",
|
|
61
|
+
"expo-media-library": "^14.0.1",
|
|
62
|
+
"expo-notifications": "^0.14.1",
|
|
63
|
+
"glob": "^7.2.0",
|
|
64
|
+
"inquirer": "^8.2.0",
|
|
65
|
+
"js-convert-case": "^4.2.0",
|
|
66
|
+
"react": "17.0.2",
|
|
67
|
+
"react-native": "0.66.4",
|
|
68
|
+
"react-native-builder-bob": "^0.18.0",
|
|
69
|
+
"react-native-document-picker": "^8.0.0",
|
|
70
|
+
"react-native-file-access": "^2.4.3",
|
|
71
|
+
"react-native-image-picker": "^4.7.1",
|
|
72
|
+
"react-native-permissions": "^3.6.0",
|
|
73
|
+
"react-native-safe-area-context": "^3.3.2",
|
|
74
|
+
"typescript": "^4.1.3"
|
|
75
|
+
},
|
|
76
|
+
"peerDependencies": {
|
|
77
|
+
"@react-native-clipboard/clipboard": "^1.8.5",
|
|
78
|
+
"@react-native-community/cameraroll": "^4.1.2",
|
|
79
|
+
"@react-native-community/netinfo": "^9.3.0",
|
|
80
|
+
"@react-native-firebase/messaging": "^14.4.0",
|
|
81
|
+
"date-fns": "^2.28.0",
|
|
82
|
+
"expo-clipboard": "^2.1.1",
|
|
83
|
+
"expo-document-picker": "^10.1.3",
|
|
84
|
+
"expo-file-system": "^13.1.4",
|
|
85
|
+
"expo-image-picker": ">=12.0.2",
|
|
86
|
+
"expo-notifications": ">=0.14.1",
|
|
87
|
+
"react": ">=16.13.1",
|
|
88
|
+
"react-native": ">=0.63.3",
|
|
89
|
+
"react-native-document-picker": "^8.0.0",
|
|
90
|
+
"react-native-file-access": "^2.4.3",
|
|
91
|
+
"react-native-image-picker": "^4.7.1",
|
|
92
|
+
"react-native-permissions": "^3.6.0",
|
|
93
|
+
"react-native-safe-area-context": "^3.3.2",
|
|
94
|
+
"sendbird": "^3.1.22"
|
|
95
|
+
},
|
|
96
|
+
"peerDependenciesMeta": {
|
|
97
|
+
"@react-native-clipboard/clipboard": {
|
|
98
|
+
"optional": true
|
|
99
|
+
},
|
|
100
|
+
"@react-native-community/cameraroll": {
|
|
101
|
+
"optional": true
|
|
102
|
+
},
|
|
103
|
+
"@react-native-firebase/messaging": {
|
|
104
|
+
"optional": true
|
|
105
|
+
},
|
|
106
|
+
"expo-clipboard": {
|
|
107
|
+
"optional": true
|
|
108
|
+
},
|
|
109
|
+
"expo-document-picker": {
|
|
110
|
+
"optional": true
|
|
111
|
+
},
|
|
112
|
+
"expo-file-system": {
|
|
113
|
+
"optional": true
|
|
114
|
+
},
|
|
115
|
+
"expo-image-picker": {
|
|
116
|
+
"optional": true
|
|
117
|
+
},
|
|
118
|
+
"expo-notifications": {
|
|
119
|
+
"optional": true
|
|
120
|
+
},
|
|
121
|
+
"react-native-document-picker": {
|
|
122
|
+
"optional": true
|
|
123
|
+
},
|
|
124
|
+
"react-native-file-access": {
|
|
125
|
+
"optional": true
|
|
126
|
+
},
|
|
127
|
+
"react-native-image-picker": {
|
|
128
|
+
"optional": true
|
|
129
|
+
},
|
|
130
|
+
"react-native-permissions": {
|
|
131
|
+
"optional": true
|
|
132
|
+
}
|
|
133
|
+
},
|
|
134
|
+
"react-native-builder-bob": {
|
|
135
|
+
"source": "src",
|
|
136
|
+
"output": "lib",
|
|
137
|
+
"targets": [
|
|
138
|
+
"commonjs",
|
|
139
|
+
"module",
|
|
140
|
+
[
|
|
141
|
+
"typescript",
|
|
142
|
+
{
|
|
143
|
+
"project": "tsconfig.build.json"
|
|
144
|
+
}
|
|
145
|
+
]
|
|
146
|
+
]
|
|
147
|
+
},
|
|
148
|
+
"typedoc": {
|
|
149
|
+
"entryPoint": "./src/index.ts",
|
|
150
|
+
"readmeFile": "./README.md",
|
|
151
|
+
"displayName": "@sendbird/uikit-react-native"
|
|
152
|
+
},
|
|
153
|
+
"gitHead": "870c05138843249a23a3978106a17e7a4e466d4d"
|
|
154
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import React, { ErrorInfo } from 'react';
|
|
2
|
+
import { View } from 'react-native';
|
|
3
|
+
|
|
4
|
+
import TypedPlaceholder from './components/TypedPlaceholder';
|
|
5
|
+
import type { ErrorBoundaryProps } from './types';
|
|
6
|
+
|
|
7
|
+
const DefaultErrorBoundaryComponent = (props: ErrorBoundaryProps) => {
|
|
8
|
+
return (
|
|
9
|
+
<View style={{ flex: 1, justifyContent: 'center', alignItems: 'center' }}>
|
|
10
|
+
<TypedPlaceholder type={'error-wrong'} onPressRetry={props.reset} />
|
|
11
|
+
</View>
|
|
12
|
+
);
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
class InternalErrorBoundary extends React.PureComponent<{
|
|
16
|
+
onError?: (props: ErrorBoundaryProps) => void;
|
|
17
|
+
ErrorInfoComponent?: (props: ErrorBoundaryProps) => JSX.Element;
|
|
18
|
+
}> {
|
|
19
|
+
static defaultProps = {
|
|
20
|
+
ErrorInfoComponent: DefaultErrorBoundaryComponent,
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
state: { error: Error | null; errorInfo: ErrorInfo | null } = {
|
|
24
|
+
error: null,
|
|
25
|
+
errorInfo: null,
|
|
26
|
+
};
|
|
27
|
+
|
|
28
|
+
componentDidCatch = (error: Error, errorInfo: ErrorInfo) => {
|
|
29
|
+
this.setState({ error, errorInfo });
|
|
30
|
+
this.props.onError?.({ error, errorInfo, reset: this.reset });
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
reset = () => {
|
|
34
|
+
this.setState({ error: null, errorInfo: null });
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
render = () => {
|
|
38
|
+
if (this.state.error && this.state.errorInfo) {
|
|
39
|
+
return (
|
|
40
|
+
this.props.ErrorInfoComponent?.({
|
|
41
|
+
error: this.state.error,
|
|
42
|
+
errorInfo: this.state.errorInfo,
|
|
43
|
+
reset: this.reset,
|
|
44
|
+
}) ?? null
|
|
45
|
+
);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
return <>{this.props.children}</>;
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
export default InternalErrorBoundary;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import type { KeyValuePairGet, KeyValuePairSet, LocalCacheStorage } from './types';
|
|
2
|
+
|
|
3
|
+
export default class InternalLocalCacheStorage implements LocalCacheStorage {
|
|
4
|
+
constructor(private storage: LocalCacheStorage) {}
|
|
5
|
+
|
|
6
|
+
getAllKeys() {
|
|
7
|
+
return this.storage.getAllKeys();
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
getItem(key: string) {
|
|
11
|
+
return this.storage.getItem(key);
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
removeItem(key: string) {
|
|
15
|
+
return this.storage.removeItem(key);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
setItem(key: string, value: string) {
|
|
19
|
+
return this.storage.setItem(key, value);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
async multiGet(keys: string[]) {
|
|
23
|
+
if (this.storage.multiGet) {
|
|
24
|
+
return this.storage.multiGet(keys);
|
|
25
|
+
} else {
|
|
26
|
+
return Promise.all(keys.map(async (key) => [key, await this.getItem(key)] as KeyValuePairGet));
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
async multiRemove(keys: string[]) {
|
|
31
|
+
if (this.storage.multiRemove) {
|
|
32
|
+
await this.storage.multiRemove(keys);
|
|
33
|
+
} else {
|
|
34
|
+
await Promise.all(keys.map(async (key) => this.removeItem(key)));
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
async multiSet(keyValuePairs: Array<KeyValuePairSet>) {
|
|
39
|
+
if (this.storage.multiSet) {
|
|
40
|
+
await this.storage.multiSet(keyValuePairs);
|
|
41
|
+
} else {
|
|
42
|
+
await Promise.all(keyValuePairs.map(([key, value]) => this.storage.setItem(key, value)));
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
}
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
import React, { useEffect, useRef, useState } from 'react';
|
|
2
|
+
import { Platform } from 'react-native';
|
|
3
|
+
import { SafeAreaProvider } from 'react-native-safe-area-context';
|
|
4
|
+
import Sendbird from 'sendbird';
|
|
5
|
+
|
|
6
|
+
import type { HeaderStyleContextType, UIKitTheme } from '@sendbird/uikit-react-native-foundation';
|
|
7
|
+
import {
|
|
8
|
+
DialogProvider,
|
|
9
|
+
Header,
|
|
10
|
+
HeaderStyleProvider,
|
|
11
|
+
LightUIKitTheme,
|
|
12
|
+
ToastProvider,
|
|
13
|
+
UIKitThemeProvider,
|
|
14
|
+
} from '@sendbird/uikit-react-native-foundation';
|
|
15
|
+
import type { SendbirdChatSDK } from '@sendbird/uikit-utils';
|
|
16
|
+
|
|
17
|
+
import InternalErrorBoundary from './InternalErrorBoundary';
|
|
18
|
+
import InternalLocalCacheStorage from './InternalLocalCacheStorage';
|
|
19
|
+
import { LocalizationProvider } from './contexts/Localization';
|
|
20
|
+
import { PlatformServiceProvider } from './contexts/PlatformService';
|
|
21
|
+
import { SendbirdChatProvider } from './contexts/SendbirdChat';
|
|
22
|
+
import { useLocalization } from './hooks/useContext';
|
|
23
|
+
import StringSetEn from './localization/StringSet.en';
|
|
24
|
+
import type { StringSet } from './localization/StringSet.type';
|
|
25
|
+
import SBUDynamicModule from './platform/dynamicModule';
|
|
26
|
+
import type { ClipboardServiceInterface, FileServiceInterface, NotificationServiceInterface } from './platform/types';
|
|
27
|
+
import type { ErrorBoundaryProps, LocalCacheStorage } from './types';
|
|
28
|
+
import VERSION from './version';
|
|
29
|
+
|
|
30
|
+
const NetInfo = SBUDynamicModule.get('@react-native-community/netinfo', 'warn');
|
|
31
|
+
|
|
32
|
+
export const SendbirdUIKit = Object.freeze({
|
|
33
|
+
VERSION,
|
|
34
|
+
PLATFORM: Platform.OS.toLowerCase(),
|
|
35
|
+
});
|
|
36
|
+
|
|
37
|
+
export type SendbirdUIKitContainerProps = {
|
|
38
|
+
children?: React.ReactNode;
|
|
39
|
+
appId: string;
|
|
40
|
+
platformServices: {
|
|
41
|
+
file: FileServiceInterface;
|
|
42
|
+
notification: NotificationServiceInterface;
|
|
43
|
+
clipboard: ClipboardServiceInterface;
|
|
44
|
+
};
|
|
45
|
+
chatOptions?: {
|
|
46
|
+
localCacheStorage?: LocalCacheStorage;
|
|
47
|
+
enableAutoPushTokenRegistration?: boolean;
|
|
48
|
+
onInitialized?: (sdkInstance: SendbirdChatSDK) => SendbirdChatSDK;
|
|
49
|
+
};
|
|
50
|
+
localization?: {
|
|
51
|
+
stringSet?: StringSet;
|
|
52
|
+
};
|
|
53
|
+
styles?: {
|
|
54
|
+
theme?: UIKitTheme;
|
|
55
|
+
statusBarTranslucent?: boolean;
|
|
56
|
+
defaultHeaderTitleAlign?: 'left' | 'center';
|
|
57
|
+
HeaderComponent?: HeaderStyleContextType['HeaderComponent'];
|
|
58
|
+
};
|
|
59
|
+
toast?: {
|
|
60
|
+
dismissTimeout?: number;
|
|
61
|
+
};
|
|
62
|
+
errorBoundary?: {
|
|
63
|
+
onError?: (props: ErrorBoundaryProps) => void;
|
|
64
|
+
ErrorInfoComponent?: (props: ErrorBoundaryProps) => JSX.Element;
|
|
65
|
+
};
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
const SendbirdUIKitContainer = ({
|
|
69
|
+
children,
|
|
70
|
+
appId,
|
|
71
|
+
chatOptions,
|
|
72
|
+
platformServices,
|
|
73
|
+
localization,
|
|
74
|
+
styles,
|
|
75
|
+
toast,
|
|
76
|
+
errorBoundary,
|
|
77
|
+
}: SendbirdUIKitContainerProps) => {
|
|
78
|
+
const unsubscribes = useRef<(() => void)[]>([]).current;
|
|
79
|
+
const getSendbirdSDK = () => {
|
|
80
|
+
let sdk: SendbirdChatSDK;
|
|
81
|
+
|
|
82
|
+
if (chatOptions?.localCacheStorage) {
|
|
83
|
+
sdk = new Sendbird({ appId, localCacheEnabled: true });
|
|
84
|
+
sdk.useAsyncStorageAsDatabase(new InternalLocalCacheStorage(chatOptions.localCacheStorage));
|
|
85
|
+
} else {
|
|
86
|
+
sdk = new Sendbird({ appId });
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
if (chatOptions?.onInitialized) {
|
|
90
|
+
sdk = chatOptions?.onInitialized(sdk);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
if (SendbirdUIKit.VERSION) {
|
|
94
|
+
// @ts-ignore
|
|
95
|
+
sdk.addExtension('sb_uikit', SendbirdUIKit.VERSION);
|
|
96
|
+
}
|
|
97
|
+
if (SendbirdUIKit.PLATFORM) {
|
|
98
|
+
// @ts-ignore
|
|
99
|
+
sdk.addExtension('device-os-platform', SendbirdUIKit.PLATFORM);
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
if (NetInfo) {
|
|
103
|
+
const listener = (callback: () => void, callbackType: 'online' | 'offline') => {
|
|
104
|
+
const unsubscribe = NetInfo.addEventListener((state) => {
|
|
105
|
+
const online = Boolean(state.isConnected) || Boolean(state.isInternetReachable);
|
|
106
|
+
if (online && callbackType === 'online') callback();
|
|
107
|
+
if (!online && callbackType === 'offline') callback();
|
|
108
|
+
});
|
|
109
|
+
unsubscribes.push(unsubscribe);
|
|
110
|
+
return unsubscribe;
|
|
111
|
+
};
|
|
112
|
+
sdk.setOnlineListener?.((onOnline) => listener(onOnline, 'online'));
|
|
113
|
+
sdk.setOfflineListener?.((onOffline) => listener(onOffline, 'offline'));
|
|
114
|
+
}
|
|
115
|
+
return sdk;
|
|
116
|
+
};
|
|
117
|
+
|
|
118
|
+
const [sdkInstance, setSdkInstance] = useState<SendbirdChatSDK>(getSendbirdSDK);
|
|
119
|
+
|
|
120
|
+
useEffect(() => {
|
|
121
|
+
setSdkInstance(getSendbirdSDK);
|
|
122
|
+
return () => {
|
|
123
|
+
unsubscribes.forEach((u) => {
|
|
124
|
+
try {
|
|
125
|
+
u();
|
|
126
|
+
} catch {}
|
|
127
|
+
});
|
|
128
|
+
};
|
|
129
|
+
}, [appId, chatOptions?.localCacheStorage]);
|
|
130
|
+
|
|
131
|
+
return (
|
|
132
|
+
<SafeAreaProvider>
|
|
133
|
+
<SendbirdChatProvider
|
|
134
|
+
sdkInstance={sdkInstance}
|
|
135
|
+
enableAutoPushTokenRegistration={chatOptions?.enableAutoPushTokenRegistration ?? true}
|
|
136
|
+
>
|
|
137
|
+
<LocalizationProvider stringSet={localization?.stringSet ?? StringSetEn}>
|
|
138
|
+
<PlatformServiceProvider
|
|
139
|
+
fileService={platformServices.file}
|
|
140
|
+
notificationService={platformServices.notification}
|
|
141
|
+
clipboardService={platformServices.clipboard}
|
|
142
|
+
>
|
|
143
|
+
<UIKitThemeProvider theme={styles?.theme ?? LightUIKitTheme}>
|
|
144
|
+
<HeaderStyleProvider
|
|
145
|
+
HeaderComponent={styles?.HeaderComponent ?? Header}
|
|
146
|
+
defaultTitleAlign={styles?.defaultHeaderTitleAlign ?? 'left'}
|
|
147
|
+
statusBarTranslucent={styles?.statusBarTranslucent ?? true}
|
|
148
|
+
>
|
|
149
|
+
<LocalizedDialogProvider>
|
|
150
|
+
<ToastProvider dismissTimeout={toast?.dismissTimeout}>
|
|
151
|
+
<InternalErrorBoundary {...errorBoundary}>{children}</InternalErrorBoundary>
|
|
152
|
+
</ToastProvider>
|
|
153
|
+
</LocalizedDialogProvider>
|
|
154
|
+
</HeaderStyleProvider>
|
|
155
|
+
</UIKitThemeProvider>
|
|
156
|
+
</PlatformServiceProvider>
|
|
157
|
+
</LocalizationProvider>
|
|
158
|
+
</SendbirdChatProvider>
|
|
159
|
+
</SafeAreaProvider>
|
|
160
|
+
);
|
|
161
|
+
};
|
|
162
|
+
|
|
163
|
+
const LocalizedDialogProvider: React.FC = ({ children }) => {
|
|
164
|
+
const { STRINGS } = useLocalization();
|
|
165
|
+
return (
|
|
166
|
+
<DialogProvider
|
|
167
|
+
defaultLabels={{
|
|
168
|
+
alert: {
|
|
169
|
+
ok: STRINGS.DIALOG.ALERT_DEFAULT_OK,
|
|
170
|
+
},
|
|
171
|
+
prompt: {
|
|
172
|
+
ok: STRINGS.DIALOG.PROMPT_DEFAULT_OK,
|
|
173
|
+
cancel: STRINGS.DIALOG.PROMPT_DEFAULT_CANCEL,
|
|
174
|
+
placeholder: STRINGS.DIALOG.PROMPT_DEFAULT_PLACEHOLDER,
|
|
175
|
+
},
|
|
176
|
+
}}
|
|
177
|
+
>
|
|
178
|
+
{children}
|
|
179
|
+
</DialogProvider>
|
|
180
|
+
);
|
|
181
|
+
};
|
|
182
|
+
|
|
183
|
+
export default SendbirdUIKitContainer;
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import type { StyleProp, ViewStyle } from 'react-native';
|
|
3
|
+
|
|
4
|
+
import { Avatar } from '@sendbird/uikit-react-native-foundation';
|
|
5
|
+
import { SendbirdGroupChannel, getMembersExcludeMe, isDefaultCoverImage } from '@sendbird/uikit-utils';
|
|
6
|
+
|
|
7
|
+
import { useSendbirdChat } from '../hooks/useContext';
|
|
8
|
+
|
|
9
|
+
type Props = {
|
|
10
|
+
channel: SendbirdGroupChannel;
|
|
11
|
+
size?: number;
|
|
12
|
+
containerStyle?: StyleProp<ViewStyle>;
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
const ChannelCover: React.FC<Props> = ({ channel, ...avatarProps }) => {
|
|
16
|
+
const { currentUser } = useSendbirdChat();
|
|
17
|
+
|
|
18
|
+
// channel cover
|
|
19
|
+
if (!isDefaultCoverImage(channel.coverUrl) || !currentUser) {
|
|
20
|
+
return <Avatar uri={channel.coverUrl} {...avatarProps} />;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
// no members, use anonymous profile
|
|
24
|
+
if (channel.memberCount <= 1) {
|
|
25
|
+
return <Avatar {...avatarProps} />;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
// 1:1, use member profile
|
|
29
|
+
if (channel.memberCount === 2) {
|
|
30
|
+
const otherUserProfile = channel.members.filter((m) => m.userId !== currentUser.userId)?.[0]?.profileUrl;
|
|
31
|
+
return <Avatar uri={otherUserProfile} {...avatarProps} />;
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
// group, use members profile
|
|
35
|
+
return (
|
|
36
|
+
<Avatar.Group {...avatarProps}>
|
|
37
|
+
{getMembersExcludeMe(channel, currentUser?.userId).map((m) => (
|
|
38
|
+
<Avatar key={m.userId} uri={m.profileUrl} />
|
|
39
|
+
))}
|
|
40
|
+
</Avatar.Group>
|
|
41
|
+
);
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
export default ChannelCover;
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import React, { forwardRef, useCallback, useEffect, useImperativeHandle, useRef } from 'react';
|
|
2
|
+
import { FlatList, FlatListProps, Platform } from 'react-native';
|
|
3
|
+
|
|
4
|
+
import { useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
|
|
5
|
+
import { SendbirdMessage, isMyMessage } from '@sendbird/uikit-utils';
|
|
6
|
+
|
|
7
|
+
let ANDROID_BUG_ALERT_SHOWED = Platform.OS !== 'android';
|
|
8
|
+
const BOTTOM_DETECT_THRESHOLD = 25;
|
|
9
|
+
// const AUTO_SCROLL_TO_TOP_THRESHOLD = 15;
|
|
10
|
+
|
|
11
|
+
function hasReachedToBottom(yPos: number, thresholdPx = 0) {
|
|
12
|
+
return thresholdPx >= yPos;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export type ChatFlatListRef = { scrollToBottom: (animated?: boolean) => void };
|
|
16
|
+
type Props = Omit<FlatListProps<SendbirdMessage>, 'onEndReached'> & {
|
|
17
|
+
currentUserId?: string;
|
|
18
|
+
onBottomReached: () => void;
|
|
19
|
+
onTopReached: () => void;
|
|
20
|
+
nextMessages: SendbirdMessage[];
|
|
21
|
+
onLeaveScrollBottom: (value: boolean) => void;
|
|
22
|
+
};
|
|
23
|
+
// FIXME: Inverted FlatList performance issue on Android {@link https://github.com/facebook/react-native/issues/30034}
|
|
24
|
+
const ChatFlatList = forwardRef<ChatFlatListRef, Props>(function CustomFlatList(
|
|
25
|
+
{ onTopReached, nextMessages, onBottomReached, onLeaveScrollBottom, onScroll, currentUserId, ...props },
|
|
26
|
+
ref,
|
|
27
|
+
) {
|
|
28
|
+
const { select } = useUIKitTheme();
|
|
29
|
+
const scrollRef = useRef<FlatList<SendbirdMessage>>(null);
|
|
30
|
+
const yPos = useRef(0);
|
|
31
|
+
|
|
32
|
+
useImperativeHandle(
|
|
33
|
+
ref,
|
|
34
|
+
() => ({
|
|
35
|
+
scrollToBottom: (animated = true) => scrollRef.current?.scrollToOffset({ animated, offset: 0 }),
|
|
36
|
+
}),
|
|
37
|
+
[],
|
|
38
|
+
);
|
|
39
|
+
|
|
40
|
+
useEffect(() => {
|
|
41
|
+
const latestMessage = nextMessages[nextMessages.length - 1];
|
|
42
|
+
if (!latestMessage) return;
|
|
43
|
+
|
|
44
|
+
if (hasReachedToBottom(yPos.current)) {
|
|
45
|
+
onBottomReached();
|
|
46
|
+
} else if (isMyMessage(latestMessage, currentUserId)) {
|
|
47
|
+
scrollRef.current?.scrollToOffset({ animated: false, offset: 0 });
|
|
48
|
+
}
|
|
49
|
+
}, [onBottomReached, nextMessages, currentUserId]);
|
|
50
|
+
|
|
51
|
+
const _onScroll: Props['onScroll'] = useCallback(
|
|
52
|
+
(event) => {
|
|
53
|
+
const { contentOffset } = event.nativeEvent;
|
|
54
|
+
if (BOTTOM_DETECT_THRESHOLD < yPos.current && contentOffset.y <= BOTTOM_DETECT_THRESHOLD) {
|
|
55
|
+
onLeaveScrollBottom(false);
|
|
56
|
+
} else if (BOTTOM_DETECT_THRESHOLD < contentOffset.y && yPos.current <= BOTTOM_DETECT_THRESHOLD) {
|
|
57
|
+
onLeaveScrollBottom(true);
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
yPos.current = contentOffset.y;
|
|
61
|
+
|
|
62
|
+
onScroll?.(event);
|
|
63
|
+
if (hasReachedToBottom(yPos.current)) onBottomReached();
|
|
64
|
+
},
|
|
65
|
+
[onScroll, onBottomReached],
|
|
66
|
+
);
|
|
67
|
+
|
|
68
|
+
if (__DEV__ && !ANDROID_BUG_ALERT_SHOWED) {
|
|
69
|
+
ANDROID_BUG_ALERT_SHOWED = true;
|
|
70
|
+
// eslint-disable-next-line no-console
|
|
71
|
+
console.warn(
|
|
72
|
+
'UIKit Warning: Inverted FlatList has a performance issue on Android, Maybe this is a bug please refer link\nhttps://github.com/facebook/react-native/issues/30034',
|
|
73
|
+
);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
return (
|
|
77
|
+
<FlatList
|
|
78
|
+
{...props}
|
|
79
|
+
// FIXME: inverted list of ListEmptyComponent is reversed {@link https://github.com/facebook/react-native/issues/21196#issuecomment-836937743}
|
|
80
|
+
inverted={Boolean(props.data?.length)}
|
|
81
|
+
// FIXME: maintainVisibleContentPosition is not working on Android {@link https://github.com/facebook/react-native/issues/25239}
|
|
82
|
+
// maintainVisibleContentPosition={{ minIndexForVisible: 1, autoscrollToTopThreshold: AUTO_SCROLL_TO_TOP_THRESHOLD }}
|
|
83
|
+
ref={scrollRef}
|
|
84
|
+
bounces={false}
|
|
85
|
+
keyboardShouldPersistTaps={'handled'}
|
|
86
|
+
indicatorStyle={select({ light: 'black', dark: 'white' })}
|
|
87
|
+
removeClippedSubviews
|
|
88
|
+
onEndReachedThreshold={0.5}
|
|
89
|
+
onEndReached={onTopReached}
|
|
90
|
+
scrollEventThrottle={16}
|
|
91
|
+
onScroll={_onScroll}
|
|
92
|
+
/>
|
|
93
|
+
);
|
|
94
|
+
});
|
|
95
|
+
|
|
96
|
+
export default ChatFlatList;
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { StyleSheet, View } from 'react-native';
|
|
3
|
+
|
|
4
|
+
import { Text, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
|
|
5
|
+
import type { SendbirdAdminMessage } from '@sendbird/uikit-utils';
|
|
6
|
+
|
|
7
|
+
import type { MessageRendererInterface } from '../index';
|
|
8
|
+
|
|
9
|
+
export type AdminMessageProps = MessageRendererInterface<SendbirdAdminMessage>;
|
|
10
|
+
const AdminMessage: React.FC<AdminMessageProps> = ({ message, nextMessage }) => {
|
|
11
|
+
const { colors } = useUIKitTheme();
|
|
12
|
+
|
|
13
|
+
const isNextAdmin = nextMessage?.isAdminMessage();
|
|
14
|
+
return (
|
|
15
|
+
<View style={StyleSheet.flatten([styles.container, isNextAdmin ? styles.nextAdminType : styles.next])}>
|
|
16
|
+
<Text caption2 color={colors.onBackground02} style={styles.text}>
|
|
17
|
+
{message.message}
|
|
18
|
+
</Text>
|
|
19
|
+
</View>
|
|
20
|
+
);
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
const styles = createStyleSheet({
|
|
24
|
+
container: {
|
|
25
|
+
width: 300,
|
|
26
|
+
alignSelf: 'center',
|
|
27
|
+
alignItems: 'center',
|
|
28
|
+
},
|
|
29
|
+
nextAdminType: {
|
|
30
|
+
marginBottom: 8,
|
|
31
|
+
},
|
|
32
|
+
next: {
|
|
33
|
+
marginBottom: 16,
|
|
34
|
+
},
|
|
35
|
+
text: {
|
|
36
|
+
textAlign: 'center',
|
|
37
|
+
},
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
export default AdminMessage;
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
import { View } from 'react-native';
|
|
3
|
+
|
|
4
|
+
import { Icon, Text, createStyleSheet, useUIKitTheme } from '@sendbird/uikit-react-native-foundation';
|
|
5
|
+
|
|
6
|
+
import { useLocalization } from '../../../hooks/useContext';
|
|
7
|
+
import type { FileMessageProps } from './index';
|
|
8
|
+
|
|
9
|
+
const iconMapper = { audio: 'file-audio', image: 'photo', video: 'play', file: 'file-document' } as const;
|
|
10
|
+
|
|
11
|
+
const BaseFileMessage: React.FC<FileMessageProps & { type: 'image' | 'audio' | 'video' | 'file' }> = ({
|
|
12
|
+
message,
|
|
13
|
+
variant,
|
|
14
|
+
pressed,
|
|
15
|
+
type,
|
|
16
|
+
}) => {
|
|
17
|
+
const { STRINGS } = useLocalization();
|
|
18
|
+
const { colors } = useUIKitTheme();
|
|
19
|
+
const color = colors.ui.message[variant][pressed ? 'pressed' : 'enabled'];
|
|
20
|
+
return (
|
|
21
|
+
<View style={[styles.container, { backgroundColor: color.background }]}>
|
|
22
|
+
<Icon
|
|
23
|
+
icon={iconMapper[type]}
|
|
24
|
+
size={24}
|
|
25
|
+
containerStyle={{ backgroundColor: colors.background, padding: 2, borderRadius: 8, marginRight: 8 }}
|
|
26
|
+
/>
|
|
27
|
+
<Text body3 ellipsizeMode={'middle'} numberOfLines={1} color={color.textMsg} style={styles.name}>
|
|
28
|
+
{STRINGS.GROUP_CHANNEL.MESSAGE_BUBBLE_FILE_TITLE(message)}
|
|
29
|
+
</Text>
|
|
30
|
+
</View>
|
|
31
|
+
);
|
|
32
|
+
};
|
|
33
|
+
|
|
34
|
+
const styles = createStyleSheet({
|
|
35
|
+
container: {
|
|
36
|
+
flexDirection: 'row',
|
|
37
|
+
alignItems: 'center',
|
|
38
|
+
justifyContent: 'center',
|
|
39
|
+
paddingHorizontal: 12,
|
|
40
|
+
paddingVertical: 6,
|
|
41
|
+
borderRadius: 16,
|
|
42
|
+
},
|
|
43
|
+
name: {
|
|
44
|
+
flexShrink: 1,
|
|
45
|
+
},
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
export default BaseFileMessage;
|