@amityco/ts-sdk-react-native 7.16.0 → 7.17.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.
Files changed (46) hide show
  1. package/dist/@types/domains/comment.d.ts +4 -0
  2. package/dist/@types/domains/comment.d.ts.map +1 -1
  3. package/dist/@types/domains/notification.d.ts +2 -0
  4. package/dist/@types/domains/notification.d.ts.map +1 -1
  5. package/dist/@types/domains/poll.d.ts +9 -3
  6. package/dist/@types/domains/poll.d.ts.map +1 -1
  7. package/dist/@types/domains/room.d.ts +9 -1
  8. package/dist/@types/domains/room.d.ts.map +1 -1
  9. package/dist/client/api/getProductCatalogueSetting.d.ts +1 -1
  10. package/dist/client/api/loginWithAccessToken.d.ts +1 -1
  11. package/dist/client/api/setAccessTokenHandler.d.ts +1 -1
  12. package/dist/commentRepository/api/createComment.d.ts +1 -1
  13. package/dist/commentRepository/api/createComment.d.ts.map +1 -1
  14. package/dist/commentRepository/api/queryComments.d.ts.map +1 -1
  15. package/dist/commentRepository/api/updateComment.d.ts +1 -1
  16. package/dist/commentRepository/api/updateComment.d.ts.map +1 -1
  17. package/dist/commentRepository/observers/getComments/CommentPaginationController.d.ts.map +1 -1
  18. package/dist/commentRepository/observers/tests/CommentPaginationController.test.d.ts +2 -0
  19. package/dist/commentRepository/observers/tests/CommentPaginationController.test.d.ts.map +1 -0
  20. package/dist/feedRepository/observers/getCommunityFeed.d.ts +1 -1
  21. package/dist/fileRepository/api/uploadAudio.d.ts.map +1 -1
  22. package/dist/index.cjs.js +60 -45
  23. package/dist/index.esm.js +60 -45
  24. package/dist/index.umd.js +2 -2
  25. package/dist/pollRepository/api/closePoll.d.ts.map +1 -1
  26. package/dist/pollRepository/api/createPoll.d.ts.map +1 -1
  27. package/dist/pollRepository/api/getPoll.d.ts.map +1 -1
  28. package/dist/pollRepository/api/votePoll.d.ts.map +1 -1
  29. package/dist/postRepository/api/createRoomPost.d.ts +1 -1
  30. package/dist/postRepository/api/pinProduct.d.ts +1 -1
  31. package/dist/postRepository/api/unpinProduct.d.ts +1 -1
  32. package/dist/postRepository/api/updateProductTags.d.ts +1 -1
  33. package/dist/productRepository/observers/getProduct.d.ts +1 -1
  34. package/dist/productRepository/observers/searchProducts.d.ts +1 -1
  35. package/dist/reactionRepository/utils/prepareMessagePayloadForCache.d.ts.map +1 -1
  36. package/dist/roomRepository/api/updateCohostPermission.d.ts +1 -1
  37. package/dist/roomRepository/events/onLocalRoomDidUpdate.d.ts +1 -1
  38. package/dist/roomRepository/events/onRoomDidUpdate.d.ts +1 -1
  39. package/dist/utils/linkedObject/index.d.ts +1 -0
  40. package/dist/utils/linkedObject/index.d.ts.map +1 -1
  41. package/dist/utils/linkedObject/pollLinkedObject.d.ts +2 -0
  42. package/dist/utils/linkedObject/pollLinkedObject.d.ts.map +1 -0
  43. package/dist/utils/linkedObject/postLinkedObject.d.ts.map +1 -1
  44. package/dist/utils/tests/dummy/comment.d.ts +1 -0
  45. package/dist/utils/tests/dummy/comment.d.ts.map +1 -1
  46. package/package.json +1 -1
package/dist/index.esm.js CHANGED
@@ -244,8 +244,8 @@ var AnalyticsSourceTypeEnum;
244
244
 
