@hestia-earth/ui-components 0.0.12 → 0.0.13

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 (32) hide show
  1. package/bundles/hestia-earth-ui-components.umd.js +392 -238
  2. package/bundles/hestia-earth-ui-components.umd.js.map +1 -1
  3. package/common/common.module.d.ts +11 -12
  4. package/common/index.d.ts +0 -1
  5. package/common/keys.pipe.d.ts +1 -1
  6. package/common/utils.d.ts +2 -2
  7. package/cycles/cycles-emissions-logs/cycles-emissions-logs.component.d.ts +0 -1
  8. package/cycles/cycles-practices/cycles-practices.component.d.ts +39 -0
  9. package/cycles/cycles-practices-logs/cycles-practices-logs.component.d.ts +20 -0
  10. package/cycles/cycles.module.d.ts +9 -7
  11. package/cycles/index.d.ts +2 -0
  12. package/esm2015/common/common.module.js +1 -5
  13. package/esm2015/common/index.js +1 -2
  14. package/esm2015/common/keys.pipe.js +3 -3
  15. package/esm2015/common/social-tags/social-tags.component.js +2 -3
  16. package/esm2015/common/utils.js +2 -2
  17. package/esm2015/cycles/cycles-emissions/cycles-emissions.component.js +2 -2
  18. package/esm2015/cycles/cycles-emissions-logs/cycles-emissions-logs.component.js +1 -2
  19. package/esm2015/cycles/cycles-practices/cycles-practices.component.js +119 -0
  20. package/esm2015/cycles/cycles-practices-logs/cycles-practices-logs.component.js +46 -0
  21. package/esm2015/cycles/cycles.module.js +9 -1
  22. package/esm2015/cycles/index.js +3 -1
  23. package/esm2015/engine/aggregation-engine.service.js +2 -2
  24. package/esm2015/engine/engine.service.js +2 -2
  25. package/esm2015/files/files-error-summary.model.js +6 -6
  26. package/esm2015/node/node-csv-select-headers/node-csv-select-headers.component.js +6 -5
  27. package/esm2015/search/search.model.js +4 -4
  28. package/fesm2015/hestia-earth-ui-components.js +300 -188
  29. package/fesm2015/hestia-earth-ui-components.js.map +1 -1
  30. package/package.json +1 -1
  31. package/common/blank-node-diffs/blank-node-diffs.component.d.ts +0 -18
  32. package/esm2015/common/blank-node-diffs/blank-node-diffs.component.js +0 -33
