@amityco/ts-sdk-react-native 6.29.3-669217e.0 → 6.30.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 +41 -11
- package/dist/@types/core/events.d.ts.map +1 -1
- package/dist/@types/core/model.d.ts +4 -0
- package/dist/@types/core/model.d.ts.map +1 -1
- package/dist/@types/core/payload.d.ts +32 -7
- package/dist/@types/core/payload.d.ts.map +1 -1
- package/dist/@types/core/permissions.d.ts +4 -4
- package/dist/@types/core/permissions.d.ts.map +1 -1
- package/dist/@types/domains/channel.d.ts +8 -0
- package/dist/@types/domains/channel.d.ts.map +1 -1
- package/dist/@types/domains/comment.d.ts +5 -4
- package/dist/@types/domains/comment.d.ts.map +1 -1
- package/dist/@types/domains/community.d.ts +32 -8
- package/dist/@types/domains/community.d.ts.map +1 -1
- package/dist/@types/domains/follow.d.ts +21 -3
- package/dist/@types/domains/follow.d.ts.map +1 -1
- package/dist/@types/domains/group.d.ts +13 -7
- package/dist/@types/domains/group.d.ts.map +1 -1
- package/dist/@types/domains/pin.d.ts +22 -0
- package/dist/@types/domains/pin.d.ts.map +1 -0
- package/dist/@types/domains/pinnedPost.d.ts +28 -0
- package/dist/@types/domains/pinnedPost.d.ts.map +1 -0
- package/dist/@types/domains/poll.d.ts +3 -1
- package/dist/@types/domains/poll.d.ts.map +1 -1
- package/dist/@types/domains/post.d.ts +8 -5
- package/dist/@types/domains/post.d.ts.map +1 -1
- package/dist/@types/domains/stream.d.ts +2 -1
- package/dist/@types/domains/stream.d.ts.map +1 -1
- package/dist/@types/domains/user.d.ts +34 -6
- package/dist/@types/domains/user.d.ts.map +1 -1
- package/dist/channelRepository/channelMembership/observers/getMembers/ChannelMemberLiveCollectionController.d.ts.map +1 -1
- package/dist/channelRepository/channelMembership/observers/getMembers/ChannelMemberPaginationController.d.ts +3 -2
- package/dist/channelRepository/channelMembership/observers/getMembers/ChannelMemberPaginationController.d.ts.map +1 -1
- package/dist/channelRepository/channelMembership/observers/searchMembers/SearchChannelMemberLiveCollectionController.d.ts +14 -0
- package/dist/channelRepository/channelMembership/observers/searchMembers/SearchChannelMemberLiveCollectionController.d.ts.map +1 -0
- package/dist/channelRepository/channelMembership/observers/searchMembers/SearchChannelMemberPaginationController.d.ts +14 -0
- package/dist/channelRepository/channelMembership/observers/searchMembers/SearchChannelMemberPaginationController.d.ts.map +1 -0
- package/dist/channelRepository/channelMembership/observers/searchMembers/SearchChannelMemberQueryStreamController.d.ts +14 -0
- package/dist/channelRepository/channelMembership/observers/searchMembers/SearchChannelMemberQueryStreamController.d.ts.map +1 -0
- package/dist/channelRepository/channelMembership/observers/searchMembers/index.d.ts +2 -0
- package/dist/channelRepository/channelMembership/observers/searchMembers/index.d.ts.map +1 -0
- package/dist/channelRepository/channelMembership/observers/searchMembers/searchMembers.d.ts +21 -0
- package/dist/channelRepository/channelMembership/observers/searchMembers/searchMembers.d.ts.map +1 -0
- package/dist/channelRepository/events/onUserDeleted.d.ts +2 -0
- package/dist/channelRepository/events/onUserDeleted.d.ts.map +1 -0
- package/dist/channelRepository/observers/getChannels/ChannelPaginationController.d.ts +3 -3
- package/dist/channelRepository/utils/prepareChannelPayload.d.ts.map +1 -1
- package/dist/channelRepository/utils/tests/prepareChannelPayload.test.d.ts +1 -1
- package/dist/channelRepository/utils/tests/prepareChannelPayload.test.d.ts.map +1 -1
- package/dist/client/api/index.d.ts +0 -2
- package/dist/client/api/index.d.ts.map +1 -1
- package/dist/commentRepository/api/createComment.d.ts.map +1 -1
- package/dist/commentRepository/api/deleteComment.d.ts.map +1 -1
- package/dist/commentRepository/events/onCommentCreatedLocal.d.ts +17 -0
- package/dist/commentRepository/events/onCommentCreatedLocal.d.ts.map +1 -0
- package/dist/commentRepository/events/onCommentDeletedLocal.d.ts +17 -0
- package/dist/commentRepository/events/onCommentDeletedLocal.d.ts.map +1 -0
- package/dist/commentRepository/events/onLocalCommentReactionAdded.d.ts +17 -0
- package/dist/commentRepository/events/onLocalCommentReactionAdded.d.ts.map +1 -0
- package/dist/commentRepository/events/onLocalCommentReactionRemoved.d.ts +17 -0
- package/dist/commentRepository/events/onLocalCommentReactionRemoved.d.ts.map +1 -0
- package/dist/commentRepository/events/utils.d.ts +1 -0
- package/dist/commentRepository/events/utils.d.ts.map +1 -1
- package/dist/commentRepository/observers/getComment.d.ts.map +1 -1
- package/dist/commentRepository/observers/getComments/CommentLiveCollectionController.d.ts.map +1 -1
- package/dist/communityRepository/communityMembership/events/index.d.ts +2 -0
- package/dist/communityRepository/communityMembership/events/index.d.ts.map +1 -1
- package/dist/communityRepository/communityMembership/events/onLocalCommunityUserAdded.d.ts +17 -0
- package/dist/communityRepository/communityMembership/events/onLocalCommunityUserAdded.d.ts.map +1 -0
- package/dist/communityRepository/communityMembership/events/onLocalCommunityUserRemoved.d.ts +17 -0
- package/dist/communityRepository/communityMembership/events/onLocalCommunityUserRemoved.d.ts.map +1 -0
- package/dist/communityRepository/communityMembership/events/onUserDeleted.d.ts +17 -0
- package/dist/communityRepository/communityMembership/events/onUserDeleted.d.ts.map +1 -0
- package/dist/communityRepository/communityMembership/events/utils.d.ts +1 -0
- package/dist/communityRepository/communityMembership/events/utils.d.ts.map +1 -1
- package/dist/communityRepository/communityMembership/observers/getMembers/CommunityMembersLiveCollectionController.d.ts.map +1 -1
- package/dist/communityRepository/communityMembership/observers/getMembers/CommunityMembersPaginationController.d.ts.map +1 -1
- package/dist/communityRepository/communityMembership/observers/getMembers/enums.d.ts +4 -1
- package/dist/communityRepository/communityMembership/observers/getMembers/enums.d.ts.map +1 -1
- package/dist/communityRepository/communityMembership/observers/searchMembers/SearchCommunityMembersLiveCollectionController.d.ts.map +1 -1
- package/dist/communityRepository/communityMembership/observers/searchMembers/SearchCommunityMembersPaginationController.d.ts.map +1 -1
- package/dist/communityRepository/communityModeration/api/addRoles.d.ts.map +1 -1
- package/dist/communityRepository/communityModeration/api/removeRoles.d.ts.map +1 -1
- package/dist/communityRepository/communityModeration/events/onLocalCommunityRoleAdded.d.ts +17 -0
- package/dist/communityRepository/communityModeration/events/onLocalCommunityRoleAdded.d.ts.map +1 -0
- package/dist/communityRepository/communityModeration/events/onLocalCommunityRoleRemoved.d.ts +17 -0
- package/dist/communityRepository/communityModeration/events/onLocalCommunityRoleRemoved.d.ts.map +1 -0
- package/dist/communityRepository/utils/payload.d.ts +3 -6
- package/dist/communityRepository/utils/payload.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/model/idResolvers.d.ts.map +1 -1
- package/dist/core/model/index.d.ts.map +1 -1
- package/dist/fileRepository/api/uploadFile.d.ts.map +1 -1
- package/dist/fileRepository/api/uploadImage.d.ts.map +1 -1
- package/dist/fileRepository/api/uploadVideo.d.ts.map +1 -1
- package/dist/group/utils/withUser.d.ts +13 -0
- package/dist/group/utils/withUser.d.ts.map +1 -1
- package/dist/index.cjs.js +2247 -1250
- package/dist/index.esm.js +2435 -1437
- package/dist/index.umd.js +3 -3
- package/dist/pollRepository/observers/observePoll.d.ts +1 -1
- package/dist/pollRepository/observers/observePoll.d.ts.map +1 -1
- package/dist/postRepository/events/onLocalPostDeleted.d.ts +17 -0
- package/dist/postRepository/events/onLocalPostDeleted.d.ts.map +1 -0
- package/dist/postRepository/events/onLocalPostReactionAdded.d.ts +17 -0
- package/dist/postRepository/events/onLocalPostReactionAdded.d.ts.map +1 -0
- package/dist/postRepository/events/onLocalPostReactionRemoved.d.ts +17 -0
- package/dist/postRepository/events/onLocalPostReactionRemoved.d.ts.map +1 -0
- package/dist/postRepository/events/onPostUpdatedLocal.d.ts +17 -0
- package/dist/postRepository/events/onPostUpdatedLocal.d.ts.map +1 -0
- package/dist/postRepository/events/utils.d.ts +1 -0
- package/dist/postRepository/events/utils.d.ts.map +1 -1
- package/dist/postRepository/internalApi/index.d.ts +1 -12
- package/dist/postRepository/internalApi/index.d.ts.map +1 -1
- package/dist/postRepository/observers/getPinnedPosts/PinnedPostLiveCollectionController.d.ts +14 -0
- package/dist/postRepository/observers/getPinnedPosts/PinnedPostLiveCollectionController.d.ts.map +1 -0
- package/dist/postRepository/observers/getPinnedPosts/PinnedPostPaginationController.d.ts +13 -0
- package/dist/postRepository/observers/getPinnedPosts/PinnedPostPaginationController.d.ts.map +1 -0
- package/dist/postRepository/observers/getPinnedPosts/PinnedPostQueryStreamController.d.ts +9 -0
- package/dist/postRepository/observers/getPinnedPosts/PinnedPostQueryStreamController.d.ts.map +1 -0
- package/dist/postRepository/observers/getPinnedPosts.d.ts +12 -0
- package/dist/postRepository/observers/getPinnedPosts.d.ts.map +1 -0
- package/dist/postRepository/observers/getPost.d.ts.map +1 -1
- package/dist/postRepository/observers/getPosts/PostLiveCollectionController.d.ts.map +1 -1
- package/dist/postRepository/observers/index.d.ts +1 -0
- package/dist/postRepository/observers/index.d.ts.map +1 -1
- package/dist/postRepository/utils/payload.d.ts.map +1 -1
- package/dist/reactionRepository/api/addReaction.d.ts.map +1 -1
- package/dist/reactionRepository/api/removeReaction.d.ts.map +1 -1
- package/dist/report/api/createReport.d.ts +1 -2
- package/dist/report/api/createReport.d.ts.map +1 -1
- package/dist/report/api/deleteReport.d.ts +1 -2
- package/dist/report/api/deleteReport.d.ts.map +1 -1
- package/dist/report/api/isReportedByMe.d.ts +1 -2
- package/dist/report/api/isReportedByMe.d.ts.map +1 -1
- package/dist/streamRepository/observers/getStreams/GetStreamsPageController.d.ts +1 -1
- package/dist/userRepository/api/flagUser.d.ts.map +1 -1
- package/dist/userRepository/api/getUser.d.ts.map +1 -1
- package/dist/userRepository/api/getUserByIds.d.ts.map +1 -1
- package/dist/userRepository/api/queryBlockedUsers.d.ts.map +1 -1
- package/dist/userRepository/api/queryUsers.d.ts.map +1 -1
- package/dist/userRepository/api/unflagUser.d.ts.map +1 -1
- package/dist/userRepository/api/updateUser.d.ts.map +1 -1
- package/dist/userRepository/events/utils.d.ts.map +1 -1
- package/dist/userRepository/internalApi/getUser.d.ts.map +1 -1
- package/dist/userRepository/internalApi/queryUsers.d.ts.map +1 -1
- package/dist/userRepository/observers/enums.d.ts +8 -0
- package/dist/userRepository/observers/enums.d.ts.map +1 -0
- package/dist/userRepository/observers/getBlockedUsers/BlockedUserLiveCollectionController.d.ts +14 -0
- package/dist/userRepository/observers/getBlockedUsers/BlockedUserLiveCollectionController.d.ts.map +1 -0
- package/dist/userRepository/observers/getBlockedUsers/BlockedUserPaginationController.d.ts +5 -0
- package/dist/userRepository/observers/getBlockedUsers/BlockedUserPaginationController.d.ts.map +1 -0
- package/dist/userRepository/observers/getBlockedUsers/BlockedUserQueryStreamController.d.ts +15 -0
- package/dist/userRepository/observers/getBlockedUsers/BlockedUserQueryStreamController.d.ts.map +1 -0
- package/dist/userRepository/observers/getBlockedUsers.d.ts.map +1 -1
- package/dist/userRepository/observers/getUsers/UserLiveCollectionController.d.ts +14 -0
- package/dist/userRepository/observers/getUsers/UserLiveCollectionController.d.ts.map +1 -0
- package/dist/userRepository/observers/getUsers/UserPaginationController.d.ts +5 -0
- package/dist/userRepository/observers/getUsers/UserPaginationController.d.ts.map +1 -0
- package/dist/userRepository/observers/getUsers/UserQueryStreamController.d.ts +15 -0
- package/dist/userRepository/observers/getUsers/UserQueryStreamController.d.ts.map +1 -0
- package/dist/userRepository/observers/getUsers.d.ts +0 -1
- package/dist/userRepository/observers/getUsers.d.ts.map +1 -1
- package/dist/userRepository/observers/searchUserByDisplayName/SearchUserLiveCollectionController.d.ts +14 -0
- package/dist/userRepository/observers/searchUserByDisplayName/SearchUserLiveCollectionController.d.ts.map +1 -0
- package/dist/userRepository/observers/searchUserByDisplayName/SearchUserPaginationController.d.ts +5 -0
- package/dist/userRepository/observers/searchUserByDisplayName/SearchUserPaginationController.d.ts.map +1 -0
- package/dist/userRepository/observers/searchUserByDisplayName/SearchUserQueryStreamController.d.ts +15 -0
- package/dist/userRepository/observers/searchUserByDisplayName/SearchUserQueryStreamController.d.ts.map +1 -0
- package/dist/userRepository/observers/searchUserByDisplayName.d.ts.map +1 -1
- package/dist/userRepository/relationship/block/api/blockUser.d.ts.map +1 -1
- package/dist/userRepository/relationship/block/api/unBlockUser.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/api/acceptFollower.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/api/acceptMyFollower.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/api/declineFollower.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/api/declineMyFollower.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/api/follow.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/api/unfollow.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/api/utils.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/enums.d.ts +11 -0
- package/dist/userRepository/relationship/follow/enums.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/events/index.d.ts +5 -0
- package/dist/userRepository/relationship/follow/events/index.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/events/onFollowInfoUpdated.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/events/onFollowerUserDeleted.d.ts +4 -0
- package/dist/userRepository/relationship/follow/events/onFollowerUserDeleted.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/events/onFollowingUserDeleted.d.ts +4 -0
- package/dist/userRepository/relationship/follow/events/onFollowingUserDeleted.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/events/onLocalFollowRequestAccepted.d.ts +2 -0
- package/dist/userRepository/relationship/follow/events/onLocalFollowRequestAccepted.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/events/onLocalFollowRequestDeclined.d.ts +2 -0
- package/dist/userRepository/relationship/follow/events/onLocalFollowRequestDeclined.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/events/onLocalFollowerRequested.d.ts +2 -0
- package/dist/userRepository/relationship/follow/events/onLocalFollowerRequested.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/events/onLocalUserFollowed.d.ts +2 -0
- package/dist/userRepository/relationship/follow/events/onLocalUserFollowed.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/events/onLocalUserUnfollowed.d.ts +2 -0
- package/dist/userRepository/relationship/follow/events/onLocalUserUnfollowed.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/events/utils.d.ts +2 -1
- package/dist/userRepository/relationship/follow/events/utils.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/observers/getFollowers/FollowerLiveCollectionController.d.ts +14 -0
- package/dist/userRepository/relationship/follow/observers/getFollowers/FollowerLiveCollectionController.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/observers/getFollowers/FollowerPaginationController.d.ts +5 -0
- package/dist/userRepository/relationship/follow/observers/getFollowers/FollowerPaginationController.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/observers/getFollowers/FollowerQueryStreamController.d.ts +15 -0
- package/dist/userRepository/relationship/follow/observers/getFollowers/FollowerQueryStreamController.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/observers/getFollowers.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/observers/getFollowings/FollowingLiveCollectionController.d.ts +14 -0
- package/dist/userRepository/relationship/follow/observers/getFollowings/FollowingLiveCollectionController.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/observers/getFollowings/FollowingPaginationController.d.ts +5 -0
- package/dist/userRepository/relationship/follow/observers/getFollowings/FollowingPaginationController.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/observers/getFollowings/FollowingQueryStreamController.d.ts +15 -0
- package/dist/userRepository/relationship/follow/observers/getFollowings/FollowingQueryStreamController.d.ts.map +1 -0
- package/dist/userRepository/relationship/follow/observers/getFollowings.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/observers/observeFollowers.d.ts +1 -1
- package/dist/userRepository/relationship/follow/observers/observeFollowers.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/observers/observeFollowings.d.ts +1 -1
- package/dist/userRepository/relationship/follow/observers/observeFollowings.d.ts.map +1 -1
- package/dist/userRepository/relationship/follow/utils.d.ts +4 -0
- package/dist/userRepository/relationship/follow/utils.d.ts.map +1 -0
- package/dist/userRepository/utils/convertRawUserToInternalUser.d.ts +2 -0
- package/dist/userRepository/utils/convertRawUserToInternalUser.d.ts.map +1 -0
- package/dist/userRepository/utils/prepareBlockedUserPayload.d.ts +2 -0
- package/dist/userRepository/utils/prepareBlockedUserPayload.d.ts.map +1 -0
- package/dist/userRepository/utils/prepareUserPayload.d.ts +2 -0
- package/dist/userRepository/utils/prepareUserPayload.d.ts.map +1 -0
- package/dist/utils/linkedObject/commentLinkedObject.d.ts.map +1 -1
- package/dist/utils/linkedObject/index.d.ts +2 -1
- package/dist/utils/linkedObject/index.d.ts.map +1 -1
- package/dist/utils/linkedObject/pinnedPostLinkedObject.d.ts +2 -0
- package/dist/utils/linkedObject/pinnedPostLinkedObject.d.ts.map +1 -0
- package/dist/utils/tests/dummy/block.d.ts +2 -2
- package/dist/utils/tests/dummy/channel.d.ts +12 -12
- package/dist/utils/tests/dummy/channel.d.ts.map +1 -1
- package/dist/utils/tests/dummy/community.d.ts +2 -2
- package/dist/utils/tests/dummy/follow.d.ts +2 -2
- package/dist/utils/tests/dummy/user.d.ts +10 -2
- package/dist/utils/tests/dummy/user.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/@types/core/events.ts +40 -13
- package/src/@types/core/model.ts +6 -0
- package/src/@types/core/payload.ts +39 -9
- package/src/@types/core/permissions.ts +4 -4
- package/src/@types/domains/channel.ts +13 -0
- package/src/@types/domains/comment.ts +6 -4
- package/src/@types/domains/community.ts +40 -12
- package/src/@types/domains/follow.ts +26 -12
- package/src/@types/domains/group.ts +14 -6
- package/src/@types/domains/pin.ts +27 -0
- package/src/@types/domains/pinnedPost.ts +35 -0
- package/src/@types/domains/poll.ts +5 -1
- package/src/@types/domains/post.ts +9 -5
- package/src/@types/domains/stream.ts +3 -1
- package/src/@types/domains/user.ts +49 -6
- package/src/channelRepository/channelMembership/observers/getMembers/ChannelMemberLiveCollectionController.ts +6 -0
- package/src/channelRepository/channelMembership/observers/getMembers/ChannelMemberPaginationController.ts +4 -1
- package/src/channelRepository/channelMembership/observers/searchMembers/SearchChannelMemberLiveCollectionController.ts +148 -0
- package/src/channelRepository/channelMembership/observers/searchMembers/SearchChannelMemberPaginationController.ts +31 -0
- package/src/channelRepository/channelMembership/observers/searchMembers/SearchChannelMemberQueryStreamController.ts +112 -0
- package/src/channelRepository/channelMembership/observers/searchMembers/index.ts +1 -0
- package/src/channelRepository/channelMembership/observers/searchMembers/searchMembers.ts +111 -0
- package/src/channelRepository/events/onUserDeleted.ts +46 -0
- package/src/channelRepository/utils/prepareChannelPayload.ts +8 -4
- package/src/client/api/index.ts +0 -3
- package/src/commentRepository/api/createComment.ts +16 -12
- package/src/commentRepository/api/deleteComment.ts +23 -13
- package/src/commentRepository/events/onCommentCreatedLocal.ts +22 -0
- package/src/commentRepository/events/onCommentDeletedLocal.ts +20 -0
- package/src/commentRepository/events/onLocalCommentReactionAdded.ts +42 -0
- package/src/commentRepository/events/onLocalCommentReactionRemoved.ts +42 -0
- package/src/commentRepository/events/utils.ts +77 -0
- package/src/commentRepository/observers/getComment.ts +6 -19
- package/src/commentRepository/observers/getComments/CommentLiveCollectionController.ts +8 -0
- package/src/communityRepository/communityMembership/api/addMembers.ts +1 -1
- package/src/communityRepository/communityMembership/api/removeMembers.ts +1 -1
- package/src/communityRepository/communityMembership/events/index.ts +2 -0
- package/src/communityRepository/communityMembership/events/onLocalCommunityUserAdded.ts +20 -0
- package/src/communityRepository/communityMembership/events/onLocalCommunityUserRemoved.ts +20 -0
- package/src/communityRepository/communityMembership/events/onUserDeleted.ts +64 -0
- package/src/communityRepository/communityMembership/events/utils.ts +50 -2
- package/src/communityRepository/communityMembership/observers/getMembers/CommunityMembersLiveCollectionController.ts +26 -1
- package/src/communityRepository/communityMembership/observers/getMembers/CommunityMembersPaginationController.ts +4 -1
- package/src/communityRepository/communityMembership/observers/getMembers/enums.ts +3 -0
- package/src/communityRepository/communityMembership/observers/searchMembers/SearchCommunityMembersLiveCollectionController.ts +14 -0
- package/src/communityRepository/communityMembership/observers/searchMembers/SearchCommunityMembersPaginationController.ts +4 -1
- package/src/communityRepository/communityModeration/api/addRoles.ts +5 -2
- package/src/communityRepository/communityModeration/api/removeRoles.ts +5 -2
- package/src/communityRepository/communityModeration/events/onLocalCommunityRoleAdded.ts +38 -0
- package/src/communityRepository/communityModeration/events/onLocalCommunityRoleRemoved.ts +38 -0
- package/src/communityRepository/utils/payload.ts +47 -53
- package/src/core/model/idResolvers.ts +3 -0
- package/src/core/model/index.ts +3 -0
- package/src/fileRepository/api/uploadFile.ts +5 -10
- package/src/fileRepository/api/uploadImage.ts +5 -8
- package/src/fileRepository/api/uploadVideo.ts +7 -9
- package/src/group/utils/withUser.ts +33 -0
- package/src/postRepository/api/deletePost.ts +9 -9
- package/src/postRepository/api/updatePost.ts +1 -1
- package/src/postRepository/events/onLocalPostDeleted.ts +20 -0
- package/src/postRepository/events/onLocalPostReactionAdded.ts +38 -0
- package/src/postRepository/events/onLocalPostReactionRemoved.ts +41 -0
- package/src/postRepository/events/onPostUpdatedLocal.ts +20 -0
- package/src/postRepository/events/utils.ts +41 -6
- package/src/postRepository/internalApi/index.ts +1 -16
- package/src/postRepository/observers/getPinnedPosts/PinnedPostLiveCollectionController.ts +104 -0
- package/src/postRepository/observers/getPinnedPosts/PinnedPostPaginationController.ts +23 -0
- package/src/postRepository/observers/getPinnedPosts/PinnedPostQueryStreamController.ts +61 -0
- package/src/postRepository/observers/getPinnedPosts.ts +41 -0
- package/src/postRepository/observers/getPost.ts +8 -0
- package/src/postRepository/observers/getPosts/PostLiveCollectionController.ts +8 -0
- package/src/postRepository/observers/index.ts +1 -0
- package/src/postRepository/utils/payload.ts +31 -7
- package/src/reactionRepository/api/addReaction.ts +27 -2
- package/src/reactionRepository/api/removeReaction.ts +27 -2
- package/src/report/api/createReport.ts +100 -31
- package/src/report/api/deleteReport.ts +100 -31
- package/src/report/api/isReportedByMe.ts +72 -11
- package/src/userRepository/api/flagUser.ts +5 -2
- package/src/userRepository/api/getUser.ts +4 -43
- package/src/userRepository/api/getUserByIds.ts +5 -2
- package/src/userRepository/api/queryBlockedUsers.ts +6 -6
- package/src/userRepository/api/queryUsers.ts +11 -87
- package/src/userRepository/api/unflagUser.ts +5 -2
- package/src/userRepository/api/updateUser.ts +5 -11
- package/src/userRepository/events/utils.ts +4 -1
- package/src/userRepository/internalApi/getUser.ts +12 -16
- package/src/userRepository/internalApi/queryUsers.ts +7 -4
- package/src/userRepository/observers/enums.ts +7 -0
- package/src/userRepository/observers/getBlockedUsers/BlockedUserLiveCollectionController.ts +106 -0
- package/src/userRepository/observers/getBlockedUsers/BlockedUserPaginationController.ts +24 -0
- package/src/userRepository/observers/getBlockedUsers/BlockedUserQueryStreamController.ts +76 -0
- package/src/userRepository/observers/getBlockedUsers.ts +8 -81
- package/src/userRepository/observers/getUsers/UserLiveCollectionController.ts +131 -0
- package/src/userRepository/observers/getUsers/UserPaginationController.ts +25 -0
- package/src/userRepository/observers/getUsers/UserQueryStreamController.ts +82 -0
- package/src/userRepository/observers/getUsers.ts +7 -137
- package/src/userRepository/observers/searchUserByDisplayName/SearchUserLiveCollectionController.ts +116 -0
- package/src/userRepository/observers/searchUserByDisplayName/SearchUserPaginationController.ts +25 -0
- package/src/userRepository/observers/searchUserByDisplayName/SearchUserQueryStreamController.ts +82 -0
- package/src/userRepository/observers/searchUserByDisplayName.ts +25 -1
- package/src/userRepository/relationship/block/api/blockUser.ts +4 -1
- package/src/userRepository/relationship/block/api/unBlockUser.ts +4 -1
- package/src/userRepository/relationship/follow/api/acceptFollower.ts +4 -1
- package/src/userRepository/relationship/follow/api/acceptMyFollower.ts +4 -1
- package/src/userRepository/relationship/follow/api/declineFollower.ts +5 -2
- package/src/userRepository/relationship/follow/api/declineMyFollower.ts +5 -2
- package/src/userRepository/relationship/follow/api/follow.ts +8 -1
- package/src/userRepository/relationship/follow/api/unfollow.ts +4 -1
- package/src/userRepository/relationship/follow/api/utils.ts +6 -2
- package/src/userRepository/relationship/follow/enums.ts +10 -0
- package/src/userRepository/relationship/follow/events/index.ts +6 -0
- package/src/userRepository/relationship/follow/events/onFollowInfoUpdated.ts +6 -1
- package/src/userRepository/relationship/follow/events/onFollowerUserDeleted.ts +33 -0
- package/src/userRepository/relationship/follow/events/onFollowingUserDeleted.ts +33 -0
- package/src/userRepository/relationship/follow/events/onLocalFollowRequestAccepted.ts +5 -0
- package/src/userRepository/relationship/follow/events/onLocalFollowRequestDeclined.ts +5 -0
- package/src/userRepository/relationship/follow/events/onLocalFollowerRequested.ts +5 -0
- package/src/userRepository/relationship/follow/events/onLocalUserFollowed.ts +5 -0
- package/src/userRepository/relationship/follow/events/onLocalUserUnfollowed.ts +5 -0
- package/src/userRepository/relationship/follow/events/utils.ts +25 -14
- package/src/userRepository/relationship/follow/observers/getFollowers/FollowerLiveCollectionController.ts +132 -0
- package/src/userRepository/relationship/follow/observers/getFollowers/FollowerPaginationController.ts +29 -0
- package/src/userRepository/relationship/follow/observers/getFollowers/FollowerQueryStreamController.ts +95 -0
- package/src/userRepository/relationship/follow/observers/getFollowers.ts +8 -106
- package/src/userRepository/relationship/follow/observers/getFollowings/FollowingLiveCollectionController.ts +136 -0
- package/src/userRepository/relationship/follow/observers/getFollowings/FollowingPaginationController.ts +29 -0
- package/src/userRepository/relationship/follow/observers/getFollowings/FollowingQueryStreamController.ts +95 -0
- package/src/userRepository/relationship/follow/observers/getFollowings.ts +6 -106
- package/src/userRepository/relationship/follow/observers/observeFollowers.ts +11 -0
- package/src/userRepository/relationship/follow/observers/observeFollowings.ts +11 -0
- package/src/userRepository/relationship/follow/utils.ts +36 -0
- package/src/userRepository/utils/convertRawUserToInternalUser.ts +6 -0
- package/src/userRepository/utils/prepareBlockedUserPayload.ts +19 -0
- package/src/userRepository/utils/prepareUserPayload.ts +8 -0
- package/src/utils/linkedObject/commentLinkedObject.ts +13 -16
- package/src/utils/linkedObject/index.ts +2 -0
- package/src/utils/linkedObject/pinnedPostLinkedObject.ts +28 -0
|
@@ -1,10 +1,9 @@
|
|
|
1
1
|
import { getActiveClient } from '~/client/api';
|
|
2
2
|
import { ingestInCache } from '~/cache/api/ingestInCache';
|
|
3
3
|
import { createEventSubscriber, fireEvent } from '~/core/events';
|
|
4
|
-
import { pullFromCache, queryCache, upsertInCache } from '~/cache/api';
|
|
5
|
-
import { pushToTombstone } from '~/cache/api/pushToTombstone';
|
|
6
|
-
import { prepareMembershipPayload } from '~/group/utils';
|
|
4
|
+
import { dropFromCache, pullFromCache, queryCache, upsertInCache } from '~/cache/api';
|
|
7
5
|
import { isInTombstone } from '~/cache/api/isInTombstone';
|
|
6
|
+
import { preparePostPayload } from '~/postRepository/utils/payload';
|
|
8
7
|
|
|
9
8
|
export const createPostEventSubscriber = (
|
|
10
9
|
event: keyof Amity.MqttPostEvents,
|
|
@@ -16,9 +15,9 @@ export const createPostEventSubscriber = (
|
|
|
16
15
|
if (!client.cache) {
|
|
17
16
|
callback(payload.posts[0]);
|
|
18
17
|
} else {
|
|
19
|
-
const
|
|
18
|
+
const data = preparePostPayload(payload);
|
|
20
19
|
|
|
21
|
-
const
|
|
20
|
+
const { communities } = data;
|
|
22
21
|
|
|
23
22
|
ingestInCache(data);
|
|
24
23
|
|
|
@@ -49,7 +48,7 @@ export const createPostEventSubscriber = (
|
|
|
49
48
|
// But if it is hard delete, it will pushed into tombstone before fire an event to BE. it means it will stay in tombstone already
|
|
50
49
|
// and will got skip to notify in a previous code block
|
|
51
50
|
if (postedUserId !== client.userId) {
|
|
52
|
-
|
|
51
|
+
dropFromCache(['post', 'get', postId]);
|
|
53
52
|
}
|
|
54
53
|
|
|
55
54
|
return callback(payload.posts[0]);
|
|
@@ -76,3 +75,39 @@ export const createPostEventSubscriber = (
|
|
|
76
75
|
|
|
77
76
|
return createEventSubscriber(client, event, event, filter);
|
|
78
77
|
};
|
|
78
|
+
|
|
79
|
+
export const createLocalPostEventSubscriber = (
|
|
80
|
+
event: keyof Omit<Amity.LocalPostEvents, 'local.post.addReaction' | 'local.post.removeReaction'>,
|
|
81
|
+
callback: Amity.Listener<Amity.InternalPost>,
|
|
82
|
+
) => {
|
|
83
|
+
const client = getActiveClient();
|
|
84
|
+
|
|
85
|
+
const filter = (payload: Amity.PostPayload) => {
|
|
86
|
+
if (!client.cache) {
|
|
87
|
+
callback(payload.posts[0]);
|
|
88
|
+
} else {
|
|
89
|
+
const data = preparePostPayload(payload);
|
|
90
|
+
|
|
91
|
+
const { communities } = data;
|
|
92
|
+
|
|
93
|
+
ingestInCache(data);
|
|
94
|
+
|
|
95
|
+
if (communities?.[0] && !['local.post.updated'].includes(event)) {
|
|
96
|
+
fireEvent('community.updated', {
|
|
97
|
+
communities,
|
|
98
|
+
categories: [],
|
|
99
|
+
communityUsers: data.communityUsers,
|
|
100
|
+
feeds: [],
|
|
101
|
+
files: [],
|
|
102
|
+
users: [],
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
const post = pullFromCache<Amity.InternalPost>(['post', 'get', payload.posts[0].postId])!;
|
|
107
|
+
|
|
108
|
+
callback(post.data);
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
|
|
112
|
+
return createEventSubscriber(client, event, event, filter);
|
|
113
|
+
};
|
|
@@ -1,16 +1 @@
|
|
|
1
|
-
export * from './
|
|
2
|
-
|
|
3
|
-
export * from './createPost';
|
|
4
|
-
export * from './updatePost';
|
|
5
|
-
export * from './editPost';
|
|
6
|
-
|
|
7
|
-
export * from './deletePost';
|
|
8
|
-
export * from './softDeletePost';
|
|
9
|
-
export * from './hardDeletePost';
|
|
10
|
-
|
|
11
|
-
export * from './approvePost';
|
|
12
|
-
export * from './declinePost';
|
|
13
|
-
|
|
14
|
-
export * from './flagPost';
|
|
15
|
-
export * from './unflagPost';
|
|
16
|
-
export * from './isPostFlaggedByMe';
|
|
1
|
+
export * from './getPost';
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import hash from 'object-hash';
|
|
2
|
+
import { pullFromCache, pushToCache } from '~/cache/api';
|
|
3
|
+
import { PinnedPostPaginationController } from './PinnedPostPaginationController';
|
|
4
|
+
import { PinnedPostQueryStreamController } from './PinnedPostQueryStreamController';
|
|
5
|
+
import { LiveCollectionController } from '~/core/liveCollection/LiveCollectionController';
|
|
6
|
+
import { isNonNullable } from '~/utils';
|
|
7
|
+
import { LinkedObject } from '~/utils/linkedObject';
|
|
8
|
+
import { sortByLastCreated } from '~/core/query';
|
|
9
|
+
|
|
10
|
+
export class PinnedPostLiveCollectionController extends LiveCollectionController<
|
|
11
|
+
'pinnedPost',
|
|
12
|
+
Amity.PinnedPostLiveCollection,
|
|
13
|
+
Amity.PinnedPost,
|
|
14
|
+
PinnedPostPaginationController
|
|
15
|
+
> {
|
|
16
|
+
private queryStreamController: PinnedPostQueryStreamController;
|
|
17
|
+
|
|
18
|
+
private query: Amity.PinnedPostLiveCollection;
|
|
19
|
+
|
|
20
|
+
constructor(
|
|
21
|
+
query: Amity.PinnedPostLiveCollection,
|
|
22
|
+
callback: Amity.LiveCollectionCallback<Amity.PinnedPost>,
|
|
23
|
+
) {
|
|
24
|
+
const queryStreamId = hash(query);
|
|
25
|
+
const cacheKey = ['pinnedPosts', 'collection', queryStreamId];
|
|
26
|
+
const paginationController = new PinnedPostPaginationController(query);
|
|
27
|
+
|
|
28
|
+
super(paginationController, queryStreamId, cacheKey, callback);
|
|
29
|
+
|
|
30
|
+
this.query = query;
|
|
31
|
+
this.queryStreamController = new PinnedPostQueryStreamController(
|
|
32
|
+
this.query,
|
|
33
|
+
this.cacheKey,
|
|
34
|
+
this.notifyChange.bind(this),
|
|
35
|
+
response => response,
|
|
36
|
+
);
|
|
37
|
+
|
|
38
|
+
this.callback = callback.bind(this);
|
|
39
|
+
this.loadPage({ initial: true });
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
protected setup() {
|
|
43
|
+
const collection = pullFromCache<Amity.PostLiveCollectionCache>(this.cacheKey)?.data;
|
|
44
|
+
if (!collection) {
|
|
45
|
+
pushToCache(this.cacheKey, {
|
|
46
|
+
data: [],
|
|
47
|
+
params: {},
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
protected async persistModel(queryPayload: Amity.PinnedPostPayload & Amity.Pagination) {
|
|
53
|
+
await this.queryStreamController.saveToMainDB(queryPayload);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
protected persistQueryStream({
|
|
57
|
+
response,
|
|
58
|
+
direction,
|
|
59
|
+
refresh,
|
|
60
|
+
}: Amity.LiveCollectionPersistQueryStreamParams<'pinnedPost'>) {
|
|
61
|
+
this.queryStreamController.appendToQueryStream(response, direction, refresh);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
// eslint-disable-next-line class-methods-use-this
|
|
65
|
+
startSubscription() {
|
|
66
|
+
return [] as Amity.Unsubscriber[];
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
notifyChange({ origin, loading, error }: Amity.LiveCollectionNotifyParams) {
|
|
70
|
+
const collection = pullFromCache<Amity.PinnedPostLiveCollectionCache>(this.cacheKey)?.data;
|
|
71
|
+
if (!collection) return;
|
|
72
|
+
|
|
73
|
+
let data = (
|
|
74
|
+
collection.data
|
|
75
|
+
.map(id => pullFromCache<Amity.InternalPin>(['pin', 'get', id])!)
|
|
76
|
+
.filter(isNonNullable)
|
|
77
|
+
.map(({ data }) => data) ?? []
|
|
78
|
+
).map(LinkedObject.pinnedPost);
|
|
79
|
+
|
|
80
|
+
data = this.applyFilter(data);
|
|
81
|
+
|
|
82
|
+
if (!this.shouldNotify(data) && origin === 'event') return;
|
|
83
|
+
|
|
84
|
+
this.callback({
|
|
85
|
+
data,
|
|
86
|
+
loading,
|
|
87
|
+
error,
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
private applyFilter(data: Amity.PinnedPost[]) {
|
|
92
|
+
let pinnedPost = data;
|
|
93
|
+
switch (this.query.sortBy) {
|
|
94
|
+
case 'lastCreated':
|
|
95
|
+
pinnedPost = pinnedPost.sort(({ post: postA }, { post: postB }) =>
|
|
96
|
+
sortByLastCreated({ createdAt: postA?.createdAt! }, { createdAt: postB?.createdAt! }),
|
|
97
|
+
);
|
|
98
|
+
break;
|
|
99
|
+
default:
|
|
100
|
+
break;
|
|
101
|
+
}
|
|
102
|
+
return pinnedPost;
|
|
103
|
+
}
|
|
104
|
+
}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { PaginationController } from '~/core/liveCollection/PaginationController';
|
|
2
|
+
import { COLLECTION_DEFAULT_PAGINATION_LIMIT } from '~/utils/constants';
|
|
3
|
+
|
|
4
|
+
export class PinnedPostPaginationController extends PaginationController<
|
|
5
|
+
'pinnedPost',
|
|
6
|
+
Amity.PinnedPostLiveCollection
|
|
7
|
+
> {
|
|
8
|
+
async getRequest(queryParams: Amity.PinnedPostLiveCollection, token: string | undefined) {
|
|
9
|
+
const { limit = COLLECTION_DEFAULT_PAGINATION_LIMIT, ...params } = queryParams;
|
|
10
|
+
|
|
11
|
+
const { communityId, placement } = params;
|
|
12
|
+
|
|
13
|
+
const path = placement
|
|
14
|
+
? `/api/v1/pinned-posts/communities/${communityId}/${placement}`
|
|
15
|
+
: `/api/v1/pinned-posts/communities/${communityId}`;
|
|
16
|
+
|
|
17
|
+
const { data: queryResponse } = await this.http.get<Amity.PinnedPostPayload & Amity.Pagination>(
|
|
18
|
+
path,
|
|
19
|
+
);
|
|
20
|
+
|
|
21
|
+
return queryResponse;
|
|
22
|
+
}
|
|
23
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { QueryStreamController } from '~/core/liveCollection/QueryStreamController';
|
|
2
|
+
import { pullFromCache, pushToCache } from '~/cache/api';
|
|
3
|
+
import { ingestInCache } from '~/cache/api/ingestInCache';
|
|
4
|
+
import { getResolver } from '~/core/model';
|
|
5
|
+
import { getActiveClient } from '~/client';
|
|
6
|
+
|
|
7
|
+
export class PinnedPostQueryStreamController extends QueryStreamController<
|
|
8
|
+
Amity.PinnedPostPayload,
|
|
9
|
+
Amity.PinnedPostLiveCollection
|
|
10
|
+
> {
|
|
11
|
+
private notifyChange: (params: Amity.LiveCollectionNotifyParams) => void;
|
|
12
|
+
|
|
13
|
+
private preparePayload: (response: Amity.PinnedPostPayload) => Amity.ProcessedPostPayload;
|
|
14
|
+
|
|
15
|
+
constructor(
|
|
16
|
+
query: Amity.PinnedPostLiveCollection,
|
|
17
|
+
cacheKey: string[],
|
|
18
|
+
notifyChange: (params: Amity.LiveCollectionNotifyParams) => void,
|
|
19
|
+
preparePayload: (response: Amity.PinnedPostPayload) => Amity.ProcessedPostPayload,
|
|
20
|
+
) {
|
|
21
|
+
super(query, cacheKey);
|
|
22
|
+
this.notifyChange = notifyChange;
|
|
23
|
+
this.preparePayload = preparePayload;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
// eslint-disable-next-line class-methods-use-this
|
|
27
|
+
async saveToMainDB(response: Amity.PinnedPostPayload) {
|
|
28
|
+
const client = getActiveClient();
|
|
29
|
+
const cachedAt = client.cache && Date.now();
|
|
30
|
+
|
|
31
|
+
if (client.cache) {
|
|
32
|
+
ingestInCache(response, { cachedAt });
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
appendToQueryStream(
|
|
37
|
+
response: Amity.PinnedPostPayload & Partial<Amity.Pagination>,
|
|
38
|
+
direction: Amity.LiveCollectionPageDirection,
|
|
39
|
+
refresh = false,
|
|
40
|
+
) {
|
|
41
|
+
if (refresh) {
|
|
42
|
+
pushToCache(this.cacheKey, {
|
|
43
|
+
data: response.pins.map(getResolver('pin')),
|
|
44
|
+
});
|
|
45
|
+
} else {
|
|
46
|
+
const collection = pullFromCache<Amity.PinnedPostLiveCollectionCache>(this.cacheKey)?.data;
|
|
47
|
+
|
|
48
|
+
const pinnedPosts = collection?.data ?? [];
|
|
49
|
+
|
|
50
|
+
pushToCache(this.cacheKey, {
|
|
51
|
+
...collection,
|
|
52
|
+
data: [...new Set([...pinnedPosts, ...response.pins.map(getResolver('pin'))])],
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
this.notifyChange({
|
|
56
|
+
origin: Amity.LiveDataOrigin.SERVER,
|
|
57
|
+
loading: false,
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import { getActiveClient } from '~/client/api';
|
|
2
|
+
import { dropFromCache } from '~/cache/api';
|
|
3
|
+
import { ENABLE_CACHE_MESSAGE } from '~/utils/constants';
|
|
4
|
+
import { PinnedPostLiveCollectionController } from './getPinnedPosts/PinnedPostLiveCollectionController';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Get pinned posts for a community
|
|
8
|
+
*
|
|
9
|
+
* @param communityId the ID of the community
|
|
10
|
+
* @param placement the placement of the pinned post ('announcement' or 'default'), or null to fetch all pinned posts
|
|
11
|
+
* @returns the associated pinned post(s)
|
|
12
|
+
*
|
|
13
|
+
* @category Pined Posts Live Collection
|
|
14
|
+
*
|
|
15
|
+
*/
|
|
16
|
+
export const getPinnedPosts = (
|
|
17
|
+
params: Amity.LiveCollectionParams<Amity.PinnedPostLiveCollection>,
|
|
18
|
+
callback: Amity.LiveCollectionCallback<Amity.PinnedPost>,
|
|
19
|
+
config?: Amity.LiveCollectionConfig,
|
|
20
|
+
) => {
|
|
21
|
+
const { log, cache } = getActiveClient();
|
|
22
|
+
|
|
23
|
+
if (!cache) {
|
|
24
|
+
console.log(ENABLE_CACHE_MESSAGE);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
const timestamp = Date.now();
|
|
28
|
+
log(`getPinnedPosts(tmpid: ${timestamp}) > listen`);
|
|
29
|
+
|
|
30
|
+
const pinnedPostLiveCollection = new PinnedPostLiveCollectionController(params, callback);
|
|
31
|
+
const disposers = pinnedPostLiveCollection.startSubscription();
|
|
32
|
+
|
|
33
|
+
const cacheKey = pinnedPostLiveCollection.getCacheKey();
|
|
34
|
+
|
|
35
|
+
disposers.push(() => dropFromCache(cacheKey));
|
|
36
|
+
|
|
37
|
+
return () => {
|
|
38
|
+
log(`getPinnedPosts(tmpid: ${timestamp}) > dispose`);
|
|
39
|
+
disposers.forEach(fn => fn());
|
|
40
|
+
};
|
|
41
|
+
};
|
|
@@ -15,6 +15,10 @@ import { pullFromCache, pushToCache } from '~/cache/api';
|
|
|
15
15
|
import { LinkedObject } from '~/utils/linkedObject';
|
|
16
16
|
import { onCommentCreated, onCommentDeleted } from '~/commentRepository';
|
|
17
17
|
import { convertEventPayload } from '~/utils/event';
|
|
18
|
+
import { onPostUpdatedLocal } from '~/postRepository/events/onPostUpdatedLocal';
|
|
19
|
+
import { onLocalPostReactionAdded } from '~/postRepository/events/onLocalPostReactionAdded';
|
|
20
|
+
import { onLocalPostReactionRemoved } from '~/postRepository/events/onLocalPostReactionRemoved';
|
|
21
|
+
import { onLocalPostDeleted } from '~/postRepository/events/onLocalPostDeleted';
|
|
18
22
|
|
|
19
23
|
/* begin_public_function
|
|
20
24
|
id: post.get
|
|
@@ -52,6 +56,8 @@ export const getPost = (
|
|
|
52
56
|
return liveObject(postId, responder, 'postId', _getPost, [
|
|
53
57
|
onPostApproved,
|
|
54
58
|
onPostDeclined,
|
|
59
|
+
onLocalPostReactionAdded,
|
|
60
|
+
onLocalPostReactionRemoved,
|
|
55
61
|
(callback: Amity.Listener<Amity.InternalPost>) => {
|
|
56
62
|
return onPostDeleted((post: Amity.InternalPost) => {
|
|
57
63
|
let targetPost = post;
|
|
@@ -89,6 +95,8 @@ export const getPost = (
|
|
|
89
95
|
},
|
|
90
96
|
onPostUnflagged,
|
|
91
97
|
onPostUpdated,
|
|
98
|
+
onPostUpdatedLocal,
|
|
99
|
+
onLocalPostDeleted,
|
|
92
100
|
convertEventPayload(
|
|
93
101
|
(callback: Amity.Listener<Amity.InternalComment>) => {
|
|
94
102
|
return onCommentCreated(async (comment: Amity.InternalComment) => {
|
|
@@ -28,6 +28,10 @@ import { preparePostPayload } from '~/postRepository/utils/payload';
|
|
|
28
28
|
import { convertEventPayload } from '~/utils/event';
|
|
29
29
|
import { onCommentCreated, onCommentDeleted } from '~/commentRepository';
|
|
30
30
|
import { getPost } from '~/postRepository/internalApi/getPost';
|
|
31
|
+
import { onPostUpdatedLocal } from '~/postRepository/events/onPostUpdatedLocal';
|
|
32
|
+
import { onLocalPostReactionAdded } from '~/postRepository/events/onLocalPostReactionAdded';
|
|
33
|
+
import { onLocalPostReactionRemoved } from '~/postRepository/events/onLocalPostReactionRemoved';
|
|
34
|
+
import { onLocalPostDeleted } from '~/postRepository/events/onLocalPostDeleted';
|
|
31
35
|
|
|
32
36
|
export class PostLiveCollectionController extends LiveCollectionController<
|
|
33
37
|
'post',
|
|
@@ -84,6 +88,7 @@ export class PostLiveCollectionController extends LiveCollectionController<
|
|
|
84
88
|
return this.queryStreamController.subscribeRTE([
|
|
85
89
|
{ fn: onPostCreated, action: EnumPostActions.OnPostCreated },
|
|
86
90
|
{ fn: onPostUpdated, action: EnumPostActions.OnPostUpdated },
|
|
91
|
+
{ fn: onPostUpdatedLocal, action: EnumPostActions.OnPostUpdated },
|
|
87
92
|
{ fn: onPostDeleted, action: EnumPostActions.OnPostDeleted },
|
|
88
93
|
{ fn: onPostFlagged, action: EnumPostActions.OnPostFlagged },
|
|
89
94
|
{ fn: onPostUnflagged, action: EnumPostActions.OnPostUnflagged },
|
|
@@ -91,6 +96,9 @@ export class PostLiveCollectionController extends LiveCollectionController<
|
|
|
91
96
|
{ fn: onPostDeclined, action: EnumPostActions.OnPostDeclined },
|
|
92
97
|
{ fn: onPostReactionAdded, action: EnumPostActions.OnPostReactionAdded },
|
|
93
98
|
{ fn: onPostReactionRemoved, action: EnumPostActions.OnPostReactionRemoved },
|
|
99
|
+
{ fn: onLocalPostReactionAdded, action: EnumPostActions.OnPostReactionAdded },
|
|
100
|
+
{ fn: onLocalPostReactionRemoved, action: EnumPostActions.OnPostReactionRemoved },
|
|
101
|
+
{ fn: onLocalPostDeleted, action: EnumPostActions.OnPostDeleted },
|
|
94
102
|
{
|
|
95
103
|
fn: convertEventPayload(
|
|
96
104
|
(callback: Amity.Listener<Amity.InternalComment>) => {
|
|
@@ -1,17 +1,41 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { addPostSetting } from '~/communityRepository/utils';
|
|
2
|
+
import { updateMembershipStatus } from '~/communityRepository/utils/communityWithMembership';
|
|
2
3
|
|
|
3
4
|
export const preparePostPayload = (postPayload: Amity.PostPayload): Amity.ProcessedPostPayload => {
|
|
4
|
-
|
|
5
|
+
// Unpack community payload by mapping payload field to postSetting value.
|
|
6
|
+
const communitiesWithPostSetting = addPostSetting({ communities: postPayload.communities });
|
|
5
7
|
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
8
|
+
// map users with community
|
|
9
|
+
const mappedCommunityUsers: Array<Amity.Membership<'community'>> = postPayload.communityUsers.map(
|
|
10
|
+
communityUser => {
|
|
11
|
+
const user = postPayload.users.find(user => user.userId === communityUser.userId)!;
|
|
12
|
+
|
|
13
|
+
return {
|
|
14
|
+
...communityUser,
|
|
15
|
+
user,
|
|
16
|
+
};
|
|
17
|
+
},
|
|
18
|
+
);
|
|
19
|
+
|
|
20
|
+
const communityWithMembershipStatus = updateMembershipStatus(
|
|
21
|
+
communitiesWithPostSetting,
|
|
22
|
+
mappedCommunityUsers,
|
|
23
|
+
);
|
|
24
|
+
|
|
25
|
+
// feed type
|
|
26
|
+
const posts = postPayload.posts.map(post => {
|
|
27
|
+
const feedType = postPayload.feeds.find(feed => feed.feedId === post.feedId)?.feedType;
|
|
28
|
+
|
|
29
|
+
return {
|
|
30
|
+
...post,
|
|
31
|
+
feedType,
|
|
32
|
+
};
|
|
9
33
|
});
|
|
10
34
|
|
|
11
35
|
return {
|
|
12
36
|
...postPayload,
|
|
13
37
|
posts,
|
|
14
|
-
communities,
|
|
15
|
-
communityUsers,
|
|
38
|
+
communities: communityWithMembershipStatus,
|
|
39
|
+
communityUsers: mappedCommunityUsers,
|
|
16
40
|
};
|
|
17
41
|
};
|
|
@@ -4,6 +4,7 @@ import { upsertInCache, pullFromCache, pushToCache } from '~/cache/api';
|
|
|
4
4
|
|
|
5
5
|
import { UNSYNCED_OBJECT_CACHED_AT_VALUE } from '~/utils/constants';
|
|
6
6
|
import { dispatchReactable } from '../utils';
|
|
7
|
+
import { fireEvent } from '~/core/events';
|
|
7
8
|
|
|
8
9
|
/* begin_public_function
|
|
9
10
|
id: reaction.add
|
|
@@ -50,8 +51,32 @@ export const addReaction = async (
|
|
|
50
51
|
referenceId,
|
|
51
52
|
]);
|
|
52
53
|
|
|
53
|
-
model
|
|
54
|
-
|
|
54
|
+
if (!model) return true;
|
|
55
|
+
|
|
56
|
+
const updatedModel = {
|
|
57
|
+
...model.data,
|
|
58
|
+
reactionsCount: model.data.reactionsCount + 1,
|
|
59
|
+
myReactions: [...(model.data.myReactions ?? []), reactionName],
|
|
60
|
+
reactions: {
|
|
61
|
+
...model.data.reactions,
|
|
62
|
+
[reactionName]: (model.data.reactions[reactionName] ?? 0) + 1,
|
|
63
|
+
},
|
|
64
|
+
} as Amity.Models[Amity.ReactableType];
|
|
65
|
+
|
|
66
|
+
if (referenceType === 'comment') {
|
|
67
|
+
fireEvent('local.comment.addReaction', {
|
|
68
|
+
comment: updatedModel as Amity.InternalComment,
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
return true;
|
|
72
|
+
}
|
|
73
|
+
if (referenceType === 'post') {
|
|
74
|
+
fireEvent('local.post.addReaction', {
|
|
75
|
+
post: updatedModel as Amity.InternalPost,
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
return true;
|
|
79
|
+
}
|
|
55
80
|
}
|
|
56
81
|
|
|
57
82
|
return true;
|
|
@@ -5,6 +5,7 @@ import { upsertInCache, pullFromCache, pushToCache } from '~/cache/api';
|
|
|
5
5
|
import { UNSYNCED_OBJECT_CACHED_AT_VALUE } from '~/utils/constants';
|
|
6
6
|
|
|
7
7
|
import { dispatchReactable } from '../utils';
|
|
8
|
+
import { fireEvent } from '~/core/events';
|
|
8
9
|
|
|
9
10
|
/* begin_public_function
|
|
10
11
|
id: reaction.remove
|
|
@@ -53,8 +54,32 @@ export const removeReaction = async (
|
|
|
53
54
|
referenceId,
|
|
54
55
|
]);
|
|
55
56
|
|
|
56
|
-
model
|
|
57
|
-
|
|
57
|
+
if (!model) return true;
|
|
58
|
+
|
|
59
|
+
const updatedModel = {
|
|
60
|
+
...model.data,
|
|
61
|
+
reactionsCount: Math.max(0, model.data.reactionsCount - 1),
|
|
62
|
+
myReactions: (model.data.myReactions ?? []).filter(item => item !== reactionName),
|
|
63
|
+
reactions: {
|
|
64
|
+
...model.data.reactions,
|
|
65
|
+
[reactionName]: Math.max(0, (model.data.reactions[reactionName] ?? 0) - 1),
|
|
66
|
+
},
|
|
67
|
+
} as Amity.Models[Amity.ReactableType];
|
|
68
|
+
|
|
69
|
+
if (referenceType === 'comment') {
|
|
70
|
+
fireEvent('local.comment.removeReaction', {
|
|
71
|
+
comment: updatedModel as Amity.InternalComment,
|
|
72
|
+
});
|
|
73
|
+
|
|
74
|
+
return true;
|
|
75
|
+
}
|
|
76
|
+
if (referenceType === 'post') {
|
|
77
|
+
fireEvent('local.post.removeReaction', {
|
|
78
|
+
post: updatedModel as Amity.InternalPost,
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
return true;
|
|
82
|
+
}
|
|
58
83
|
}
|
|
59
84
|
|
|
60
85
|
return true;
|
|
@@ -2,10 +2,94 @@ import { getActiveClient } from '~/client/api/activeClient';
|
|
|
2
2
|
|
|
3
3
|
import { ingestInCache } from '~/cache/api/ingestInCache';
|
|
4
4
|
import { fireEvent } from '~/core/events';
|
|
5
|
-
import { prepareMembershipPayload } from '~/group/utils';
|
|
6
|
-
|
|
7
5
|
import { prepareMessagePayload } from '~/messageRepository/utils';
|
|
8
|
-
import
|
|
6
|
+
import { preparePostPayload } from '~/postRepository/utils/payload';
|
|
7
|
+
import { prepareUserPayload } from '~/userRepository/utils/prepareUserPayload';
|
|
8
|
+
import { prepareCommentPayload } from '~/commentRepository/utils/payload';
|
|
9
|
+
|
|
10
|
+
const createMessageReport = async ({
|
|
11
|
+
client,
|
|
12
|
+
referenceId,
|
|
13
|
+
}: {
|
|
14
|
+
client: Amity.Client;
|
|
15
|
+
referenceId: string;
|
|
16
|
+
}) => {
|
|
17
|
+
const { data: payload } = await client.http.post<Amity.MessagePayload>(
|
|
18
|
+
`/api/v5/messages/${encodeURIComponent(referenceId)}/flags`,
|
|
19
|
+
);
|
|
20
|
+
|
|
21
|
+
if (client.cache) {
|
|
22
|
+
const messagePayload = await prepareMessagePayload(payload as Amity.MessagePayload);
|
|
23
|
+
ingestInCache(messagePayload);
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
fireEvent(`message.flagged`, payload);
|
|
27
|
+
|
|
28
|
+
return !!payload;
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
const createPostReport = async ({
|
|
32
|
+
client,
|
|
33
|
+
referenceId,
|
|
34
|
+
}: {
|
|
35
|
+
client: Amity.Client;
|
|
36
|
+
referenceId: string;
|
|
37
|
+
}) => {
|
|
38
|
+
const { data: payload } = await client.http.post<Amity.PostPayload>(
|
|
39
|
+
`/api/v3/post/${encodeURIComponent(referenceId)}/flag`,
|
|
40
|
+
);
|
|
41
|
+
|
|
42
|
+
if (client.cache) {
|
|
43
|
+
const postPayload = await preparePostPayload(payload);
|
|
44
|
+
ingestInCache(postPayload);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
fireEvent(`post.flagged`, payload);
|
|
48
|
+
|
|
49
|
+
return !!payload;
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
const createUserReport = async ({
|
|
53
|
+
client,
|
|
54
|
+
referenceId,
|
|
55
|
+
}: {
|
|
56
|
+
client: Amity.Client;
|
|
57
|
+
referenceId: string;
|
|
58
|
+
}) => {
|
|
59
|
+
const { data: payload } = await client.http.post<Amity.UserPayload>(
|
|
60
|
+
`/api/v4/me/flags/${encodeURIComponent(referenceId)}`,
|
|
61
|
+
);
|
|
62
|
+
|
|
63
|
+
if (client.cache) {
|
|
64
|
+
const userPayload = await prepareUserPayload(payload);
|
|
65
|
+
ingestInCache(userPayload);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
fireEvent(`user.flagged`, payload);
|
|
69
|
+
|
|
70
|
+
return !!payload;
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
const createCommentReport = async ({
|
|
74
|
+
client,
|
|
75
|
+
referenceId,
|
|
76
|
+
}: {
|
|
77
|
+
client: Amity.Client;
|
|
78
|
+
referenceId: string;
|
|
79
|
+
}) => {
|
|
80
|
+
const { data: payload } = await client.http.post<Amity.CommentPayload>(
|
|
81
|
+
`/api/v3/comment/${encodeURIComponent(referenceId)}/flag`,
|
|
82
|
+
);
|
|
83
|
+
|
|
84
|
+
if (client.cache) {
|
|
85
|
+
const commentPayload = await prepareCommentPayload(payload);
|
|
86
|
+
ingestInCache(commentPayload);
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
fireEvent(`comment.flagged`, payload);
|
|
90
|
+
|
|
91
|
+
return !!payload;
|
|
92
|
+
};
|
|
9
93
|
|
|
10
94
|
/**
|
|
11
95
|
* ```js
|
|
@@ -21,42 +105,27 @@ import REFERENCE_TYPES from '../constants/referenceTypes';
|
|
|
21
105
|
* @async
|
|
22
106
|
* */
|
|
23
107
|
export const createReport = async (
|
|
24
|
-
referenceType:
|
|
108
|
+
referenceType: 'post' | 'comment' | 'message' | 'user',
|
|
25
109
|
referenceId: string,
|
|
26
110
|
): Promise<boolean> => {
|
|
27
111
|
const client = getActiveClient();
|
|
28
112
|
client.log('report/createReport', { referenceType, referenceId });
|
|
29
113
|
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
if (referenceType === 'message') {
|
|
36
|
-
return `/api/v5/messages/${encodeURIComponent(referenceId)}/flags`;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
const { domainName } = REFERENCE_TYPES[referenceType];
|
|
40
|
-
|
|
41
|
-
return `/api/v3/${domainName}/${encodeURIComponent(referenceId)}/flag`;
|
|
42
|
-
};
|
|
114
|
+
if (referenceType === 'user') {
|
|
115
|
+
return createUserReport({ client, referenceId });
|
|
116
|
+
}
|
|
43
117
|
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
118
|
+
if (referenceType === 'message') {
|
|
119
|
+
return createMessageReport({ client, referenceId });
|
|
120
|
+
}
|
|
47
121
|
|
|
48
|
-
if (
|
|
49
|
-
|
|
50
|
-
const messagePayload = await prepareMessagePayload(payload as Amity.MessagePayload);
|
|
51
|
-
ingestInCache(messagePayload);
|
|
52
|
-
} else if (referenceType === 'post') {
|
|
53
|
-
ingestInCache(prepareMembershipPayload(payload as Amity.PostPayload, 'communityUsers'));
|
|
54
|
-
} else {
|
|
55
|
-
ingestInCache(payload as Amity.CommentPayload | Amity.UserPayload);
|
|
56
|
-
}
|
|
122
|
+
if (referenceType === 'post') {
|
|
123
|
+
return createPostReport({ client, referenceId });
|
|
57
124
|
}
|
|
58
125
|
|
|
59
|
-
|
|
126
|
+
if (referenceType === 'comment') {
|
|
127
|
+
return createCommentReport({ client, referenceId });
|
|
128
|
+
}
|
|
60
129
|
|
|
61
|
-
return
|
|
130
|
+
return false;
|
|
62
131
|
};
|