245
245
  function getVersion() {
246
246
  try {
247
- // the string ''v7.16.0-esm'' should be replaced by actual value by @rollup/plugin-replace
248
- return 'v7.16.0-esm';
247
+ // the string ''v7.17.0-esm'' should be replaced by actual value by @rollup/plugin-replace
248
+ return 'v7.17.0-esm';
249
249
  }
250
250
  catch (error) {
251
251
  return '__dev__';
@@ -21529,6 +21529,15 @@ const getUserMarker = async () => {
21529
21529
  return { data: latestUserMarker, cachedAt };
21530
21530
  };
21531
21531
 
21532
+ const getMessageFromMainDB = (messageId) => {
21533
+ var _a, _b;
21534
+ const message = (_a = pullFromCache(['message', 'get', messageId])) === null || _a === void 0 ? void 0 : _a.data;
21535
+ if (message)
21536
+ return message;
21537
+ const messages = queryCache(['message', 'get']);
21538
+ return (_b = messages === null || messages === void 0 ? void 0 : messages.find(({ data }) => data.messageId === messageId)) === null || _b === void 0 ? void 0 : _b.data;
21539
+ };
21540
+
21532
21541
  /** @hidden */
21533
21542
  /*
21534
21543
  * @param message payload from http request without myReactions
@@ -21536,9 +21545,9 @@ const getUserMarker = async () => {
21536
21545
  */
21537
21546
  const prepareMessagePayloadForCache = (payload, reactors, event) => {
21538
21547
  const client = getActiveClient();
21539
- const cached = pullFromCache(['message', 'get', payload.messageId]);
21548
+ const cached = getMessageFromMainDB(payload.messageId);
21540
21549
  // '[]' in cases where the new reaction is the first one
21541
- const myReactions = (cached === null || cached === void 0 ? void 0 : cached.data.myReactions) || [];
21550
+ const myReactions = (cached === null || cached === void 0 ? void 0 : cached.myReactions) || [];
21542
21551
  // add myReactions to the payload
21543
21552
  Object.assign(payload, { myReactions });
21544
21553
  // check if there are any updates to the reactions
@@ -22841,23 +22850,21 @@ const onChannelSetUserMuted = (callback) => {
22841
22850
  if (callbacks.length === 0) {
22842
22851
  const client = getActiveClient();
22843
22852
  const filter = async (payload) => {
22844
- var _a, _b;
22853
+ var _a, _b, _c;
22845
22854
  payload.userIds.forEach(userId =>
22846
22855
  // If muteTimeout > now => user is muted
22847
22856
  // Otherwise => user is unmuted
22848
22857
  upsertInCache(['channelUsers', 'get', `${payload.channelId}#${userId}`], {
22849
22858
  isMuted: Date.parse(payload.muteTimeout) > Date.now(),
22850
22859
  }));
22851
- const channel = (_a = pullFromCache([
22852
- 'channel',
22853
- 'get',
22854
- payload.channelId,
22855
- ])) === null || _a === void 0 ? void 0 : _a.data;
22856
- const channelUser = (_b = pullFromCache([
22860
+ const channel = (_b = (_a = queryCache(['channel', 'get'])) === null || _a === void 0 ? void 0 : _a.find(({ data }) => {
22861
+ return data.channelPublicId === payload.channelId;
22862
+ })) === null || _b === void 0 ? void 0 : _b.data;
22863
+ const channelUser = (_c = pullFromCache([
22857
22864
  'channelUsers',
22858
22865
  'get',
22859
22866
  `${payload.channelId}#${payload.userIds[0]}`,
22860
- ])) === null || _b === void 0 ? void 0 : _b.data;
22867
+ ])) === null || _c === void 0 ? void 0 : _c.data;
22861
22868
  if (channel && channelUser) {
22862
22869
  callbacks.forEach(cb => cb(channel, channelUser));
22863
22870
  }
@@ -23348,7 +23355,7 @@ const getSocialSettings = async () => {
23348
23355
  */
23349
23356
  /**
23350
23357
  * ```js
23351
- * import { getProductCatalogueSetting } from '@amityco/ts-sdk'
23358
+ * import { getProductCatalogueSetting } from '@amityco/ts-sdk-react-native'
23352
23359
  * const productCatalogueSetting = await getProductCatalogueSetting()
23353
23360
  * ```
23354
23361
  *
@@ -25577,7 +25584,7 @@ async function runMqtt$1() {
25577
25584
  */
25578
25585
  /**
25579
25586
  * ```js
25580
- * import { loginWithAccessToken } from '@amityco/ts-sdk'
25587
+ * import { loginWithAccessToken } from '@amityco/ts-sdk-react-native'
25581
25588
  * const success = await loginWithAccessToken('eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9...')
25582
25589
  * ```
25583
25590
  *
@@ -26827,7 +26834,7 @@ const loginAsBot = async (params) => {
26827
26834
  */
26828
26835
  /**
26829
26836
  * ```js
26830
- * import { setAccessTokenHandler } from '@amityco/ts-sdk'
26837
+ * import { setAccessTokenHandler } from '@amityco/ts-sdk-react-native'
26831
26838
  *
26832
26839
  * const tokenHandler = {
26833
26840
  * async onTokenRenew() {
@@ -29681,6 +29688,15 @@ const roomLinkedObject = (room) => {
29681
29688
  } });
29682
29689
  };
29683
29690
 
29691
+ const pollLinkedObject = (poll) => {
29692
+ return Object.assign(Object.assign({}, poll), { answers: poll.answers.map(answer => (Object.assign(Object.assign({}, answer), { get image() {
29693
+ var _a;
29694
+ if (!answer.fileId)
29695
+ return undefined;
29696
+ return (_a = pullFromCache(['file', 'get', answer.fileId])) === null || _a === void 0 ? void 0 : _a.data;
29697
+ } }))) });
29698
+ };
29699
+
29684
29700
  /*
29685
29701
  * verifies membership status
29686
29702
  */
@@ -30680,7 +30696,7 @@ const postLinkedObject = (post) => {
30680
30696
  const cache = (_b = pullFromCache(['poll', 'get', (_a = post === null || post === void 0 ? void 0 : post.data) === null || _a === void 0 ? void 0 : _a.pollId])) === null || _b === void 0 ? void 0 : _b.data;
30681
30697
  if (!cache)
30682
30698
  return;
30683
- return cache;
30699
+ return pollLinkedObject(cache);
30684
30700
  },
30685
30701
  getClipInfo() {
30686
30702
  var _a, _b;
@@ -31602,6 +31618,7 @@ const LinkedObject = {
31602
31618
  event: eventLinkedObject,
31603
31619
  eventResponse: eventResponseLinkedObject,
31604
31620
  product: productLinkedObject,
31621
+ poll: pollLinkedObject,
31605
31622
  };
31606
31623
 
31607
31624
  /* begin_public_function
@@ -32974,9 +32991,10 @@ const uploadClip = async (formData, feedType, onProgress) => {
32974
32991
  const uploadAudio = async (formData, onProgress) => {
32975
32992
  const client = getActiveClient();
32976
32993
  client.log('file/uploadAudio', formData);
32977
- const file = formData.get('file');
32978
- if (!file)
32994
+ const files = formData.getAll('file');
32995
+ if (files.length === 0)
32979
32996
  throw new Error('The formData object must have a `file` key with audio file.');
32997
+ const file = files[0];
32980
32998
  const accessType = GlobalFileAccessType$1.getInstance().getFileAccessType();
32981
32999
  formData.append('accessType', accessType);
32982
33000
  formData.append('preferredFilename', file.name);
@@ -36606,15 +36624,6 @@ class MessagePaginationController extends PaginationController {
36606
36624
  }
36607
36625
  }
36608
36626
 
36609
- const getMessageFromMainDB = (messageId) => {
36610
- var _a, _b;
36611
- const message = (_a = pullFromCache(['message', 'get', messageId])) === null || _a === void 0 ? void 0 : _a.data;
36612
- if (message)
36613
- return message;
36614
- const messages = queryCache(['message', 'get']);
36615
- return (_b = messages === null || messages === void 0 ? void 0 : messages.find(({ data }) => data.messageId === messageId)) === null || _b === void 0 ? void 0 : _b.data;
36616
- };
36617
-
36618
36627
  class MessageLiveCollectionController extends LiveCollectionController {
36619
36628
  constructor(query, callback) {
36620
36629
  const queryStreamId = hash(query);
@@ -42505,11 +42514,14 @@ const getComment = (commentId, callback) => {
42505
42514
 
42506
42515
  class CommentPaginationController extends PaginationController {
42507
42516
  async getRequest(queryParams, token) {
42508
- const { limit = COLLECTION_DEFAULT_PAGINATION_LIMIT, includeDeleted } = queryParams, params = __rest(queryParams, ["limit", "includeDeleted"]);
42517
+ var _a;
42518
+ const { pageSize, limit, includeDeleted } = queryParams, params = __rest(queryParams, ["pageSize", "limit", "includeDeleted"]);
42519
+ const effectiveLimit = (_a = pageSize !== null && pageSize !== void 0 ? pageSize : limit) !== null && _a !== void 0 ? _a : COLLECTION_DEFAULT_PAGINATION_LIMIT;
42509
42520
  const baseOptions = {
42510
- type: params.sortBy || queryParams.limit ? 'pagination' : undefined,
42521
+ type: params.sortBy || queryParams.limit || queryParams.pageSize ? 'pagination' : undefined,
42511
42522
  };
42512
- const options = token ? Object.assign(Object.assign({}, baseOptions), { token }) : Object.assign(Object.assign({}, baseOptions), { limit });
42523
+ const options = token
42524
+ ? Object.assign(Object.assign({}, baseOptions), { token }) : Object.assign(Object.assign({}, baseOptions), { pageSize: effectiveLimit, limit: effectiveLimit });
42513
42525
  const { data: queryResponse } = await this.http.get(`/api/v3/comments`, {
42514
42526
  params: Object.assign(Object.assign({}, params), { isDeleted: inferIsDeleted(includeDeleted), options }),
42515
42527
  });
@@ -43730,7 +43742,7 @@ class CommunityFeedLiveCollectionController extends LiveCollectionController {
43730
43742
  */
43731
43743
  /**
43732
43744
  * ```js
43733
- * import { FeedRepository } from '@amityco/ts-sdk'
43745
+ * import { FeedRepository } from '@amityco/ts-sdk-react-native'
43734
43746
  *
43735
43747
  * let posts = []
43736
43748
  * const unsubscribe = FeedRepository.getCommunityFeed({
@@ -44408,7 +44420,7 @@ const createMixedMediaPost = async (bundle) => {
44408
44420
  */
44409
44421
  /**
44410
44422
  * ```js
44411
- * import { PostRepository } from '@amityco/ts-sdk'
44423
+ * import { PostRepository } from '@amityco/ts-sdk-react-native'
44412
44424
  * const created = await PostRepository.createRoomPost({
44413
44425
  * targetType: 'user',
44414
44426
  * targetId: 'foobar',
@@ -44446,7 +44458,7 @@ const createRoomPost = async (bundle) => {
44446
44458
  */
44447
44459
  /**
44448
44460
  * ```js
44449
- * import { PostRepository } from '@amityco/ts-sdk'
44461
+ * import { PostRepository } from '@amityco/ts-sdk-react-native'
44450
44462
  * const pinProduct = await PostRepository.pinProduct(postId, pinnedProductId)
44451
44463
  * ```
44452
44464
  *
@@ -44480,7 +44492,7 @@ const pinProduct = async (postId, pinnedProductId) => {
44480
44492
  */
44481
44493
  /**
44482
44494
  * ```js
44483
- * import { PostRepository } from '@amityco/ts-sdk'
44495
+ * import { PostRepository } from '@amityco/ts-sdk-react-native'
44484
44496
  * const unpinProduct = await PostRepository.unpinProduct(postId)
44485
44497
  * ```
44486
44498
  *
@@ -44511,7 +44523,7 @@ const unpinProduct = async (postId) => {
44511
44523
  */
44512
44524
  /**
44513
44525
  * ```js
44514
- * import { PostRepository } from '@amityco/ts-sdk'
44526
+ * import { PostRepository } from '@amityco/ts-sdk-react-native'
44515
44527
  * const updateProductTags = await PostRepository.updateProductTags(postId, productTags)
44516
44528
  * ```
44517
44529
  *
@@ -45937,7 +45949,7 @@ const leaveRoom = async (roomId) => {
45937
45949
  */
45938
45950
  /**
45939
45951
  * ```js
45940
- * import { updateCohostPermission } from '@amityco/ts-sdk'
45952
+ * import { updateCohostPermission } from '@amityco/ts-sdk-react-native'
45941
45953
  * const updated = await updateCohostPermission('roomId', 'cohostId', true)
45942
45954
  * ```
45943
45955
  *
@@ -46343,7 +46355,7 @@ const onRoomTerminated = (callback) => {
46343
46355
 
46344
46356
  /**
46345
46357
  * ```js
46346
- * import { onRoomDidUpdate } from '@amityco/ts-sdk'
46358
+ * import { onRoomDidUpdate } from '@amityco/ts-sdk-react-native'
46347
46359
  * const dispose = onRoomDidUpdate(room => {
46348
46360
  * // ...
46349
46361
  * })
@@ -46515,7 +46527,7 @@ const onRoomLeft = (callback) => {
46515
46527
 
46516
46528
  /**
46517
46529
  * ```js
46518
- * import { onLocalRoomDidUpdate } from '@amityco/ts-sdk'
46530
+ * import { onLocalRoomDidUpdate } from '@amityco/ts-sdk-react-native'
46519
46531
  * const dispose = onLocalRoomDidUpdate(room => {
46520
46532
  * // ...
46521
46533
  * })
@@ -48089,7 +48101,7 @@ const createPoll = async (bundle) => {
48089
48101
  ingestInCache(data, { cachedAt });
48090
48102
  const { polls } = data;
48091
48103
  return {
48092
- data: polls[0],
48104
+ data: pollLinkedObject(polls[0]),
48093
48105
  cachedAt,
48094
48106
  };
48095
48107
  };
@@ -48121,8 +48133,9 @@ const closePoll = async (pollId) => {
48121
48133
  ingestInCache(data, { cachedAt });
48122
48134
  fireEvent('poll.updated', data);
48123
48135
  const { polls } = data;
48136
+ const poll = polls.find(poll => poll.pollId === pollId);
48124
48137
  return {
48125
- data: polls.find(poll => poll.pollId === pollId),
48138
+ data: pollLinkedObject(poll),
48126
48139
  cachedAt,
48127
48140
  };
48128
48141
  };
@@ -48153,8 +48166,9 @@ const getPoll$1 = async (pollId) => {
48153
48166
  if (client.cache)
48154
48167
  ingestInCache(data, { cachedAt });
48155
48168
  const { polls } = data;
48169
+ const poll = polls.find(poll => poll.pollId === pollId);
48156
48170
  return {
48157
- data: polls.find(poll => poll.pollId === pollId),
48171
+ data: pollLinkedObject(poll),
48158
48172
  cachedAt,
48159
48173
  };
48160
48174
  };
@@ -48181,7 +48195,7 @@ getPoll$1.locally = (pollId) => {
48181
48195
  if (!cached)
48182
48196
  return;
48183
48197
  return {
48184
- data: cached.data,
48198
+ data: pollLinkedObject(cached.data),
48185
48199
  cachedAt: cached.cachedAt,
48186
48200
  };
48187
48201
  };
@@ -48243,9 +48257,10 @@ const votePoll = async (pollId, answerIds) => {
48243
48257
  if (client.cache)
48244
48258
  ingestInCache(data, { cachedAt });
48245
48259
  const { polls } = data;
48260
+ const poll = polls.find(poll => poll.pollId === pollId);
48246
48261
  fireEvent('poll.updated', data);
48247
48262
  return {
48248
- data: polls.find(poll => poll.pollId === pollId),
48263
+ data: pollLinkedObject(poll),
48249
48264
  cachedAt,
48250
48265
  };
48251
48266
  };
@@ -51259,7 +51274,7 @@ getProduct$1.locally = (productId) => {
51259
51274
  */
51260
51275
  /**
51261
51276
  * ```js
51262
- * import { ProductRepository } from '@amityco/ts-sdk';
51277
+ * import { ProductRepository } from '@amityco/ts-sdk-react-native';
51263
51278
  *
51264
51279
  * let product;
51265
51280
  *
@@ -51382,7 +51397,7 @@ class SearchProductLiveCollectionController extends LiveCollectionController {
51382
51397
  */
51383
51398
  /**
51384
51399
  * ```js
51385
- * import { ProductRepository } from '@amityco/ts-sdk'
51400
+ * import { ProductRepository } from '@amityco/ts-sdk-react-native'
51386
51401
  *
51387
51402
  * let products = []
51388
51403
  * const unsub = ProductRepository.searchProducts({