@hestia-earth/ui-components 0.27.2 → 0.27.3

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.
@@ -51,14 +51,14 @@ export class HeSearchService {
51
51
  .post(`${this.commonService.apiBaseUrl}/search`, params)
52
52
  .pipe(catchError(() => of(emptySearchResult())));
53
53
  }
54
- search(params) {
55
- return this.search$(params).toPromise();
54
+ async search(params) {
55
+ return await this.search$(params).toPromise();
56
56
  }
57
- count(params = {}) {
58
- return this.http
59
- .post(`${this.commonService.apiBaseUrl}/count`, params)
60
- .toPromise()
61
- .catch(() => 0);
57
+ count$(params = {}) {
58
+ return this.http.post(`${this.commonService.apiBaseUrl}/count`, params).pipe(catchError(() => of(0)));
59
+ }
60
+ async count(params = {}) {
61
+ return await this.count$(params).toPromise();
62
62
  }
63
63
  get$(type, id) {
64
64
  return this.http
@@ -72,10 +72,10 @@ export class HeSearchService {
72
72
  })
73
73
  .pipe(catchError(() => of(emptySearchResult())), map(({ results }) => results[0] || null));
74
74
  }
75
- get(type, id) {
76
- return this.get$(type, id).toPromise();
75
+ async get(type, id) {
76
+ return await this.get$(type, id).toPromise();
77
77
  }
78
- suggest(term, type, extraQueries = [], fullQuery, limit = 10, includes = []) {
78
+ suggest$(term, type, extraQueries = [], fullQuery, limit = 10, includes = []) {
79
79
  const query = fullQuery || suggestQuery(term, type, extraQueries);
80
80
  return this.http
81
81
  .post(`${this.commonService.apiBaseUrl}/search`, {
@@ -85,8 +85,11 @@ export class HeSearchService {
85
85
  })
86
86
  .pipe(catchError(() => of(emptySearchResult())), map(({ results }) => results.map(({ _score, ...res }) => res)));
87
87
  }
88
- suggestSource(term, limit = 5, fields = ['bibliography.title'], includes = ['bibliography.title']) {
89
- return this.suggest(term, NodeType.Source, [], suggestSourceQuery(term, fields), limit, includes).pipe(map((sources) => sources.map(source => ({
88
+ suggest(term, type, extraQueries = [], fullQuery, limit = 10, includes = []) {
89
+ return this.suggest$(term, type, extraQueries, fullQuery, limit, includes).toPromise();
90
+ }
91
+ suggestSource$(term, limit = 5, fields = ['bibliography.title'], includes = ['bibliography.title']) {
92
+ return this.suggest$(term, NodeType.Source, [], suggestSourceQuery(term, fields), limit, includes).pipe(map((sources) => sources.map(source => ({
90
93
  ...source,
91
94
  bibliography: {
92
95
  // needed to create a nested property
@@ -95,6 +98,9 @@ export class HeSearchService {
95
98
  }
96
99
  }))));
97
100
  }
101
+ suggestSource(term, limit = 5, fields = ['bibliography.title'], includes = ['bibliography.title']) {
102
+ return this.suggestSource$(term, limit, fields, includes).toPromise();
103
+ }
98
104
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: HeSearchService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
99
105
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: HeSearchService, providedIn: 'root' }); }
100
106
  }
@@ -104,4 +110,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
104
110
  providedIn: 'root'
105
111
  }]
106
112
  }] });
107
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search.service.js","sourceRoot":"","sources":["../../../src/search/search.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport { of } from 'rxjs';\nimport { catchError, map } from 'rxjs/operators';\nimport {\n  JSONLD,\n  NodeType,\n  ICycleJSONLD,\n  ISourceJSONLD,\n  ITermJSONLD,\n  Source,\n  SchemaType,\n  IImpactAssessmentJSONLD\n} from '@hestia-earth/schema';\n\nimport { HeCommonService } from '../common/common.service';\nimport {\n  matchType,\n  matchPhraseQuery,\n  matchPhrasePrefixQuery,\n  matchQuery,\n  searchableType,\n  searchableTypes,\n  matchBoolPrefixQuery,\n  matchExactQuery\n} from './search.model';\n\nexport type searchResult = ICycleJSONLD | ISourceJSONLD | IImpactAssessmentJSONLD | ITermJSONLD;\n\nexport type sortOrders = 'asc' | 'desc';\n\ninterface ISearchParamSort {\n  [key: string]: sortOrders;\n}\n\ninterface ISearchScript {\n  _script: {\n    type?: string;\n    order?: sortOrders;\n    script: string;\n  };\n}\n\nexport interface ISearchParams {\n  limit?: number;\n  offset?: number;\n  fields?: string[];\n  sort?: ISearchParamSort[] | ISearchScript;\n  query?: any;\n}\n\nexport interface ISearchResultExtended {\n  _score: number;\n  // geospacial search\n  location?: {\n    lat: number;\n    lon: number;\n  };\n  // used in search\n  properties?: string[];\n  expanded?: boolean;\n  extended?: boolean;\n  pinned?: boolean;\n  loading?: boolean;\n  selected?: boolean;\n  // count for lists\n  inputsCount?: number;\n  emissionsCount?: number;\n  productsCount?: number;\n}\n\nexport interface ISearchResults<C extends JSONLD<T>, T extends NodeType = searchableType> {\n  /**\n   * Amount of time the query took\n   */\n  time: number;\n  /**\n   * Numnber of results\n   */\n  count: number;\n  results: (C & ISearchResultExtended)[];\n}\n\nconst emptySearchResult = <C extends JSONLD<T>, T extends NodeType>() =>\n  ({\n    time: 0,\n    count: 0,\n    results: []\n  }) as ISearchResults<C, T>;\n\nexport const MAX_RESULTS = 10000;\n\nexport const suggestMatchQuery = (query: string) => [\n  matchPhraseQuery(query, 10),\n  matchQuery('nameNormalized', query, 8),\n  matchPhrasePrefixQuery(query, 2)\n];\n\nexport const suggestQuery = <T extends NodeType = searchableType>(\n  query: string,\n  type?: T,\n  extraQueries: any[] = []\n) => ({\n  bool: {\n    must: extraQueries,\n    should: (type ? [type] : searchableTypes).map(v => ({\n      bool: {\n        must: [matchType(v)],\n        should: suggestMatchQuery(query),\n        minimum_should_match: 1\n      }\n    })),\n    minimum_should_match: 1\n  }\n});\n\nconst suggestSourceQuery = (query: string, fields: string[]) => ({\n  bool: {\n    must: [matchType(NodeType.Source)],\n    should: [\n      matchPhraseQuery(query, 100, ...fields),\n      matchPhrasePrefixQuery(query, 20, ...fields),\n      matchBoolPrefixQuery(query, 10, ...fields)\n    ],\n    minimum_should_match: 1\n  }\n});\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class HeSearchService {\n  protected http = inject(HttpClient);\n  protected commonService = inject(HeCommonService);\n\n  public search$<C extends JSONLD<T>, T extends NodeType = searchableType>(params: ISearchParams) {\n    return this.http\n      .post<ISearchResults<C, T>>(`${this.commonService.apiBaseUrl}/search`, params)\n      .pipe(catchError(() => of(emptySearchResult<C, T>())));\n  }\n\n  public search<C extends JSONLD<T>, T extends NodeType = searchableType>(params: ISearchParams) {\n    return this.search$<C, T>(params).toPromise();\n  }\n\n  public count(params = {}) {\n    return this.http\n      .post<number>(`${this.commonService.apiBaseUrl}/count`, params)\n      .toPromise()\n      .catch(() => 0);\n  }\n\n  public get$<C extends JSONLD<T>, T extends NodeType>(type: T, id: string) {\n    return this.http\n      .post<ISearchResults<C, T>>(`${this.commonService.apiBaseUrl}/search`, {\n        limit: 1,\n        query: {\n          bool: {\n            must: [matchType(type), matchExactQuery('@id', id)]\n          }\n        }\n      })\n      .pipe(\n        catchError(() => of(emptySearchResult<C, T>())),\n        map(({ results }) => results[0] || null)\n      );\n  }\n\n  public get<C extends JSONLD<T>, T extends NodeType>(type: T, id: string) {\n    return this.get$<C, T>(type, id).toPromise();\n  }\n\n  public suggest<C extends JSONLD<T>, T extends NodeType = searchableType>(\n    term: string,\n    type?: T,\n    extraQueries: any[] = [],\n    fullQuery?: any,\n    limit = 10,\n    includes: string[] = []\n  ) {\n    const query = fullQuery || suggestQuery(term, type, extraQueries);\n    return this.http\n      .post<ISearchResults<C, T>>(`${this.commonService.apiBaseUrl}/search`, {\n        limit,\n        fields: ['name', '@id', type ? '' : '@type', 'termType', 'aggregated', ...includes].filter(val => !!val),\n        query\n      })\n      .pipe(\n        catchError(() => of(emptySearchResult<C, T>())),\n        map(({ results }) => results.map(({ _score, ...res }) => res))\n      );\n  }\n\n  public suggestSource(term: string, limit = 5, fields = ['bibliography.title'], includes = ['bibliography.title']) {\n    return this.suggest(term, NodeType.Source, [], suggestSourceQuery(term, fields), limit, includes).pipe(\n      map((sources: Partial<Source>[]) =>\n        sources.map(\n          source =>\n            ({\n              ...source,\n              bibliography: {\n                // needed to create a nested property\n                type: SchemaType.Bibliography,\n                ...source.bibliography\n              }\n            }) as Partial<Source>\n        )\n      )\n    );\n  }\n}\n"]}
113
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search.service.js","sourceRoot":"","sources":["../../../src/search/search.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport { of } from 'rxjs';\nimport { catchError, map } from 'rxjs/operators';\nimport {\n  JSONLD,\n  NodeType,\n  ICycleJSONLD,\n  ISourceJSONLD,\n  ITermJSONLD,\n  Source,\n  SchemaType,\n  IImpactAssessmentJSONLD\n} from '@hestia-earth/schema';\n\nimport { HeCommonService } from '../common/common.service';\nimport {\n  matchType,\n  matchPhraseQuery,\n  matchPhrasePrefixQuery,\n  matchQuery,\n  searchableType,\n  searchableTypes,\n  matchBoolPrefixQuery,\n  matchExactQuery\n} from './search.model';\n\nexport type searchResult = ICycleJSONLD | ISourceJSONLD | IImpactAssessmentJSONLD | ITermJSONLD;\n\nexport type sortOrders = 'asc' | 'desc';\n\ninterface ISearchParamSort {\n  [key: string]: sortOrders;\n}\n\ninterface ISearchScript {\n  _script: {\n    type?: string;\n    order?: sortOrders;\n    script: string;\n  };\n}\n\nexport interface ISearchParams {\n  limit?: number;\n  offset?: number;\n  fields?: string[];\n  sort?: ISearchParamSort[] | ISearchScript;\n  query?: any;\n}\n\nexport interface ISearchResultExtended {\n  _score: number;\n  // geospacial search\n  location?: {\n    lat: number;\n    lon: number;\n  };\n  // used in search\n  properties?: string[];\n  expanded?: boolean;\n  extended?: boolean;\n  pinned?: boolean;\n  loading?: boolean;\n  selected?: boolean;\n  // count for lists\n  inputsCount?: number;\n  emissionsCount?: number;\n  productsCount?: number;\n}\n\nexport interface ISearchResults<C extends JSONLD<T>, T extends NodeType = searchableType> {\n  /**\n   * Amount of time the query took\n   */\n  time: number;\n  /**\n   * Numnber of results\n   */\n  count: number;\n  results: (C & ISearchResultExtended)[];\n}\n\nconst emptySearchResult = <C extends JSONLD<T>, T extends NodeType>() =>\n  ({\n    time: 0,\n    count: 0,\n    results: []\n  }) as ISearchResults<C, T>;\n\nexport const MAX_RESULTS = 10000;\n\nexport const suggestMatchQuery = (query: string) => [\n  matchPhraseQuery(query, 10),\n  matchQuery('nameNormalized', query, 8),\n  matchPhrasePrefixQuery(query, 2)\n];\n\nexport const suggestQuery = <T extends NodeType = searchableType>(\n  query: string,\n  type?: T,\n  extraQueries: any[] = []\n) => ({\n  bool: {\n    must: extraQueries,\n    should: (type ? [type] : searchableTypes).map(v => ({\n      bool: {\n        must: [matchType(v)],\n        should: suggestMatchQuery(query),\n        minimum_should_match: 1\n      }\n    })),\n    minimum_should_match: 1\n  }\n});\n\nconst suggestSourceQuery = (query: string, fields: string[]) => ({\n  bool: {\n    must: [matchType(NodeType.Source)],\n    should: [\n      matchPhraseQuery(query, 100, ...fields),\n      matchPhrasePrefixQuery(query, 20, ...fields),\n      matchBoolPrefixQuery(query, 10, ...fields)\n    ],\n    minimum_should_match: 1\n  }\n});\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class HeSearchService {\n  protected http = inject(HttpClient);\n  protected commonService = inject(HeCommonService);\n\n  public search$<C extends JSONLD<T>, T extends NodeType = searchableType>(params: ISearchParams) {\n    return this.http\n      .post<ISearchResults<C, T>>(`${this.commonService.apiBaseUrl}/search`, params)\n      .pipe(catchError(() => of(emptySearchResult<C, T>())));\n  }\n\n  public async search<C extends JSONLD<T>, T extends NodeType = searchableType>(params: ISearchParams) {\n    return await this.search$<C, T>(params).toPromise();\n  }\n\n  public count$(params = {}) {\n    return this.http.post<number>(`${this.commonService.apiBaseUrl}/count`, params).pipe(catchError(() => of(0)));\n  }\n\n  public async count(params = {}) {\n    return await this.count$(params).toPromise();\n  }\n\n  public get$<C extends JSONLD<T>, T extends NodeType>(type: T, id: string) {\n    return this.http\n      .post<ISearchResults<C, T>>(`${this.commonService.apiBaseUrl}/search`, {\n        limit: 1,\n        query: {\n          bool: {\n            must: [matchType(type), matchExactQuery('@id', id)]\n          }\n        }\n      })\n      .pipe(\n        catchError(() => of(emptySearchResult<C, T>())),\n        map(({ results }) => results[0] || null)\n      );\n  }\n\n  public async get<C extends JSONLD<T>, T extends NodeType>(type: T, id: string) {\n    return await this.get$<C, T>(type, id).toPromise();\n  }\n\n  public suggest$<C extends JSONLD<T>, T extends NodeType = searchableType>(\n    term: string,\n    type?: T,\n    extraQueries: any[] = [],\n    fullQuery?: any,\n    limit = 10,\n    includes: string[] = []\n  ) {\n    const query = fullQuery || suggestQuery(term, type, extraQueries);\n    return this.http\n      .post<ISearchResults<C, T>>(`${this.commonService.apiBaseUrl}/search`, {\n        limit,\n        fields: ['name', '@id', type ? '' : '@type', 'termType', 'aggregated', ...includes].filter(val => !!val),\n        query\n      })\n      .pipe(\n        catchError(() => of(emptySearchResult<C, T>())),\n        map(({ results }) => results.map(({ _score, ...res }) => res))\n      );\n  }\n\n  public suggest<C extends JSONLD<T>, T extends NodeType = searchableType>(\n    term: string,\n    type?: T,\n    extraQueries: any[] = [],\n    fullQuery?: any,\n    limit = 10,\n    includes: string[] = []\n  ) {\n    return this.suggest$<C, T>(term, type, extraQueries, fullQuery, limit, includes).toPromise();\n  }\n\n  public suggestSource$(term: string, limit = 5, fields = ['bibliography.title'], includes = ['bibliography.title']) {\n    return this.suggest$(term, NodeType.Source, [], suggestSourceQuery(term, fields), limit, includes).pipe(\n      map((sources: Partial<Source>[]) =>\n        sources.map(\n          source =>\n            ({\n              ...source,\n              bibliography: {\n                // needed to create a nested property\n                type: SchemaType.Bibliography,\n                ...source.bibliography\n              }\n            }) as Partial<Source>\n        )\n      )\n    );\n  }\n\n  public suggestSource(term: string, limit = 5, fields = ['bibliography.title'], includes = ['bibliography.title']) {\n    return this.suggestSource$(term, limit, fields, includes).toPromise();\n  }\n}\n"]}
@@ -403,14 +403,14 @@ class HeSearchService {
403
403
  .post(`${this.commonService.apiBaseUrl}/search`, params)
404
404
  .pipe(catchError(() => of(emptySearchResult())));
405
405
  }
406
- search(params) {
407
- return this.search$(params).toPromise();
406
+ async search(params) {
407
+ return await this.search$(params).toPromise();
408
408
  }
409
- count(params = {}) {
410
- return this.http
411
- .post(`${this.commonService.apiBaseUrl}/count`, params)
412
- .toPromise()
413
- .catch(() => 0);
409
+ count$(params = {}) {
410
+ return this.http.post(`${this.commonService.apiBaseUrl}/count`, params).pipe(catchError(() => of(0)));
411
+ }
412
+ async count(params = {}) {
413
+ return await this.count$(params).toPromise();
414
414
  }
415
415
  get$(type, id) {
416
416
  return this.http
@@ -424,10 +424,10 @@ class HeSearchService {
424
424
  })
425
425
  .pipe(catchError(() => of(emptySearchResult())), map(({ results }) => results[0] || null));
426
426
  }
427
- get(type, id) {
428
- return this.get$(type, id).toPromise();
427
+ async get(type, id) {
428
+ return await this.get$(type, id).toPromise();
429
429
  }
430
- suggest(term, type, extraQueries = [], fullQuery, limit = 10, includes = []) {
430
+ suggest$(term, type, extraQueries = [], fullQuery, limit = 10, includes = []) {
431
431
  const query = fullQuery || suggestQuery(term, type, extraQueries);
432
432
  return this.http
433
433
  .post(`${this.commonService.apiBaseUrl}/search`, {
@@ -437,8 +437,11 @@ class HeSearchService {
437
437
  })
438
438
  .pipe(catchError(() => of(emptySearchResult())), map(({ results }) => results.map(({ _score, ...res }) => res)));
439
439
  }
440
- suggestSource(term, limit = 5, fields = ['bibliography.title'], includes = ['bibliography.title']) {
441
- return this.suggest(term, NodeType.Source, [], suggestSourceQuery(term, fields), limit, includes).pipe(map((sources) => sources.map(source => ({
440
+ suggest(term, type, extraQueries = [], fullQuery, limit = 10, includes = []) {
441
+ return this.suggest$(term, type, extraQueries, fullQuery, limit, includes).toPromise();
442
+ }
443
+ suggestSource$(term, limit = 5, fields = ['bibliography.title'], includes = ['bibliography.title']) {
444
+ return this.suggest$(term, NodeType.Source, [], suggestSourceQuery(term, fields), limit, includes).pipe(map((sources) => sources.map(source => ({
442
445
  ...source,
443
446
  bibliography: {
444
447
  // needed to create a nested property
@@ -447,6 +450,9 @@ class HeSearchService {
447
450
  }
448
451
  }))));
449
452
  }
453
+ suggestSource(term, limit = 5, fields = ['bibliography.title'], includes = ['bibliography.title']) {
454
+ return this.suggestSource$(term, limit, fields, includes).toPromise();
455
+ }
450
456
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: HeSearchService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
451
457
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: HeSearchService, providedIn: 'root' }); }
452
458
  }
@@ -490,7 +496,7 @@ class BibliographiesSearchConfirmComponent {
490
496
  const fields = [`bibliography.${this.searchBy}`];
491
497
  const includes = ['bibliography.title', 'bibliography.documentDOI', 'bibliography.scopus'];
492
498
  return this.searchSources
493
- ? this.searchService.suggestSource(term, this.searchLimit(), fields, includes)
499
+ ? this.searchService.suggestSource$(term, this.searchLimit(), fields, includes)
494
500
  : of([]);
495
501
  }
496
502
  runSearchBibliographies(term) {
@@ -7337,7 +7343,7 @@ class EngineRequirementsFormComponent {
7337
7343
  this.inputFormatterProductTermId = ({ name }) => name;
7338
7344
  }
7339
7345
  suggestTerm(term) {
7340
- return this.searchService.suggest(term, NodeType.Term, null, {
7346
+ return this.searchService.suggest$(term, NodeType.Term, null, {
7341
7347
  bool: {
7342
7348
  must: [
7343
7349
  matchType(NodeType.Term),
@@ -8813,7 +8819,7 @@ class FilesFormEditableComponent {
8813
8819
  this.formatNewProperty = ({ name }) => name;
8814
8820
  this.suggestExistingNode = (type, term, uniqueKey = '@id') => term.length < MIN_TYPEAHEAD_LENGTH
8815
8821
  ? of([])
8816
- : this.searchService.suggest(term, type, [], {
8822
+ : this.searchService.suggest$(term, type, [], {
8817
8823
  bool: {
8818
8824
  must: [matchType(type)],
8819
8825
  should: [
@@ -8843,10 +8849,10 @@ class FilesFormEditableComponent {
8843
8849
  [NodeType.Site]: this.suggestNode(NodeType.Site),
8844
8850
  [NodeType.Source]: this.suggestNode(NodeType.Source, (term, { key }) => term.length < MIN_TYPEAHEAD_LENGTH
8845
8851
  ? of([])
8846
- : this.searchService.suggestSource(term, 5, [`bibliography.${key}`], [`bibliography.${key}`])),
8852
+ : this.searchService.suggestSource$(term, 5, [`bibliography.${key}`], [`bibliography.${key}`])),
8847
8853
  [NodeType.Term]: this.suggestNode(NodeType.Term, (term, { suggestions }) => term.length < MIN_TYPEAHEAD_LENGTH
8848
8854
  ? of([])
8849
- : this.searchService.suggest(term, NodeType.Term, suggestions?.queries || [], null, 5, this.suggestTermFields))
8855
+ : this.searchService.suggest$(term, NodeType.Term, suggestions?.queries || [], null, 5, this.suggestTermFields))
8850
8856
  };
8851
8857
  this.propertySuggest = ({ fullKey, suggestions }) => (text$) => text$.pipe(debounceTime(suggestions?.type === defaultSuggestionType ? 0 : 300), distinctUntilChanged(), mergeMap(term => {
8852
8858
  const property = findProperty(this.properties, fullKey);