@amityco/ts-sdk-react-native 6.26.1-4e1acd6.0 → 6.26.1-c3b0164.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/payload.d.ts +0 -1
- package/dist/@types/core/payload.d.ts.map +1 -1
- package/dist/commentRepository/observers/getComments.d.ts.map +1 -1
- package/dist/index.cjs.js +116 -155
- package/dist/index.esm.js +116 -155
- package/dist/index.umd.js +3 -3
- package/package.json +1 -1
- package/src/@types/core/payload.ts +0 -5
- package/src/commentRepository/observers/getComments.ts +141 -5
- package/dist/commentRepository/observers/getComments/CommentLiveCollectionController.d.ts +0 -14
- package/dist/commentRepository/observers/getComments/CommentLiveCollectionController.d.ts.map +0 -1
- package/dist/commentRepository/observers/getComments/CommentPaginationController.d.ts +0 -5
- package/dist/commentRepository/observers/getComments/CommentPaginationController.d.ts.map +0 -1
- package/dist/commentRepository/observers/getComments/CommentQueryStreamController.d.ts +0 -15
- package/dist/commentRepository/observers/getComments/CommentQueryStreamController.d.ts.map +0 -1
- package/dist/commentRepository/observers/getComments/enums.d.ts +0 -10
- package/dist/commentRepository/observers/getComments/enums.d.ts.map +0 -1
- package/dist/commentRepository/utils/payload.d.ts +0 -2
- package/dist/commentRepository/utils/payload.d.ts.map +0 -1
- package/src/commentRepository/observers/getComments/CommentLiveCollectionController.ts +0 -132
- package/src/commentRepository/observers/getComments/CommentPaginationController.ts +0 -25
- package/src/commentRepository/observers/getComments/CommentQueryStreamController.ts +0 -90
- package/src/commentRepository/observers/getComments/enums.ts +0 -9
- package/src/commentRepository/utils/payload.ts +0 -5
package/package.json
CHANGED
|
@@ -361,11 +361,6 @@ declare global {
|
|
|
361
361
|
communityUsers: Amity.Membership<'community'>[];
|
|
362
362
|
};
|
|
363
363
|
|
|
364
|
-
type ProcessedCommentPayload<T extends Amity.CommentContentType = any> = Omit<
|
|
365
|
-
CommentPayload<T>,
|
|
366
|
-
'users' | 'files' | 'communityUsers'
|
|
367
|
-
>;
|
|
368
|
-
|
|
369
364
|
type PollPayload = {
|
|
370
365
|
users: Amity.InternalUser[];
|
|
371
366
|
polls: Amity.Poll[];
|
|
@@ -1,7 +1,34 @@
|
|
|
1
|
+
/* eslint-disable no-use-before-define */
|
|
2
|
+
import { getResolver } from '~/core/model';
|
|
1
3
|
import { getActiveClient } from '~/client/api';
|
|
2
|
-
import { dropFromCache } from '~/cache/api';
|
|
4
|
+
import { dropFromCache, pullFromCache, pushToCache } from '~/cache/api';
|
|
3
5
|
|
|
4
|
-
import {
|
|
6
|
+
import {
|
|
7
|
+
createQuery,
|
|
8
|
+
filterByPropEquality,
|
|
9
|
+
queryOptions,
|
|
10
|
+
runQuery,
|
|
11
|
+
sortByFirstCreated,
|
|
12
|
+
sortByLastCreated,
|
|
13
|
+
} from '~/core/query';
|
|
14
|
+
|
|
15
|
+
import {
|
|
16
|
+
COLLECTION_DEFAULT_CACHING_POLICY,
|
|
17
|
+
COLLECTION_DEFAULT_PAGINATION_LIMIT,
|
|
18
|
+
} from '~/utils/constants';
|
|
19
|
+
|
|
20
|
+
import { CACHE_SHORTEN_LIFESPAN } from '~/cache/utils';
|
|
21
|
+
import { LinkedObject } from '~/utils/linkedObject';
|
|
22
|
+
import {
|
|
23
|
+
onCommentCreated,
|
|
24
|
+
onCommentDeleted,
|
|
25
|
+
onCommentFlagged,
|
|
26
|
+
onCommentReactionAdded,
|
|
27
|
+
onCommentReactionRemoved,
|
|
28
|
+
onCommentUnflagged,
|
|
29
|
+
onCommentUpdated,
|
|
30
|
+
} from '../events';
|
|
31
|
+
import { queryComments } from '../internalApi/queryComments';
|
|
5
32
|
|
|
6
33
|
/* begin_public_function
|
|
7
34
|
id: comment.query
|
|
@@ -40,11 +67,120 @@ export const getComments = (
|
|
|
40
67
|
const timestamp = Date.now();
|
|
41
68
|
log(`getComments(tmpid: ${timestamp}) > listen`);
|
|
42
69
|
|
|
43
|
-
const
|
|
44
|
-
|
|
70
|
+
const { limit: queryLimit, ...queryParams } = params;
|
|
71
|
+
|
|
72
|
+
const limit = queryLimit ?? COLLECTION_DEFAULT_PAGINATION_LIMIT;
|
|
73
|
+
const { policy = COLLECTION_DEFAULT_CACHING_POLICY } = config ?? {};
|
|
74
|
+
|
|
75
|
+
const disposers: Amity.Unsubscriber[] = [];
|
|
76
|
+
|
|
77
|
+
const sortBy = params.sortBy ? params.sortBy : 'lastCreated';
|
|
78
|
+
const cacheKey = [
|
|
79
|
+
'comment',
|
|
80
|
+
'collection',
|
|
81
|
+
{
|
|
82
|
+
referenceId: params.referenceType,
|
|
83
|
+
referenceType: params.referenceId,
|
|
84
|
+
parentId: params?.parentId || '',
|
|
85
|
+
sortBy,
|
|
86
|
+
},
|
|
87
|
+
];
|
|
88
|
+
|
|
89
|
+
const responder = (data: Amity.CommentLiveCollectionCache) => {
|
|
90
|
+
let comments: Amity.InternalComment[] =
|
|
91
|
+
data.data
|
|
92
|
+
.map(commentId => pullFromCache<Amity.InternalComment>(['comment', 'get', commentId])!)
|
|
93
|
+
.filter(({ data }) => data.parentId === params?.parentId)
|
|
94
|
+
.filter(Boolean)
|
|
95
|
+
.map(({ data }) => LinkedObject.comment(data)) ?? [];
|
|
96
|
+
|
|
97
|
+
if (!params.includeDeleted) {
|
|
98
|
+
comments = filterByPropEquality(comments, 'isDeleted', false);
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
comments = comments.sort(sortBy === 'lastCreated' ? sortByLastCreated : sortByFirstCreated);
|
|
102
|
+
|
|
103
|
+
callback({
|
|
104
|
+
onNextPage: onFetch,
|
|
105
|
+
data: comments,
|
|
106
|
+
hasNextPage: !!data.params?.page,
|
|
107
|
+
loading: data.loading,
|
|
108
|
+
error: data.error,
|
|
109
|
+
});
|
|
110
|
+
};
|
|
111
|
+
|
|
112
|
+
const realtimeRouter = (action: Amity.CommentActionType) => (comment: Amity.InternalComment) => {
|
|
113
|
+
const collection = pullFromCache<Amity.CommentLiveCollectionCache>(cacheKey)?.data;
|
|
114
|
+
|
|
115
|
+
if (
|
|
116
|
+
params.referenceId !== comment.referenceId ||
|
|
117
|
+
params.referenceType !== comment.referenceType ||
|
|
118
|
+
!collection
|
|
119
|
+
) {
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
if (action === 'onCreate') {
|
|
124
|
+
collection.data = [...new Set([comment.commentId, ...collection.data])];
|
|
125
|
+
} else if (action === 'onDelete') {
|
|
126
|
+
collection.data = collection.data.filter(p => p !== comment.commentId);
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
pushToCache(cacheKey, collection);
|
|
130
|
+
|
|
131
|
+
responder(collection);
|
|
132
|
+
};
|
|
133
|
+
|
|
134
|
+
const onFetch = (initial = false) => {
|
|
135
|
+
const collection = pullFromCache<Amity.CommentLiveCollectionCache>(cacheKey)?.data;
|
|
136
|
+
|
|
137
|
+
const comments = collection?.data ?? [];
|
|
138
|
+
|
|
139
|
+
if (!initial && comments.length > 0 && !collection?.params?.page) return;
|
|
140
|
+
|
|
141
|
+
const query = createQuery(queryComments, {
|
|
142
|
+
...queryParams,
|
|
143
|
+
limit: queryLimit,
|
|
144
|
+
page: !initial ? collection?.params.page : undefined,
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
runQuery(
|
|
148
|
+
query,
|
|
149
|
+
({ data: result, error, loading, paging }) => {
|
|
150
|
+
const page = paging?.next;
|
|
151
|
+
|
|
152
|
+
const data = {
|
|
153
|
+
loading,
|
|
154
|
+
error,
|
|
155
|
+
params: { page },
|
|
156
|
+
data: comments,
|
|
157
|
+
};
|
|
158
|
+
|
|
159
|
+
if (result) {
|
|
160
|
+
data.data = initial
|
|
161
|
+
? result.map(getResolver('comment')) // Replace a collection list with new data from BE
|
|
162
|
+
: [...new Set([...comments, ...result.map(getResolver('comment'))])];
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
pushToCache(cacheKey, data);
|
|
166
|
+
|
|
167
|
+
responder(data);
|
|
168
|
+
},
|
|
169
|
+
queryOptions(policy, CACHE_SHORTEN_LIFESPAN),
|
|
170
|
+
);
|
|
171
|
+
};
|
|
45
172
|
|
|
46
|
-
|
|
173
|
+
disposers.push(
|
|
174
|
+
onCommentCreated(realtimeRouter('onCreate')),
|
|
175
|
+
onCommentUpdated(realtimeRouter('onUpdate')),
|
|
176
|
+
onCommentDeleted(realtimeRouter('onDelete')),
|
|
177
|
+
onCommentFlagged(realtimeRouter('onFlagged')),
|
|
178
|
+
onCommentUnflagged(realtimeRouter('onUnflagged')),
|
|
179
|
+
onCommentReactionAdded(realtimeRouter('onReactionAdded')),
|
|
180
|
+
onCommentReactionRemoved(realtimeRouter('onReactionRemoved')),
|
|
181
|
+
);
|
|
47
182
|
|
|
183
|
+
onFetch(true);
|
|
48
184
|
disposers.push(() => dropFromCache(cacheKey));
|
|
49
185
|
|
|
50
186
|
return () => {
|
|
@@ -1,14 +0,0 @@
|
|
|
1
|
-
import { CommentPaginationController } from './CommentPaginationController';
|
|
2
|
-
import { LiveCollectionController } from '~/core/liveCollection/LiveCollectionController';
|
|
3
|
-
export declare class CommentLiveCollectionController extends LiveCollectionController<'comment', Amity.CommentLiveCollection, Amity.Comment, CommentPaginationController> {
|
|
4
|
-
private queryStreamController;
|
|
5
|
-
private query;
|
|
6
|
-
constructor(query: Amity.CommentLiveCollection, callback: Amity.LiveCollectionCallback<Amity.Comment>);
|
|
7
|
-
protected setup(): void;
|
|
8
|
-
protected persistModel(queryPayload: Amity.CommentPayload & Amity.Pagination): Promise<void>;
|
|
9
|
-
protected persistQueryStream({ response, direction, refresh, }: Amity.LiveCollectionPersistQueryStreamParams<'comment'>): void;
|
|
10
|
-
startSubscription(): Amity.Unsubscriber[];
|
|
11
|
-
notifyChange({ origin, loading, error }: Amity.LiveCollectionNotifyParams): void;
|
|
12
|
-
applyFilter(data: Amity.InternalComment[]): Amity.InternalComment<any>[];
|
|
13
|
-
}
|
|
14
|
-
//# sourceMappingURL=CommentLiveCollectionController.d.ts.map
|
package/dist/commentRepository/observers/getComments/CommentLiveCollectionController.d.ts.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CommentLiveCollectionController.d.ts","sourceRoot":"","sources":["../../../../src/commentRepository/observers/getComments/CommentLiveCollectionController.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,2BAA2B,EAAE,MAAM,+BAA+B,CAAC;AAE5E,OAAO,EAAE,wBAAwB,EAAE,MAAM,gDAAgD,CAAC;AAgB1F,qBAAa,+BAAgC,SAAQ,wBAAwB,CAC3E,SAAS,EACT,KAAK,CAAC,qBAAqB,EAC3B,KAAK,CAAC,OAAO,EACb,2BAA2B,CAC5B;IACC,OAAO,CAAC,qBAAqB,CAA+B;IAE5D,OAAO,CAAC,KAAK,CAA8B;gBAGzC,KAAK,EAAE,KAAK,CAAC,qBAAqB,EAClC,QAAQ,EAAE,KAAK,CAAC,sBAAsB,CAAC,KAAK,CAAC,OAAO,CAAC;IAoBvD,SAAS,CAAC,KAAK;cAUC,YAAY,CAAC,YAAY,EAAE,KAAK,CAAC,cAAc,GAAG,KAAK,CAAC,UAAU;IAIlF,SAAS,CAAC,kBAAkB,CAAC,EAC3B,QAAQ,EACR,SAAS,EACT,OAAO,GACR,EAAE,KAAK,CAAC,sCAAsC,CAAC,SAAS,CAAC;IAI1D,iBAAiB;IAYjB,YAAY,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,EAAE,KAAK,CAAC,0BAA0B;IAsBzE,WAAW,CAAC,IAAI,EAAE,KAAK,CAAC,eAAe,EAAE;CAuB1C"}
|
|
@@ -1,5 +0,0 @@
|
|
|
1
|
-
import { PaginationController } from '~/core/liveCollection/PaginationController';
|
|
2
|
-
export declare class CommentPaginationController extends PaginationController<'comment', Amity.CommentLiveCollection> {
|
|
3
|
-
getRequest(queryParams: Amity.CommentLiveCollection, token: string | undefined): Promise<Amity.CommentPayload<any> & Amity.Pagination>;
|
|
4
|
-
}
|
|
5
|
-
//# sourceMappingURL=CommentPaginationController.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CommentPaginationController.d.ts","sourceRoot":"","sources":["../../../../src/commentRepository/observers/getComments/CommentPaginationController.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,4CAA4C,CAAC;AAIlF,qBAAa,2BAA4B,SAAQ,oBAAoB,CACnE,SAAS,EACT,KAAK,CAAC,qBAAqB,CAC5B;IACO,UAAU,CAAC,WAAW,EAAE,KAAK,CAAC,qBAAqB,EAAE,KAAK,EAAE,MAAM,GAAG,SAAS;CAgBrF"}
|
|
@@ -1,15 +0,0 @@
|
|
|
1
|
-
import { QueryStreamController } from '~/core/liveCollection/QueryStreamController';
|
|
2
|
-
import { EnumCommentActions } from './enums';
|
|
3
|
-
export declare class CommentQueryStreamController extends QueryStreamController<Amity.CommentPayload, Amity.CommentLiveCollection> {
|
|
4
|
-
private notifyChange;
|
|
5
|
-
private preparePayload;
|
|
6
|
-
constructor(query: Amity.CommentLiveCollection, cacheKey: string[], notifyChange: (params: Amity.LiveCollectionNotifyParams) => void, preparePayload: (response: Amity.CommentPayload) => Amity.ProcessedCommentPayload);
|
|
7
|
-
saveToMainDB(response: Amity.CommentPayload): Promise<void>;
|
|
8
|
-
appendToQueryStream(response: Amity.CommentPayload & Partial<Amity.Pagination>, direction: Amity.LiveCollectionPageDirection, refresh?: boolean): void;
|
|
9
|
-
reactor(action: EnumCommentActions): (comment: Amity.InternalComment) => void;
|
|
10
|
-
subscribeRTE(createSubscriber: {
|
|
11
|
-
fn: (reactor: (comment: Amity.InternalComment) => void) => Amity.Unsubscriber;
|
|
12
|
-
action: EnumCommentActions;
|
|
13
|
-
}[]): Amity.Unsubscriber[];
|
|
14
|
-
}
|
|
15
|
-
//# sourceMappingURL=CommentQueryStreamController.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"CommentQueryStreamController.d.ts","sourceRoot":"","sources":["../../../../src/commentRepository/observers/getComments/CommentQueryStreamController.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,6CAA6C,CAAC;AAKpF,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAE7C,qBAAa,4BAA6B,SAAQ,qBAAqB,CACrE,KAAK,CAAC,cAAc,EACpB,KAAK,CAAC,qBAAqB,CAC5B;IACC,OAAO,CAAC,YAAY,CAAqD;IAEzE,OAAO,CAAC,cAAc,CAAoE;gBAGxF,KAAK,EAAE,KAAK,CAAC,qBAAqB,EAClC,QAAQ,EAAE,MAAM,EAAE,EAClB,YAAY,EAAE,CAAC,MAAM,EAAE,KAAK,CAAC,0BAA0B,KAAK,IAAI,EAChE,cAAc,EAAE,CAAC,QAAQ,EAAE,KAAK,CAAC,cAAc,KAAK,KAAK,CAAC,uBAAuB;IAO7E,YAAY,CAAC,QAAQ,EAAE,KAAK,CAAC,cAAc;IAWjD,mBAAmB,CACjB,QAAQ,EAAE,KAAK,CAAC,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC,UAAU,CAAC,EAC1D,SAAS,EAAE,KAAK,CAAC,2BAA2B,EAC5C,OAAO,UAAQ;IAkBjB,OAAO,CAAC,MAAM,EAAE,kBAAkB,aACf,MAAM,eAAe;IAsBxC,YAAY,CACV,gBAAgB,EAAE;QAChB,EAAE,EAAE,CAAC,OAAO,EAAE,CAAC,OAAO,EAAE,KAAK,CAAC,eAAe,KAAK,IAAI,KAAK,KAAK,CAAC,YAAY,CAAC;QAC9E,MAAM,EAAE,kBAAkB,CAAC;KAC5B,EAAE;CAIN"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
export declare enum EnumCommentActions {
|
|
2
|
-
OnCommentCreated = "onCommentCreated",
|
|
3
|
-
OnCommentUpdated = "onCommentUpdated",
|
|
4
|
-
OnCommentDeleted = "onCommentDeleted",
|
|
5
|
-
OnCommentFlagged = "onCommentFlagged",
|
|
6
|
-
OnCommentUnflagged = "onCommentUnflagged",
|
|
7
|
-
OnCommentReactionAdded = "onCommentReactionAdded",
|
|
8
|
-
OnCommentReactionRemoved = "onCommentReactionRemoved"
|
|
9
|
-
}
|
|
10
|
-
//# sourceMappingURL=enums.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"enums.d.ts","sourceRoot":"","sources":["../../../../src/commentRepository/observers/getComments/enums.ts"],"names":[],"mappings":"AAAA,oBAAY,kBAAkB;IAC5B,gBAAgB,qBAAqB;IACrC,gBAAgB,qBAAqB;IACrC,gBAAgB,qBAAqB;IACrC,gBAAgB,qBAAqB;IACrC,kBAAkB,uBAAuB;IACzC,sBAAsB,2BAA2B;IACjD,wBAAwB,6BAA6B;CACtD"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"payload.d.ts","sourceRoot":"","sources":["../../../src/commentRepository/utils/payload.ts"],"names":[],"mappings":"AAAA,wBAAgB,qBAAqB,CACnC,OAAO,EAAE,KAAK,CAAC,cAAc,GAC5B,KAAK,CAAC,uBAAuB,CAE/B"}
|
|
@@ -1,132 +0,0 @@
|
|
|
1
|
-
import hash from 'object-hash';
|
|
2
|
-
import { pullFromCache, pushToCache } from '~/cache/api';
|
|
3
|
-
import { CommentPaginationController } from './CommentPaginationController';
|
|
4
|
-
import { CommentQueryStreamController } from './CommentQueryStreamController';
|
|
5
|
-
import { LiveCollectionController } from '~/core/liveCollection/LiveCollectionController';
|
|
6
|
-
import {
|
|
7
|
-
onCommentCreated,
|
|
8
|
-
onCommentUpdated,
|
|
9
|
-
onCommentDeleted,
|
|
10
|
-
onCommentFlagged,
|
|
11
|
-
onCommentUnflagged,
|
|
12
|
-
onCommentReactionAdded,
|
|
13
|
-
onCommentReactionRemoved,
|
|
14
|
-
} from '~/commentRepository/events';
|
|
15
|
-
import { filterByPropEquality, sortByFirstCreated, sortByLastCreated } from '~/core/query';
|
|
16
|
-
import { isNonNullable } from '~/utils';
|
|
17
|
-
import { EnumCommentActions } from './enums';
|
|
18
|
-
import { LinkedObject } from '~/utils/linkedObject';
|
|
19
|
-
import { prepareCommentPayload } from '~/commentRepository/utils/payload';
|
|
20
|
-
|
|
21
|
-
export class CommentLiveCollectionController extends LiveCollectionController<
|
|
22
|
-
'comment',
|
|
23
|
-
Amity.CommentLiveCollection,
|
|
24
|
-
Amity.Comment,
|
|
25
|
-
CommentPaginationController
|
|
26
|
-
> {
|
|
27
|
-
private queryStreamController: CommentQueryStreamController;
|
|
28
|
-
|
|
29
|
-
private query: Amity.CommentLiveCollection;
|
|
30
|
-
|
|
31
|
-
constructor(
|
|
32
|
-
query: Amity.CommentLiveCollection,
|
|
33
|
-
callback: Amity.LiveCollectionCallback<Amity.Comment>,
|
|
34
|
-
) {
|
|
35
|
-
const queryStreamId = hash(query);
|
|
36
|
-
const cacheKey = ['comments', 'collection', queryStreamId];
|
|
37
|
-
const paginationController = new CommentPaginationController(query);
|
|
38
|
-
|
|
39
|
-
super(paginationController, queryStreamId, cacheKey, callback);
|
|
40
|
-
|
|
41
|
-
this.query = query;
|
|
42
|
-
this.queryStreamController = new CommentQueryStreamController(
|
|
43
|
-
this.query,
|
|
44
|
-
this.cacheKey,
|
|
45
|
-
this.notifyChange.bind(this),
|
|
46
|
-
prepareCommentPayload,
|
|
47
|
-
);
|
|
48
|
-
|
|
49
|
-
this.callback = callback.bind(this);
|
|
50
|
-
this.loadPage({ initial: true });
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
protected setup() {
|
|
54
|
-
const collection = pullFromCache<Amity.CommentLiveCollectionCache>(this.cacheKey)?.data;
|
|
55
|
-
if (!collection) {
|
|
56
|
-
pushToCache(this.cacheKey, {
|
|
57
|
-
data: [],
|
|
58
|
-
params: {},
|
|
59
|
-
});
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
protected async persistModel(queryPayload: Amity.CommentPayload & Amity.Pagination) {
|
|
64
|
-
await this.queryStreamController.saveToMainDB(queryPayload);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
protected persistQueryStream({
|
|
68
|
-
response,
|
|
69
|
-
direction,
|
|
70
|
-
refresh,
|
|
71
|
-
}: Amity.LiveCollectionPersistQueryStreamParams<'comment'>) {
|
|
72
|
-
this.queryStreamController.appendToQueryStream(response, direction, refresh);
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
startSubscription() {
|
|
76
|
-
return this.queryStreamController.subscribeRTE([
|
|
77
|
-
{ fn: onCommentCreated, action: EnumCommentActions.OnCommentCreated },
|
|
78
|
-
{ fn: onCommentUpdated, action: EnumCommentActions.OnCommentUpdated },
|
|
79
|
-
{ fn: onCommentDeleted, action: EnumCommentActions.OnCommentDeleted },
|
|
80
|
-
{ fn: onCommentFlagged, action: EnumCommentActions.OnCommentFlagged },
|
|
81
|
-
{ fn: onCommentUnflagged, action: EnumCommentActions.OnCommentUnflagged },
|
|
82
|
-
{ fn: onCommentReactionAdded, action: EnumCommentActions.OnCommentReactionAdded },
|
|
83
|
-
{ fn: onCommentReactionRemoved, action: EnumCommentActions.OnCommentReactionRemoved },
|
|
84
|
-
]);
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
notifyChange({ origin, loading, error }: Amity.LiveCollectionNotifyParams) {
|
|
88
|
-
const collection = pullFromCache<Amity.CommentLiveCollectionCache>(this.cacheKey)?.data;
|
|
89
|
-
if (!collection) return;
|
|
90
|
-
|
|
91
|
-
const data = this.applyFilter(
|
|
92
|
-
collection.data
|
|
93
|
-
.map(id => pullFromCache<Amity.InternalComment>(['comments', 'get', id])!)
|
|
94
|
-
.filter(isNonNullable)
|
|
95
|
-
.map(({ data }) => data) ?? [],
|
|
96
|
-
).map(LinkedObject.comment);
|
|
97
|
-
|
|
98
|
-
if (!this.shouldNotify(data) && origin === 'event') return;
|
|
99
|
-
|
|
100
|
-
this.callback({
|
|
101
|
-
onNextPage: () => this.loadPage({ direction: Amity.LiveCollectionPageDirection.NEXT }),
|
|
102
|
-
data,
|
|
103
|
-
hasNextPage: !!this.paginationController.getNextToken(),
|
|
104
|
-
loading,
|
|
105
|
-
error,
|
|
106
|
-
});
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
applyFilter(data: Amity.InternalComment[]) {
|
|
110
|
-
let comments = data;
|
|
111
|
-
|
|
112
|
-
if (this.query.includeDeleted) {
|
|
113
|
-
comments = filterByPropEquality(comments, 'isDeleted', false);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
if (this.query.parentId) {
|
|
117
|
-
comments = comments.filter(comment => comment.parentId === this.query.parentId);
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
switch (this.query.sortBy) {
|
|
121
|
-
case 'firstCreated':
|
|
122
|
-
comments = comments.sort(sortByFirstCreated);
|
|
123
|
-
break;
|
|
124
|
-
case 'lastCreated':
|
|
125
|
-
default:
|
|
126
|
-
comments = comments.sort(sortByLastCreated);
|
|
127
|
-
break;
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
return comments;
|
|
131
|
-
}
|
|
132
|
-
}
|
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { PaginationController } from '~/core/liveCollection/PaginationController';
|
|
2
|
-
import { COLLECTION_DEFAULT_PAGINATION_LIMIT } from '~/utils/constants';
|
|
3
|
-
import { inferIsDeleted } from '~/utils/inferIsDeleted';
|
|
4
|
-
|
|
5
|
-
export class CommentPaginationController extends PaginationController<
|
|
6
|
-
'comment',
|
|
7
|
-
Amity.CommentLiveCollection
|
|
8
|
-
> {
|
|
9
|
-
async getRequest(queryParams: Amity.CommentLiveCollection, token: string | undefined) {
|
|
10
|
-
const { limit = COLLECTION_DEFAULT_PAGINATION_LIMIT, includeDeleted, ...params } = queryParams;
|
|
11
|
-
const options = token ? { token } : { limit };
|
|
12
|
-
|
|
13
|
-
const { data: queryResponse } = await this.http.get<Amity.CommentPayload & Amity.Pagination>(
|
|
14
|
-
`/api/v3/comments`,
|
|
15
|
-
{
|
|
16
|
-
params: {
|
|
17
|
-
...params,
|
|
18
|
-
isDeleted: inferIsDeleted(includeDeleted),
|
|
19
|
-
options,
|
|
20
|
-
},
|
|
21
|
-
},
|
|
22
|
-
);
|
|
23
|
-
return queryResponse;
|
|
24
|
-
}
|
|
25
|
-
}
|
|
@@ -1,90 +0,0 @@
|
|
|
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
|
-
import { EnumCommentActions } from './enums';
|
|
7
|
-
|
|
8
|
-
export class CommentQueryStreamController extends QueryStreamController<
|
|
9
|
-
Amity.CommentPayload,
|
|
10
|
-
Amity.CommentLiveCollection
|
|
11
|
-
> {
|
|
12
|
-
private notifyChange: (params: Amity.LiveCollectionNotifyParams) => void;
|
|
13
|
-
|
|
14
|
-
private preparePayload: (response: Amity.CommentPayload) => Amity.ProcessedCommentPayload;
|
|
15
|
-
|
|
16
|
-
constructor(
|
|
17
|
-
query: Amity.CommentLiveCollection,
|
|
18
|
-
cacheKey: string[],
|
|
19
|
-
notifyChange: (params: Amity.LiveCollectionNotifyParams) => void,
|
|
20
|
-
preparePayload: (response: Amity.CommentPayload) => Amity.ProcessedCommentPayload,
|
|
21
|
-
) {
|
|
22
|
-
super(query, cacheKey);
|
|
23
|
-
this.notifyChange = notifyChange;
|
|
24
|
-
this.preparePayload = preparePayload;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
async saveToMainDB(response: Amity.CommentPayload) {
|
|
28
|
-
const processedPayload = await this.preparePayload(response);
|
|
29
|
-
|
|
30
|
-
const client = getActiveClient();
|
|
31
|
-
const cachedAt = client.cache && Date.now();
|
|
32
|
-
|
|
33
|
-
if (client.cache) {
|
|
34
|
-
ingestInCache(processedPayload, { cachedAt });
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
appendToQueryStream(
|
|
39
|
-
response: Amity.CommentPayload & Partial<Amity.Pagination>,
|
|
40
|
-
direction: Amity.LiveCollectionPageDirection,
|
|
41
|
-
refresh = false,
|
|
42
|
-
) {
|
|
43
|
-
if (refresh) {
|
|
44
|
-
pushToCache(this.cacheKey, {
|
|
45
|
-
data: response.comments.map(getResolver('comment')),
|
|
46
|
-
});
|
|
47
|
-
} else {
|
|
48
|
-
const collection = pullFromCache<Amity.CommunityLiveCollectionCache>(this.cacheKey)?.data;
|
|
49
|
-
|
|
50
|
-
const comments = collection?.data ?? [];
|
|
51
|
-
|
|
52
|
-
pushToCache(this.cacheKey, {
|
|
53
|
-
...collection,
|
|
54
|
-
data: [...new Set([...comments, ...response.comments.map(getResolver('comment'))])],
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
reactor(action: EnumCommentActions) {
|
|
60
|
-
return (comment: Amity.InternalComment) => {
|
|
61
|
-
const collection = pullFromCache<Amity.CommentLiveCollectionCache>(this.cacheKey)?.data;
|
|
62
|
-
|
|
63
|
-
if (
|
|
64
|
-
this.query.referenceId !== comment.referenceId ||
|
|
65
|
-
this.query.referenceType !== comment.referenceType ||
|
|
66
|
-
!collection
|
|
67
|
-
) {
|
|
68
|
-
return;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
if (action === EnumCommentActions.OnCommentCreated) {
|
|
72
|
-
collection.data = [...new Set([comment.commentId, ...collection.data])];
|
|
73
|
-
} else if (action === EnumCommentActions.OnCommentDeleted) {
|
|
74
|
-
collection.data = collection.data.filter(p => p !== comment.commentId);
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
pushToCache(this.cacheKey, collection);
|
|
78
|
-
this.notifyChange({ origin: Amity.LiveDataOrigin.EVENT, loading: false });
|
|
79
|
-
};
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
subscribeRTE(
|
|
83
|
-
createSubscriber: {
|
|
84
|
-
fn: (reactor: (comment: Amity.InternalComment) => void) => Amity.Unsubscriber;
|
|
85
|
-
action: EnumCommentActions;
|
|
86
|
-
}[],
|
|
87
|
-
) {
|
|
88
|
-
return createSubscriber.map(subscriber => subscriber.fn(this.reactor(subscriber.action)));
|
|
89
|
-
}
|
|
90
|
-
}
|
|
@@ -1,9 +0,0 @@
|
|
|
1
|
-
export enum EnumCommentActions {
|
|
2
|
-
OnCommentCreated = 'onCommentCreated',
|
|
3
|
-
OnCommentUpdated = 'onCommentUpdated',
|
|
4
|
-
OnCommentDeleted = 'onCommentDeleted',
|
|
5
|
-
OnCommentFlagged = 'onCommentFlagged',
|
|
6
|
-
OnCommentUnflagged = 'onCommentUnflagged',
|
|
7
|
-
OnCommentReactionAdded = 'onCommentReactionAdded',
|
|
8
|
-
OnCommentReactionRemoved = 'onCommentReactionRemoved',
|
|
9
|
-
}
|