@amityco/ts-sdk 7.7.1-c7691770.0 → 7.7.1-d8ab682e.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 (68) hide show
  1. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/@types/domains/hashtag.d.ts +1 -1
  2. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/@types/domains/hashtag.js.map +1 -1
  3. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/@types/domains/post.d.ts +12 -1
  4. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/@types/domains/post.d.ts.map +1 -1
  5. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/@types/domains/post.js.map +1 -1
  6. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/api/getPostsByHashtag.d.ts +15 -0
  7. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/api/getPostsByHashtag.d.ts.map +1 -0
  8. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/api/getPostsByHashtag.js +61 -0
  9. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/api/getPostsByHashtag.js.map +1 -0
  10. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/api/index.d.ts +1 -0
  11. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/api/index.d.ts.map +1 -1
  12. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/api/index.js +1 -0
  13. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/api/index.js.map +1 -1
  14. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/api/queryPosts.js +2 -2
  15. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/api/queryPosts.js.map +1 -1
  16. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/getPostsByHashtag/SearchPostLiveCollectionController.d.ts +14 -0
  17. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/getPostsByHashtag/SearchPostLiveCollectionController.d.ts.map +1 -0
  18. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/getPostsByHashtag/SearchPostLiveCollectionController.js +126 -0
  19. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/getPostsByHashtag/SearchPostLiveCollectionController.js.map +1 -0
  20. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/getPostsByHashtag/SearchPostPaginationController.d.ts +5 -0
  21. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/getPostsByHashtag/SearchPostPaginationController.d.ts.map +1 -0
  22. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/getPostsByHashtag/SearchPostPaginationController.js +27 -0
  23. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/getPostsByHashtag/SearchPostPaginationController.js.map +1 -0
  24. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/getPostsByHashtag/SearchPostQueryStreamController.d.ts +15 -0
  25. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/getPostsByHashtag/SearchPostQueryStreamController.d.ts.map +1 -0
  26. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/getPostsByHashtag/SearchPostQueryStreamController.js +65 -0
  27. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/getPostsByHashtag/SearchPostQueryStreamController.js.map +1 -0
  28. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/index.d.ts +1 -0
  29. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/index.d.ts.map +1 -1
  30. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/index.js +1 -0
  31. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/index.js.map +1 -1
  32. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/searchPostsByHashtag.d.ts +22 -0
  33. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/searchPostsByHashtag.d.ts.map +1 -0
  34. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/searchPostsByHashtag.js +45 -0
  35. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/dist/postRepository/observers/searchPostsByHashtag.js.map +1 -0
  36. package/.rollup.cache/home/runner/work/AmityTypescriptSDK/AmityTypescriptSDK/packages/sdk/tsconfig.tsbuildinfo +1 -1
  37. package/dist/@types/domains/hashtag.d.ts +1 -1
  38. package/dist/@types/domains/post.d.ts +12 -1
  39. package/dist/@types/domains/post.d.ts.map +1 -1
  40. package/dist/index.cjs.js +289 -1
  41. package/dist/index.esm.js +289 -1
  42. package/dist/index.umd.js +4 -4
  43. package/dist/postRepository/api/getPostsByHashtag.d.ts +15 -0
  44. package/dist/postRepository/api/getPostsByHashtag.d.ts.map +1 -0
  45. package/dist/postRepository/api/index.d.ts +1 -0
  46. package/dist/postRepository/api/index.d.ts.map +1 -1
  47. package/dist/postRepository/observers/getPostsByHashtag/SearchPostLiveCollectionController.d.ts +14 -0
  48. package/dist/postRepository/observers/getPostsByHashtag/SearchPostLiveCollectionController.d.ts.map +1 -0
  49. package/dist/postRepository/observers/getPostsByHashtag/SearchPostPaginationController.d.ts +5 -0
  50. package/dist/postRepository/observers/getPostsByHashtag/SearchPostPaginationController.d.ts.map +1 -0
  51. package/dist/postRepository/observers/getPostsByHashtag/SearchPostQueryStreamController.d.ts +15 -0
  52. package/dist/postRepository/observers/getPostsByHashtag/SearchPostQueryStreamController.d.ts.map +1 -0
  53. package/dist/postRepository/observers/index.d.ts +1 -0
  54. package/dist/postRepository/observers/index.d.ts.map +1 -1
  55. package/dist/postRepository/observers/searchPostsByHashtag.d.ts +22 -0
  56. package/dist/postRepository/observers/searchPostsByHashtag.d.ts.map +1 -0
  57. package/package.json +1 -1
  58. package/src/@types/domains/hashtag.ts +1 -1
  59. package/src/@types/domains/post.ts +16 -1
  60. package/src/postRepository/api/getPostsByHashtag.ts +78 -0
  61. package/src/postRepository/api/index.ts +2 -0
  62. package/src/postRepository/api/queryPosts.ts +2 -2
  63. package/src/postRepository/observers/getPostsByHashtag/SearchPostLiveCollectionController.ts +183 -0
  64. package/src/postRepository/observers/getPostsByHashtag/SearchPostPaginationController.ts +49 -0
  65. package/src/postRepository/observers/getPostsByHashtag/SearchPostQueryStreamController.ts +99 -0
  66. package/src/postRepository/observers/index.ts +1 -0
  67. package/src/postRepository/observers/searchPostsByHashtag.ts +56 -0
  68. package/tsconfig.tsbuildinfo +1 -1
