@amityco/ts-sdk-react-native 6.36.1-938a6a9.0 → 7.0.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/.env +26 -26
- package/dist/@types/core/events.d.ts +6 -6
- package/dist/@types/core/events.d.ts.map +1 -1
- package/dist/@types/domains/analytics.d.ts +0 -3
- package/dist/@types/domains/analytics.d.ts.map +1 -1
- package/dist/@types/domains/channel.d.ts +9 -33
- package/dist/@types/domains/channel.d.ts.map +1 -1
- package/dist/@types/domains/client.d.ts +0 -4
- package/dist/@types/domains/client.d.ts.map +1 -1
- package/dist/@types/domains/community.d.ts +2 -10
- package/dist/@types/domains/community.d.ts.map +1 -1
- package/dist/@types/domains/feed.d.ts +0 -11
- package/dist/@types/domains/feed.d.ts.map +1 -1
- package/dist/@types/domains/message.d.ts +0 -12
- package/dist/@types/domains/message.d.ts.map +1 -1
- package/dist/@types/domains/subChannel.d.ts +0 -4
- package/dist/@types/domains/subChannel.d.ts.map +1 -1
- package/dist/@types/domains/user.d.ts +1 -5
- package/dist/@types/domains/user.d.ts.map +1 -1
- package/dist/channelRepository/api/deleteChannel.d.ts.map +1 -1
- package/dist/channelRepository/api/index.d.ts +0 -1
- package/dist/channelRepository/api/index.d.ts.map +1 -1
- package/dist/channelRepository/channelMembership/observers/getMembers/ChannelMemberLiveCollectionController.d.ts.map +1 -1
- package/dist/channelRepository/channelMembership/observers/getMembers/getMembers.d.ts.map +1 -1
- package/dist/channelRepository/channelMembership/observers/searchMembers/SearchChannelMemberLiveCollectionController.d.ts.map +1 -1
- package/dist/channelRepository/channelMembership/observers/searchMembers/searchMembers.d.ts.map +1 -1
- package/dist/channelRepository/{api → internalApi}/getChannel.d.ts +2 -2
- package/dist/channelRepository/internalApi/getChannel.d.ts.map +1 -0
- package/dist/channelRepository/internalApi/getChannelByIds.d.ts +32 -0
- package/dist/channelRepository/internalApi/getChannelByIds.d.ts.map +1 -0
- package/dist/channelRepository/{api → internalApi}/markAsRead.d.ts +0 -3
- package/dist/channelRepository/internalApi/markAsRead.d.ts.map +1 -0
- package/dist/channelRepository/observers/getChannel.d.ts.map +1 -1
- package/dist/channelRepository/observers/getChannels/ChannelLiveCollectionController.d.ts.map +1 -1
- package/dist/channelRepository/observers/index.d.ts +0 -2
- package/dist/channelRepository/observers/index.d.ts.map +1 -1
- package/dist/channelRepository/utils/constructChannelDynamicValue.d.ts.map +1 -1
- package/dist/channelRepository/utils/constructChannelObject.d.ts +2 -0
- package/dist/channelRepository/utils/constructChannelObject.d.ts.map +1 -0
- package/dist/channelRepository/utils/getChannelIsMentioned.d.ts +1 -1
- package/dist/channelRepository/utils/getChannelIsMentioned.d.ts.map +1 -1
- package/dist/channelRepository/utils/getSubChannelsUnreadCount.d.ts +1 -1
- package/dist/channelRepository/utils/getSubChannelsUnreadCount.d.ts.map +1 -1
- package/dist/channelRepository/utils/resolveChannels.d.ts.map +1 -1
- package/dist/channelRepository/utils/updateChannelCache.d.ts +1 -1
- package/dist/channelRepository/utils/updateChannelCache.d.ts.map +1 -1
- package/dist/client/observers/index.d.ts +0 -1
- package/dist/client/observers/index.d.ts.map +1 -1
- package/dist/client/utils/endpoints.d.ts +1 -1
- package/dist/client/utils/markerSyncEngine.d.ts +0 -4
- package/dist/client/utils/markerSyncEngine.d.ts.map +1 -1
- package/dist/client/utils/subscribeGlobalTopic.d.ts.map +1 -1
- package/dist/commentRepository/observers/index.d.ts +0 -2
- package/dist/commentRepository/observers/index.d.ts.map +1 -1
- package/dist/communityRepository/api/index.d.ts +0 -1
- package/dist/communityRepository/api/index.d.ts.map +1 -1
- package/dist/communityRepository/api/queryCommunities.d.ts.map +1 -1
- package/dist/communityRepository/communityMembership/observers/getMembers/CommunityMembersLiveCollectionController.d.ts.map +1 -1
- package/dist/communityRepository/communityMembership/observers/getMembers/CommunityMembersQueryStreamController.d.ts.map +1 -1
- package/dist/communityRepository/communityMembership/observers/getMembers.d.ts.map +1 -1
- package/dist/communityRepository/communityMembership/observers/searchMembers/SearchCommunityMembersPaginationController.d.ts +1 -1
- package/dist/communityRepository/communityMembership/observers/searchMembers/SearchCommunityMembersPaginationController.d.ts.map +1 -1
- package/dist/communityRepository/observers/getCommunities/CommunitiesLiveCollectionController.d.ts.map +1 -1
- package/dist/communityRepository/observers/getCommunities/CommunitiesPaginationController.d.ts.map +1 -1
- package/dist/communityRepository/observers/getCommunities/CommunitiesQueryStreamController.d.ts.map +1 -1
- package/dist/communityRepository/observers/index.d.ts +0 -1
- package/dist/communityRepository/observers/index.d.ts.map +1 -1
- package/dist/communityRepository/observers/searchCommunities.d.ts +1 -1
- package/dist/communityRepository/observers/searchCommunities.d.ts.map +1 -1
- package/dist/communityRepository/utils/communityQueryFilter.d.ts.map +1 -1
- package/dist/core/events.d.ts +3 -3
- package/dist/core/events.d.ts.map +1 -1
- package/dist/core/subscription.d.ts +1 -0
- package/dist/core/subscription.d.ts.map +1 -1
- package/dist/feedRepository/api/getCustomRankingGlobalFeed.d.ts +2 -35
- package/dist/feedRepository/api/getCustomRankingGlobalFeed.d.ts.map +1 -1
- package/dist/feedRepository/api/queryGlobalFeed.d.ts +2 -24
- package/dist/feedRepository/api/queryGlobalFeed.d.ts.map +1 -1
- package/dist/fileRepository/api/index.d.ts +0 -3
- package/dist/fileRepository/api/index.d.ts.map +1 -1
- package/dist/fileRepository/index.d.ts +0 -1
- package/dist/fileRepository/index.d.ts.map +1 -1
- package/dist/index.cjs.js +1262 -2689
- package/dist/index.esm.js +1226 -2654
- package/dist/index.umd.js +3 -3
- package/dist/messagePreview/utils/getChannelMessagePreviewWithUser.d.ts +1 -5
- package/dist/messagePreview/utils/getChannelMessagePreviewWithUser.d.ts.map +1 -1
- package/dist/messagePreview/utils/getSubChannelMessagePreviewWithUser.d.ts +0 -1
- package/dist/messagePreview/utils/getSubChannelMessagePreviewWithUser.d.ts.map +1 -1
- package/dist/messageRepository/api/createMessage.d.ts.map +1 -1
- package/dist/messageRepository/api/index.d.ts +0 -1
- package/dist/messageRepository/api/index.d.ts.map +1 -1
- package/dist/messageRepository/internalApi/getMessage.d.ts.map +1 -1
- package/dist/messageRepository/observers/getMessages/MessageLiveCollectionController.d.ts.map +1 -1
- package/dist/messageRepository/observers/getMessages/MessageQueryStreamController.d.ts.map +1 -1
- package/dist/messageRepository/observers/getMessages/getMessages.d.ts +0 -1
- package/dist/messageRepository/observers/getMessages/getMessages.d.ts.map +1 -1
- package/dist/messageRepository/observers/index.d.ts +0 -2
- package/dist/messageRepository/observers/index.d.ts.map +1 -1
- package/dist/messageRepository/utils/prepareMessagePayload.d.ts +1 -1
- package/dist/messageRepository/utils/prepareMessagePayload.d.ts.map +1 -1
- package/dist/pollRepository/observers/index.d.ts +0 -1
- package/dist/pollRepository/observers/index.d.ts.map +1 -1
- package/dist/postRepository/api/index.d.ts +0 -1
- package/dist/postRepository/api/index.d.ts.map +1 -1
- package/dist/postRepository/observers/index.d.ts +0 -2
- package/dist/postRepository/observers/index.d.ts.map +1 -1
- package/dist/role/api/queryRoles.d.ts +0 -7
- package/dist/role/api/queryRoles.d.ts.map +1 -1
- package/dist/streamRepository/api/index.d.ts +0 -2
- package/dist/streamRepository/api/index.d.ts.map +1 -1
- package/dist/streamRepository/events/onStreamFlagged.d.ts.map +1 -1
- package/dist/streamRepository/internalApi/getStream.d.ts.map +1 -0
- package/dist/subChannelRepository/utils/markReadEngine.d.ts +0 -34
- package/dist/subChannelRepository/utils/markReadEngine.d.ts.map +1 -1
- package/dist/userRepository/internalApi/queryUsers.d.ts.map +1 -1
- package/dist/userRepository/observers/getUsers/UserLiveCollectionController.d.ts.map +1 -1
- package/dist/userRepository/observers/getUsers/UserPaginationController.d.ts.map +1 -1
- package/dist/userRepository/observers/index.d.ts +0 -2
- package/dist/userRepository/observers/index.d.ts.map +1 -1
- package/dist/userRepository/relationship/block/index.d.ts +0 -1
- package/dist/userRepository/relationship/block/index.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/api/index.d.ts +0 -2
- package/dist/userRepository/relationship/follow/api/index.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/observers/index.d.ts +0 -3
- package/dist/userRepository/relationship/follow/observers/index.d.ts.map +1 -1
- package/dist/utils/liveObject.d.ts +1 -1
- package/package.json +1 -1
- package/src/@types/core/events.ts +8 -9
- package/src/@types/domains/analytics.ts +0 -7
- package/src/@types/domains/channel.ts +15 -46
- package/src/@types/domains/client.ts +0 -4
- package/src/@types/domains/community.ts +0 -8
- package/src/@types/domains/feed.ts +0 -11
- package/src/@types/domains/message.ts +0 -12
- package/src/@types/domains/subChannel.ts +0 -4
- package/src/@types/domains/user.ts +0 -4
- package/src/channelRepository/api/deleteChannel.ts +3 -2
- package/src/channelRepository/api/getChannelByIds.ts +5 -5
- package/src/channelRepository/api/index.ts +0 -2
- package/src/channelRepository/channelMembership/observers/getMembers/ChannelMemberLiveCollectionController.ts +0 -8
- package/src/channelRepository/channelMembership/observers/getMembers/getMembers.ts +0 -8
- package/src/channelRepository/channelMembership/observers/searchMembers/SearchChannelMemberLiveCollectionController.ts +0 -8
- package/src/channelRepository/channelMembership/observers/searchMembers/searchMembers.ts +0 -8
- package/src/channelRepository/{api → internalApi}/getChannel.ts +4 -4
- package/src/channelRepository/internalApi/getChannelByIds.ts +105 -0
- package/src/channelRepository/{api → internalApi}/markAsRead.ts +0 -3
- package/src/channelRepository/observers/getChannel.ts +36 -15
- package/src/channelRepository/observers/getChannels/ChannelLiveCollectionController.ts +11 -12
- package/src/channelRepository/observers/index.ts +0 -2
- package/src/channelRepository/utils/constructChannelDynamicValue.ts +4 -9
- package/src/channelRepository/utils/constructChannelObject.ts +16 -0
- package/src/channelRepository/utils/getChannelIsMentioned.ts +4 -1
- package/src/channelRepository/utils/getSubChannelsUnreadCount.ts +1 -1
- package/src/channelRepository/utils/resolveChannels.ts +7 -2
- package/src/channelRepository/utils/updateChannelCache.ts +4 -1
- package/src/client/observers/getUserUnread.ts +1 -1
- package/src/client/observers/index.ts +0 -1
- package/src/client/utils/endpoints.ts +1 -1
- package/src/client/utils/markerSyncEngine.ts +0 -9
- package/src/client/utils/subscribeGlobalTopic.ts +3 -0
- package/src/commentRepository/observers/index.ts +0 -2
- package/src/communityRepository/api/index.ts +0 -3
- package/src/communityRepository/api/queryCommunities.ts +1 -2
- package/src/communityRepository/communityMembership/observers/getMembers/CommunityMembersLiveCollectionController.ts +0 -12
- package/src/communityRepository/communityMembership/observers/getMembers/CommunityMembersQueryStreamController.ts +0 -7
- package/src/communityRepository/communityMembership/observers/getMembers.ts +0 -4
- package/src/communityRepository/communityMembership/observers/searchMembers/SearchCommunityMembersPaginationController.ts +1 -1
- package/src/communityRepository/communityMembership/observers/tests/getMembers.test.ts +0 -1
- package/src/communityRepository/observers/getCommunities/CommunitiesLiveCollectionController.ts +12 -16
- package/src/communityRepository/observers/getCommunities/CommunitiesPaginationController.ts +0 -1
- package/src/communityRepository/observers/getCommunities/CommunitiesQueryStreamController.ts +0 -4
- package/src/communityRepository/observers/index.ts +0 -2
- package/src/communityRepository/observers/searchCommunities.ts +1 -1
- package/src/communityRepository/observers/tests/getCommunities.test.ts +0 -1
- package/src/communityRepository/utils/communityQueryFilter.ts +1 -8
- package/src/core/events.ts +7 -5
- package/src/core/subscription.ts +6 -0
- package/src/feedRepository/api/getCustomRankingGlobalFeed.ts +8 -55
- package/src/feedRepository/api/queryGlobalFeed.ts +6 -58
- package/src/feedRepository/api/test/getCustomRankingGlobalFeed.test.ts +1 -1
- package/src/feedRepository/api/test/queryGlobalFeed.test.ts +1 -1
- package/src/fileRepository/api/index.ts +0 -5
- package/src/fileRepository/index.ts +0 -1
- package/src/liveStreamPlayer/api/getPlayer.ts +1 -1
- package/src/messagePreview/utils/getChannelMessagePreviewWithUser.ts +2 -2
- package/src/messageRepository/api/createMessage.ts +5 -1
- package/src/messageRepository/api/index.ts +0 -2
- package/src/messageRepository/api/tests/createMessage.test.ts +6 -1
- package/src/messageRepository/api/tests/deleteMessage.test.ts +5 -1
- package/src/messageRepository/internalApi/getMessage.ts +0 -6
- package/src/messageRepository/observers/getMessages/MessageLiveCollectionController.ts +0 -20
- package/src/messageRepository/observers/getMessages/MessageQueryStreamController.ts +0 -10
- package/src/messageRepository/observers/getMessages/getMessages.ts +0 -54
- package/src/messageRepository/observers/index.ts +0 -3
- package/src/messageRepository/utils/prepareMessagePayload.ts +1 -7
- package/src/pollRepository/observers/index.ts +0 -1
- package/src/postRepository/api/index.ts +0 -1
- package/src/postRepository/observers/index.ts +0 -2
- package/src/role/api/queryRoles.ts +1 -13
- package/src/streamRepository/api/deleteStream.ts +1 -1
- package/src/streamRepository/api/index.ts +0 -4
- package/src/streamRepository/api/tests/getStream.test.ts +1 -1
- package/src/streamRepository/events/onStreamFlagged.ts +1 -6
- package/src/streamRepository/events/onStreamRecorded.ts +1 -1
- package/src/streamRepository/events/onStreamStarted.ts +1 -1
- package/src/streamRepository/events/onStreamStopped.ts +1 -1
- package/src/streamRepository/events/onStreamTerminated.ts +1 -1
- package/src/streamRepository/observers/getStreamById.ts +1 -1
- package/src/subChannelRepository/utils/markReadEngine.ts +0 -106
- package/src/userRepository/internalApi/queryUsers.ts +1 -9
- package/src/userRepository/observers/getUsers/UserLiveCollectionController.ts +12 -16
- package/src/userRepository/observers/getUsers/UserPaginationController.ts +1 -2
- package/src/userRepository/observers/index.ts +0 -2
- package/src/userRepository/observers/tests/getUsers.test.ts +1 -43
- package/src/userRepository/relationship/block/index.ts +0 -1
- package/src/userRepository/relationship/follow/api/index.ts +0 -4
- package/src/userRepository/relationship/follow/observers/index.ts +0 -4
- package/src/utils/linkedObject/channelLinkedObject.ts +1 -1
- package/src/utils/liveObject.ts +2 -2
- package/dist/channelRepository/api/getChannel.d.ts.map +0 -1
- package/dist/channelRepository/api/markAsRead.d.ts.map +0 -1
- package/dist/channelRepository/observers/observeChannel.d.ts +0 -18
- package/dist/channelRepository/observers/observeChannel.d.ts.map +0 -1
- package/dist/channelRepository/observers/observeChannels.d.ts +0 -17
- package/dist/channelRepository/observers/observeChannels.d.ts.map +0 -1
- package/dist/client/observers/getTotalUnreadCount.d.ts +0 -20
- package/dist/client/observers/getTotalUnreadCount.d.ts.map +0 -1
- package/dist/client/observers/tests/getTotalUnreadCount.test.d.ts +0 -2
- package/dist/client/observers/tests/getTotalUnreadCount.test.d.ts.map +0 -1
- package/dist/commentRepository/observers/observeComment.d.ts +0 -18
- package/dist/commentRepository/observers/observeComment.d.ts.map +0 -1
- package/dist/commentRepository/observers/observeComments.d.ts +0 -26
- package/dist/commentRepository/observers/observeComments.d.ts.map +0 -1
- package/dist/communityRepository/api/getTopTrendingCommunities.d.ts +0 -35
- package/dist/communityRepository/api/getTopTrendingCommunities.d.ts.map +0 -1
- package/dist/communityRepository/api/test/getTopTrendingCommunities.test.d.ts +0 -2
- package/dist/communityRepository/api/test/getTopTrendingCommunities.test.d.ts.map +0 -1
- package/dist/communityRepository/observers/observeCommunity.d.ts +0 -18
- package/dist/communityRepository/observers/observeCommunity.d.ts.map +0 -1
- package/dist/feedRepository/internalApi/getCustomRankingGlobalFeed.d.ts +0 -8
- package/dist/feedRepository/internalApi/getCustomRankingGlobalFeed.d.ts.map +0 -1
- package/dist/feedRepository/internalApi/index.d.ts +0 -3
- package/dist/feedRepository/internalApi/index.d.ts.map +0 -1
- package/dist/feedRepository/internalApi/queryGlobalFeed.d.ts +0 -9
- package/dist/feedRepository/internalApi/queryGlobalFeed.d.ts.map +0 -1
- package/dist/feedRepository/internalApi/test/getCustomRankingGlobalFeed.test.d.ts +0 -2
- package/dist/feedRepository/internalApi/test/getCustomRankingGlobalFeed.test.d.ts.map +0 -1
- package/dist/feedRepository/internalApi/test/queryGlobalFeed.test.d.ts +0 -2
- package/dist/feedRepository/internalApi/test/queryGlobalFeed.test.d.ts.map +0 -1
- package/dist/fileRepository/api/createFile.d.ts +0 -17
- package/dist/fileRepository/api/createFile.d.ts.map +0 -1
- package/dist/fileRepository/api/createImage.d.ts +0 -17
- package/dist/fileRepository/api/createImage.d.ts.map +0 -1
- package/dist/fileRepository/api/createVideo.d.ts +0 -18
- package/dist/fileRepository/api/createVideo.d.ts.map +0 -1
- package/dist/fileRepository/observers/index.d.ts +0 -2
- package/dist/fileRepository/observers/index.d.ts.map +0 -1
- package/dist/fileRepository/observers/observeFile.d.ts +0 -18
- package/dist/fileRepository/observers/observeFile.d.ts.map +0 -1
- package/dist/messageRepository/api/getMessage.d.ts +0 -32
- package/dist/messageRepository/api/getMessage.d.ts.map +0 -1
- package/dist/messageRepository/api/getMessages.d.ts +0 -32
- package/dist/messageRepository/api/getMessages.d.ts.map +0 -1
- package/dist/messageRepository/observers/observeMessage.d.ts +0 -21
- package/dist/messageRepository/observers/observeMessage.d.ts.map +0 -1
- package/dist/messageRepository/observers/observeMessages.d.ts +0 -23
- package/dist/messageRepository/observers/observeMessages.d.ts.map +0 -1
- package/dist/pollRepository/observers/observePoll.d.ts +0 -18
- package/dist/pollRepository/observers/observePoll.d.ts.map +0 -1
- package/dist/postRepository/api/updatePost.d.ts +0 -24
- package/dist/postRepository/api/updatePost.d.ts.map +0 -1
- package/dist/postRepository/observers/observePost.d.ts +0 -18
- package/dist/postRepository/observers/observePost.d.ts.map +0 -1
- package/dist/postRepository/observers/observePosts.d.ts +0 -34
- package/dist/postRepository/observers/observePosts.d.ts.map +0 -1
- package/dist/streamRepository/api/getStream.d.ts.map +0 -1
- package/dist/streamRepository/api/queryStreams.d.ts +0 -25
- package/dist/streamRepository/api/queryStreams.d.ts.map +0 -1
- package/dist/userRepository/observers/getViewedUsers.d.ts +0 -7
- package/dist/userRepository/observers/getViewedUsers.d.ts.map +0 -1
- package/dist/userRepository/observers/observeUser.d.ts +0 -17
- package/dist/userRepository/observers/observeUser.d.ts.map +0 -1
- package/dist/userRepository/observers/tests/getViewedUsers.test.d.ts +0 -2
- package/dist/userRepository/observers/tests/getViewedUsers.test.d.ts.map +0 -1
- package/dist/userRepository/relationship/block/observers/getBlockedUsers.d.ts +0 -2
- package/dist/userRepository/relationship/block/observers/getBlockedUsers.d.ts.map +0 -1
- package/dist/userRepository/relationship/block/observers/index.d.ts +0 -2
- package/dist/userRepository/relationship/block/observers/index.d.ts.map +0 -1
- package/dist/userRepository/relationship/follow/api/acceptFollower.d.ts +0 -19
- package/dist/userRepository/relationship/follow/api/acceptFollower.d.ts.map +0 -1
- package/dist/userRepository/relationship/follow/api/declineFollower.d.ts +0 -19
- package/dist/userRepository/relationship/follow/api/declineFollower.d.ts.map +0 -1
- package/dist/userRepository/relationship/follow/observers/observeFollowInfo.d.ts +0 -18
- package/dist/userRepository/relationship/follow/observers/observeFollowInfo.d.ts.map +0 -1
- package/dist/userRepository/relationship/follow/observers/observeFollowers.d.ts +0 -18
- package/dist/userRepository/relationship/follow/observers/observeFollowers.d.ts.map +0 -1
- package/dist/userRepository/relationship/follow/observers/observeFollowings.d.ts +0 -18
- package/dist/userRepository/relationship/follow/observers/observeFollowings.d.ts.map +0 -1
- package/src/channelRepository/observers/observeChannel.ts +0 -109
- package/src/channelRepository/observers/observeChannels.ts +0 -74
- package/src/client/observers/getTotalUnreadCount.ts +0 -53
- package/src/client/observers/tests/getTotalUnreadCount.test.ts +0 -101
- package/src/commentRepository/observers/observeComment.ts +0 -102
- package/src/commentRepository/observers/observeComments.ts +0 -77
- package/src/communityRepository/api/getTopTrendingCommunities.ts +0 -97
- package/src/communityRepository/api/test/getTopTrendingCommunities.test.ts +0 -102
- package/src/communityRepository/observers/observeCommunity.ts +0 -103
- package/src/feedRepository/internalApi/getCustomRankingGlobalFeed.ts +0 -87
- package/src/feedRepository/internalApi/index.ts +0 -2
- package/src/feedRepository/internalApi/queryGlobalFeed.ts +0 -95
- package/src/feedRepository/internalApi/test/getCustomRankingGlobalFeed.test.ts +0 -138
- package/src/feedRepository/internalApi/test/queryGlobalFeed.test.ts +0 -130
- package/src/fileRepository/api/createFile.ts +0 -59
- package/src/fileRepository/api/createImage.ts +0 -59
- package/src/fileRepository/api/createVideo.ts +0 -69
- package/src/fileRepository/observers/index.ts +0 -1
- package/src/fileRepository/observers/observeFile.ts +0 -49
- package/src/messageRepository/api/getMessage.ts +0 -102
- package/src/messageRepository/api/getMessages.ts +0 -83
- package/src/messageRepository/observers/observeMessage.ts +0 -94
- package/src/messageRepository/observers/observeMessages.ts +0 -89
- package/src/pollRepository/observers/observePoll.ts +0 -67
- package/src/postRepository/api/updatePost.ts +0 -63
- package/src/postRepository/observers/observePost.ts +0 -115
- package/src/postRepository/observers/observePosts.ts +0 -86
- package/src/streamRepository/api/queryStreams.ts +0 -63
- package/src/userRepository/observers/getViewedUsers.ts +0 -99
- package/src/userRepository/observers/observeUser.ts +0 -71
- package/src/userRepository/observers/tests/getViewedUsers.test.ts +0 -39
- package/src/userRepository/relationship/block/observers/getBlockedUsers.ts +0 -13
- package/src/userRepository/relationship/block/observers/index.ts +0 -1
- package/src/userRepository/relationship/follow/api/acceptFollower.ts +0 -40
- package/src/userRepository/relationship/follow/api/declineFollower.ts +0 -40
- package/src/userRepository/relationship/follow/observers/observeFollowInfo.ts +0 -64
- package/src/userRepository/relationship/follow/observers/observeFollowers.ts +0 -74
- package/src/userRepository/relationship/follow/observers/observeFollowings.ts +0 -74
- /package/dist/streamRepository/{api → internalApi}/getStream.d.ts +0 -0
- /package/src/streamRepository/{api → internalApi}/getStream.ts +0 -0
|
@@ -1,97 +0,0 @@
|
|
|
1
|
-
import { getActiveClient } from '~/client/api';
|
|
2
|
-
|
|
3
|
-
import { getResolver } from '~/core/model';
|
|
4
|
-
import { pullFromCache, pushToCache } from '~/cache/api';
|
|
5
|
-
import { ingestInCache } from '~/cache/api/ingestInCache';
|
|
6
|
-
|
|
7
|
-
import { prepareCommunityPayload } from '../utils';
|
|
8
|
-
|
|
9
|
-
/* begin_public_function
|
|
10
|
-
id: community.query.trending_communities
|
|
11
|
-
*/
|
|
12
|
-
/**
|
|
13
|
-
* @deprecated This API renamed to `getTrendingCommunities()`.
|
|
14
|
-
* Please use getTrendingCommunities() instead.
|
|
15
|
-
*
|
|
16
|
-
* ```js
|
|
17
|
-
* import { CommunityRepository } from '@amityco/ts-sdk-react-native'
|
|
18
|
-
* const trendingCommunities = await CommunityRepository.getTrendingCommunities()
|
|
19
|
-
* ```
|
|
20
|
-
*
|
|
21
|
-
* Gets a list of top trending {@link Amity.Community} objects
|
|
22
|
-
*
|
|
23
|
-
* @param query The query parameters
|
|
24
|
-
* @returns A list of {@link Amity.Community} objects
|
|
25
|
-
*
|
|
26
|
-
* @category Community API
|
|
27
|
-
* @async
|
|
28
|
-
*/
|
|
29
|
-
export const getTopTrendingCommunities = async (
|
|
30
|
-
query?: Partial<Amity.PageLimit>,
|
|
31
|
-
): Promise<Amity.Cached<Amity.Community[]>> => {
|
|
32
|
-
const client = getActiveClient();
|
|
33
|
-
client.log('channel/getTopTrendingCommunities', query);
|
|
34
|
-
|
|
35
|
-
const { limit = 5 } = query ?? {};
|
|
36
|
-
|
|
37
|
-
// API-FIX: backend doesnt answer Amity.Response
|
|
38
|
-
// const { data } = await client.http.get<Amity.Response<CommunityPayload>>(
|
|
39
|
-
const { data: payload } = await client.http.get<Amity.CommunityPayload>(
|
|
40
|
-
`/api/v3/communities/top-trending`,
|
|
41
|
-
{ params: { options: { limit } } },
|
|
42
|
-
);
|
|
43
|
-
|
|
44
|
-
const data = prepareCommunityPayload(payload);
|
|
45
|
-
const { communities } = data;
|
|
46
|
-
|
|
47
|
-
const cachedAt = client.cache && Date.now();
|
|
48
|
-
|
|
49
|
-
if (client.cache) {
|
|
50
|
-
ingestInCache(data, { cachedAt });
|
|
51
|
-
|
|
52
|
-
const cacheKey = ['community', 'top-trending', { params: { options: { limit } } }];
|
|
53
|
-
pushToCache(cacheKey, { communities: communities.map(getResolver('community')) });
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
return { data: communities, cachedAt };
|
|
57
|
-
};
|
|
58
|
-
/* end_public_function */
|
|
59
|
-
|
|
60
|
-
/**
|
|
61
|
-
* ```js
|
|
62
|
-
* import { getTopTrendingCommunities } from '@amityco/ts-sdk-react-native'
|
|
63
|
-
* const communities = getTopTrendingCommunities.locally()
|
|
64
|
-
* ```
|
|
65
|
-
*
|
|
66
|
-
* Gets a list of top trending {@link Amity.Community} objects from cache
|
|
67
|
-
*
|
|
68
|
-
* @param query The query parameters
|
|
69
|
-
* @returns communities
|
|
70
|
-
*
|
|
71
|
-
* @category Community API
|
|
72
|
-
*/
|
|
73
|
-
getTopTrendingCommunities.locally = (
|
|
74
|
-
query: Parameters<typeof getTopTrendingCommunities>[0],
|
|
75
|
-
): Amity.Cached<Amity.Community[]> | undefined => {
|
|
76
|
-
const client = getActiveClient();
|
|
77
|
-
client.log('community/getTopTrendingCommunities.locally', query);
|
|
78
|
-
|
|
79
|
-
if (!client.cache) return;
|
|
80
|
-
|
|
81
|
-
const { limit = 5 } = query ?? {};
|
|
82
|
-
|
|
83
|
-
const queryKey = ['community', 'top-trending', { params: { options: { limit } } }];
|
|
84
|
-
const { data, cachedAt } =
|
|
85
|
-
pullFromCache<{ communities: Pick<Amity.Community, 'communityId'>[] }>(queryKey) ?? {};
|
|
86
|
-
|
|
87
|
-
if (!data?.communities.length) return;
|
|
88
|
-
|
|
89
|
-
const communities: Amity.Community[] = data.communities
|
|
90
|
-
.map(communityId => pullFromCache<Amity.Community>(['community', 'get', communityId])!)
|
|
91
|
-
.filter(Boolean)
|
|
92
|
-
.map(({ data }) => data);
|
|
93
|
-
|
|
94
|
-
return communities.length === data?.communities?.length
|
|
95
|
-
? { data: communities, cachedAt }
|
|
96
|
-
: undefined;
|
|
97
|
-
};
|
|
@@ -1,102 +0,0 @@
|
|
|
1
|
-
import { disableCache, enableCache, pullFromCache, pushToCache } from '~/cache/api';
|
|
2
|
-
import { client, community11, community21 } from '~/utils/tests';
|
|
3
|
-
|
|
4
|
-
import { getTopTrendingCommunities } from '../getTopTrendingCommunities';
|
|
5
|
-
|
|
6
|
-
const topTrendCommunities = [community11, community21];
|
|
7
|
-
const topTrendIds = topTrendCommunities.map(({ communityId }) => communityId);
|
|
8
|
-
|
|
9
|
-
const pagingToken = {
|
|
10
|
-
previous: 'eyJiZWZvcmUiOjU1LCJsYXN0IjoxMH0=',
|
|
11
|
-
next: 'eyJiZWZvcmUiOjU1LCJsYXN0IjoxMH0=',
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
const pagingCriteria = { limit: 10 };
|
|
15
|
-
|
|
16
|
-
const resolvedGetValue = {
|
|
17
|
-
data: {
|
|
18
|
-
communities: topTrendCommunities,
|
|
19
|
-
communityUsers: [community11, community21],
|
|
20
|
-
files: [],
|
|
21
|
-
users: [],
|
|
22
|
-
categories: [],
|
|
23
|
-
feeds: [],
|
|
24
|
-
paging: pagingToken,
|
|
25
|
-
},
|
|
26
|
-
};
|
|
27
|
-
|
|
28
|
-
describe('getTopTrendingCommunities', () => {
|
|
29
|
-
test('should return fetched top trend communities with correct paging', async () => {
|
|
30
|
-
client.http.get = jest.fn().mockResolvedValueOnce(resolvedGetValue);
|
|
31
|
-
|
|
32
|
-
await expect(getTopTrendingCommunities(pagingCriteria)).resolves.toEqual(
|
|
33
|
-
expect.objectContaining({ data: topTrendCommunities }),
|
|
34
|
-
);
|
|
35
|
-
});
|
|
36
|
-
|
|
37
|
-
test('should update cache after fetching top trend communities', async () => {
|
|
38
|
-
enableCache();
|
|
39
|
-
client.http.get = jest.fn().mockResolvedValue(resolvedGetValue);
|
|
40
|
-
|
|
41
|
-
await getTopTrendingCommunities(pagingCriteria);
|
|
42
|
-
|
|
43
|
-
const recieved = pullFromCache([
|
|
44
|
-
'community',
|
|
45
|
-
'top-trending',
|
|
46
|
-
{ params: { options: pagingCriteria } },
|
|
47
|
-
])?.data;
|
|
48
|
-
|
|
49
|
-
expect(recieved).toEqual({ communities: topTrendIds });
|
|
50
|
-
|
|
51
|
-
disableCache();
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
test('should throw an error if request fails', async () => {
|
|
55
|
-
client.http.get = jest.fn().mockRejectedValueOnce(new Error('error'));
|
|
56
|
-
|
|
57
|
-
await expect(getTopTrendingCommunities(pagingCriteria)).rejects.toThrow('error');
|
|
58
|
-
});
|
|
59
|
-
});
|
|
60
|
-
|
|
61
|
-
describe('getTopTrendingCommunities.locally', () => {
|
|
62
|
-
beforeEach(() => enableCache());
|
|
63
|
-
afterEach(() => disableCache());
|
|
64
|
-
|
|
65
|
-
test('should return cached top trend communities', () => {
|
|
66
|
-
topTrendCommunities.forEach(community =>
|
|
67
|
-
pushToCache(['community', 'get', community.communityId], community),
|
|
68
|
-
);
|
|
69
|
-
|
|
70
|
-
pushToCache(['community', 'top-trending', { params: { options: pagingCriteria } }], {
|
|
71
|
-
communities: topTrendIds,
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
expect(getTopTrendingCommunities.locally(pagingCriteria)?.data).toEqual(topTrendCommunities);
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
test('it should return undefined if top trend communities not in cache', () => {
|
|
78
|
-
topTrendCommunities.forEach(community =>
|
|
79
|
-
pushToCache(['community', 'get', community.communityId], community),
|
|
80
|
-
);
|
|
81
|
-
|
|
82
|
-
pushToCache(['community', 'top-trending', { params: { options: pagingCriteria } }], {
|
|
83
|
-
communities: topTrendIds,
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
expect(getTopTrendingCommunities.locally({ limit: -1 })).toBeUndefined();
|
|
87
|
-
});
|
|
88
|
-
|
|
89
|
-
test('should return undefined if cache not enabled', () => {
|
|
90
|
-
disableCache();
|
|
91
|
-
|
|
92
|
-
topTrendCommunities.forEach(community =>
|
|
93
|
-
pushToCache(['community', 'get', community.communityId], community),
|
|
94
|
-
);
|
|
95
|
-
|
|
96
|
-
pushToCache(['community', 'top-trending', { params: { options: pagingCriteria } }], {
|
|
97
|
-
communities: topTrendIds,
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
expect(getTopTrendingCommunities.locally(pagingCriteria)).toBeUndefined();
|
|
101
|
-
});
|
|
102
|
-
});
|
|
@@ -1,103 +0,0 @@
|
|
|
1
|
-
import { createQuery, runQuery } from '~/core/query/query';
|
|
2
|
-
|
|
3
|
-
import { getActiveClient } from '~/client/api';
|
|
4
|
-
|
|
5
|
-
import { getCommunity } from '../api/getCommunity';
|
|
6
|
-
|
|
7
|
-
import { onCommunityUpdated, onCommunityDeleted } from '../events';
|
|
8
|
-
import {
|
|
9
|
-
onCommunityUserAdded,
|
|
10
|
-
onCommunityUserRemoved,
|
|
11
|
-
onCommunityUserBanned,
|
|
12
|
-
onCommunityUserUnbanned,
|
|
13
|
-
onCommunityJoined,
|
|
14
|
-
onCommunityLeft,
|
|
15
|
-
} from '../communityMembership/events';
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* ```js
|
|
19
|
-
* import { observeCommunity } from '@amityco/ts-sdk-react-native'
|
|
20
|
-
*
|
|
21
|
-
* let community = {}
|
|
22
|
-
* const dispose = observeCommunity(communityId, updated => community = updated)
|
|
23
|
-
* ```
|
|
24
|
-
*
|
|
25
|
-
* Observe all mutation on a given {@link Amity.Community}
|
|
26
|
-
*
|
|
27
|
-
* @param communityId the ID of the community to observe
|
|
28
|
-
* @param callback the function to call when new data are available
|
|
29
|
-
* @returns An {@link Amity.Unsubscriber} function to run when willing to stop observing the community
|
|
30
|
-
*
|
|
31
|
-
* @category Community Observer
|
|
32
|
-
*/
|
|
33
|
-
export const observeCommunity = <
|
|
34
|
-
Events extends [
|
|
35
|
-
'onFetch',
|
|
36
|
-
'onUpdate',
|
|
37
|
-
'onDelete',
|
|
38
|
-
'onJoin',
|
|
39
|
-
'onLeft',
|
|
40
|
-
'onUserAdded',
|
|
41
|
-
'onUserRemoved',
|
|
42
|
-
'onUserBanned',
|
|
43
|
-
'onUserUnbanned',
|
|
44
|
-
],
|
|
45
|
-
>(
|
|
46
|
-
communityId: string,
|
|
47
|
-
callback: Amity.ObjectListener<Amity.Snapshot<Amity.Community | undefined>, Events>,
|
|
48
|
-
): Amity.Unsubscriber => {
|
|
49
|
-
const { log } = getActiveClient();
|
|
50
|
-
|
|
51
|
-
const timestamp = Date.now();
|
|
52
|
-
log(`observeCommunity(tmpid: ${timestamp}) > listen`);
|
|
53
|
-
|
|
54
|
-
// wrapper function to make sure
|
|
55
|
-
const router = (result: Amity.Snapshot<Amity.Community | undefined>, action: Events[number]) => {
|
|
56
|
-
if (callback instanceof Function) return callback(result);
|
|
57
|
-
|
|
58
|
-
if (action !== 'onFetch') callback.onEvent?.(action, result);
|
|
59
|
-
|
|
60
|
-
callback[action]?.(result);
|
|
61
|
-
};
|
|
62
|
-
|
|
63
|
-
const realtimeRouter = (result: Amity.Snapshot<Amity.Community>, action: Events[number]) => {
|
|
64
|
-
if (result.data?.communityId !== communityId) return;
|
|
65
|
-
|
|
66
|
-
router(result, action);
|
|
67
|
-
};
|
|
68
|
-
|
|
69
|
-
const disposers: Amity.Unsubscriber[] = [];
|
|
70
|
-
|
|
71
|
-
disposers.push(
|
|
72
|
-
onCommunityUpdated(data =>
|
|
73
|
-
realtimeRouter({ data, loading: false, origin: 'event' }, 'onUpdate'),
|
|
74
|
-
),
|
|
75
|
-
onCommunityDeleted(data =>
|
|
76
|
-
realtimeRouter({ data, loading: false, origin: 'event' }, 'onDelete'),
|
|
77
|
-
),
|
|
78
|
-
onCommunityJoined(data => realtimeRouter({ data, loading: false, origin: 'event' }, 'onJoin')),
|
|
79
|
-
onCommunityLeft(data => realtimeRouter({ data, loading: false, origin: 'event' }, 'onLeft')),
|
|
80
|
-
onCommunityUserAdded(data =>
|
|
81
|
-
realtimeRouter({ data, loading: false, origin: 'event' }, 'onUserAdded'),
|
|
82
|
-
),
|
|
83
|
-
onCommunityUserRemoved(data =>
|
|
84
|
-
realtimeRouter({ data, loading: false, origin: 'event' }, 'onUserRemoved'),
|
|
85
|
-
),
|
|
86
|
-
onCommunityUserBanned(data =>
|
|
87
|
-
realtimeRouter({ data, loading: false, origin: 'event' }, 'onUserBanned'),
|
|
88
|
-
),
|
|
89
|
-
onCommunityUserUnbanned(data =>
|
|
90
|
-
realtimeRouter({ data, loading: false, origin: 'event' }, 'onUserUnbanned'),
|
|
91
|
-
),
|
|
92
|
-
);
|
|
93
|
-
|
|
94
|
-
runQuery(
|
|
95
|
-
createQuery(getCommunity, communityId),
|
|
96
|
-
result => (result.data || result.error) && router(result, 'onFetch'),
|
|
97
|
-
);
|
|
98
|
-
|
|
99
|
-
return () => {
|
|
100
|
-
log(`observeCommunity(tmpid: ${timestamp}) > dispose`);
|
|
101
|
-
disposers.forEach(fn => fn());
|
|
102
|
-
};
|
|
103
|
-
};
|
|
@@ -1,87 +0,0 @@
|
|
|
1
|
-
import { getActiveClient } from '~/client/api/activeClient';
|
|
2
|
-
|
|
3
|
-
import { toPage, toToken } from '~/core/query';
|
|
4
|
-
import { ingestInCache } from '~/cache/api/ingestInCache';
|
|
5
|
-
import { pullFromCache, pushToCache } from '~/cache/api';
|
|
6
|
-
import { getResolver } from '~/core/model';
|
|
7
|
-
import { prepareMembershipPayload } from '~/group/utils';
|
|
8
|
-
|
|
9
|
-
export const getCustomRankingGlobalFeed = async (query?: {
|
|
10
|
-
dataTypes?: ('video' | 'image' | 'file' | 'liveStream')[];
|
|
11
|
-
page?: Amity.Page;
|
|
12
|
-
}): Promise<Amity.Cached<Amity.Paged<Amity.InternalPost>>> => {
|
|
13
|
-
const client = getActiveClient();
|
|
14
|
-
client.log('feed/getCustomRankingGlobalFeed', query);
|
|
15
|
-
|
|
16
|
-
const { page, ...params } = query ?? {};
|
|
17
|
-
|
|
18
|
-
const { data: queryPayload } = await client.http.get<Amity.PostPayload & Amity.Pagination>(
|
|
19
|
-
`/api/v5/me/global-feeds`,
|
|
20
|
-
{
|
|
21
|
-
params: {
|
|
22
|
-
...params,
|
|
23
|
-
options: {
|
|
24
|
-
token: toToken(page, 'skiplimit'),
|
|
25
|
-
},
|
|
26
|
-
},
|
|
27
|
-
},
|
|
28
|
-
);
|
|
29
|
-
|
|
30
|
-
const { paging, ...payload } = queryPayload;
|
|
31
|
-
|
|
32
|
-
const data = prepareMembershipPayload(payload, 'communityUsers');
|
|
33
|
-
|
|
34
|
-
const { posts } = data;
|
|
35
|
-
|
|
36
|
-
const cachedAt = client.cache && Date.now();
|
|
37
|
-
|
|
38
|
-
if (client.cache) {
|
|
39
|
-
ingestInCache(data);
|
|
40
|
-
|
|
41
|
-
const cacheKey = [
|
|
42
|
-
'customGlobalFeed',
|
|
43
|
-
'query',
|
|
44
|
-
{ ...params, options: { ...page } } as Amity.Serializable,
|
|
45
|
-
];
|
|
46
|
-
pushToCache(cacheKey, { posts: posts.map(getResolver('post')), paging });
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
const nextPage = toPage(paging.next);
|
|
50
|
-
const prevPage = toPage(paging.previous);
|
|
51
|
-
|
|
52
|
-
return { data: posts, cachedAt, prevPage, nextPage };
|
|
53
|
-
};
|
|
54
|
-
|
|
55
|
-
getCustomRankingGlobalFeed.locally = (
|
|
56
|
-
query?: Parameters<typeof getCustomRankingGlobalFeed>[0],
|
|
57
|
-
): Amity.Cached<Amity.Paged<Amity.InternalPost>> | undefined => {
|
|
58
|
-
const client = getActiveClient();
|
|
59
|
-
client.log('post/getCustomRankingGlobalFeed.locally', query);
|
|
60
|
-
|
|
61
|
-
if (!client.cache) return;
|
|
62
|
-
|
|
63
|
-
const { page, ...params } = query ?? {};
|
|
64
|
-
|
|
65
|
-
const queryKey = [
|
|
66
|
-
'customGlobalFeed',
|
|
67
|
-
'query',
|
|
68
|
-
{ ...params, options: { ...page } } as Amity.Serializable,
|
|
69
|
-
];
|
|
70
|
-
|
|
71
|
-
const { data, cachedAt } =
|
|
72
|
-
pullFromCache<{ posts: Amity.InternalPost['postId'][] } & Amity.Pagination>(queryKey) ?? {};
|
|
73
|
-
|
|
74
|
-
if (!data?.posts.length) return;
|
|
75
|
-
|
|
76
|
-
const posts: Amity.InternalPost[] = data.posts
|
|
77
|
-
.map(postId => pullFromCache<Amity.InternalPost>(['post', 'get', postId])!)
|
|
78
|
-
.filter(Boolean)
|
|
79
|
-
.map(({ data }) => data);
|
|
80
|
-
|
|
81
|
-
const prevPage = toPage(data?.paging.previous);
|
|
82
|
-
const nextPage = toPage(data?.paging.next);
|
|
83
|
-
|
|
84
|
-
return posts.length === data?.posts?.length
|
|
85
|
-
? { data: posts, cachedAt, prevPage, nextPage }
|
|
86
|
-
: undefined;
|
|
87
|
-
};
|
|
@@ -1,95 +0,0 @@
|
|
|
1
|
-
import { getActiveClient } from '~/client/api/activeClient';
|
|
2
|
-
|
|
3
|
-
import { toPage, toToken } from '~/core/query';
|
|
4
|
-
import { ingestInCache } from '~/cache/api/ingestInCache';
|
|
5
|
-
import { pullFromCache, pushToCache } from '~/cache/api';
|
|
6
|
-
import { getResolver } from '~/core/model';
|
|
7
|
-
import { prepareMembershipPayload } from '~/group/utils';
|
|
8
|
-
|
|
9
|
-
export const queryGlobalFeed = async (query?: {
|
|
10
|
-
dataTypes?: ('video' | 'image' | 'file' | 'liveStream')[];
|
|
11
|
-
useCustomRanking?: boolean;
|
|
12
|
-
page?: Amity.Page;
|
|
13
|
-
}): Promise<Amity.Cached<Amity.Paged<Amity.InternalPost>>> => {
|
|
14
|
-
const client = getActiveClient();
|
|
15
|
-
client.log('feed/queryGlobalFeed', query);
|
|
16
|
-
|
|
17
|
-
const { useCustomRanking, page, ...params } = query ?? {};
|
|
18
|
-
|
|
19
|
-
/*
|
|
20
|
-
* TODO: Remove useCustomRanking key from query
|
|
21
|
-
*/
|
|
22
|
-
if (useCustomRanking)
|
|
23
|
-
console.warn(
|
|
24
|
-
'The param "useCustomRanking" has been deprecated. To get custom ranking feed use FeedRepository.getCustomRankingGlobalFeed instead',
|
|
25
|
-
);
|
|
26
|
-
|
|
27
|
-
const { data: queryPayload } = await client.http.get<Amity.PostPayload & Amity.Pagination>(
|
|
28
|
-
`/api/v4/me/global-feeds`,
|
|
29
|
-
{
|
|
30
|
-
params: {
|
|
31
|
-
...params,
|
|
32
|
-
options: {
|
|
33
|
-
token: toToken(page, 'skiplimit'),
|
|
34
|
-
},
|
|
35
|
-
},
|
|
36
|
-
},
|
|
37
|
-
);
|
|
38
|
-
|
|
39
|
-
const { paging, ...payload } = queryPayload;
|
|
40
|
-
|
|
41
|
-
const data = prepareMembershipPayload(payload, 'communityUsers');
|
|
42
|
-
|
|
43
|
-
const { posts } = data;
|
|
44
|
-
|
|
45
|
-
const cachedAt = client.cache && Date.now();
|
|
46
|
-
|
|
47
|
-
if (client.cache) {
|
|
48
|
-
ingestInCache(data);
|
|
49
|
-
|
|
50
|
-
const cacheKey = [
|
|
51
|
-
'globalFeed',
|
|
52
|
-
'query',
|
|
53
|
-
{ ...params, options: { ...page } } as Amity.Serializable,
|
|
54
|
-
];
|
|
55
|
-
pushToCache(cacheKey, { posts: posts.map(getResolver('post')), paging });
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
const nextPage = toPage(paging.next);
|
|
59
|
-
const prevPage = toPage(paging.previous);
|
|
60
|
-
|
|
61
|
-
return { data: posts, cachedAt, prevPage, nextPage };
|
|
62
|
-
};
|
|
63
|
-
|
|
64
|
-
queryGlobalFeed.locally = (
|
|
65
|
-
query?: Parameters<typeof queryGlobalFeed>[0],
|
|
66
|
-
): Amity.Cached<Amity.Paged<Amity.InternalPost>> | undefined => {
|
|
67
|
-
const client = getActiveClient();
|
|
68
|
-
client.log('post/queryGlobalFeed.locally', query);
|
|
69
|
-
|
|
70
|
-
if (!client.cache) return;
|
|
71
|
-
|
|
72
|
-
const { page, ...params } = query ?? {};
|
|
73
|
-
|
|
74
|
-
const queryKey = [
|
|
75
|
-
'globalFeed',
|
|
76
|
-
'query',
|
|
77
|
-
{ ...params, options: { ...page } } as Amity.Serializable,
|
|
78
|
-
];
|
|
79
|
-
const { data, cachedAt } =
|
|
80
|
-
pullFromCache<{ posts: Amity.InternalPost['postId'][] } & Amity.Pagination>(queryKey) ?? {};
|
|
81
|
-
|
|
82
|
-
if (!data?.posts.length) return;
|
|
83
|
-
|
|
84
|
-
const posts: Amity.InternalPost[] = data.posts
|
|
85
|
-
.map(postId => pullFromCache<Amity.InternalPost>(['post', 'get', postId])!)
|
|
86
|
-
.filter(Boolean)
|
|
87
|
-
.map(({ data }) => data);
|
|
88
|
-
|
|
89
|
-
const prevPage = toPage(data?.paging.previous);
|
|
90
|
-
const nextPage = toPage(data?.paging.next);
|
|
91
|
-
|
|
92
|
-
return posts.length === data?.posts?.length
|
|
93
|
-
? { data: posts, cachedAt, prevPage, nextPage }
|
|
94
|
-
: undefined;
|
|
95
|
-
};
|
|
@@ -1,138 +0,0 @@
|
|
|
1
|
-
import { disableCache, enableCache, pullFromCache, pushToCache } from '~/cache/api';
|
|
2
|
-
|
|
3
|
-
import { client, deepCopy, post11, post12, user11 } from '~/utils/tests';
|
|
4
|
-
|
|
5
|
-
import { getCustomRankingGlobalFeed } from '../getCustomRankingGlobalFeed';
|
|
6
|
-
|
|
7
|
-
const pagingToken = {
|
|
8
|
-
previous: 'eyJiZWZvcmUiOjU1LCJsYXN0IjoxMH0=',
|
|
9
|
-
next: 'eyJiZWZvcmUiOjU1LCJsYXN0IjoxMH0=',
|
|
10
|
-
};
|
|
11
|
-
|
|
12
|
-
const postsToQuery = [post11, post12];
|
|
13
|
-
const postIdsToQuery = postsToQuery.map(post => post.postId);
|
|
14
|
-
const pagingCriteria = { limit: 10 };
|
|
15
|
-
const queryCriteriaWithoutPage = {};
|
|
16
|
-
const queryCriteria = { ...queryCriteriaWithoutPage, page: pagingCriteria };
|
|
17
|
-
|
|
18
|
-
const resolvedQueryFeedValue = {
|
|
19
|
-
data: {
|
|
20
|
-
posts: postsToQuery,
|
|
21
|
-
postChildren: [],
|
|
22
|
-
categories: [],
|
|
23
|
-
comments: [],
|
|
24
|
-
communityUsers: [],
|
|
25
|
-
feeds: [],
|
|
26
|
-
files: [],
|
|
27
|
-
polls: [],
|
|
28
|
-
users: [user11],
|
|
29
|
-
paging: pagingToken,
|
|
30
|
-
},
|
|
31
|
-
};
|
|
32
|
-
|
|
33
|
-
describe('getCustomRankingGlobalFeed', () => {
|
|
34
|
-
test('it should return fetched feed with correct paging', async () => {
|
|
35
|
-
client.http.get = jest.fn().mockResolvedValueOnce(resolvedQueryFeedValue);
|
|
36
|
-
|
|
37
|
-
const result = await getCustomRankingGlobalFeed(queryCriteria);
|
|
38
|
-
|
|
39
|
-
expect(deepCopy(result)).toEqual(
|
|
40
|
-
expect.objectContaining(
|
|
41
|
-
deepCopy({
|
|
42
|
-
data: postsToQuery,
|
|
43
|
-
prevPage: { before: 55, limit: 10 },
|
|
44
|
-
nextPage: { before: 55, limit: 10 },
|
|
45
|
-
}),
|
|
46
|
-
),
|
|
47
|
-
);
|
|
48
|
-
});
|
|
49
|
-
|
|
50
|
-
test('it should update cache after fetching feed', async () => {
|
|
51
|
-
enableCache();
|
|
52
|
-
client.http.get = jest.fn().mockResolvedValue(resolvedQueryFeedValue);
|
|
53
|
-
|
|
54
|
-
await getCustomRankingGlobalFeed(queryCriteria);
|
|
55
|
-
|
|
56
|
-
const recieved = pullFromCache([
|
|
57
|
-
'customGlobalFeed',
|
|
58
|
-
'query',
|
|
59
|
-
{ ...queryCriteriaWithoutPage, options: pagingCriteria },
|
|
60
|
-
])?.data;
|
|
61
|
-
|
|
62
|
-
expect(recieved).toEqual({
|
|
63
|
-
posts: postIdsToQuery,
|
|
64
|
-
paging: pagingToken,
|
|
65
|
-
});
|
|
66
|
-
|
|
67
|
-
disableCache();
|
|
68
|
-
});
|
|
69
|
-
|
|
70
|
-
test('it should call the correct api', async () => {
|
|
71
|
-
const resolver = jest.fn().mockResolvedValue(resolvedQueryFeedValue);
|
|
72
|
-
client.http.get = resolver;
|
|
73
|
-
|
|
74
|
-
await getCustomRankingGlobalFeed(queryCriteria);
|
|
75
|
-
|
|
76
|
-
expect(resolver).toHaveBeenCalledWith(`/api/v5/me/global-feeds`, expect.any(Object));
|
|
77
|
-
});
|
|
78
|
-
|
|
79
|
-
test('it should throw an error if request fails', async () => {
|
|
80
|
-
client.http.get = jest.fn().mockRejectedValueOnce(new Error('error'));
|
|
81
|
-
|
|
82
|
-
await expect(getCustomRankingGlobalFeed(queryCriteria)).rejects.toThrow('error');
|
|
83
|
-
});
|
|
84
|
-
});
|
|
85
|
-
|
|
86
|
-
describe('getCustomRankingGlobalFeed.locally', () => {
|
|
87
|
-
beforeEach(enableCache);
|
|
88
|
-
afterEach(disableCache);
|
|
89
|
-
|
|
90
|
-
test('it should return cached feed', () => {
|
|
91
|
-
postsToQuery.forEach(post => pushToCache(['post', 'get', post.postId], post));
|
|
92
|
-
|
|
93
|
-
pushToCache(
|
|
94
|
-
['customGlobalFeed', 'query', { ...queryCriteriaWithoutPage, options: pagingCriteria }],
|
|
95
|
-
{
|
|
96
|
-
posts: postIdsToQuery,
|
|
97
|
-
paging: pagingToken,
|
|
98
|
-
},
|
|
99
|
-
);
|
|
100
|
-
|
|
101
|
-
pushToCache(['user', 'get', user11.userId], user11);
|
|
102
|
-
|
|
103
|
-
expect(deepCopy(getCustomRankingGlobalFeed.locally(queryCriteria))).toEqual(
|
|
104
|
-
expect.objectContaining(
|
|
105
|
-
deepCopy({
|
|
106
|
-
data: postsToQuery,
|
|
107
|
-
prevPage: { before: 55, limit: 10 },
|
|
108
|
-
nextPage: { before: 55, limit: 10 },
|
|
109
|
-
}),
|
|
110
|
-
),
|
|
111
|
-
);
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
test('it should accept undefined query param', async () => {
|
|
115
|
-
client.http.get = jest.fn().mockResolvedValueOnce(resolvedQueryFeedValue);
|
|
116
|
-
|
|
117
|
-
expect(() => getCustomRankingGlobalFeed.locally()).not.toThrow();
|
|
118
|
-
});
|
|
119
|
-
|
|
120
|
-
test(`it shouldn't return if individual feed cache not exist`, () => {
|
|
121
|
-
pushToCache(['globalFeed', 'query', { ...queryCriteriaWithoutPage, options: pagingCriteria }], {
|
|
122
|
-
posts: postIdsToQuery,
|
|
123
|
-
paging: pagingToken,
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
expect(getCustomRankingGlobalFeed.locally(queryCriteria)).toBeUndefined();
|
|
127
|
-
});
|
|
128
|
-
|
|
129
|
-
test('it should return undefined if feed not in cache', () => {
|
|
130
|
-
expect(getCustomRankingGlobalFeed.locally({})).toBeUndefined();
|
|
131
|
-
});
|
|
132
|
-
|
|
133
|
-
test('it should return undefined if cache disabled', () => {
|
|
134
|
-
disableCache();
|
|
135
|
-
|
|
136
|
-
expect(getCustomRankingGlobalFeed.locally({})).toBeUndefined();
|
|
137
|
-
});
|
|
138
|
-
});
|