@@ -39,17 +39,17 @@ export const buildSummary = (nodes = [], errors = [], summaryData = []) => from(
39
39
  prev[message].paths[label] = prev[message].paths[label] || [];
40
40
  prev[message].paths[label].push({ node, error, term });
41
41
  return prev;
42
- }, {}), mergeMap(data => from(Object.keys(data)).pipe(filter(message => !!message), mergeMap(message => Object.keys(data[message].paths).map(path => {
42
+ }, {}), mergeMap(data => from(Object.keys(data)).pipe(filter(message => !!message), mergeMap(message => Object.entries(data[message].paths).map(([path, summaries]) => {
43
43
  var _a;
44
44
  return ({
45
45
  level: data[message].level,
46
46
  path,
47
47
  message,
48
- formattedMessage: (_a = formatError(data[message].paths[path][0].error, data[message].paths[path].length)) === null || _a === void 0 ? void 0 : _a.message,
49
- terms: uniqueTerms(data[message].paths[path]).join(' ; '),
50
- errors: data[message].paths[path],
51
- count: data[message].paths[path].length,
48
+ formattedMessage: (_a = formatError(summaries[0].error, summaries.length)) === null || _a === void 0 ? void 0 : _a.message,
49
+ terms: uniqueTerms(summaries).join(' ; '),
50
+ errors: summaries,
51
+ count: summaries.length,
52
52
  showErrors: summaryShowErrors(summaryData, { level: data[message].level, path, message })
53
53
  });
54
54
  })), filter(({ formattedMessage }) => !!formattedMessage))), toArray(), map(values => values.sort(({ level }) => level === 'error' ? -1 : 1)));
55
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"files-error-summary.model.js","sourceRoot":"","sources":["../../../src/files/files-error-summary.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { from } from 'rxjs';\nimport { filter, map, mergeMap, reduce, toArray } from 'rxjs/operators';\nconst get = require('lodash.get');\nimport { JSON as HestiaJson, SchemaType } from '@hestia-earth/schema';\nimport { unique } from '@hestia-earth/utils';\n\nimport {\n  IValidationError, IValidationErrorWithIndex, validationErrorLevel,\n  code, filterError, formatError, nodeLink, parseDataPath\n} from './files-error.model';\nimport { dataPathToKey } from './files-form.model';\n\ninterface ISummaryError {\n  node: HestiaJson<SchemaType>;\n  error: IValidationError;\n  term?: any;\n}\n\ninterface ISummaryGrouped {\n  [message: string]: {\n    level: validationErrorLevel;\n    paths: {\n      [type: string]: ISummaryError[];\n    };\n  };\n}\n\nexport interface ISummary {\n  level: validationErrorLevel;\n  path: string;\n  message: string;\n  formattedMessage: string;\n  count: number;\n  showErrors: boolean;\n  errors: ISummaryError[];\n  terms?: string;\n}\n\nconst nodeTerm = (node: HestiaJson<SchemaType>, key: string) => {\n  const termType = get(node, `${key}.type`, get(node, `${key}.@type`, null));\n  return termType === SchemaType.Term ? get(node, key, null) : null;\n};\n\nconst findNodeTerm = (node: HestiaJson<SchemaType>, { dataPath }: IValidationError) =>\n  nodeTerm(node, dataPathToKey(dataPath)) ||\n  nodeTerm(node, `${dataPathToKey(dataPath)}.term`) ||\n  nodeTerm(node, dataPathToKey(dataPath, true)) ||\n  nodeTerm(node, `${dataPathToKey(dataPath, true)}.term`);\n\nconst uniqueTerms = (errors: ISummaryError[]) => unique(\n  errors\n    .map(({ term }) => term ? nodeLink(term) || code(term.name || term['@id'] || term.id) : null)\n    .filter(Boolean)\n);\n\nconst summaryShowErrors = (summaryData: ISummary[], { path, level, message }: Partial<ISummary>) =>\n  summaryData.find(summary =>\n    summary.path === path && summary.level === level && summary.message === message\n  )?.showErrors || true;\n\n/**\n * Build the summary objects.\n *\n * @param nodes The list of nodes.\n * @param errors The list of errors per node.\n * @param summaryData The previously computed summary objects.\n * @returns\n */\nexport const buildSummary = (\n  nodes: HestiaJson<SchemaType>[] = [],\n  errors: (IValidationError[] | IValidationErrorWithIndex)[] = [],\n  summaryData: ISummary[] = []\n) =>\n  from(errors).pipe(\n    mergeMap(error => 'error' in error ? (error as IValidationErrorWithIndex).error : error),\n    filter(filterError),\n    reduce((prev, error) => {\n      const { message } = error;\n      const [dataPath] = parseDataPath(error.dataPath);\n      const node = get(nodes, error.nodeIndex, null);\n      const label = dataPath ? dataPath.label : node?.type;\n      const term = error.params?.term || findNodeTerm(node, error);\n      prev[message] = prev[message] || { level: error.level, paths: {} };\n      prev[message].paths[label] = prev[message].paths[label] || [];\n      prev[message].paths[label].push({ node, error, term });\n      return prev;\n    }, {} as ISummaryGrouped),\n    mergeMap(data => from(Object.keys(data)).pipe(\n      filter(message => !!message),\n      mergeMap(message => Object.keys(data[message].paths).map(path => ({\n        level: data[message].level,\n        path,\n        message,\n        formattedMessage: formatError(data[message].paths[path][0].error, data[message].paths[path].length)?.message,\n        terms: uniqueTerms(data[message].paths[path]).join(' ; '),\n        errors: data[message].paths[path],\n        count: data[message].paths[path].length,\n        showErrors: summaryShowErrors(summaryData, { level: data[message].level, path, message })\n      } as ISummary))),\n      filter(({ formattedMessage }) => !!formattedMessage)\n    )),\n    toArray(),\n    map(values => values.sort(({ level }) => level === 'error' ? -1 : 1))\n  );\n"]}
55
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"files-error-summary.model.js","sourceRoot":"","sources":["../../../src/files/files-error-summary.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { from } from 'rxjs';\nimport { filter, map, mergeMap, reduce, toArray } from 'rxjs/operators';\nconst get = require('lodash.get');\nimport { JSON as HestiaJson, SchemaType } from '@hestia-earth/schema';\nimport { unique } from '@hestia-earth/utils';\n\nimport {\n  IValidationError, IValidationErrorWithIndex, validationErrorLevel,\n  code, filterError, formatError, nodeLink, parseDataPath\n} from './files-error.model';\nimport { dataPathToKey } from './files-form.model';\n\ninterface ISummaryError {\n  node: HestiaJson<SchemaType>;\n  error: IValidationError;\n  term?: any;\n}\n\ninterface ISummaryGrouped {\n  [message: string]: {\n    level: validationErrorLevel;\n    paths: {\n      [type: string]: ISummaryError[];\n    };\n  };\n}\n\nexport interface ISummary {\n  level: validationErrorLevel;\n  path: string;\n  message: string;\n  formattedMessage: string;\n  count: number;\n  showErrors: boolean;\n  errors: ISummaryError[];\n  terms?: string;\n}\n\nconst nodeTerm = (node: HestiaJson<SchemaType>, key: string) => {\n  const termType = get(node, `${key}.type`, get(node, `${key}.@type`, null));\n  return termType === SchemaType.Term ? get(node, key, null) : null;\n};\n\nconst findNodeTerm = (node: HestiaJson<SchemaType>, { dataPath }: IValidationError) =>\n  nodeTerm(node, dataPathToKey(dataPath)) ||\n  nodeTerm(node, `${dataPathToKey(dataPath)}.term`) ||\n  nodeTerm(node, dataPathToKey(dataPath, true)) ||\n  nodeTerm(node, `${dataPathToKey(dataPath, true)}.term`);\n\nconst uniqueTerms = (errors: ISummaryError[]) => unique(\n  errors\n    .map(({ term }) => term ? nodeLink(term) || code(term.name || term['@id'] || term.id) : null)\n    .filter(Boolean)\n);\n\nconst summaryShowErrors = (summaryData: ISummary[], { path, level, message }: Partial<ISummary>) =>\n  summaryData.find(summary =>\n    summary.path === path && summary.level === level && summary.message === message\n  )?.showErrors || true;\n\n/**\n * Build the summary objects.\n *\n * @param nodes The list of nodes.\n * @param errors The list of errors per node.\n * @param summaryData The previously computed summary objects.\n * @returns\n */\nexport const buildSummary = (\n  nodes: HestiaJson<SchemaType>[] = [],\n  errors: (IValidationError[] | IValidationErrorWithIndex)[] = [],\n  summaryData: ISummary[] = []\n) =>\n  from(errors).pipe(\n    mergeMap(error => 'error' in error ? (error as IValidationErrorWithIndex).error : error),\n    filter(filterError),\n    reduce((prev, error) => {\n      const { message } = error;\n      const [dataPath] = parseDataPath(error.dataPath);\n      const node = get(nodes, error.nodeIndex, null);\n      const label = dataPath ? dataPath.label : node?.type;\n      const term = error.params?.term || findNodeTerm(node, error);\n      prev[message] = prev[message] || { level: error.level, paths: {} };\n      prev[message].paths[label] = prev[message].paths[label] || [];\n      prev[message].paths[label].push({ node, error, term });\n      return prev;\n    }, {} as ISummaryGrouped),\n    mergeMap(data => from(Object.keys(data)).pipe(\n      filter(message => !!message),\n      mergeMap(message => Object.entries(data[message].paths).map(([path, summaries]) => ({\n        level: data[message].level,\n        path,\n        message,\n        formattedMessage: formatError(summaries[0].error, summaries.length)?.message,\n        terms: uniqueTerms(summaries).join(' ; '),\n        errors: summaries,\n        count: summaries.length,\n        showErrors: summaryShowErrors(summaryData, { level: data[message].level, path, message })\n      } as ISummary))),\n      filter(({ formattedMessage }) => !!formattedMessage)\n    )),\n    toArray(),\n    map(values => values.sort(({ level }) => level === 'error' ? -1 : 1))\n  );\n"]}
@@ -62,8 +62,10 @@ export class NodeCsvSelectHeadersComponent {
62
62
  this.allSelected = Object.keys(this.headers).every(key => this.headers[key].selected);
63
63
  }