package/dist/index.esm.js CHANGED
@@ -39763,6 +39763,60 @@ const createClipPost = async (bundle) => {
39763
39763
  };
39764
39764
  /* end_public_function */
39765
39765
 
39766
+ /**
39767
+ * ```js
39768
+ * import { PostRepository } from '@amityco/ts-sdk';
39769
+ * const { data: posts, prevPage, nextPage } = await PostRepository.searchPostsByHashtag({ hashtags: ['amity'], limit: 10 });
39770
+ * ```
39771
+ *
39772
+ * Queries a paginable list of {@link Amity.Post} objects
39773
+ *
39774
+ * @param query The query parameters
39775
+ * @returns posts
39776
+ * @category Post API
39777
+ * @async
39778
+ */
39779
+ const getPostsByHashtag = async (query) => {
39780
+ const client = getActiveClient();
39781
+ client.log('post/queryByHashtag', query);
39782
+ const { page, limit = 10 } = query, params = __rest(query, ["page", "limit"]);
39783
+ const { dataTypes, matchingOnlyParentPost, hashtags } = params;
39784
+ const options = (() => {
39785
+ if (page)
39786
+ return { token: page };
39787
+ if (limit)
39788
+ return { limit };
39789
+ return undefined;
39790
+ })();
39791
+ // API-FIX: parameters should be querystring. (1)
39792
+ // API-FIX: backend should answer Amity.Response (2)
39793
+ // const { data } = await client.http.get<Amity.Response<Amity.PagedResponse<Amity.PostPayload>>>(
39794
+ const { data } = await client.http.get(`/api/v1/search/posts`, {
39795
+ params: Object.assign(Object.assign({}, params), { hashtags,
39796
+ /*
39797
+ * when creating post like image, file, video BE will create 2 posts
39798
+ * 1. parent post to store text with dataType=text
39799
+ * 2. child post to store dataTypes post data
39800
+ *
39801
+ * By default, BE queries only parent post
39802
+ */
39803
+ matchingOnlyParentPost: matchingOnlyParentPost !== null && matchingOnlyParentPost !== void 0 ? matchingOnlyParentPost : !(dataTypes === null || dataTypes === void 0 ? void 0 : dataTypes.length), options }),
39804
+ });
39805
+ // API-FIX: backend should answer Amity.Response (2)
39806
+ // const { paging, posts } = unwrapPayload(data)
39807
+ // unpacking
39808
+ const { paging } = data, payload = __rest(data, ["paging"]);
39809
+ const preparedPayload = prepareMembershipPayload(payload, 'communityUsers');
39810
+ const { posts } = payload;
39811
+ const cachedAt = client.cache && Date.now();
39812
+ if (client.cache) {
39813
+ ingestInCache(preparedPayload, { cachedAt });
39814
+ const cacheKey = ['post', 'query', Object.assign(Object.assign({}, params), { options })];
39815
+ pushToCache(cacheKey, { posts: posts.map(getResolver('post')), paging });
39816
+ }
39817
+ return { data: posts.map(LinkedObject.post), cachedAt, paging };
39818
+ };
39819
+
39766
39820
  /* begin_public_function
39767
39821
  id: comment.get_by_ids
39768
39822
  */
@@ -41650,6 +41704,238 @@ const semanticSearchPosts = (params, callback, config) => {
41650
41704
  };
41651
41705
  };
41652
41706
 
