@amityco/ts-sdk 6.17.3 → 6.18.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/dist/@types/core/events.d.ts +4 -2
- package/dist/@types/core/events.d.ts.map +1 -1
- package/dist/@types/core/marker.d.ts +12 -1
- package/dist/@types/core/marker.d.ts.map +1 -1
- package/dist/@types/core/model.d.ts +6 -2
- package/dist/@types/core/model.d.ts.map +1 -1
- package/dist/@types/core/payload.d.ts +20 -3
- package/dist/@types/core/payload.d.ts.map +1 -1
- package/dist/@types/core/readReceipt.d.ts +21 -0
- package/dist/@types/core/readReceipt.d.ts.map +1 -0
- package/dist/@types/domains/channel.d.ts +11 -1
- package/dist/@types/domains/channel.d.ts.map +1 -1
- package/dist/@types/domains/client.d.ts +12 -2
- package/dist/@types/domains/client.d.ts.map +1 -1
- package/dist/@types/domains/community.d.ts +1 -3
- package/dist/@types/domains/community.d.ts.map +1 -1
- package/dist/@types/domains/group.d.ts +2 -2
- package/dist/@types/domains/group.d.ts.map +1 -1
- package/dist/@types/domains/marker.d.ts +15 -0
- package/dist/@types/domains/marker.d.ts.map +1 -1
- package/dist/@types/domains/message.d.ts +4 -0
- package/dist/@types/domains/message.d.ts.map +1 -1
- package/dist/@types/domains/story.d.ts +20 -3
- package/dist/@types/domains/story.d.ts.map +1 -1
- package/dist/@types/domains/subChannel.d.ts +4 -0
- package/dist/@types/domains/subChannel.d.ts.map +1 -1
- package/dist/channelRepository/api/markAsRead.d.ts.map +1 -1
- package/dist/channelRepository/channelModeration/api/index.d.ts +2 -0
- package/dist/channelRepository/channelModeration/api/index.d.ts.map +1 -1
- package/dist/channelRepository/channelModeration/api/muteMembers.d.ts +17 -0
- package/dist/channelRepository/channelModeration/api/muteMembers.d.ts.map +1 -0
- package/dist/channelRepository/channelModeration/api/unmuteMembers.d.ts +16 -0
- package/dist/channelRepository/channelModeration/api/unmuteMembers.d.ts.map +1 -0
- package/dist/channelRepository/events/onChannelDeleted.d.ts.map +1 -1
- package/dist/channelRepository/events/onChannelLeft.d.ts.map +1 -1
- package/dist/channelRepository/events/onChannelMemberBanned.d.ts.map +1 -1
- 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/getChannels/ChannelQueryStreamController.d.ts.map +1 -1
- package/dist/channelRepository/utils/getChannelIsMentioned.d.ts +10 -0
- package/dist/channelRepository/utils/getChannelIsMentioned.d.ts.map +1 -0
- package/dist/channelRepository/utils/getSubChannelsUnreadCount.d.ts +10 -0
- package/dist/channelRepository/utils/getSubChannelsUnreadCount.d.ts.map +1 -0
- package/dist/channelRepository/utils/prepareChannelPayload.d.ts.map +1 -1
- package/dist/client/api/accessTokenExpiryWatcher.d.ts +1 -1
- package/dist/client/api/accessTokenExpiryWatcher.d.ts.map +1 -1
- package/dist/client/api/createClient.d.ts.map +1 -1
- package/dist/client/api/enableUnreadCount.d.ts +2 -0
- package/dist/client/api/enableUnreadCount.d.ts.map +1 -0
- package/dist/client/api/index.d.ts +1 -0
- package/dist/client/api/index.d.ts.map +1 -1
- package/dist/client/api/login.d.ts.map +1 -1
- package/dist/client/api/markerSync.d.ts.map +1 -1
- package/dist/client/api/renewal.d.ts.map +1 -1
- package/dist/client/api/validateTexts.d.ts +8 -0
- package/dist/client/api/validateTexts.d.ts.map +1 -0
- package/dist/client/api/validateUrls.d.ts +8 -0
- package/dist/client/api/validateUrls.d.ts.map +1 -0
- package/dist/client/observers/getUserUnread.d.ts +1 -1
- package/dist/client/observers/getUserUnread.d.ts.map +1 -1
- package/dist/client/utils/ReadReceiptSync/readReceiptSyncEngine.d.ts +33 -0
- package/dist/client/utils/ReadReceiptSync/readReceiptSyncEngine.d.ts.map +1 -0
- package/dist/client/utils/ReadReceiptSync/readReceiptSyncEngineOnLoginHandler.d.ts +3 -0
- package/dist/client/utils/ReadReceiptSync/readReceiptSyncEngineOnLoginHandler.d.ts.map +1 -0
- package/dist/client/utils/markerSyncEngine.d.ts +2 -0
- package/dist/client/utils/markerSyncEngine.d.ts.map +1 -1
- package/dist/client/utils/setClientToken.d.ts.map +1 -1
- package/dist/client/utils/subscribeGlobalTopic.d.ts.map +1 -1
- package/dist/commentRepository/api/deleteComment.d.ts.map +1 -1
- package/dist/commentRepository/api/queryComments.d.ts.map +1 -1
- package/dist/commentRepository/events/utils.d.ts.map +1 -1
- package/dist/commentRepository/internalApi/queryComments.d.ts.map +1 -1
- package/dist/commentRepository/utils/convertToInternalComment.d.ts +8 -0
- package/dist/commentRepository/utils/convertToInternalComment.d.ts.map +1 -0
- 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/core/query/sorting.d.ts +6 -0
- package/dist/core/query/sorting.d.ts.map +1 -1
- package/dist/core/subscription.d.ts +1 -0
- package/dist/core/subscription.d.ts.map +1 -1
- package/dist/index.cjs.js +5745 -4474
- package/dist/index.esm.js +5183 -3914
- package/dist/index.umd.js +4 -4
- package/dist/marker/api/getChannelMarkers.d.ts.map +1 -1
- package/dist/marker/api/getMessageMarkers.d.ts.map +1 -1
- package/dist/marker/api/getSubChannelMarkers.d.ts.map +1 -1
- package/dist/marker/api/getUserMarker.d.ts +1 -1
- package/dist/marker/api/getUserMarker.d.ts.map +1 -1
- package/dist/marker/api/getUserMessageFeedMarkers.d.ts +18 -0
- package/dist/marker/api/getUserMessageFeedMarkers.d.ts.map +1 -0
- package/dist/marker/events/onMessageMarked.d.ts.map +1 -1
- package/dist/marker/events/onUserFeedMarkerUpdated.d.ts +17 -0
- package/dist/marker/events/onUserFeedMarkerUpdated.d.ts.map +1 -0
- package/dist/marker/events/onUserMarkerSync.d.ts.map +1 -1
- package/dist/marker/utils/addFlagIsDeletedSubChannelUnreadByChannelId.d.ts +2 -0
- package/dist/marker/utils/addFlagIsDeletedSubChannelUnreadByChannelId.d.ts.map +1 -0
- package/dist/marker/utils/addFlagIsDeletedSubChannelUnreadBySubChannelId.d.ts +2 -0
- package/dist/marker/utils/addFlagIsDeletedSubChannelUnreadBySubChannelId.d.ts.map +1 -0
- package/dist/marker/utils/deleteChannelUnreadByChannelId.d.ts +2 -0
- package/dist/marker/utils/deleteChannelUnreadByChannelId.d.ts.map +1 -0
- package/dist/marker/utils/persistUnreadCountInfo.d.ts +2 -0
- package/dist/marker/utils/persistUnreadCountInfo.d.ts.map +1 -0
- package/dist/marker/utils/reCalculateChannelUnreadInfo.d.ts +2 -0
- package/dist/marker/utils/reCalculateChannelUnreadInfo.d.ts.map +1 -0
- package/dist/marker/utils/updateSubChannelUnreadFromMessage.d.ts +2 -0
- package/dist/marker/utils/updateSubChannelUnreadFromMessage.d.ts.map +1 -0
- package/dist/messagePreview/utils/getSubChannelMessagePreviewWithUser.d.ts +1 -0
- package/dist/messagePreview/utils/getSubChannelMessagePreviewWithUser.d.ts.map +1 -1
- package/dist/messagePreview/utils/updateMessagePreviewFromMessage.d.ts +2 -2
- package/dist/messagePreview/utils/updateMessagePreviewFromMessage.d.ts.map +1 -1
- package/dist/messageRepository/api/createMessage.d.ts.map +1 -1
- package/dist/messageRepository/api/deleteMessage.d.ts.map +1 -1
- package/dist/messageRepository/api/editMessage.d.ts.map +1 -1
- package/dist/messageRepository/api/getMessage.d.ts.map +1 -1
- package/dist/messageRepository/api/getMessages.d.ts.map +1 -1
- package/dist/messageRepository/api/markAsDelivered.d.ts.map +1 -1
- package/dist/messageRepository/api/queryMessages.d.ts.map +1 -1
- package/dist/messageRepository/api/softDeleteMessage.d.ts.map +1 -1
- package/dist/messageRepository/api/updateMessage.d.ts.map +1 -1
- package/dist/messageRepository/events/onMessageCreated.d.ts +2 -2
- package/dist/messageRepository/events/onMessageCreated.d.ts.map +1 -1
- package/dist/messageRepository/events/onMessageDeleted.d.ts +1 -1
- package/dist/messageRepository/events/onMessageDeleted.d.ts.map +1 -1
- package/dist/messageRepository/events/onMessageFetched.d.ts +1 -1
- package/dist/messageRepository/events/onMessageFetched.d.ts.map +1 -1
- package/dist/messageRepository/events/onMessageFlagCleared.d.ts +1 -1
- package/dist/messageRepository/events/onMessageFlagCleared.d.ts.map +1 -1
- package/dist/messageRepository/events/onMessageFlagged.d.ts +1 -1
- package/dist/messageRepository/events/onMessageFlagged.d.ts.map +1 -1
- package/dist/messageRepository/events/onMessageReactionAdded.d.ts +1 -1
- package/dist/messageRepository/events/onMessageReactionAdded.d.ts.map +1 -1
- package/dist/messageRepository/events/onMessageReactionRemoved.d.ts +1 -1
- package/dist/messageRepository/events/onMessageReactionRemoved.d.ts.map +1 -1
- package/dist/messageRepository/events/onMessageUnflagged.d.ts +1 -1
- package/dist/messageRepository/events/onMessageUnflagged.d.ts.map +1 -1
- package/dist/messageRepository/events/onMessageUpdated.d.ts +1 -1
- package/dist/messageRepository/events/onMessageUpdated.d.ts.map +1 -1
- package/dist/messageRepository/internalApi/getMessage.d.ts +32 -0
- package/dist/messageRepository/internalApi/getMessage.d.ts.map +1 -0
- package/dist/messageRepository/internalApi/getMessages.d.ts +32 -0
- package/dist/messageRepository/internalApi/getMessages.d.ts.map +1 -0
- package/dist/messageRepository/observers/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 +2 -2
- package/dist/messageRepository/observers/getMessages/MessageQueryStreamController.d.ts.map +1 -1
- package/dist/messageRepository/observers/observeMessage.d.ts.map +1 -1
- package/dist/messageRepository/observers/observeMessages.d.ts.map +1 -1
- package/dist/messageRepository/utils/getMessageReadCount.d.ts +1 -1
- package/dist/messageRepository/utils/getMessageReadCount.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/reactionRepository/events/onReactionAdded.d.ts +1 -1
- package/dist/reactionRepository/events/onReactionAdded.d.ts.map +1 -1
- package/dist/reactionRepository/events/onReactionRemoved.d.ts +1 -1
- package/dist/reactionRepository/events/onReactionRemoved.d.ts.map +1 -1
- package/dist/reactionRepository/events/onReactorAdded.d.ts.map +1 -1
- package/dist/reactionRepository/events/onReactorRemoved.d.ts.map +1 -1
- package/dist/reactionRepository/utils/fetchReference.d.ts +1 -1
- package/dist/reactionRepository/utils/fetchReference.d.ts.map +1 -1
- package/dist/reactionRepository/utils/prepareMessagePayloadForCache.d.ts +1 -1
- package/dist/reactionRepository/utils/prepareMessagePayloadForCache.d.ts.map +1 -1
- package/dist/reactionRepository/utils/prepareReactionPayloadFormEvent.d.ts +1 -0
- package/dist/reactionRepository/utils/prepareReactionPayloadFormEvent.d.ts.map +1 -1
- package/dist/storyRepository/api/createImageStory.d.ts.map +1 -1
- package/dist/storyRepository/api/createVideoStory.d.ts.map +1 -1
- package/dist/storyRepository/constants.d.ts +2 -0
- package/dist/storyRepository/constants.d.ts.map +1 -1
- package/dist/storyRepository/events/onStoryReactionAdded.d.ts.map +1 -1
- package/dist/storyRepository/events/onStoryReactionRemoved.d.ts.map +1 -1
- package/dist/storyRepository/internalApi/getStoryByStoryId.d.ts.map +1 -1
- package/dist/storyRepository/observers/getActiveStoriesByTarget.d.ts.map +1 -1
- package/dist/storyRepository/observers/getGlobalStoryTargets/GlobalStoryLiveCollectionController.d.ts +14 -0
- package/dist/storyRepository/observers/getGlobalStoryTargets/GlobalStoryLiveCollectionController.d.ts.map +1 -0
- package/dist/storyRepository/observers/getGlobalStoryTargets/GlobalStoryPageController.d.ts +13 -0
- package/dist/storyRepository/observers/getGlobalStoryTargets/GlobalStoryPageController.d.ts.map +1 -0
- package/dist/storyRepository/observers/getGlobalStoryTargets/GlobalStoryQueryStreamController.d.ts +16 -0
- package/dist/storyRepository/observers/getGlobalStoryTargets/GlobalStoryQueryStreamController.d.ts.map +1 -0
- package/dist/storyRepository/observers/getGlobalStoryTargets/getGlobalStoryTargets.d.ts +2 -0
- package/dist/storyRepository/observers/getGlobalStoryTargets/getGlobalStoryTargets.d.ts.map +1 -0
- package/dist/storyRepository/observers/getGlobalStoryTargets/index.d.ts +2 -0
- package/dist/storyRepository/observers/getGlobalStoryTargets/index.d.ts.map +1 -0
- package/dist/storyRepository/observers/getStoriesByTargetIds/StoryPaginationNoPageController.d.ts.map +1 -1
- package/dist/storyRepository/observers/index.d.ts +1 -0
- package/dist/storyRepository/observers/index.d.ts.map +1 -1
- package/dist/storyRepository/utils/StoryComputedValue.d.ts +21 -0
- package/dist/storyRepository/utils/StoryComputedValue.d.ts.map +1 -0
- package/dist/storyRepository/utils/convertRawToStory.d.ts +2 -2
- package/dist/storyRepository/utils/convertRawToStory.d.ts.map +1 -1
- package/dist/storyRepository/utils/convertStoryPayloadToRaw.d.ts.map +1 -1
- package/dist/subChannelRepository/api/markAsReadBySegment.d.ts +16 -0
- package/dist/subChannelRepository/api/markAsReadBySegment.d.ts.map +1 -0
- package/dist/subChannelRepository/api/readingAPI.d.ts.map +1 -1
- package/dist/subChannelRepository/api/startReadingAPI.d.ts.map +1 -1
- package/dist/subChannelRepository/api/stopReadingAPI.d.ts.map +1 -1
- package/dist/subChannelRepository/events/onSubChannelCreated.d.ts.map +1 -1
- package/dist/subChannelRepository/events/onSubChannelDeleted.d.ts.map +1 -1
- package/dist/subChannelRepository/index.d.ts +1 -0
- package/dist/subChannelRepository/index.d.ts.map +1 -1
- package/dist/subChannelRepository/observers/getSubChannel.d.ts.map +1 -1
- package/dist/subChannelRepository/observers/getSubChannels/SubChannelLiveCollectionController.d.ts.map +1 -1
- package/dist/subChannelRepository/utils/convertSubChannelFromRaw.d.ts.map +1 -1
- package/dist/subChannelRepository/utils/getSubChannelIsMentioned.d.ts +2 -0
- package/dist/subChannelRepository/utils/getSubChannelIsMentioned.d.ts.map +1 -0
- package/dist/subChannelRepository/utils/getSubChannelUnreadCount.d.ts.map +1 -1
- package/dist/subChannelRepository/utils/markReadEngine.d.ts +2 -0
- package/dist/subChannelRepository/utils/markReadEngine.d.ts.map +1 -1
- package/dist/subChannelRepository/utils/messageReceiptSync.d.ts +31 -0
- package/dist/subChannelRepository/utils/messageReceiptSync.d.ts.map +1 -0
- package/dist/subChannelRepository/utils/persistOptimisticUnreadInfo.d.ts +2 -0
- package/dist/subChannelRepository/utils/persistOptimisticUnreadInfo.d.ts.map +1 -0
- package/dist/utils/linkedObject/index.d.ts +1 -0
- package/dist/utils/linkedObject/index.d.ts.map +1 -1
- package/dist/utils/linkedObject/messageLinkedObject.d.ts +2 -0
- package/dist/utils/linkedObject/messageLinkedObject.d.ts.map +1 -0
- package/dist/utils/linkedObject/storyLinkedObject.d.ts.map +1 -1
- package/dist/utils/linkedObject/storyTargetLinkedObject.d.ts.map +1 -1
- package/dist/utils/marker.d.ts +0 -1
- package/dist/utils/marker.d.ts.map +1 -1
- package/dist/utils/tests/dummy/channel.d.ts.map +1 -1
- package/dist/utils/tests/dummy/community.d.ts +1 -1
- package/dist/utils/tests/dummy/marker.d.ts +1 -0
- package/dist/utils/tests/dummy/marker.d.ts.map +1 -1
- package/package.json +1 -1
- package/src/@types/core/events.ts +4 -2
- package/src/@types/core/marker.ts +13 -1
- package/src/@types/core/model.ts +8 -2
- package/src/@types/core/payload.ts +26 -3
- package/src/@types/core/readReceipt.ts +23 -0
- package/src/@types/domains/channel.ts +11 -1
- package/src/@types/domains/client.ts +14 -6
- package/src/@types/domains/community.ts +2 -3
- package/src/@types/domains/group.ts +2 -2
- package/src/@types/domains/marker.ts +17 -0
- package/src/@types/domains/message.ts +6 -0
- package/src/@types/domains/story.ts +26 -4
- package/src/@types/domains/subChannel.ts +4 -0
- package/src/channelRepository/api/markAsRead.ts +3 -7
- package/src/channelRepository/channelModeration/api/index.ts +3 -0
- package/src/channelRepository/channelModeration/api/muteMembers.ts +47 -0
- package/src/channelRepository/channelModeration/api/unmuteMembers.ts +43 -0
- package/src/channelRepository/events/onChannelCreated.ts +1 -1
- package/src/channelRepository/events/onChannelDeleted.ts +9 -0
- package/src/channelRepository/events/onChannelJoined.ts +1 -1
- package/src/channelRepository/events/onChannelLeft.ts +10 -1
- package/src/channelRepository/events/onChannelMemberAdded.ts +1 -1
- package/src/channelRepository/events/onChannelMemberBanned.ts +17 -0
- package/src/channelRepository/events/onChannelMemberRemoved.ts +1 -1
- package/src/channelRepository/events/onChannelMemberRoleAdded.ts +1 -1
- package/src/channelRepository/events/onChannelMemberRoleRemoved.ts +1 -1
- package/src/channelRepository/events/onChannelMemberUnbanned.ts +1 -1
- package/src/channelRepository/events/onChannelMuted.ts +1 -1
- package/src/channelRepository/events/onChannelUpdated.ts +1 -1
- package/src/channelRepository/observers/getChannel.ts +12 -8
- package/src/channelRepository/observers/getChannels/ChannelLiveCollectionController.ts +44 -11
- package/src/channelRepository/observers/getChannels/ChannelQueryStreamController.ts +4 -1
- package/src/channelRepository/utils/getChannelIsMentioned.ts +42 -0
- package/src/channelRepository/utils/getSubChannelsUnreadCount.ts +50 -0
- package/src/channelRepository/utils/prepareChannelPayload.ts +25 -4
- package/src/channelRepository/utils/tests/prepareChannelPayload.test.ts +6 -0
- package/src/client/api/accessTokenExpiryWatcher.ts +7 -2
- package/src/client/api/createClient.ts +11 -0
- package/src/client/api/enableUnreadCount.ts +24 -0
- package/src/client/api/index.ts +2 -0
- package/src/client/api/login.ts +7 -5
- package/src/client/api/markerSync.ts +2 -7
- package/src/client/api/renewal.ts +2 -5
- package/src/client/api/validateTexts.ts +23 -0
- package/src/client/api/validateUrls.ts +23 -0
- package/src/client/observers/getUserUnread.ts +38 -13
- package/src/client/utils/ReadReceiptSync/readReceiptSyncEngine.ts +259 -0
- package/src/client/utils/ReadReceiptSync/readReceiptSyncEngineOnLoginHandler.ts +21 -0
- package/src/client/utils/markerSyncEngine.ts +30 -5
- package/src/client/utils/setClientToken.ts +0 -2
- package/src/client/utils/subscribeGlobalTopic.ts +2 -0
- package/src/commentRepository/api/deleteComment.ts +29 -12
- package/src/commentRepository/api/queryComments.ts +4 -2
- package/src/commentRepository/events/utils.ts +1 -2
- package/src/commentRepository/internalApi/queryComments.ts +4 -3
- package/src/commentRepository/utils/convertToInternalComment.ts +17 -0
- package/src/core/model/idResolvers.ts +3 -0
- package/src/core/model/index.ts +3 -0
- package/src/core/query/sorting.ts +8 -0
- package/src/core/subscription.ts +6 -0
- package/src/marker/api/getChannelMarkers.ts +2 -4
- package/src/marker/api/getMessageMarkers.ts +1 -5
- package/src/marker/api/getSubChannelMarkers.ts +12 -7
- package/src/marker/api/getUserMarker.ts +3 -10
- package/src/marker/api/getUserMessageFeedMarkers.ts +35 -0
- package/src/marker/api/tests/getSubChannelMarkers.test.ts +7 -0
- package/src/marker/events/onChannelMarkerFetched.ts +1 -1
- package/src/marker/events/onChannelMarkerUpdated.ts +1 -1
- package/src/marker/events/onFeedlMarkerFetched.ts +1 -1
- package/src/marker/events/onFeedlMarkerUpdated.ts +1 -1
- package/src/marker/events/onMessageMarked.ts +28 -12
- package/src/marker/events/onMessageMarkerFetched.ts +1 -1
- package/src/marker/events/onSubChannelMarkerFetched.ts +1 -1
- package/src/marker/events/onSubChannelMarkerUpdated.ts +1 -1
- package/src/marker/events/onUserFeedMarkerUpdated.ts +38 -0
- package/src/marker/events/onUserMarkerFetched.ts +1 -1
- package/src/marker/events/onUserMarkerSync.ts +3 -8
- package/src/marker/utils/addFlagIsDeletedSubChannelUnreadByChannelId.ts +19 -0
- package/src/marker/utils/addFlagIsDeletedSubChannelUnreadBySubChannelId.ts +13 -0
- package/src/marker/utils/deleteChannelUnreadByChannelId.ts +11 -0
- package/src/marker/utils/persistUnreadCountInfo.ts +47 -0
- package/src/marker/utils/reCalculateChannelUnreadInfo.ts +37 -0
- package/src/marker/utils/updateSubChannelUnreadFromMessage.ts +40 -0
- package/src/messagePreview/utils/updateMessagePreviewFromMessage.ts +2 -2
- package/src/messageRepository/api/createMessage.ts +6 -4
- package/src/messageRepository/api/deleteMessage.ts +6 -5
- package/src/messageRepository/api/editMessage.ts +5 -4
- package/src/messageRepository/api/getMessage.ts +2 -1
- package/src/messageRepository/api/getMessages.ts +2 -1
- package/src/messageRepository/api/markAsDelivered.ts +2 -6
- package/src/messageRepository/api/queryMessages.ts +8 -1
- package/src/messageRepository/api/softDeleteMessage.ts +6 -5
- package/src/messageRepository/api/updateMessage.ts +5 -4
- package/src/messageRepository/events/onMessageCreated.ts +12 -2
- package/src/messageRepository/events/onMessageDeleted.ts +4 -2
- package/src/messageRepository/events/onMessageFetched.ts +3 -1
- package/src/messageRepository/events/onMessageFlagCleared.ts +1 -1
- package/src/messageRepository/events/onMessageFlagged.ts +4 -2
- package/src/messageRepository/events/onMessageReactionAdded.ts +1 -1
- package/src/messageRepository/events/onMessageReactionRemoved.ts +1 -1
- package/src/messageRepository/events/onMessageUnflagged.ts +3 -1
- package/src/messageRepository/events/onMessageUpdated.ts +4 -2
- package/src/messageRepository/events/tests/events.test.ts +4 -1
- package/src/messageRepository/internalApi/getMessage.ts +101 -0
- package/src/messageRepository/internalApi/getMessages.ts +82 -0
- package/src/messageRepository/observers/getMessage.ts +10 -2
- package/src/messageRepository/observers/getMessages/MessageLiveCollectionController.ts +4 -2
- package/src/messageRepository/observers/getMessages/MessageQueryStreamController.ts +2 -2
- package/src/messageRepository/observers/observeMessage.ts +13 -4
- package/src/messageRepository/observers/observeMessages.ts +19 -6
- package/src/messageRepository/utils/getMessageReadCount.ts +5 -4
- package/src/messageRepository/utils/prepareMessagePayload.ts +6 -10
- package/src/reactionRepository/events/onReactionAdded.ts +1 -0
- package/src/reactionRepository/events/onReactorAdded.ts +13 -0
- package/src/reactionRepository/events/onReactorRemoved.ts +13 -0
- package/src/reactionRepository/utils/fetchReference.ts +1 -1
- package/src/reactionRepository/utils/prepareMessagePayloadForCache.ts +1 -1
- package/src/reactionRepository/utils/prepareReactionPayloadFormEvent.ts +68 -15
- package/src/storyRepository/api/createImageStory.ts +7 -0
- package/src/storyRepository/api/createVideoStory.ts +7 -0
- package/src/storyRepository/constants.ts +2 -0
- package/src/storyRepository/events/onStoryCreated.ts +2 -2
- package/src/storyRepository/events/onStoryDeleted.ts +2 -2
- package/src/storyRepository/events/onStoryReactionAdded.ts +11 -5
- package/src/storyRepository/events/onStoryReactionRemoved.ts +11 -5
- package/src/storyRepository/events/onStoryUpdated.ts +2 -2
- package/src/storyRepository/internalApi/createStory.ts +2 -2
- package/src/storyRepository/internalApi/deleteStory.ts +1 -1
- package/src/storyRepository/internalApi/getActiveStoriesByTarget.ts +2 -2
- package/src/storyRepository/internalApi/getStoryByStoryId.ts +2 -1
- package/src/storyRepository/observers/getActiveStoriesByTarget.ts +11 -5
- package/src/storyRepository/observers/getGlobalStoryTargets/GlobalStoryLiveCollectionController.ts +152 -0
- package/src/storyRepository/observers/getGlobalStoryTargets/GlobalStoryPageController.ts +73 -0
- package/src/storyRepository/observers/getGlobalStoryTargets/GlobalStoryQueryStreamController.ts +94 -0
- package/src/storyRepository/observers/getGlobalStoryTargets/getGlobalStoryTargets.ts +32 -0
- package/src/storyRepository/observers/getGlobalStoryTargets/index.ts +1 -0
- package/src/storyRepository/observers/getStoriesByTargetIds/StoryPaginationNoPageController.ts +0 -2
- package/src/storyRepository/observers/getStoriesByTargetIds/StoryQueryStreamController.ts +2 -2
- package/src/storyRepository/observers/index.ts +1 -0
- package/src/storyRepository/utils/StoryComputedValue.ts +136 -0
- package/src/storyRepository/utils/convertRawToStory.ts +11 -4
- package/src/storyRepository/utils/convertStoryPayloadToRaw.ts +23 -0
- package/src/subChannelRepository/api/markAsReadBySegment.ts +35 -0
- package/src/subChannelRepository/api/readingAPI.ts +2 -7
- package/src/subChannelRepository/api/startReadingAPI.ts +2 -7
- package/src/subChannelRepository/api/stopReadingAPI.ts +2 -7
- package/src/subChannelRepository/events/onSubChannelCreated.ts +7 -1
- package/src/subChannelRepository/events/onSubChannelDeleted.ts +10 -1
- package/src/subChannelRepository/events/onSubChannelFetched.ts +1 -1
- package/src/subChannelRepository/index.ts +1 -0
- package/src/subChannelRepository/observers/getSubChannel.ts +10 -8
- package/src/subChannelRepository/observers/getSubChannels/SubChannelLiveCollectionController.ts +9 -4
- package/src/subChannelRepository/utils/convertSubChannelFromRaw.ts +5 -2
- package/src/subChannelRepository/utils/{getSubChannelHasMentioned.ts → getSubChannelIsMentioned.ts} +19 -1
- package/src/subChannelRepository/utils/getSubChannelUnreadCount.ts +18 -0
- package/src/subChannelRepository/utils/markReadEngine.ts +2 -0
- package/src/subChannelRepository/utils/messageReceiptSync.ts +73 -0
- package/src/subChannelRepository/utils/persistOptimisticUnreadInfo.ts +23 -0
- package/src/utils/linkedObject/index.ts +2 -0
- package/src/utils/linkedObject/messageLinkedObject.ts +21 -0
- package/src/utils/linkedObject/storyLinkedObject.ts +2 -1
- package/src/utils/linkedObject/storyTargetLinkedObject.ts +26 -4
- package/src/utils/marker.ts +0 -6
- package/src/utils/tests/dummy/channel.ts +8 -0
- package/src/utils/tests/dummy/marker.ts +15 -1
- package/dist/channelRepository/utils/getChannelHasMentioned.d.ts +0 -7
- package/dist/channelRepository/utils/getChannelHasMentioned.d.ts.map +0 -1
- package/dist/channelRepository/utils/getChannelUnreadCount.d.ts +0 -2
- package/dist/channelRepository/utils/getChannelUnreadCount.d.ts.map +0 -1
- package/dist/storyRepository/utils/calculateHasUnseenFlag.d.ts +0 -6
- package/dist/storyRepository/utils/calculateHasUnseenFlag.d.ts.map +0 -1
- package/dist/subChannelRepository/utils/getSubChannelHasMentioned.d.ts +0 -2
- package/dist/subChannelRepository/utils/getSubChannelHasMentioned.d.ts.map +0 -1
- package/src/channelRepository/utils/getChannelHasMentioned.ts +0 -28
- package/src/channelRepository/utils/getChannelUnreadCount.ts +0 -27
- package/src/storyRepository/utils/calculateHasUnseenFlag.ts +0 -47
|
@@ -1,11 +1,7 @@
|
|
|
1
1
|
import { ingestInCache } from '~/cache/api/ingestInCache';
|
|
2
2
|
import { getActiveClient } from '~/client/api/activeClient';
|
|
3
3
|
import { fireEvent } from '~/core/events';
|
|
4
|
-
import {
|
|
5
|
-
convertChannelMarkerResponse,
|
|
6
|
-
convertSubChannelMarkerResponse,
|
|
7
|
-
convertUserMarkerResponse,
|
|
8
|
-
} from '~/utils/marker';
|
|
4
|
+
import { convertChannelMarkerResponse, convertSubChannelMarkerResponse } from '~/utils/marker';
|
|
9
5
|
|
|
10
6
|
/**
|
|
11
7
|
* ```js
|
|
@@ -36,10 +32,9 @@ export const stopReadingAPI = async (
|
|
|
36
32
|
userEntityMarkers: userEntityMarkersPayload,
|
|
37
33
|
userFeedMarkers: userFeedMarkersPayload,
|
|
38
34
|
feedMarkers,
|
|
39
|
-
userMarkers
|
|
35
|
+
userMarkers,
|
|
40
36
|
} = payload;
|
|
41
37
|
|
|
42
|
-
const userMarkers = convertUserMarkerResponse(userMarkersPayload);
|
|
43
38
|
const userEntityMarkers = convertChannelMarkerResponse(userEntityMarkersPayload);
|
|
44
39
|
const userFeedMarkers = convertSubChannelMarkerResponse(userFeedMarkersPayload);
|
|
45
40
|
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { ingestInCache } from '~/cache/api/ingestInCache';
|
|
2
|
-
import { getActiveClient } from '~/client/api';
|
|
2
|
+
import { getActiveClient } from '~/client/api/activeClient';
|
|
3
3
|
import { createEventSubscriber } from '~/core/events';
|
|
4
4
|
import { prepareSubChannelPayload } from '../utils';
|
|
5
|
+
import { persistOptimisticUnreadInfo } from '../utils/persistOptimisticUnreadInfo';
|
|
5
6
|
|
|
6
7
|
/**
|
|
7
8
|
* ```js
|
|
@@ -24,6 +25,11 @@ export const onSubChannelCreated = (callback: Amity.Listener<Amity.SubChannel>)
|
|
|
24
25
|
const filter = async (rawPayload: Amity.SubChannelPayload) => {
|
|
25
26
|
const payload = await prepareSubChannelPayload(rawPayload);
|
|
26
27
|
|
|
28
|
+
// optimistically create subChannelUnreadInfo
|
|
29
|
+
if (client.isUnreadCountEnabled && client.getMarkerSyncConsistentMode()) {
|
|
30
|
+
persistOptimisticUnreadInfo(rawPayload);
|
|
31
|
+
}
|
|
32
|
+
|
|
27
33
|
ingestInCache(payload);
|
|
28
34
|
callback(payload.messageFeeds[0]);
|
|
29
35
|
};
|
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
import { ingestInCache } from '~/cache/api/ingestInCache';
|
|
2
|
-
import { getActiveClient } from '~/client/api';
|
|
2
|
+
import { getActiveClient } from '~/client/api/activeClient';
|
|
3
3
|
import { createEventSubscriber } from '~/core/events';
|
|
4
4
|
import { prepareSubChannelPayload } from '../utils';
|
|
5
|
+
import { addFlagIsDeletedSubChannelUnreadBySubChannelId } from '../../marker/utils/addFlagIsDeletedSubChannelUnreadBySubChannelId';
|
|
6
|
+
import { reCalculateChannelUnreadInfo } from '~/marker/utils/reCalculateChannelUnreadInfo';
|
|
5
7
|
|
|
6
8
|
/**
|
|
7
9
|
* ```js
|
|
@@ -24,6 +26,13 @@ export const onSubChannelDeleted = (callback: Amity.Listener<Amity.SubChannel>)
|
|
|
24
26
|
const filter = async (rawPayload: Amity.SubChannelPayload) => {
|
|
25
27
|
const payload = await prepareSubChannelPayload(rawPayload);
|
|
26
28
|
|
|
29
|
+
if (client.isUnreadCountEnabled && client.getMarkerSyncConsistentMode()) {
|
|
30
|
+
payload.messageFeeds.forEach(subChannel => {
|
|
31
|
+
addFlagIsDeletedSubChannelUnreadBySubChannelId(subChannel.subChannelId);
|
|
32
|
+
reCalculateChannelUnreadInfo(subChannel.channelId);
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
|
|
27
36
|
ingestInCache(payload);
|
|
28
37
|
callback(payload.messageFeeds[0]);
|
|
29
38
|
};
|
|
@@ -20,6 +20,7 @@ import { getActiveClient } from '~/client';
|
|
|
20
20
|
import { getSubChannelMessagePreviewWithUser } from '~/messagePreview/utils';
|
|
21
21
|
import { isEqual } from '~/utils/isEqual';
|
|
22
22
|
import { updateSubChannelCache } from '../utils/updateSubChannelCache';
|
|
23
|
+
import { onUserFeedMarkerUpdated } from '~/marker/events/onUserFeedMarkerUpdated';
|
|
23
24
|
|
|
24
25
|
/* begin_public_function
|
|
25
26
|
id: subchannel.get
|
|
@@ -115,8 +116,8 @@ export const getSubChannel = (
|
|
|
115
116
|
});
|
|
116
117
|
},
|
|
117
118
|
convertEventPayload(
|
|
118
|
-
(callback: Amity.Listener<Amity.
|
|
119
|
-
const updateMessagePreview = async (message: Amity.
|
|
119
|
+
(callback: Amity.Listener<Amity.InternalMessage>) => {
|
|
120
|
+
const updateMessagePreview = async (message: Amity.InternalMessage) => {
|
|
120
121
|
const messagePreviewSetting = await client.getMessagePreviewSetting(false);
|
|
121
122
|
if (messagePreviewSetting === Amity.MessagePreviewSetting.NO_MESSAGE_PREVIEW) return;
|
|
122
123
|
|
|
@@ -143,8 +144,8 @@ export const getSubChannel = (
|
|
|
143
144
|
'subChannel',
|
|
144
145
|
),
|
|
145
146
|
convertEventPayload(
|
|
146
|
-
(callback: Amity.Listener<Amity.
|
|
147
|
-
const updateMessagePreview = async (message: Amity.
|
|
147
|
+
(callback: Amity.Listener<Amity.InternalMessage>) => {
|
|
148
|
+
const updateMessagePreview = async (message: Amity.InternalMessage) => {
|
|
148
149
|
const messagePreviewSetting = await client.getMessagePreviewSetting(false);
|
|
149
150
|
if (messagePreviewSetting === Amity.MessagePreviewSetting.NO_MESSAGE_PREVIEW) return;
|
|
150
151
|
|
|
@@ -171,8 +172,8 @@ export const getSubChannel = (
|
|
|
171
172
|
'subChannel',
|
|
172
173
|
),
|
|
173
174
|
convertEventPayload(
|
|
174
|
-
(callback: Amity.Listener<Amity.
|
|
175
|
-
const updateMessagePreview = async (message: Amity.
|
|
175
|
+
(callback: Amity.Listener<Amity.InternalMessage>) => {
|
|
176
|
+
const updateMessagePreview = async (message: Amity.InternalMessage) => {
|
|
176
177
|
const messagePreviewSetting = await client.getMessagePreviewSetting(false);
|
|
177
178
|
if (messagePreviewSetting === Amity.MessagePreviewSetting.NO_MESSAGE_PREVIEW) return;
|
|
178
179
|
|
|
@@ -190,8 +191,8 @@ export const getSubChannel = (
|
|
|
190
191
|
'subChannel',
|
|
191
192
|
),
|
|
192
193
|
convertEventPayload(
|
|
193
|
-
(callback: Amity.Listener<Amity.
|
|
194
|
-
const updateMessagePreview = async (message: Amity.
|
|
194
|
+
(callback: Amity.Listener<Amity.InternalMessage>) => {
|
|
195
|
+
const updateMessagePreview = async (message: Amity.InternalMessage) => {
|
|
195
196
|
const messagePreviewSetting = await client.getMessagePreviewSetting(false);
|
|
196
197
|
if (messagePreviewSetting === Amity.MessagePreviewSetting.NO_MESSAGE_PREVIEW) return;
|
|
197
198
|
|
|
@@ -216,6 +217,7 @@ export const getSubChannel = (
|
|
|
216
217
|
'subChannelId',
|
|
217
218
|
'subChannel',
|
|
218
219
|
),
|
|
220
|
+
convertEventPayload(onUserFeedMarkerUpdated, 'feedId', 'subChannel'),
|
|
219
221
|
],
|
|
220
222
|
{
|
|
221
223
|
forceDispatch: true,
|
package/src/subChannelRepository/observers/getSubChannels/SubChannelLiveCollectionController.ts
CHANGED
|
@@ -29,6 +29,7 @@ import { getSubChannel } from '~/subChannelRepository/api/getSubChannel';
|
|
|
29
29
|
import { updateSubChannelCache } from '~/subChannelRepository/utils/updateSubChannelCache';
|
|
30
30
|
import { prepareSubChannelPayload } from '~/subChannelRepository/utils';
|
|
31
31
|
import { onSubChannelFetched } from '~/subChannelRepository/events/onSubChannelFetched';
|
|
32
|
+
import { onUserFeedMarkerUpdated } from '~/marker/events/onUserFeedMarkerUpdated';
|
|
32
33
|
|
|
33
34
|
export class SubChannelLiveCollectionController extends LiveCollectionController<
|
|
34
35
|
'subChannel',
|
|
@@ -231,8 +232,8 @@ export class SubChannelLiveCollectionController extends LiveCollectionController
|
|
|
231
232
|
},
|
|
232
233
|
{
|
|
233
234
|
fn: convertEventPayload(
|
|
234
|
-
(callback: Amity.Listener<Amity.
|
|
235
|
-
const updateMessagePreview = async (message: Amity.
|
|
235
|
+
(callback: Amity.Listener<Amity.InternalMessage>) => {
|
|
236
|
+
const updateMessagePreview = async (message: Amity.InternalMessage) => {
|
|
236
237
|
const client = getActiveClient();
|
|
237
238
|
const messagePreviewSetting = await client.getMessagePreviewSetting(false);
|
|
238
239
|
|
|
@@ -257,8 +258,8 @@ export class SubChannelLiveCollectionController extends LiveCollectionController
|
|
|
257
258
|
},
|
|
258
259
|
{
|
|
259
260
|
fn: convertEventPayload(
|
|
260
|
-
(callback: Amity.Listener<Amity.
|
|
261
|
-
const updateMessagePreview = async (message: Amity.
|
|
261
|
+
(callback: Amity.Listener<Amity.InternalMessage>) => {
|
|
262
|
+
const updateMessagePreview = async (message: Amity.InternalMessage) => {
|
|
262
263
|
const client = getActiveClient();
|
|
263
264
|
const messagePreviewSetting = await client.getMessagePreviewSetting(false);
|
|
264
265
|
|
|
@@ -289,6 +290,10 @@ export class SubChannelLiveCollectionController extends LiveCollectionController
|
|
|
289
290
|
),
|
|
290
291
|
action: 'onUpdate',
|
|
291
292
|
},
|
|
293
|
+
{
|
|
294
|
+
fn: convertEventPayload(onUserFeedMarkerUpdated, 'feedId', 'subChannel'),
|
|
295
|
+
action: 'onUpdate',
|
|
296
|
+
},
|
|
292
297
|
]);
|
|
293
298
|
}
|
|
294
299
|
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { getSubChannelIsMentioned } from './getSubChannelIsMentioned';
|
|
2
2
|
import { getSubChannelUnreadCount } from './getSubChannelUnreadCount';
|
|
3
3
|
|
|
4
4
|
export const MARKER_INCLUDED_SUB_CHANNEL_TYPE = ['broadcast', 'conversation', 'community'];
|
|
@@ -24,7 +24,10 @@ export function convertFromRaw({
|
|
|
24
24
|
return getSubChannelUnreadCount(channelId, messageFeedId);
|
|
25
25
|
},
|
|
26
26
|
get hasMentioned() {
|
|
27
|
-
return
|
|
27
|
+
return getSubChannelIsMentioned(channelId, messageFeedId);
|
|
28
|
+
},
|
|
29
|
+
get isMentioned() {
|
|
30
|
+
return getSubChannelIsMentioned(channelId, messageFeedId);
|
|
28
31
|
},
|
|
29
32
|
...rest,
|
|
30
33
|
channelId: channelPublicId,
|
package/src/subChannelRepository/utils/{getSubChannelHasMentioned.ts → getSubChannelIsMentioned.ts}
RENAMED
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { pullFromCache } from '~/cache/api/pullFromCache';
|
|
2
|
+
import { getActiveClient } from '~/client/api/activeClient';
|
|
2
3
|
import { getActiveUser } from '~/client/api/activeUser';
|
|
3
4
|
import { getResolver } from '~/core/model';
|
|
4
5
|
|
|
5
|
-
export function
|
|
6
|
+
export function getSubChannelIsMentioned(
|
|
6
7
|
channelId: string,
|
|
7
8
|
subChannelId: string,
|
|
8
9
|
marker?: Amity.SubChannelMarker,
|
|
@@ -12,6 +13,23 @@ export function getSubChannelHasMentioned(
|
|
|
12
13
|
return marker.hasMentioned;
|
|
13
14
|
}
|
|
14
15
|
|
|
16
|
+
const client = getActiveClient();
|
|
17
|
+
|
|
18
|
+
// If consistent mode is enabled, look in the SubChannelUnreadCountInfo cache
|
|
19
|
+
if (client.isUnreadCountEnabled && client.getMarkerSyncConsistentMode()) {
|
|
20
|
+
const cachedUnreadCount = pullFromCache<Amity.SubChannelUnreadInfo>([
|
|
21
|
+
'subChannelUnreadInfo',
|
|
22
|
+
'get',
|
|
23
|
+
subChannelId,
|
|
24
|
+
])?.data;
|
|
25
|
+
|
|
26
|
+
if (cachedUnreadCount) {
|
|
27
|
+
return cachedUnreadCount.isMentioned;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
return false;
|
|
31
|
+
}
|
|
32
|
+
|
|
15
33
|
const key = {
|
|
16
34
|
entityId: channelId,
|
|
17
35
|
feedId: subChannelId,
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { pullFromCache } from '~/cache/api/pullFromCache';
|
|
2
|
+
import { getActiveClient } from '~/client/api/activeClient';
|
|
2
3
|
import { getActiveUser } from '~/client/api/activeUser';
|
|
3
4
|
import { getResolver } from '~/core/model';
|
|
4
5
|
|
|
@@ -12,6 +13,23 @@ export function getSubChannelUnreadCount(
|
|
|
12
13
|
return marker.unreadCount;
|
|
13
14
|
}
|
|
14
15
|
|
|
16
|
+
const client = getActiveClient();
|
|
17
|
+
|
|
18
|
+
// If consistent mode is enabled, look in the SubChannelUnreadCountInfo cache
|
|
19
|
+
if (client.isUnreadCountEnabled && client.getMarkerSyncConsistentMode()) {
|
|
20
|
+
const cachedUnreadCount = pullFromCache<Amity.SubChannelUnreadInfo>([
|
|
21
|
+
'subChannelUnreadInfo',
|
|
22
|
+
'get',
|
|
23
|
+
subChannelId,
|
|
24
|
+
])?.data;
|
|
25
|
+
|
|
26
|
+
if (cachedUnreadCount) {
|
|
27
|
+
return cachedUnreadCount.isDeleted ? 0 : cachedUnreadCount.unreadCount;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
return 0;
|
|
31
|
+
}
|
|
32
|
+
|
|
15
33
|
const key = {
|
|
16
34
|
entityId: channelId,
|
|
17
35
|
feedId: subChannelId,
|
|
@@ -107,6 +107,7 @@ const disposeAll = () => {
|
|
|
107
107
|
id: subchannel.start_reading
|
|
108
108
|
*/
|
|
109
109
|
/**
|
|
110
|
+
* @deprecated Use {@link startMessageReceiptSync} instead.
|
|
110
111
|
* ```js
|
|
111
112
|
* import { startReading } from '@amityco/ts-sdk'
|
|
112
113
|
* const success = await startReading('foo')
|
|
@@ -142,6 +143,7 @@ export const startReading = async (subChannelId: Amity.SubChannel['subChannelId'
|
|
|
142
143
|
id: subchannel.stop_reading
|
|
143
144
|
*/
|
|
144
145
|
/**
|
|
146
|
+
* @deprecated Use {@link stopMessageReceiptSync} instead.
|
|
145
147
|
* ```js
|
|
146
148
|
* import { stopReading } from '@amityco/ts-sdk'
|
|
147
149
|
* const success = await stopReading('foo')
|
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
import { getMarkedMessageTopic, subscribeTopic } from '~/core/subscription';
|
|
2
|
+
import { getSubChannel } from '../api/getSubChannel';
|
|
3
|
+
|
|
4
|
+
const disposers: Record<string, () => void> = {};
|
|
5
|
+
|
|
6
|
+
const getParentChannelId = async (
|
|
7
|
+
subChannelId: Amity.SubChannel['subChannelId'],
|
|
8
|
+
): Promise<Amity.SubChannel['channelId']> => {
|
|
9
|
+
const cached = getSubChannel.locally(subChannelId);
|
|
10
|
+
|
|
11
|
+
if (cached) {
|
|
12
|
+
return cached.data.channelId;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
const { data } = await getSubChannel(subChannelId);
|
|
16
|
+
return data.channelId;
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
const registerTopicSubscribers = async (subChannelId: Amity.SubChannel['subChannelId']) => {
|
|
20
|
+
const channelId = await getParentChannelId(subChannelId);
|
|
21
|
+
const markedMessageTopic = getMarkedMessageTopic({ channelId, subChannelId });
|
|
22
|
+
|
|
23
|
+
disposers[subChannelId] = subscribeTopic(markedMessageTopic);
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
/* begin_public_function
|
|
27
|
+
id: subchannel.start_message_receipt_sync
|
|
28
|
+
*/
|
|
29
|
+
/**
|
|
30
|
+
* ```js
|
|
31
|
+
* import { SubChannelRepository } from '@amityco/ts-sdk'
|
|
32
|
+
* const success = await SubChannelRepository.startMessageReceiptSync(subChannelId)
|
|
33
|
+
* ```
|
|
34
|
+
*
|
|
35
|
+
* Start reading a {@link Amity.SubChannel}
|
|
36
|
+
*
|
|
37
|
+
* @param subChannelId The {@link Amity.SubChannel} ID to start reading
|
|
38
|
+
* @return true if the reading of the sub channel had begun
|
|
39
|
+
*
|
|
40
|
+
* @category subChannel API
|
|
41
|
+
* @async
|
|
42
|
+
*/
|
|
43
|
+
|
|
44
|
+
export const startMessageReceiptSync = async (
|
|
45
|
+
subChannelId: Amity.SubChannel['subChannelId'],
|
|
46
|
+
): Promise<boolean> => {
|
|
47
|
+
await registerTopicSubscribers(subChannelId);
|
|
48
|
+
return true;
|
|
49
|
+
};
|
|
50
|
+
/* end_public_function */
|
|
51
|
+
|
|
52
|
+
/* begin_public_function
|
|
53
|
+
id: subchannel.stop_message_receipt_sync
|
|
54
|
+
*/
|
|
55
|
+
/**
|
|
56
|
+
* ```js
|
|
57
|
+
* import { SubChannelRepository } from '@amityco/ts-sdk'
|
|
58
|
+
* const success = await SubChannelRepository.startMessageReceiptSync(subChannelId)
|
|
59
|
+
* ```
|
|
60
|
+
*
|
|
61
|
+
* Start reading a {@link Amity.SubChannel}
|
|
62
|
+
*
|
|
63
|
+
* @param subChannelId The {@link Amity.SubChannel} ID to start reading
|
|
64
|
+
* @return true if the reading of the sub channel had begun
|
|
65
|
+
*
|
|
66
|
+
* @category subChannel API
|
|
67
|
+
* @async
|
|
68
|
+
*/
|
|
69
|
+
export const stopMessageReceiptSync = (subChannelId: Amity.SubChannel['subChannelId']): boolean => {
|
|
70
|
+
if (disposers[subChannelId]) disposers[subChannelId]();
|
|
71
|
+
return true;
|
|
72
|
+
};
|
|
73
|
+
/* end_public_function */
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { pushToCache } from '~/cache/api';
|
|
2
|
+
|
|
3
|
+
export const persistOptimisticUnreadInfo = (rawPayload: Amity.SubChannelPayload) => {
|
|
4
|
+
rawPayload.messageFeeds.forEach(messageFeed => {
|
|
5
|
+
const subChannelUnreadInfo: Amity.SubChannelUnreadInfo = {
|
|
6
|
+
channelId: messageFeed.channelId,
|
|
7
|
+
subChannelId: messageFeed.messageFeedId,
|
|
8
|
+
unreadCount: 0,
|
|
9
|
+
readToSegment: 0,
|
|
10
|
+
lastMentionSegment: 0,
|
|
11
|
+
lastSegment: 0,
|
|
12
|
+
isMentioned: false,
|
|
13
|
+
isDeleted: false,
|
|
14
|
+
createdAt: messageFeed.createdAt,
|
|
15
|
+
updatedAt: messageFeed.updatedAt,
|
|
16
|
+
};
|
|
17
|
+
|
|
18
|
+
pushToCache(
|
|
19
|
+
['subChannelUnreadInfo', 'get', subChannelUnreadInfo.subChannelId],
|
|
20
|
+
subChannelUnreadInfo,
|
|
21
|
+
);
|
|
22
|
+
});
|
|
23
|
+
};
|
|
@@ -3,6 +3,7 @@ import { categoryLinkedObject } from './categoryLinkedObject';
|
|
|
3
3
|
import { commentLinkedObject } from './commentLinkedObject';
|
|
4
4
|
import { userLinkedObject } from './userLinkedObject';
|
|
5
5
|
import { postLinkedObject } from './postLinkedObject';
|
|
6
|
+
import { messageLinkedObject } from './messageLinkedObject';
|
|
6
7
|
import { storyTargetLinkedObject } from './storyTargetLinkedObject';
|
|
7
8
|
|
|
8
9
|
export const LinkedObject = {
|
|
@@ -12,4 +13,5 @@ export const LinkedObject = {
|
|
|
12
13
|
category: categoryLinkedObject,
|
|
13
14
|
story: storyLinkedObject,
|
|
14
15
|
storyTarget: storyTargetLinkedObject,
|
|
16
|
+
message: messageLinkedObject,
|
|
15
17
|
};
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import ReadReceiptSyncEngine from '~/client/utils/ReadReceiptSync/readReceiptSyncEngine';
|
|
2
|
+
import { getMessageReadCount } from '~/messageRepository/utils/getMessageReadCount';
|
|
3
|
+
|
|
4
|
+
export const messageLinkedObject = (message: Amity.InternalMessage): Amity.Message => {
|
|
5
|
+
const { creatorPrivateId, ...rest } = message;
|
|
6
|
+
return {
|
|
7
|
+
...rest,
|
|
8
|
+
get readCount() {
|
|
9
|
+
return getMessageReadCount(message).readCount;
|
|
10
|
+
},
|
|
11
|
+
get deliveredCount() {
|
|
12
|
+
return getMessageReadCount(message).deliveredCount;
|
|
13
|
+
},
|
|
14
|
+
markRead: () => {
|
|
15
|
+
const { subChannelId, channelSegment } = message;
|
|
16
|
+
const markReadReceiptEngine = ReadReceiptSyncEngine.getInstance();
|
|
17
|
+
|
|
18
|
+
markReadReceiptEngine.markRead(subChannelId, channelSegment);
|
|
19
|
+
},
|
|
20
|
+
};
|
|
21
|
+
};
|
|
@@ -8,10 +8,11 @@ export const storyLinkedObject = (story: Amity.InternalStory): Amity.Story => {
|
|
|
8
8
|
const analyticsEngineInstance = AnalyticsEngine.getInstance();
|
|
9
9
|
|
|
10
10
|
const storyTargetCache = pullFromCache<Amity.RawStoryTarget>([
|
|
11
|
-
|
|
11
|
+
STORY_KEY_CACHE.STORY_TARGET,
|
|
12
12
|
'get',
|
|
13
13
|
story.targetId,
|
|
14
14
|
]);
|
|
15
|
+
|
|
15
16
|
const communityCacheData = pullFromCache<Amity.Community>(['community', 'get', story.targetId]);
|
|
16
17
|
|
|
17
18
|
return {
|
|
@@ -1,13 +1,35 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { StoryComputedValue } from '~/storyRepository/utils/StoryComputedValue';
|
|
2
2
|
|
|
3
3
|
export const storyTargetLinkedObject = (storyTarget: Amity.RawStoryTarget): Amity.StoryTarget => {
|
|
4
|
-
const {
|
|
5
|
-
|
|
4
|
+
const {
|
|
5
|
+
targetType,
|
|
6
|
+
targetId,
|
|
7
|
+
lastStoryExpiresAt,
|
|
8
|
+
lastStorySeenExpiresAt,
|
|
9
|
+
targetUpdatedAt,
|
|
10
|
+
localFilter,
|
|
11
|
+
} = storyTarget;
|
|
12
|
+
|
|
13
|
+
const computedValue = new StoryComputedValue(
|
|
14
|
+
targetId,
|
|
15
|
+
lastStoryExpiresAt,
|
|
16
|
+
lastStorySeenExpiresAt,
|
|
17
|
+
);
|
|
6
18
|
|
|
7
19
|
return {
|
|
8
20
|
targetType,
|
|
9
21
|
targetId,
|
|
22
|
+
lastStoryExpiresAt,
|
|
10
23
|
updatedAt: targetUpdatedAt,
|
|
11
|
-
|
|
24
|
+
|
|
25
|
+
// Additional data
|
|
26
|
+
hasUnseen: computedValue.getHasUnseenFlag(),
|
|
27
|
+
syncingStoriesCount: computedValue.syncingStoriesCount,
|
|
28
|
+
failedStoriesCount: computedValue.failedStoriesCount,
|
|
29
|
+
|
|
30
|
+
localFilter,
|
|
31
|
+
localLastExpires: computedValue.localLastStoryExpires,
|
|
32
|
+
localLastSeen: computedValue.localLastStorySeenExpiresAt,
|
|
33
|
+
localSortingDate: computedValue.getLocalLastSortingDate(),
|
|
12
34
|
};
|
|
13
35
|
};
|
package/src/utils/marker.ts
CHANGED
|
@@ -10,12 +10,6 @@ function doConvert<
|
|
|
10
10
|
}));
|
|
11
11
|
}
|
|
12
12
|
|
|
13
|
-
export function convertUserMarkerResponse(
|
|
14
|
-
userMarkerResponse: Amity.UserMarkerResponse[],
|
|
15
|
-
): Amity.UserMarker[] {
|
|
16
|
-
return doConvert(userMarkerResponse);
|
|
17
|
-
}
|
|
18
|
-
|
|
19
13
|
export function convertChannelMarkerResponse(
|
|
20
14
|
channelMarkerResponse: Amity.UserEntityMarkerResponse[],
|
|
21
15
|
): Amity.ChannelMarker[] {
|
|
@@ -114,6 +114,8 @@ export const channelModel1: Amity.InternalChannel = {
|
|
|
114
114
|
unreadCount: 0,
|
|
115
115
|
hasMentioned: false,
|
|
116
116
|
messagePreviewId: undefined,
|
|
117
|
+
isMentioned: false,
|
|
118
|
+
subChannelsUnreadCount: 0,
|
|
117
119
|
};
|
|
118
120
|
|
|
119
121
|
export const channelModel2: Amity.InternalChannel = {
|
|
@@ -123,6 +125,8 @@ export const channelModel2: Amity.InternalChannel = {
|
|
|
123
125
|
unreadCount: 0,
|
|
124
126
|
hasMentioned: false,
|
|
125
127
|
messagePreviewId: undefined,
|
|
128
|
+
isMentioned: false,
|
|
129
|
+
subChannelsUnreadCount: 0,
|
|
126
130
|
};
|
|
127
131
|
|
|
128
132
|
export const channel1: Amity.Channel = {
|
|
@@ -133,6 +137,8 @@ export const channel1: Amity.Channel = {
|
|
|
133
137
|
hasMentioned: false,
|
|
134
138
|
messagePreviewId: undefined,
|
|
135
139
|
messagePreview: null,
|
|
140
|
+
isMentioned: false,
|
|
141
|
+
subChannelsUnreadCount: 0,
|
|
136
142
|
};
|
|
137
143
|
|
|
138
144
|
export const channel2: Amity.Channel = {
|
|
@@ -143,6 +149,8 @@ export const channel2: Amity.Channel = {
|
|
|
143
149
|
hasMentioned: false,
|
|
144
150
|
messagePreviewId: undefined,
|
|
145
151
|
messagePreview: null,
|
|
152
|
+
isMentioned: false,
|
|
153
|
+
subChannelsUnreadCount: 0,
|
|
146
154
|
};
|
|
147
155
|
|
|
148
156
|
export const rawChannelUser = generateRawChannelUser();
|
|
@@ -60,6 +60,8 @@ export const generateSubChannelMarkerResponse = ({
|
|
|
60
60
|
createdAt: date,
|
|
61
61
|
updatedAt: date,
|
|
62
62
|
isMentioned: false,
|
|
63
|
+
oldUnreadCount: 0,
|
|
64
|
+
lastMentionSegment: 0,
|
|
63
65
|
...params,
|
|
64
66
|
});
|
|
65
67
|
|
|
@@ -94,7 +96,7 @@ export const generateFeedMarker = ({
|
|
|
94
96
|
export const generateUserMarker = (params?: Partial<Amity.UserMarker>): Amity.UserMarker => ({
|
|
95
97
|
lastSyncAt: date,
|
|
96
98
|
userId: activeUser.userId,
|
|
97
|
-
|
|
99
|
+
isMentioned: false,
|
|
98
100
|
unreadCount: 0,
|
|
99
101
|
createdAt: date,
|
|
100
102
|
updatedAt: date,
|
|
@@ -112,3 +114,15 @@ export const generateUserMarkerResponse = (
|
|
|
112
114
|
updatedAt: date,
|
|
113
115
|
...params,
|
|
114
116
|
});
|
|
117
|
+
|
|
118
|
+
export const generateFeedMarkerResponse = (
|
|
119
|
+
params?: Partial<Amity.FeedMarker>,
|
|
120
|
+
): Amity.FeedMarker => ({
|
|
121
|
+
feedId: 'feedId',
|
|
122
|
+
entityId: 'entityId',
|
|
123
|
+
lastSegment: 0,
|
|
124
|
+
isDeleted: false,
|
|
125
|
+
createdAt: date,
|
|
126
|
+
updatedAt: date,
|
|
127
|
+
...params,
|
|
128
|
+
});
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* The function use to get value of hasMentioned field.
|
|
3
|
-
* function will get the value from marker params first, if there is no hasMentioned field, will look in to the cache.
|
|
4
|
-
* If not found in the cache, use `false` as defaul value.
|
|
5
|
-
*/
|
|
6
|
-
export declare const getChannelHasMentioned: (channel: Amity.RawChannel, marker?: Amity.ChannelMarker) => boolean;
|
|
7
|
-
//# sourceMappingURL=getChannelHasMentioned.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"getChannelHasMentioned.d.ts","sourceRoot":"","sources":["../../../src/channelRepository/utils/getChannelHasMentioned.ts"],"names":[],"mappings":"AAiBA;;;;GAIG;AAEH,eAAO,MAAM,sBAAsB,YAAa,MAAM,UAAU,WAAW,MAAM,aAAa,YAI7F,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"getChannelUnreadCount.d.ts","sourceRoot":"","sources":["../../../src/channelRepository/utils/getChannelUnreadCount.ts"],"names":[],"mappings":"AAiBA,eAAO,MAAM,qBAAqB,YAAa,MAAM,UAAU,WAAW,MAAM,aAAa,WAS5F,CAAC"}
|
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
export declare const calculateHasUnseenFlag: (params: {
|
|
2
|
-
targetId: Amity.Story['targetId'];
|
|
3
|
-
lastStoryExpiresAt: Amity.RawStoryTarget['lastStoryExpiresAt'];
|
|
4
|
-
lastStorySeenExpiresAt: Amity.RawStoryTarget['lastStorySeenExpiresAt'];
|
|
5
|
-
}) => boolean;
|
|
6
|
-
//# sourceMappingURL=calculateHasUnseenFlag.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"calculateHasUnseenFlag.d.ts","sourceRoot":"","sources":["../../../src/storyRepository/utils/calculateHasUnseenFlag.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,sBAAsB,WAAY;IAC7C,QAAQ,EAAE,MAAM,KAAK,CAAC,UAAU,CAAC,CAAC;IAClC,kBAAkB,EAAE,MAAM,cAAc,CAAC,oBAAoB,CAAC,CAAC;IAC/D,sBAAsB,EAAE,MAAM,cAAc,CAAC,wBAAwB,CAAC,CAAC;CACxE,KAAG,OAuCH,CAAC"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"getSubChannelHasMentioned.d.ts","sourceRoot":"","sources":["../../../src/subChannelRepository/utils/getSubChannelHasMentioned.ts"],"names":[],"mappings":"AAIA,wBAAgB,yBAAyB,CACvC,SAAS,EAAE,MAAM,EACjB,YAAY,EAAE,MAAM,EACpB,MAAM,CAAC,EAAE,KAAK,CAAC,gBAAgB,WA0BhC"}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import { pullFromCache } from '~/cache/api/pullFromCache';
|
|
2
|
-
import { getActiveUser } from '~/client/api/activeUser';
|
|
3
|
-
import { getResolver } from '~/core/model';
|
|
4
|
-
|
|
5
|
-
const getCachedMarker = (entityId: string) => {
|
|
6
|
-
const key = {
|
|
7
|
-
entityId,
|
|
8
|
-
userId: getActiveUser()._id,
|
|
9
|
-
};
|
|
10
|
-
|
|
11
|
-
return pullFromCache<Amity.ChannelMarker>([
|
|
12
|
-
'channelMarker',
|
|
13
|
-
'get',
|
|
14
|
-
getResolver('channelMarker')(key),
|
|
15
|
-
])?.data;
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
/**
|
|
19
|
-
* The function use to get value of hasMentioned field.
|
|
20
|
-
* function will get the value from marker params first, if there is no hasMentioned field, will look in to the cache.
|
|
21
|
-
* If not found in the cache, use `false` as defaul value.
|
|
22
|
-
*/
|
|
23
|
-
|
|
24
|
-
export const getChannelHasMentioned = (channel: Amity.RawChannel, marker?: Amity.ChannelMarker) => {
|
|
25
|
-
return marker?.hasMentioned !== undefined
|
|
26
|
-
? marker?.hasMentioned
|
|
27
|
-
: getCachedMarker(channel.channelId)?.hasMentioned ?? false;
|
|
28
|
-
};
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
import { pullFromCache } from '~/cache/api/pullFromCache';
|
|
2
|
-
import { getActiveUser } from '~/client/api/activeUser';
|
|
3
|
-
import { getResolver } from '~/core/model';
|
|
4
|
-
|
|
5
|
-
const getCachedMarker = (entityId: string) => {
|
|
6
|
-
const key = {
|
|
7
|
-
entityId,
|
|
8
|
-
userId: getActiveUser()._id,
|
|
9
|
-
};
|
|
10
|
-
|
|
11
|
-
return pullFromCache<Amity.ChannelMarker>([
|
|
12
|
-
'channelMarker',
|
|
13
|
-
'get',
|
|
14
|
-
getResolver('channelMarker')(key),
|
|
15
|
-
])?.data;
|
|
16
|
-
};
|
|
17
|
-
|
|
18
|
-
export const getChannelUnreadCount = (channel: Amity.RawChannel, marker?: Amity.ChannelMarker) => {
|
|
19
|
-
if (marker?.isDeleted) {
|
|
20
|
-
// NOTE: This is a temporary solution to handle the channel marker when the user is forced to
|
|
21
|
-
// leave the channel because currently backend can't handle this, so every time a user is banned
|
|
22
|
-
// from a channel or the channel is deleted the channel's unread count will reset to zero
|
|
23
|
-
return 0;
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
return marker?.unreadCount ?? getCachedMarker(channel.channelId)?.unreadCount ?? 0;
|
|
27
|
-
};
|