64
64
  toggleAll() {
65
- return Object.keys(this.headers).map(key => {
66
- const group = this.headers[key];
65
+ // select all term fields
66
+ Object.keys(this.termFieldSelected).map(key => (this.termFieldSelected[key] = true));
67
+ // select all keys
68
+ return Object.entries(this.headers).map(([key, group]) => {
67
69
  group.selected = this.allSelected;
68
70
  return this.updateGroup(key);
69
71
  });
@@ -91,8 +93,7 @@ export class NodeCsvSelectHeadersComponent {
91
93
  // Term fields
92
94
  toggleTermField(field) {
93
95
  const selected = this.termFieldSelected[field];
94
- return Object.keys(this.headers).map(key => {
95
- const group = this.headers[key];
96
+ return Object.entries(this.headers).map(([key, group]) => {
96
97
  group.headers.filter(isTermField(field)).map(header => header.selected = selected);
97
98
  return this.updateGroupHeader(key);
98
99
  });
@@ -116,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
116
117
  }], headersChanged: [{
117
118
  type: Output
118
119
  }] } });
119
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-csv-select-headers.component.js","sourceRoot":"","sources":["../../../../src/node/node-csv-select-headers/node-csv-select-headers.component.ts","../../../../src/node/node-csv-select-headers/node-csv-select-headers.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport { definitions } from '@hestia-earth/json-schema';\nimport { isDefaultCSVSelected, isCSVIncluded } from '@hestia-earth/json-schema/schema-utils';\n\nimport { HeSchemaService } from '../../schema/schema.service';\n\ninterface IHeader {\n  header: string;\n  selected: boolean;\n}\n\ninterface IGroupedHeaders {\n  [group: string]: {\n    selected: boolean;\n    partialSelected: boolean;\n    open: boolean;\n    headers: IHeader[];\n  };\n}\n\nconst headerGroup = (header: string) => {\n  const parts = header.split('.');\n  return parts.length === 2 ? '' : [parts[0], parts[1]].join('.');\n};\n\nconst termFields = [\n  '@id', 'name', 'units', 'termType'\n];\n\nconst isTermField = (field: string) => ({ header }: IHeader) => [\n  'term', 'methodModel', 'country', 'product', 'operation', 'key'\n].some(parent => header.endsWith([parent, field].join('.')));\n\n@Component({\n  selector: 'he-node-csv-select-headers',\n  templateUrl: './node-csv-select-headers.component.html',\n  styleUrls: ['./node-csv-select-headers.component.scss']\n})\nexport class NodeCsvSelectHeadersComponent implements OnInit {\n  @Input()\n  private csv = '';\n  @Input()\n  private keys?: string[];\n  @Input()\n  private includeDefaultCSV = false;\n\n  @Output()\n  public headersChanged = new EventEmitter<string[]>();\n\n  public headers: IGroupedHeaders = {};\n  public allSelected = false;\n\n  public showSelectTermFields = false;\n  public termFields = termFields;\n  public termFieldSelected: any = {};\n\n  constructor(\n    private schemaService: HeSchemaService\n  ) {}\n\n  async ngOnInit() {\n    const schemas = await this.schemaService.schemas();\n    const isSelected = await this.isSelected(schemas);\n    const headers = await this.schemaService.parseHeaders(this.csv);\n    this.headers = headers.filter(isCSVIncluded(schemas)).reduce((prev, header) => {\n      const group = headerGroup(header);\n      prev[group] = prev[group] || { headers: [], selected: false, partialSelected: false, open: true };\n      prev[group].headers.push({ header, selected: isSelected(header) });\n      return prev;\n    }, {} as IGroupedHeaders);\n    Object.keys(this.headers).map(groupKey => this.updateGroupHeader(groupKey));\n    this.termFieldSelected = termFields.reduce((prev, curr) => ({ ...prev, [curr]: curr === '@id' }), {});\n    this.reresh();\n  }\n\n  private async isSelected(schemas: definitions) {\n    const isSelected = this.includeDefaultCSV ? () => true : isDefaultCSVSelected(schemas);\n    return (key: string) => (!this.keys?.length || this.keys.some(v => key.startsWith(v))) && isSelected(key);\n  }\n\n  public dropHeader(event: CdkDragDrop<IHeader[]>, groupKey: string) {\n    moveItemInArray(this.headers[groupKey].headers, event.previousIndex, event.currentIndex);\n    this.headersChanged.emit(this.selectedHeaders);\n  }\n\n  private updateAllSelected() {\n    this.allSelected = Object.keys(this.headers).every(key => this.headers[key].selected);\n  }\n\n  public toggleAll() {\n    return Object.keys(this.headers).map(key => {\n      const group = this.headers[key];\n      group.selected = this.allSelected;\n      return this.updateGroup(key);\n    });\n  }\n\n  public updateGroup(groupKey: string) {\n    const group = this.headers[groupKey];\n    group.headers.map(header => header.selected = group.selected);\n  }\n\n  public updateGroupHeader(groupKey: string) {\n    const group = this.headers[groupKey];\n    const allSelected = group.headers.every(({ selected }) => selected);\n    group.selected = allSelected;\n    group.partialSelected = !allSelected && group.headers.some(({ selected }) => selected);\n  }\n\n  public get selectedHeaders() {\n    return Object.values(this.headers)\n      .flatMap(({ headers }) => headers)\n      .filter(({ selected }) => selected)\n      .map(({ header }) => header);\n  }\n\n  public reresh() {\n    this.updateAllSelected();\n    this.headersChanged.emit(this.selectedHeaders);\n  }\n\n  // Term fields\n\n  public toggleTermField(field: string) {\n    const selected = this.termFieldSelected[field];\n    return Object.keys(this.headers).map(key => {\n      const group = this.headers[key];\n      group.headers.filter(isTermField(field)).map(header => header.selected = selected);\n      return this.updateGroupHeader(key);\n    });\n  }\n}\n","<p class=\"mb-2\">Please select which columns you would like to include:</p>\n\n<p class=\"my-2 is-size-7\"><i>You can drag and drop the headers to sort them as they would appear in the CSV file.</i></p>\n\n<div class=\"columns toggle-all mx-4 pb-1 mb-0\">\n  <div class=\"column\">\n    <label class=\"checkbox ml-1\">\n      <input type=\"checkbox\" class=\"selector\"\n        [(ngModel)]=\"allSelected\"\n        (change)=\"toggleAll(); reresh()\"\n      >\n      <span class=\"ml-2\">Toggle All</span>\n    </label>\n  </div>\n\n  <div class=\"column is-narrow has-text-right\">\n    <div class=\"dropdown is-right has-text-left\"\n      [class.is-active]=\"showSelectTermFields\"\n      (clickOutside)=\"showSelectTermFields = false\"\n    >\n      <div class=\"dropdown-trigger\" (click)=\"showSelectTermFields = !showSelectTermFields\">\n        <button class=\"button is-small\"\n          aria-haspopup=\"true\" aria-controls=\"select-menu\"\n        >\n          <span>Toggle Term Fields</span>\n          <span class=\"icon is-small\">\n            <fa-icon icon=\"filter\" aria-hidden=\"true\"></fa-icon>\n          </span>\n        </button>\n      </div>\n      <div class=\"dropdown-menu\" id=\"select-menu\" role=\"menu\">\n        <div class=\"dropdown-content\">\n          <a class=\"dropdown-item\"\n            *ngFor=\"let field of termFields\"\n          >\n            <label class=\"checkbox ml-1\">\n              <input type=\"checkbox\" class=\"selector\"\n                [(ngModel)]=\"termFieldSelected[field]\"\n                (change)=\"toggleTermField(field)\"\n              >\n              <span class=\"ml-2\">{{field}}</span>\n            </label>\n          </a>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n\n<div class=\"drag-container\">\n  <div class=\"card\" *ngFor=\"let group of headers | keys\">\n    <header class=\"card-header\" *ngIf=\"group.key\">\n      <div class=\"card-header-title\">\n        <label class=\"checkbox ml-1\">\n          <input type=\"checkbox\" class=\"selector\"\n            [indeterminate]=\"group.value.partialSelected\"\n            [(ngModel)]=\"group.value.selected\"\n            (change)=\"updateGroup(group.key); reresh()\"\n          >\n          <span class=\"ml-2\">{{group.key}}</span>\n        </label>\n      </div>\n      <span class=\"card-header-icon has-text-link\" aria-label=\"open / close\"\n        (click)=\"group.value.open = !group.value.open\" pointer\n      >\n        <span class=\"icon\">\n          <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!group.value.open\"></fa-icon>\n          <fa-icon icon=\"angle-left\" [class.is-hidden]=\"group.value.open\"></fa-icon>\n        </span>\n      </span>\n    </header>\n\n    <div class=\"card-content p-3\" [class.is-hidden]=\"!group.value.open\">\n      <ul cdkDropList (cdkDropListDropped)=\"dropHeader($event, group.key)\">\n        <li *ngFor=\"let header of group.value.headers\" cdkDrag>\n          <label class=\"checkbox ml-2\">\n            <input type=\"checkbox\" class=\"selector\"\n              [(ngModel)]=\"header.selected\"\n              (change)=\"updateGroupHeader(group.key); reresh()\"\n            >\n            <span class=\"ml-2\">{{header.header}}</span>\n          </label>\n        </li>\n      </ul>\n    </div>\n  </div>\n</div>\n"]}
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-csv-select-headers.component.js","sourceRoot":"","sources":["../../../../src/node/node-csv-select-headers/node-csv-select-headers.component.ts","../../../../src/node/node-csv-select-headers/node-csv-select-headers.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { CdkDragDrop, moveItemInArray } from '@angular/cdk/drag-drop';\nimport { definitions } from '@hestia-earth/json-schema';\nimport { isDefaultCSVSelected, isCSVIncluded } from '@hestia-earth/json-schema/schema-utils';\n\nimport { HeSchemaService } from '../../schema/schema.service';\n\ninterface IHeader {\n  header: string;\n  selected: boolean;\n}\n\ninterface IGroupedHeaders {\n  [group: string]: {\n    selected: boolean;\n    partialSelected: boolean;\n    open: boolean;\n    headers: IHeader[];\n  };\n}\n\nconst headerGroup = (header: string) => {\n  const parts = header.split('.');\n  return parts.length === 2 ? '' : [parts[0], parts[1]].join('.');\n};\n\nconst termFields = [\n  '@id', 'name', 'units', 'termType'\n];\n\nconst isTermField = (field: string) => ({ header }: IHeader) => [\n  'term', 'methodModel', 'country', 'product', 'operation', 'key'\n].some(parent => header.endsWith([parent, field].join('.')));\n\n@Component({\n  selector: 'he-node-csv-select-headers',\n  templateUrl: './node-csv-select-headers.component.html',\n  styleUrls: ['./node-csv-select-headers.component.scss']\n})\nexport class NodeCsvSelectHeadersComponent implements OnInit {\n  @Input()\n  private csv = '';\n  @Input()\n  private keys?: string[];\n  @Input()\n  private includeDefaultCSV = false;\n\n  @Output()\n  public headersChanged = new EventEmitter<string[]>();\n\n  public headers: IGroupedHeaders = {};\n  public allSelected = false;\n\n  public showSelectTermFields = false;\n  public termFields = termFields;\n  public termFieldSelected: any = {};\n\n  constructor(\n    private schemaService: HeSchemaService\n  ) {}\n\n  async ngOnInit() {\n    const schemas = await this.schemaService.schemas();\n    const isSelected = await this.isSelected(schemas);\n    const headers = await this.schemaService.parseHeaders(this.csv);\n    this.headers = headers.filter(isCSVIncluded(schemas)).reduce((prev, header) => {\n      const group = headerGroup(header);\n      prev[group] = prev[group] || { headers: [], selected: false, partialSelected: false, open: true };\n      prev[group].headers.push({ header, selected: isSelected(header) });\n      return prev;\n    }, {} as IGroupedHeaders);\n    Object.keys(this.headers).map(groupKey => this.updateGroupHeader(groupKey));\n    this.termFieldSelected = termFields.reduce((prev, curr) => ({ ...prev, [curr]: curr === '@id' }), {});\n    this.reresh();\n  }\n\n  private async isSelected(schemas: definitions) {\n    const isSelected = this.includeDefaultCSV ? () => true : isDefaultCSVSelected(schemas);\n    return (key: string) => (!this.keys?.length || this.keys.some(v => key.startsWith(v))) && isSelected(key);\n  }\n\n  public dropHeader(event: CdkDragDrop<IHeader[]>, groupKey: string) {\n    moveItemInArray(this.headers[groupKey].headers, event.previousIndex, event.currentIndex);\n    this.headersChanged.emit(this.selectedHeaders);\n  }\n\n  private updateAllSelected() {\n    this.allSelected = Object.keys(this.headers).every(key => this.headers[key].selected);\n  }\n\n  public toggleAll() {\n    // select all term fields\n    Object.keys(this.termFieldSelected).map(key => (this.termFieldSelected[key] = true));\n    // select all keys\n    return Object.entries(this.headers).map(([key, group]) => {\n      group.selected = this.allSelected;\n      return this.updateGroup(key);\n    });\n  }\n\n  public updateGroup(groupKey: string) {\n    const group = this.headers[groupKey];\n    group.headers.map(header => header.selected = group.selected);\n  }\n\n  public updateGroupHeader(groupKey: string) {\n    const group = this.headers[groupKey];\n    const allSelected = group.headers.every(({ selected }) => selected);\n    group.selected = allSelected;\n    group.partialSelected = !allSelected && group.headers.some(({ selected }) => selected);\n  }\n\n  public get selectedHeaders() {\n    return Object.values(this.headers)\n      .flatMap(({ headers }) => headers)\n      .filter(({ selected }) => selected)\n      .map(({ header }) => header);\n  }\n\n  public reresh() {\n    this.updateAllSelected();\n    this.headersChanged.emit(this.selectedHeaders);\n  }\n\n  // Term fields\n\n  public toggleTermField(field: string) {\n    const selected = this.termFieldSelected[field];\n    return Object.entries(this.headers).map(([key, group]) => {\n      group.headers.filter(isTermField(field)).map(header => header.selected = selected);\n      return this.updateGroupHeader(key);\n    });\n  }\n}\n","<p class=\"mb-2\">Please select which columns you would like to include:</p>\n\n<p class=\"my-2 is-size-7\"><i>You can drag and drop the headers to sort them as they would appear in the CSV file.</i></p>\n\n<div class=\"columns toggle-all mx-4 pb-1 mb-0\">\n  <div class=\"column\">\n    <label class=\"checkbox ml-1\">\n      <input type=\"checkbox\" class=\"selector\"\n        [(ngModel)]=\"allSelected\"\n        (change)=\"toggleAll(); reresh()\"\n      >\n      <span class=\"ml-2\">Toggle All</span>\n    </label>\n  </div>\n\n  <div class=\"column is-narrow has-text-right\">\n    <div class=\"dropdown is-right has-text-left\"\n      [class.is-active]=\"showSelectTermFields\"\n      (clickOutside)=\"showSelectTermFields = false\"\n    >\n      <div class=\"dropdown-trigger\" (click)=\"showSelectTermFields = !showSelectTermFields\">\n        <button class=\"button is-small\"\n          aria-haspopup=\"true\" aria-controls=\"select-menu\"\n        >\n          <span>Toggle Term Fields</span>\n          <span class=\"icon is-small\">\n            <fa-icon icon=\"filter\" aria-hidden=\"true\"></fa-icon>\n          </span>\n        </button>\n      </div>\n      <div class=\"dropdown-menu\" id=\"select-menu\" role=\"menu\">\n        <div class=\"dropdown-content\">\n          <a class=\"dropdown-item\"\n            *ngFor=\"let field of termFields\"\n          >\n            <label class=\"checkbox ml-1\">\n              <input type=\"checkbox\" class=\"selector\"\n                [(ngModel)]=\"termFieldSelected[field]\"\n                (change)=\"toggleTermField(field)\"\n              >\n              <span class=\"ml-2\">{{field}}</span>\n            </label>\n          </a>\n        </div>\n      </div>\n    </div>\n  </div>\n</div>\n\n<div class=\"drag-container\">\n  <div class=\"card\" *ngFor=\"let group of headers | keys\">\n    <header class=\"card-header\" *ngIf=\"group.key\">\n      <div class=\"card-header-title\">\n        <label class=\"checkbox ml-1\">\n          <input type=\"checkbox\" class=\"selector\"\n            [indeterminate]=\"group.value.partialSelected\"\n            [(ngModel)]=\"group.value.selected\"\n            (change)=\"updateGroup(group.key); reresh()\"\n          >\n          <span class=\"ml-2\">{{group.key}}</span>\n        </label>\n      </div>\n      <span class=\"card-header-icon has-text-link\" aria-label=\"open / close\"\n        (click)=\"group.value.open = !group.value.open\" pointer\n      >\n        <span class=\"icon\">\n          <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!group.value.open\"></fa-icon>\n          <fa-icon icon=\"angle-left\" [class.is-hidden]=\"group.value.open\"></fa-icon>\n        </span>\n      </span>\n    </header>\n\n    <div class=\"card-content p-3\" [class.is-hidden]=\"!group.value.open\">\n      <ul cdkDropList (cdkDropListDropped)=\"dropHeader($event, group.key)\">\n        <li *ngFor=\"let header of group.value.headers\" cdkDrag>\n          <label class=\"checkbox ml-2\">\n            <input type=\"checkbox\" class=\"selector\"\n              [(ngModel)]=\"header.selected\"\n              (change)=\"updateGroupHeader(group.key); reresh()\"\n            >\n            <span class=\"ml-2\">{{header.header}}</span>\n          </label>\n        </li>\n      </ul>\n    </div>\n  </div>\n</div>\n"]}
@@ -3,9 +3,9 @@ export const searchableTypes = [
3
3
  NodeType.Cycle,
4
4
  NodeType.Source
5
5
  ];
6
- export const serializeSearchFilters = (filters) => Object.keys(filters || {})
7
- .filter(key => filters[key].length)
8
- .map(key => `${key}=${filters[key].filter(Boolean).join('|')}`)
6
+ export const serializeSearchFilters = (filters) => Object.entries(filters || {})
7
+ .filter(([_key, value]) => value.length)
8
+ .map(([key, value]) => `${key}=${value.filter(Boolean).join('|')}`)
9
9
  .join(';');
10
10
  export const deserializeSearchFilters = (filters) => (filters || '').split(';').reduce((prev, curr) => {
11
11
  const [key, values] = curr.split('=');
@@ -201,4 +201,4 @@ export const searchQuery = (type, query, filters, aggregated) => {
201
201
  };
202
202
  };
203
203
  /* eslint-enable complexity */
204
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search.model.js","sourceRoot":"","sources":["../../../src/search/search.model.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAIpF,MAAM,CAAC,MAAM,eAAe,GAAqB;IAC/C,QAAQ,CAAC,KAAK;IACd,QAAQ,CAAC,MAAM;CAChB,CAAC;AASF,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,OAAuB,EAAE,EAAE,CAChE,MAAM,CAAC,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC;KACvB,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC;KAClC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,GAAG,IAAI,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;KAC9D,IAAI,CAAC,GAAG,CAAC,CAAC;AAEf,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,OAAe,EAAkB,EAAE,CAC1E,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,IAAS,EAAE,IAAI,EAAE,EAAE;IACpD,MAAM,CAAC,GAAG,EAAE,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACtC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACtD,OAAO,IAAI,CAAC;AACd,CAAC,EAAE,EAAE,CAAC,CAAC;AAET,MAAM,CAAC,MAAM,SAAS,GAAG,CAAC,IAAuB,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC;IAClE,KAAK,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE;CACzB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,QAA+B,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC;IAC9E,KAAK,EAAE,EAAE,QAAQ,EAAE;CACpB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,GAAW,EAAE,KAAsB,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC;IAC/E,MAAM,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,QAAQ,EAAE,EAAE,EAAE;CAC/C,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,GAAW,EAAE,KAAU,EAAE,KAAc,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC;IACnF,KAAK,EAAE;QACL,CAAC,GAAG,CAAC,kBACH,KAAK,EAAE,KAAK,IACT,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAC5B;KACF;CACF,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,GAAW,EAAE,KAAU,EAAE,KAAc,EAAE,EAAE,CAAC,UAAU,CAAC,GAAG,GAAG,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;AAEvH,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,KAAa,EAAE,KAAK,GAAG,EAAE,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC;IAC9E,KAAK,EAAE,EAAE,cAAc,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE;CAC5C,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,SAAS,GAAG,CAAC,GAAW,EAAE,KAAa,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC;IACrE,KAAK,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,EAAE;CACjC,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,eAAe,GAAG,CAC7B,KAAa,EAAE,MAAgB,EAAE,OAAuB,aAAa,EAAE,KAAc,EAAE,QAA6B,EACpH,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC;IACjB,WAAW,gCACT,KAAK;QACL,MAAM;QACN,IAAI,IACD,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,GACxB,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAClC;CACF,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,KAAa,EAAE,KAAc,EAAE,GAAG,MAAgB,EAAE,EAAE,CACrF,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,eAAe,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;AAE1G,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,KAAa,EAAE,KAAK,GAAG,CAAC,EAAE,GAAG,MAAgB,EAAE,EAAE,CACtF,MAAM,CAAC,MAAM,CAAC,CAAC;IACb,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,eAAe,EAAE,KAAK,CAAC,CAAC,CAAC;IACxD,MAAM,CAAC,MAAM,CAAC;QACZ,mBAAmB,EAAE;YACnB,mBAAmB,EAAE;gBACnB,KAAK;gBACL,KAAK;aACN;SACF;KACF,CAAC,CAAC;AAEP,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,KAAa,EAAE,KAAK,GAAG,CAAC,EAAE,GAAG,MAAgB,EAAE,EAAE,CACpF,MAAM,CAAC,MAAM,CAAC,CAAC;IACb,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,aAAa,EAAE,KAAK,CAAC,CAAC,CAAC;IACtD,MAAM,CAAC,MAAM,CAAC;QACZ,iBAAiB,EAAE;YACjB,IAAI,EAAE;gBACJ,KAAK;gBACL,KAAK;aACN;SACF;KACF,CAAC,CAAC;AAEP,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,KAAa,EAAE,KAAK,GAAG,CAAC,EAAE,GAAG,MAAgB,EAAE,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC;IAC5F,mBAAmB,EAAE;QACnB,KAAK,EAAE,IAAI,KAAK,GAAG;QACnB,MAAM;QACN,gBAAgB,EAAE,IAAI;QACtB,KAAK;KACN;CACF,CAAC,CAAC;AAEH,MAAM,iBAAiB,GAAG,EAAE,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC;AAEtD,MAAM,CAAC,MAAM,iBAAiB,GAAG,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,UAAU,EAAE,EAAE,CAAC;AAEnE,MAAM,CAAC,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC;IACxC,IAAI,EAAE;QACJ,MAAM,EAAE;YACN,iBAAiB;YACjB,iBAAiB;SAClB;QACD,oBAAoB,EAAE,CAAC;KACxB;CACF,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC;IAC1C,IAAI,EAAE;QACJ,IAAI,EAAE;YACJ,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC;YACxB,aAAa,CAAC,YAAY,CAAC,MAAM,CAAC;YAClC,iBAAiB;SAClB;KACF;CACF,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,iBAAiB,GAAG,MAAM,CAAC,MAAM,CAAC;IAC7C,IAAI,kBACF,IAAI,EAAE;YACJ,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC;YACxB,aAAa,CAAC,YAAY,CAAC,MAAM,CAAC;SACnC,IACE,YAAY,CAAC,IAAI,CACrB;CACF,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,WAAW,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;AAErD,MAAM,CAAC,MAAM,YAAY,GAAG,MAAM,CAAC,MAAM,CAAC;IACxC,IAAI,EAAE;QACJ,IAAI,EAAE;YACJ,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC;YACxB,aAAa,CAAC,YAAY,CAAC,MAAM,CAAC;YAClC,WAAW;SACZ;KACF;CACF,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,WAAW,GAAG,MAAM,CAAC,MAAM,CAAC;IACvC,KAAK,EAAE,cAAc;IACrB,IAAI,EAAE,OAAO;CACd,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,CAAC;IACtC,IAAI,EAAE;QACJ,IAAI,EAAE;YACJ,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC;YACxB,aAAa,CAAC,YAAY,CAAC,IAAI,CAAC;SACjC;KACF;CACF,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,oBAAoB,GAAG,UAAU,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC;AAEnE,MAAM,WAAW,GAAG,CAAC,GAAW,EAAE,EAAE,CAAC,oBAAoB,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAEtF,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,GAAW,EAAE,KAAU,EAAE,EAAE,CACxD,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACjB,MAAM,EAAE,EAAE,IAAI,EAAE,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE;CAC3C,CAAC,CAAC,CAAC,KAAK,CAAC;AAEZ;;GAEG;AACH,MAAM,CAAC,MAAM,mBAAmB,GAE5B,MAAM,CAAC,MAAM,CAAC;IAChB,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;QAChB,aAAa,EAAE,iBAAiB,EAAE,SAAS;QAC3C,gBAAgB,EAAE,aAAa,EAAE,eAAe;QAChD,eAAe,EAAE,mBAAmB,EAAE,kBAAkB;KACzD;IACD,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,oBAAoB,EAAE,0BAA0B,CAAC;IACrE,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC,2BAA2B,EAAE,cAAc,EAAE,cAAc,CAAC;CAC3F,CAAC,CAAC;AAEH;;GAEG;AACH,MAAM,YAAY,GAEd,MAAM,CAAC,MAAM,CAAC;IAChB,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,MAAM,EAAE,aAAa,EAAE,iBAAiB,CAAC;IAC5D,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,oBAAoB,CAAC;IACjD,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE,CAAC,MAAM,EAAE,cAAc,EAAE,cAAc,CAAC;CACtE,CAAC,CAAC;AAEH,MAAM,kBAAkB,GAEpB,MAAM,CAAC,MAAM,CAAC;IAChB,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;QAChB,kBAAkB;QAClB,qBAAqB;QACrB,qBAAqB;KACtB;IACD,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,EAAE;IACrB,CAAC,QAAQ,CAAC,gBAAgB,CAAC,EAAE;QAC3B,gCAAgC;QAChC,mBAAmB;KACpB;CACF,CAAC,CAAC;AAEH;;GAEG;AACH,MAAM,aAAa,GAEf;IACF,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,QAAQ,EAAE,CAAC,oBAAoB,CAAC,EAAE;IAChE,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE,QAAQ,EAAE,CAAC,oBAAoB,CAAC,EAAE;CAClE,CAAC;AAEF,MAAM,iBAAiB,GAEnB;IACF,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG;IAC5B,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC,GAAG;CAC9B,CAAC;AAEF,+BAA+B;AAC/B,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,IAAoB,EAAE,KAAc,EAAE,OAAwB,EAAE,UAAoB,EAAE,EAAE;IAClH,MAAM,SAAS,GAAQ,+BACrB,IAAI,EAAE;YACJ,SAAS,CAAC,IAAI,CAAC;YACf,UAAU,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,IAAI;SACzC,CAAC,MAAM,CAAC,OAAO,CAAC,IACd,CAAC,KAAK,CAAC,CAAC,CAAC;QACV,MAAM,EAAE;YACN,gBAAgB,CAAC,KAAK,EAAE,GAAG,EAAE,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;YACnD,sBAAsB,CAAC,KAAK,EAAE,EAAE,EAAE,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;YACxD,oBAAoB,CAAC,KAAK,EAAE,EAAE,EAAE,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;YACtD,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,cAAc,CAAC,KAAK,EAAE,oBAAoB,CAAC,KAAK,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC;SACvG;QACD,oBAAoB,EAAE,CAAC;KACxB,CAAC,CAAC,CAAC,EAAE,CAAC,KACP,QAAQ,EAAE;YACR,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,oBAAoB;SACzC,CAAC,MAAM,CAAC,OAAO,CAAC,IACjB,CAAC;IACH,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,OAAQ,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC;IAC5E,OAAO;QACL,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;YAClB,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE;gBACnB,MAAM,SAAS,GAAG,iBAAiB,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;gBAC/C,OAAO;oBACL,IAAI,EAAE;wBACJ,MAAM,EAAE,OAAQ,CAAC,GAAG,CAAC;6BAClB,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,cAAc,CAAC,SAAS,EAAE,eAAe,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC;6BAC1E,GAAG,CAAC,IAAI,CAAC,EAAE;4BACV,MAAM,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC;4BACzD,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;4BAC3B,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,CAAC;wBAC9B,CAAC,CAAC;wBACJ,oBAAoB,EAAE,CAAC;qBACxB;iBACF,CAAC;YACJ,CAAC,CAAC;SACH,CAAC,CAAC,CAAC,SAAS;KACd,CAAC;AACJ,CAAC,CAAC;AACF,8BAA8B","sourcesContent":["import { NodeType, TermTermType, nestedSearchableKeys } from '@hestia-earth/schema';\n\nexport type searchableType = NodeType.Cycle | NodeType.Source;\n\nexport const searchableTypes: searchableType[] = [\n  NodeType.Cycle,\n  NodeType.Source\n];\n\ntype multiMatchType = 'best_fields' | 'most_fields' | 'cross_fields' | 'phrase' | 'phrase_prefix' | 'bool_prefix';\ntype multiMatchAnalyzer = 'standard';\n\nexport interface ISearchFilters {\n  [key: string]: (string | number)[];\n}\n\nexport const serializeSearchFilters = (filters: ISearchFilters) =>\n  Object.keys(filters || {})\n    .filter(key => filters[key].length)\n    .map(key => `${key}=${filters[key].filter(Boolean).join('|')}`)\n    .join(';');\n\nexport const deserializeSearchFilters = (filters: string): ISearchFilters =>\n  (filters || '').split(';').reduce((prev: any, curr) => {\n    const [key, values] = curr.split('=');\n    prev[key] = (values || '').split('|').filter(Boolean);\n    return prev;\n  }, {});\n\nexport const matchType = (type: NodeType | string) => Object.freeze({\n  match: { '@type': type }\n});\n\nexport const matchTermType = (termType: TermTermType | string) => Object.freeze({\n  match: { termType }\n});\n\nexport const matchRegex = (key: string, value: string | RegExp) => Object.freeze({\n  regexp: { [key]: { value: value.toString() } }\n});\n\nexport const matchQuery = (key: string, value: any, boost?: number) => Object.freeze({\n  match: {\n    [key]: {\n      query: value,\n      ...(boost ? { boost } : {})\n    }\n  }\n});\n\nexport const matchExactQuery = (key: string, value: any, boost?: number) => matchQuery(`${key}.keyword`, value, boost);\n\nexport const matchNameNormalized = (query: string, boost = 20) => Object.freeze({\n  match: { nameNormalized: { query, boost } }\n});\n\nexport const numberGte = (key: string, value: number) => Object.freeze({\n  range: { [key]: { gte: value } }\n});\n\nexport const multiMatchQuery = (\n  query: string, fields: string[], type: multiMatchType = 'best_fields', boost?: number, analyzer?: multiMatchAnalyzer\n) => Object.freeze({\n  multi_match: {\n    query,\n    fields,\n    type,\n    ...(boost ? { boost } : {}),\n    ...(analyzer ? { analyzer } : {})\n  }\n});\n\nexport const matchPhraseQuery = (query: string, boost?: number, ...fields: string[]) =>\n  fields.length ? multiMatchQuery(query, fields, 'phrase', boost) : matchExactQuery('name', query, boost);\n\nexport const matchPhrasePrefixQuery = (query: string, boost = 2, ...fields: string[]) =>\n  fields.length ?\n    multiMatchQuery(query, fields, 'phrase_prefix', boost) :\n    Object.freeze({\n      match_phrase_prefix: {\n        nameSearchAsYouType: {\n          query,\n          boost\n        }\n      }\n    });\n\nexport const matchBoolPrefixQuery = (query: string, boost = 1, ...fields: string[]) =>\n  fields.length ?\n    multiMatchQuery(query, fields, 'bool_prefix', boost) :\n    Object.freeze({\n      match_bool_prefix: {\n        name: {\n          query,\n          boost\n        }\n      }\n    });\n\nexport const wildcardQuery = (query: string, boost = 3, ...fields: string[]) => Object.freeze({\n  simple_query_string: {\n    query: `*${query}*`,\n    fields,\n    analyze_wildcard: true,\n    boost\n  }\n});\n\nconst matchCountryLevel = { match: { gadmLevel: 0 } };\n\nexport const matchGlobalRegion = { regexp: { '@id': 'region-*' } };\n\nexport const matchCountry = Object.freeze({\n  bool: {\n    should: [\n      matchCountryLevel,\n      matchGlobalRegion\n    ],\n    minimum_should_match: 1\n  }\n});\n\nexport const countriesQuery = Object.freeze({\n  bool: {\n    must: [\n      matchType(NodeType.Term),\n      matchTermType(TermTermType.region),\n      matchCountryLevel\n    ]\n  }\n});\n\nexport const allCountriesQuery = Object.freeze({\n  bool: {\n    must: [\n      matchType(NodeType.Term),\n      matchTermType(TermTermType.region)\n    ],\n    ...matchCountry.bool\n  }\n});\n\nexport const matchRegion = numberGte('gadmLevel', 1);\n\nexport const regionsQuery = Object.freeze({\n  bool: {\n    must: [\n      matchType(NodeType.Term),\n      matchTermType(TermTermType.region),\n      matchRegion\n    ]\n  }\n});\n\nexport const worldRegion = Object.freeze({\n  '@id': 'region-world',\n  name: 'World'\n});\n\nexport const cropsQuery = Object.freeze({\n  bool: {\n    must: [\n      matchType(NodeType.Term),\n      matchTermType(TermTermType.crop)\n    ]\n  }\n});\n\nexport const matchAggregatedQuery = matchQuery('aggregated', true);\n\nconst isNestedKey = (key: string) => nestedSearchableKeys.includes(key.split('.')[0]);\n\nexport const matchNestedKey = (key: string, query: any) =>\n  isNestedKey(key) ? {\n    nested: { path: key.split('.')[0], query }\n  } : query;\n\n/**\n * List of fields to return in the search results.\n */\nexport const searchResultsFields: {\n  [type in searchableType]: string[];\n} = Object.freeze({\n  [NodeType.Cycle]: [\n    'description', 'dataDescription', 'endDate',\n    'emissionsCount', 'inputsCount', 'productsCount',\n    'site.location', 'site.country.name', 'site.region.name'\n  ],\n  [NodeType.Source]: ['bibliography.title', 'bibliography.documentDOI'],\n  [NodeType.ImpactAssessment]: ['emissionsResourceUseCount', 'impactsCount', 'country.name']\n});\n\n/**\n * List of fields to search in.\n */\nconst searchFields: {\n  [type in searchableType]: string[];\n} = Object.freeze({\n  [NodeType.Cycle]: ['name', 'description', 'dataDescription'],\n  [NodeType.Source]: ['name', 'bibliography.title'],\n  [NodeType.ImpactAssessment]: ['name', 'product.name', 'country.name']\n});\n\nconst searchFieldsNested: {\n  [type in searchableType]: string[];\n} = Object.freeze({\n  [NodeType.Cycle]: [\n    'inputs.term.name',\n    'emissions.term.name',\n    'practices.term.name'\n  ],\n  [NodeType.Source]: [],\n  [NodeType.ImpactAssessment]: [\n    'emissionsResourceUse.term.name',\n    'impacts.term.name'\n  ]\n});\n\n/**\n * Specific strict queries per type.\n */\nconst searchQueries: {\n  [type in searchableType]: { must: any[]; must_not: any[] };\n} = {\n  [NodeType.Cycle]: { must: [], must_not: [matchAggregatedQuery] },\n  [NodeType.Source]: { must: [], must_not: [matchAggregatedQuery] }\n};\n\nconst searchFiltersKeys: {\n  [type in searchableType]: (key: string) => string;\n} = {\n  [NodeType.Cycle]: key => key,\n  [NodeType.Source]: key => key\n};\n\n/* eslint-disable complexity */\nexport const searchQuery = (type: searchableType, query?: string, filters?: ISearchFilters, aggregated?: boolean) => {\n  const boolQuery: any = ({\n    must: [\n      matchType(type),\n      aggregated ? matchAggregatedQuery : null\n    ].filter(Boolean),\n    ...(query ? {\n      should: [\n        matchPhraseQuery(query, 100, ...searchFields[type]), // make sure exact matches come first\n        matchPhrasePrefixQuery(query, 20, ...searchFields[type]),\n        matchBoolPrefixQuery(query, 10, ...searchFields[type]),\n        ...searchFieldsNested[type].map(field => matchNestedKey(field, matchBoolPrefixQuery(query, 1, field)))\n      ],\n      minimum_should_match: 1\n    } : {}),\n    must_not: [\n      aggregated ? null : matchAggregatedQuery\n    ].filter(Boolean)\n  });\n  const keys = Object.keys(filters || {}).filter(key => filters![key].length);\n  return {\n    bool: keys.length ? {\n      must: keys.map(key => {\n        const filterKey = searchFiltersKeys[type](key);\n        return {\n          bool: {\n            should: filters![key]\n              .map(value => matchNestedKey(filterKey, matchExactQuery(filterKey, value)))\n              .map(must => {\n                const localQuery = JSON.parse(JSON.stringify(boolQuery));\n                localQuery.must.push(must);\n                return { bool: localQuery };\n              }),\n            minimum_should_match: 1\n          }\n        };\n      })\n    } : boolQuery\n  };\n};\n/* eslint-enable complexity */\n"]}
204
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search.model.js","sourceRoot":"","sources":["../../../src/search/search.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { NodeType, TermTermType, nestedSearchableKeys } from '@hestia-earth/schema';\n\nexport type searchableType = NodeType.Cycle | NodeType.Source;\n\nexport const searchableTypes: searchableType[] = [\n  NodeType.Cycle,\n  NodeType.Source\n];\n\ntype multiMatchType = 'best_fields' | 'most_fields' | 'cross_fields' | 'phrase' | 'phrase_prefix' | 'bool_prefix';\ntype multiMatchAnalyzer = 'standard';\n\nexport interface ISearchFilters {\n  [key: string]: (string | number)[];\n}\n\nexport const serializeSearchFilters = (filters: ISearchFilters) =>\n  Object.entries(filters || {})\n    .filter(([_key, value]) => value.length)\n    .map(([key, value]) => `${key}=${value.filter(Boolean).join('|')}`)\n    .join(';');\n\nexport const deserializeSearchFilters = (filters: string): ISearchFilters =>\n  (filters || '').split(';').reduce((prev: any, curr) => {\n    const [key, values] = curr.split('=');\n    prev[key] = (values || '').split('|').filter(Boolean);\n    return prev;\n  }, {});\n\nexport const matchType = (type: NodeType | string) => Object.freeze({\n  match: { '@type': type }\n});\n\nexport const matchTermType = (termType: TermTermType | string) => Object.freeze({\n  match: { termType }\n});\n\nexport const matchRegex = (key: string, value: string | RegExp) => Object.freeze({\n  regexp: { [key]: { value: value.toString() } }\n});\n\nexport const matchQuery = (key: string, value: any, boost?: number) => Object.freeze({\n  match: {\n    [key]: {\n      query: value,\n      ...(boost ? { boost } : {})\n    }\n  }\n});\n\nexport const matchExactQuery = (key: string, value: any, boost?: number) => matchQuery(`${key}.keyword`, value, boost);\n\nexport const matchNameNormalized = (query: string, boost = 20) => Object.freeze({\n  match: { nameNormalized: { query, boost } }\n});\n\nexport const numberGte = (key: string, value: number) => Object.freeze({\n  range: { [key]: { gte: value } }\n});\n\nexport const multiMatchQuery = (\n  query: string, fields: string[], type: multiMatchType = 'best_fields', boost?: number, analyzer?: multiMatchAnalyzer\n) => Object.freeze({\n  multi_match: {\n    query,\n    fields,\n    type,\n    ...(boost ? { boost } : {}),\n    ...(analyzer ? { analyzer } : {})\n  }\n});\n\nexport const matchPhraseQuery = (query: string, boost?: number, ...fields: string[]) =>\n  fields.length ? multiMatchQuery(query, fields, 'phrase', boost) : matchExactQuery('name', query, boost);\n\nexport const matchPhrasePrefixQuery = (query: string, boost = 2, ...fields: string[]) =>\n  fields.length ?\n    multiMatchQuery(query, fields, 'phrase_prefix', boost) :\n    Object.freeze({\n      match_phrase_prefix: {\n        nameSearchAsYouType: {\n          query,\n          boost\n        }\n      }\n    });\n\nexport const matchBoolPrefixQuery = (query: string, boost = 1, ...fields: string[]) =>\n  fields.length ?\n    multiMatchQuery(query, fields, 'bool_prefix', boost) :\n    Object.freeze({\n      match_bool_prefix: {\n        name: {\n          query,\n          boost\n        }\n      }\n    });\n\nexport const wildcardQuery = (query: string, boost = 3, ...fields: string[]) => Object.freeze({\n  simple_query_string: {\n    query: `*${query}*`,\n    fields,\n    analyze_wildcard: true,\n    boost\n  }\n});\n\nconst matchCountryLevel = { match: { gadmLevel: 0 } };\n\nexport const matchGlobalRegion = { regexp: { '@id': 'region-*' } };\n\nexport const matchCountry = Object.freeze({\n  bool: {\n    should: [\n      matchCountryLevel,\n      matchGlobalRegion\n    ],\n    minimum_should_match: 1\n  }\n});\n\nexport const countriesQuery = Object.freeze({\n  bool: {\n    must: [\n      matchType(NodeType.Term),\n      matchTermType(TermTermType.region),\n      matchCountryLevel\n    ]\n  }\n});\n\nexport const allCountriesQuery = Object.freeze({\n  bool: {\n    must: [\n      matchType(NodeType.Term),\n      matchTermType(TermTermType.region)\n    ],\n    ...matchCountry.bool\n  }\n});\n\nexport const matchRegion = numberGte('gadmLevel', 1);\n\nexport const regionsQuery = Object.freeze({\n  bool: {\n    must: [\n      matchType(NodeType.Term),\n      matchTermType(TermTermType.region),\n      matchRegion\n    ]\n  }\n});\n\nexport const worldRegion = Object.freeze({\n  '@id': 'region-world',\n  name: 'World'\n});\n\nexport const cropsQuery = Object.freeze({\n  bool: {\n    must: [\n      matchType(NodeType.Term),\n      matchTermType(TermTermType.crop)\n    ]\n  }\n});\n\nexport const matchAggregatedQuery = matchQuery('aggregated', true);\n\nconst isNestedKey = (key: string) => nestedSearchableKeys.includes(key.split('.')[0]);\n\nexport const matchNestedKey = (key: string, query: any) =>\n  isNestedKey(key) ? {\n    nested: { path: key.split('.')[0], query }\n  } : query;\n\n/**\n * List of fields to return in the search results.\n */\nexport const searchResultsFields: {\n  [type in searchableType]: string[];\n} = Object.freeze({\n  [NodeType.Cycle]: [\n    'description', 'dataDescription', 'endDate',\n    'emissionsCount', 'inputsCount', 'productsCount',\n    'site.location', 'site.country.name', 'site.region.name'\n  ],\n  [NodeType.Source]: ['bibliography.title', 'bibliography.documentDOI'],\n  [NodeType.ImpactAssessment]: ['emissionsResourceUseCount', 'impactsCount', 'country.name']\n});\n\n/**\n * List of fields to search in.\n */\nconst searchFields: {\n  [type in searchableType]: string[];\n} = Object.freeze({\n  [NodeType.Cycle]: ['name', 'description', 'dataDescription'],\n  [NodeType.Source]: ['name', 'bibliography.title'],\n  [NodeType.ImpactAssessment]: ['name', 'product.name', 'country.name']\n});\n\nconst searchFieldsNested: {\n  [type in searchableType]: string[];\n} = Object.freeze({\n  [NodeType.Cycle]: [\n    'inputs.term.name',\n    'emissions.term.name',\n    'practices.term.name'\n  ],\n  [NodeType.Source]: [],\n  [NodeType.ImpactAssessment]: [\n    'emissionsResourceUse.term.name',\n    'impacts.term.name'\n  ]\n});\n\n/**\n * Specific strict queries per type.\n */\nconst searchQueries: {\n  [type in searchableType]: { must: any[]; must_not: any[] };\n} = {\n  [NodeType.Cycle]: { must: [], must_not: [matchAggregatedQuery] },\n  [NodeType.Source]: { must: [], must_not: [matchAggregatedQuery] }\n};\n\nconst searchFiltersKeys: {\n  [type in searchableType]: (key: string) => string;\n} = {\n  [NodeType.Cycle]: key => key,\n  [NodeType.Source]: key => key\n};\n\n/* eslint-disable complexity */\nexport const searchQuery = (type: searchableType, query?: string, filters?: ISearchFilters, aggregated?: boolean) => {\n  const boolQuery: any = ({\n    must: [\n      matchType(type),\n      aggregated ? matchAggregatedQuery : null\n    ].filter(Boolean),\n    ...(query ? {\n      should: [\n        matchPhraseQuery(query, 100, ...searchFields[type]), // make sure exact matches come first\n        matchPhrasePrefixQuery(query, 20, ...searchFields[type]),\n        matchBoolPrefixQuery(query, 10, ...searchFields[type]),\n        ...searchFieldsNested[type].map(field => matchNestedKey(field, matchBoolPrefixQuery(query, 1, field)))\n      ],\n      minimum_should_match: 1\n    } : {}),\n    must_not: [\n      aggregated ? null : matchAggregatedQuery\n    ].filter(Boolean)\n  });\n  const keys = Object.keys(filters || {}).filter(key => filters![key].length);\n  return {\n    bool: keys.length ? {\n      must: keys.map(key => {\n        const filterKey = searchFiltersKeys[type](key);\n        return {\n          bool: {\n            should: filters![key]\n              .map(value => matchNestedKey(filterKey, matchExactQuery(filterKey, value)))\n              .map(must => {\n                const localQuery = JSON.parse(JSON.stringify(boolQuery));\n                localQuery.must.push(must);\n                return { bool: localQuery };\n              }),\n            minimum_should_match: 1\n          }\n        };\n      })\n    } : boolQuery\n  };\n};\n/* eslint-enable complexity */\n"]}