41707
+ class SearchPostPaginationController extends PaginationController {
41708
+ async getRequest(queryParams, token) {
41709
+ const { limit = COLLECTION_DEFAULT_PAGINATION_LIMIT, matchingOnlyParentPost, hashtags, dataTypes, targetType = 'all' } = queryParams, params = __rest(queryParams, ["limit", "matchingOnlyParentPost", "hashtags", "dataTypes", "targetType"]);
41710
+ const baseOptions = {
41711
+ type: params.sortBy || queryParams.limit ? 'pagination' : undefined,
41712
+ };
41713
+ const options = token ? Object.assign(Object.assign({}, baseOptions), { token }) : Object.assign(Object.assign({}, baseOptions), { limit });
41714
+ const { data: queryResponse } = await this.http.get(`/api/v1/search/posts`, {
41715
+ params: Object.assign(Object.assign({}, params), { hashtags,
41716
+ dataTypes,
41717
+ targetType,
41718
+ /*
41719
+ * when creating post like image, file, video BE will create 2 posts
41720
+ * 1. parent post to store text with dataType=text
41721
+ * 2. child post to store dataTypes post data
41722
+ *
41723
+ * By default, BE queries only parent post
41724
+ */
41725
+ matchingOnlyParentPost: matchingOnlyParentPost !== null && matchingOnlyParentPost !== void 0 ? matchingOnlyParentPost : !(dataTypes === null || dataTypes === void 0 ? void 0 : dataTypes.length), options }),
41726
+ });
41727
+ return queryResponse;
41728
+ }
41729
+ }
41730
+
41731
+ class SearchPostQueryStreamController extends QueryStreamController {
41732
+ constructor(query, cacheKey, notifyChange, preparePayload) {
41733
+ super(query, cacheKey);
41734
+ this.notifyChange = notifyChange;
41735
+ this.preparePayload = preparePayload;
41736
+ }
41737
+ async saveToMainDB(response) {
41738
+ const processedPayload = await this.preparePayload(response);
41739
+ const client = getActiveClient();
41740
+ const cachedAt = client.cache && Date.now();
41741
+ if (client.cache) {
41742
+ ingestInCache(processedPayload, { cachedAt });
41743
+ }
41744
+ }
41745
+ appendToQueryStream(response, direction, refresh = false) {
41746
+ var _a, _b;
41747
+ if (refresh) {
41748
+ pushToCache(this.cacheKey, {
41749
+ data: response.posts.map(getResolver('post')),
41750
+ });
41751
+ }
41752
+ else {
41753
+ const collection = (_a = pullFromCache(this.cacheKey)) === null || _a === void 0 ? void 0 : _a.data;
41754
+ const posts = (_b = collection === null || collection === void 0 ? void 0 : collection.data) !== null && _b !== void 0 ? _b : [];
41755
+ pushToCache(this.cacheKey, Object.assign(Object.assign({}, collection), { data: [...new Set([...posts, ...response.posts.map(getResolver('post'))])] }));
41756
+ }
41757
+ }
41758
+ reactor(action) {
41759
+ return (post) => {
41760
+ var _a, _b;
41761
+ const collection = (_a = pullFromCache(this.cacheKey)) === null || _a === void 0 ? void 0 : _a.data;
41762
+ if (!collection)
41763
+ return;
41764
+ if (post.parentPostId && post.isDeleted) {
41765
+ const parentPost = (_b = pullFromCache([
41766
+ 'post',
41767
+ 'get',
41768
+ post.parentPostId,
41769
+ ])) === null || _b === void 0 ? void 0 : _b.data;
41770
+ if (!parentPost)
41771
+ return;
41772
+ parentPost.children = parentPost.children.filter(childId => childId !== post.postId);
41773
+ pushToCache(['post', 'get', parentPost.postId], parentPost);
41774
+ }
41775
+ if (action === EnumPostActions.OnPostDeclined) {
41776
+ collection.data = collection.data.filter(postId => postId !== post.postId);
41777
+ }
41778
+ if (action === EnumPostActions.OnPostCreated || action === EnumPostActions.OnPostApproved) {
41779
+ collection.data = [...new Set([post.postId, ...collection.data])];
41780
+ }
41781
+ pushToCache(this.cacheKey, collection);
41782
+ this.notifyChange({ origin: "event" /* Amity.LiveDataOrigin.EVENT */, loading: false });
41783
+ };
41784
+ }
41785
+ subscribeRTE(createSubscriber) {
41786
+ return createSubscriber.map(subscriber => subscriber.fn(this.reactor(subscriber.action)));
41787
+ }
41788
+ }
41789
+
41790
+ class SearchPostLiveCollectionController extends LiveCollectionController {
41791
+ constructor(query, callback) {
41792
+ const queryStreamId = hash(query);
41793
+ const cacheKey = ['posts', 'collection', queryStreamId];
41794
+ const paginationController = new SearchPostPaginationController(query);
41795
+ super(paginationController, queryStreamId, cacheKey, callback);
41796
+ this.query = query;
41797
+ this.queryStreamController = new SearchPostQueryStreamController(this.query, this.cacheKey, this.notifyChange.bind(this), preparePostPayload);
41798
+ this.callback = callback.bind(this);
41799
+ this.loadPage({ initial: true });
41800
+ }
41801
+ setup() {
41802
+ var _a;
41803
+ const collection = (_a = pullFromCache(this.cacheKey)) === null || _a === void 0 ? void 0 : _a.data;
41804
+ if (!collection) {
41805
+ pushToCache(this.cacheKey, {
41806
+ data: [],
41807
+ params: {},
41808
+ });
41809
+ }
41810
+ }
41811
+ async persistModel(queryPayload) {
41812
+ await this.queryStreamController.saveToMainDB(queryPayload);
41813
+ }
41814
+ persistQueryStream({ response, direction, refresh, }) {
41815
+ this.queryStreamController.appendToQueryStream(response, direction, refresh);
41816
+ }
41817
+ startSubscription() {
41818
+ return this.queryStreamController.subscribeRTE([
41819
+ { fn: onPostCreated, action: EnumPostActions.OnPostCreated },
41820
+ { fn: onPostUpdated, action: EnumPostActions.OnPostUpdated },
41821
+ { fn: onPostUpdatedLocal, action: EnumPostActions.OnPostUpdated },
41822
+ { fn: onPostDeleted, action: EnumPostActions.OnPostDeleted },
41823
+ { fn: onPostFlagged, action: EnumPostActions.OnPostFlagged },
41824
+ { fn: onPostUnflagged, action: EnumPostActions.OnPostUnflagged },
41825
+ { fn: onPostApproved, action: EnumPostActions.OnPostApproved },
41826
+ { fn: onPostDeclined, action: EnumPostActions.OnPostDeclined },
41827
+ { fn: onPostReactionAdded, action: EnumPostActions.OnPostReactionAdded },
41828
+ { fn: onPostReactionRemoved, action: EnumPostActions.OnPostReactionRemoved },
41829
+ { fn: onLocalPostReactionAdded, action: EnumPostActions.OnPostReactionAdded },
41830
+ { fn: onLocalPostReactionRemoved, action: EnumPostActions.OnPostReactionRemoved },
41831
+ { fn: onLocalPostDeleted, action: EnumPostActions.OnPostDeleted },
41832
+ {
41833
+ fn: convertEventPayload((callback) => {
41834
+ return onCommentCreated(async (comment) => {
41835
+ var _a;
41836
+ const currentCollection = (_a = pullFromCache(this.cacheKey)) === null || _a === void 0 ? void 0 : _a.data;
41837
+ if (!currentCollection || currentCollection.data.includes(comment.referenceId))
41838
+ return;
41839
+ await getPost(comment.referenceId);
41840
+ callback(comment);
41841
+ });
41842
+ }, 'referenceId', 'post'),
41843
+ action: EnumPostActions.OnPostUpdated,
41844
+ },
41845
+ {
41846
+ fn: convertEventPayload((callback) => {
41847
+ return onCommentDeleted(async (comment) => {
41848
+ var _a;
41849
+ const currentCollection = (_a = pullFromCache(this.cacheKey)) === null || _a === void 0 ? void 0 : _a.data;
41850
+ if (!currentCollection || currentCollection.data.includes(comment.referenceId))
41851
+ return;
41852
+ await getPost(comment.referenceId);
41853
+ callback(comment);
41854
+ });
41855
+ }, 'referenceId', 'post'),
41856
+ action: EnumPostActions.OnPostUpdated,
41857
+ },
41858
+ ]);
41859
+ }
41860
+ notifyChange({ origin, loading, error }) {
41861
+ var _a, _b;
41862
+ const collection = (_a = pullFromCache(this.cacheKey)) === null || _a === void 0 ? void 0 : _a.data;
41863
+ if (!collection)
41864
+ return;
41865
+ const data = this.applyFilter((_b = collection.data
41866
+ .map(id => pullFromCache(['post', 'get', id]))
41867
+ .filter(isNonNullable)
41868
+ .map(({ data }) => data)) !== null && _b !== void 0 ? _b : []).map(LinkedObject.post);
41869
+ if (!this.shouldNotify(data) && origin === 'event')
41870
+ return;
41871
+ this.callback({
41872
+ onNextPage: () => this.loadPage({ direction: "next" /* Amity.LiveCollectionPageDirection.NEXT */ }),
41873
+ data,
41874
+ hasNextPage: !!this.paginationController.getNextToken(),
41875
+ loading,
41876
+ error,
41877
+ });
41878
+ }
41879
+ applyFilter(data) {
41880
+ var _a;
41881
+ let posts = data;
41882
+ if ((_a = this.query.dataTypes) === null || _a === void 0 ? void 0 : _a.length) {
41883
+ posts = filterByPostDataTypes(posts, this.query.dataTypes);
41884
+ }
41885
+ switch (this.query.sortBy) {
41886
+ case 'firstCreated':
41887
+ posts = posts.sort(sortByFirstCreated);
41888
+ break;
41889
+ case 'lastCreated':
41890
+ default:
41891
+ posts = posts.sort(sortByLastCreated);
41892
+ break;
41893
+ }
41894
+ return posts;
41895
+ }
41896
+ }
41897
+
41898
+ /* begin_public_function
41899
+ id: post.query
41900
+ */
41901
+ /**
41902
+ * ```js
41903
+ * import { PostRepository } from '@amityco/ts-sdk'
41904
+ *
41905
+ * let posts = []
41906
+ * const unsub = PostRepository.searchPostsByHashtag({
41907
+ * hashtags: ['amity'],
41908
+ * limit: 10,
41909
+ * }, response => merge(posts, response.data))
41910
+ * ```
41911
+ *
41912
+ * Observe all mutations on a list of {@link Amity.Post} for a given target object
41913
+ *
41914
+ * @param params.hashtags the hashtags to search for
41915
+ * @param callback the function to call when new data are available
41916
+ * @param config
41917
+ * @returns An {@link Amity.Unsubscriber} function to run when willing to stop observing the messages
41918
+ *
41919
+ * @category Posts Live Collection
41920
+ */
41921
+ const searchPostsByHashtag = (params, callback, config) => {
41922
+ const { log, cache } = getActiveClient();
41923
+ if (!cache) {
41924
+ console.log(ENABLE_CACHE_MESSAGE);
41925
+ }
41926
+ const timestamp = Date.now();
41927
+ log(`searchPostsByHashtag(tmpid: ${timestamp}) > listen`);
41928
+ const postsLiveCollection = new SearchPostLiveCollectionController(params, callback);
41929
+ const disposers = postsLiveCollection.startSubscription();
41930
+ const cacheKey = postsLiveCollection.getCacheKey();
41931
+ disposers.push(() => dropFromCache(cacheKey));
41932
+ return () => {
41933
+ log(`searchPostsByHashtag(tmpid: ${timestamp}) > dispose`);
41934
+ disposers.forEach(fn => fn());
41935
+ };
41936
+ };
41937
+ /* end_public_function */
41938
+
41653
41939
  var index$8 = /*#__PURE__*/Object.freeze({
41654
41940
  __proto__: null,
41655
41941
  getPostByIds: getPostByIds,
@@ -41664,6 +41950,7 @@ var index$8 = /*#__PURE__*/Object.freeze({
41664
41950
  unflagPost: unflagPost,
41665
41951
  isPostFlaggedByMe: isPostFlaggedByMe,
41666
41952
  createClipPost: createClipPost,
41953
+ getPostsByHashtag: getPostsByHashtag,
41667
41954
  onPostCreated: onPostCreated,
41668
41955
  onPostUpdated: onPostUpdated,
41669
41956
  onPostDeleted: onPostDeleted,
@@ -41677,7 +41964,8 @@ var index$8 = /*#__PURE__*/Object.freeze({
41677
41964
  getPosts: getPosts,
41678
41965
  getPinnedPosts: getPinnedPosts,
41679
41966
  getGlobalPinnedPosts: getGlobalPinnedPosts,
41680
- semanticSearchPosts: semanticSearchPosts
41967
+ semanticSearchPosts: semanticSearchPosts,
41968
+ searchPostsByHashtag: searchPostsByHashtag
41681
41969
  });
41682
41970
 
41683
41971
  /* begin_public_function