@hestia-earth/ui-components 0.0.20 → 0.0.23

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 (40) hide show
  1. package/bundles/hestia-earth-ui-components.umd.js +232 -463
  2. package/bundles/hestia-earth-ui-components.umd.js.map +1 -1
  3. package/cycles/cycles-activity/cycles-activity.component.d.ts +4 -2
  4. package/cycles/cycles-completeness/cycles-completeness.component.d.ts +3 -1
  5. package/cycles/cycles-emissions/cycles-emissions.component.d.ts +3 -11
  6. package/cycles/cycles-emissions-chart/cycles-emissions-chart.component.d.ts +2 -1
  7. package/cycles/cycles-practices/cycles-practices.component.d.ts +3 -11
  8. package/cycles/cycles-result/cycles-result.component.d.ts +3 -1
  9. package/cycles/cycles.module.d.ts +5 -6
  10. package/cycles/index.d.ts +0 -1
  11. package/engine/engine.service.d.ts +10 -1
  12. package/esm2015/cycles/cycles-activity/cycles-activity.component.js +17 -23
  13. package/esm2015/cycles/cycles-completeness/cycles-completeness.component.js +9 -3
  14. package/esm2015/cycles/cycles-emissions/cycles-emissions.component.js +17 -56
  15. package/esm2015/cycles/cycles-emissions-chart/cycles-emissions-chart.component.js +18 -8
  16. package/esm2015/cycles/cycles-practices/cycles-practices.component.js +16 -55
  17. package/esm2015/cycles/cycles-result/cycles-result.component.js +19 -6
  18. package/esm2015/cycles/cycles.module.js +4 -8
  19. package/esm2015/cycles/index.js +1 -2
  20. package/esm2015/engine/engine.service.js +16 -2
  21. package/esm2015/files/files-error.model.js +8 -5
  22. package/esm2015/files/files-form/files-form.component.js +1 -1
  23. package/esm2015/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.js +24 -54
  24. package/esm2015/impact-assessments/impact-assessments-products/impact-assessments-products.component.js +30 -131
  25. package/esm2015/impact-assessments/impact-assessments-products-logs/impact-assessments-products-logs.component.js +6 -2
  26. package/esm2015/node/node-csv-select-headers/node-csv-select-headers.component.js +11 -7
  27. package/esm2015/node/node-logs-models/node-logs-models.component.js +11 -3
  28. package/esm2015/sites/sites-maps/sites-maps.component.js +10 -3
  29. package/esm2015/sites/sites-measurements/sites-measurements.component.js +8 -2
  30. package/fesm2015/hestia-earth-ui-components.js +160 -357
  31. package/fesm2015/hestia-earth-ui-components.js.map +1 -1
  32. package/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.d.ts +5 -8
  33. package/impact-assessments/impact-assessments-products/impact-assessments-products.component.d.ts +5 -30
  34. package/impact-assessments/impact-assessments-products-logs/impact-assessments-products-logs.component.d.ts +3 -2
  35. package/node/node-csv-select-headers/node-csv-select-headers.component.d.ts +9 -3
  36. package/package.json +4 -4
  37. package/sites/sites-maps/sites-maps.component.d.ts +3 -1
  38. package/sites/sites-measurements/sites-measurements.component.d.ts +3 -1
  39. package/cycles/cycles-suggest-form/cycles-suggest-form.component.d.ts +0 -23
  40. package/esm2015/cycles/cycles-suggest-form/cycles-suggest-form.component.js +0 -83
@@ -3,11 +3,10 @@ import { Indicator, Term, TermTermType } from '@hestia-earth/schema';
3
3
  import { IGroupedNodes } from '../../common/utils';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class ImpactAssessmentsIndicatorsChartComponent implements AfterViewInit, OnChanges {
6
- private barChartRef?;
7
- private barChart;
8
- private pieChartRef?;
9
- private pieChart;
6
+ private chartRef?;
7
+ private chart;
10
8
  private impactAssessments;
9
+ private selected;
11
10
  private key;
12
11
  filterTermTypes?: TermTermType[];
13
12
  indicatorPerImpactAssessment: IGroupedNodes<Indicator>;
@@ -17,9 +16,7 @@ export declare class ImpactAssessmentsIndicatorsChartComponent implements AfterV
17
16
  ngOnChanges(changes: SimpleChanges): void;
18
17
  private termAllowed;
19
18
  private init;
20
- private updateBarChart;
21
- private updatePieChart;
22
- updateCharts(): void;
19
+ updateChart(): void;
23
20
  static ɵfac: i0.ɵɵFactoryDeclaration<ImpactAssessmentsIndicatorsChartComponent, never>;
24
- static ɵcmp: i0.ɵɵComponentDeclaration<ImpactAssessmentsIndicatorsChartComponent, "he-impact-assessments-indicators-chart", never, { "impactAssessments": "impactAssessments"; "key": "key"; "filterTermTypes": "filterTermTypes"; }, {}, never, never>;
21
+ static ɵcmp: i0.ɵɵComponentDeclaration<ImpactAssessmentsIndicatorsChartComponent, "he-impact-assessments-indicators-chart", never, { "impactAssessments": "impactAssessments"; "selected": "selected"; "key": "key"; "filterTermTypes": "filterTermTypes"; }, {}, never, never>;
25
22
  }
@@ -1,11 +1,7 @@
1
1
  import { OnChanges, SimpleChanges } from '@angular/core';
2
- import { FormBuilder } from '@angular/forms';
3
- import { Observable } from 'rxjs';
4
2
  import { DataState } from '@hestia-earth/api';
5
3
  import { IImpactAssessmentJSONLD, Indicator, TermTermType, Term } from '@hestia-earth/schema';
6
4
  import { HeNodeService } from '../../node/node.service';
7
- import { HeSearchService } from '../../search/search.service';
8
- import { HeToastService } from '../../common/toast.service';
9
5
  import { IGroupedKeys } from '../../common/utils';
10
6
  import * as i0 from "@angular/core";
11
7
  declare enum View {
@@ -15,20 +11,17 @@ declare enum View {
15
11
  logs = "logs"
16
12
  }
17
13
  export declare class ImpactAssessmentsProductsComponent implements OnChanges {
18
- private formBuilder;
19
14
  private nodeService;
20
- private searchService;
21
- private toastService;
22
15
  private dataStateValues;
23
16
  private cycles?;
24
17
  impactAssessments: IImpactAssessmentJSONLD[];
18
+ selected: string[];
25
19
  key: 'impacts' | 'emissionsResourceUse';
26
20
  dataState?: DataState;
27
- enableCompare: boolean;
28
21
  filterTermTypes?: TermTermType[];
29
22
  enableFilterMethodModel: boolean;
23
+ loading: boolean;
30
24
  propertyValue: (value: string | number | (string | number)[], termId?: string) => number;
31
- itemColor: (index: number) => any;
32
25
  baseUrl: string;
33
26
  showDownload: boolean;
34
27
  View: typeof View;
@@ -36,15 +29,7 @@ export declare class ImpactAssessmentsProductsComponent implements OnChanges {
36
29
  methodModels: Term[];
37
30
  selectedMethodModel?: Term;
38
31
  indicators: IGroupedKeys<Indicator>[];
39
- form: import("@angular/forms").FormGroup;
40
- selectedImpactAssessments: IImpactAssessmentJSONLD[];
41
- loading: boolean;
42
- suggesting: boolean;
43
- formatter: ({ "@id": id }: {
44
- "@id": any;
45
- }) => any;
46
- suggestImpactAssessment: (text$: Observable<string>) => Observable<any[]>;
47
- constructor(formBuilder: FormBuilder, nodeService: HeNodeService, searchService: HeSearchService, toastService: HeToastService);
32
+ constructor(nodeService: HeNodeService);
48
33
  ngOnChanges(changes: SimpleChanges): void | Promise<void>;
49
34
  trackById(_index: number, item: IImpactAssessmentJSONLD): string;
50
35
  get isOriginal(): boolean;
@@ -59,19 +44,9 @@ export declare class ImpactAssessmentsProductsComponent implements OnChanges {
59
44
  impactName(impact: IImpactAssessmentJSONLD): any;
60
45
  cycleLabel({ '@id': id, name }: any): any;
61
46
  get enableBreakdown(): boolean;
62
- showRecalculationLogs(): Promise<void>;
63
- private selectAllImpacts;
64
- private unselectAllImpacts;
65
- toggleAllImpacts(): void;
66
- private selectImpact;
67
- private unselectImpact;
68
- toggleImpact(impact: IImpactAssessmentJSONLD): void;
69
47
  isSelected(impact: IImpactAssessmentJSONLD): boolean;
70
- private suggest;
71
- private loadImpact;
72
- private fetchCycle;
73
- addImpact(): Promise<void>;
48
+ showRecalculationLogs(): Promise<void>;
74
49
  static ɵfac: i0.ɵɵFactoryDeclaration<ImpactAssessmentsProductsComponent, never>;
75
- static ɵcmp: i0.ɵɵComponentDeclaration<ImpactAssessmentsProductsComponent, "he-impact-assessments-products", never, { "cycles": "cycles"; "impactAssessments": "impactAssessments"; "key": "key"; "dataState": "dataState"; "enableCompare": "enableCompare"; "filterTermTypes": "filterTermTypes"; "enableFilterMethodModel": "enableFilterMethodModel"; }, {}, never, never>;
50
+ static ɵcmp: i0.ɵɵComponentDeclaration<ImpactAssessmentsProductsComponent, "he-impact-assessments-products", never, { "cycles": "cycles"; "impactAssessments": "impactAssessments"; "selected": "selected"; "key": "key"; "dataState": "dataState"; "filterTermTypes": "filterTermTypes"; "enableFilterMethodModel": "enableFilterMethodModel"; }, {}, never, never>;
76
51
  }
77
52
  export {};
@@ -1,5 +1,5 @@
1
1
  import { OnInit } from '@angular/core';
2
- import { Emission, ITermJSONLD, NodeType, TermTermType } from '@hestia-earth/schema';
2
+ import { Emission, ITermJSONLD, NodeType } from '@hestia-earth/schema';
3
3
  import { HeSearchService } from '../../search/search.service';
4
4
  import { HeNodeService } from '../../node/node.service';
5
5
  import * as i0 from "@angular/core";
@@ -8,7 +8,7 @@ export declare class ImpactAssessmentsProductsLogsComponent implements OnInit {
8
8
  private nodeService;
9
9
  private impactAssessment?;
10
10
  key?: string;
11
- filterTermTypes?: TermTermType[];
11
+ private filterTermTypes?;
12
12
  originalValues: Emission[];
13
13
  recalculatedValues: Emission[];
14
14
  loading: boolean;
@@ -20,6 +20,7 @@ export declare class ImpactAssessmentsProductsLogsComponent implements OnInit {
20
20
  constructor(searchService: HeSearchService, nodeService: HeNodeService);
21
21
  ngOnInit(): Promise<void>;
22
22
  private get node();
23
+ get filteredType(): string;
23
24
  static ɵfac: i0.ɵɵFactoryDeclaration<ImpactAssessmentsProductsLogsComponent, never>;
24
25
  static ɵcmp: i0.ɵɵComponentDeclaration<ImpactAssessmentsProductsLogsComponent, "he-impact-assessments-products-logs", never, { "impactAssessment": "impactAssessment"; "key": "key"; "filterTermTypes": "filterTermTypes"; "originalValues": "originalValues"; "recalculatedValues": "recalculatedValues"; }, {}, never, never>;
25
26
  }
@@ -1,10 +1,14 @@
1
- import { EventEmitter, OnInit } from '@angular/core';
1
+ import { OnInit } from '@angular/core';
2
2
  import { CdkDragDrop } from '@angular/cdk/drag-drop';
3
3
  import { HeSchemaService } from '../../schema/schema.service';
4
4
  import * as i0 from "@angular/core";
5
5
  interface IHeader {
6
6
  header: string;
7
7
  selected: boolean;
8
+ /**
9
+ * `false` if it is an `internal` field.
10
+ */
11
+ included: boolean;
8
12
  }
9
13
  interface IGroupedHeaders {
10
14
  [group: string]: {
@@ -19,12 +23,14 @@ export declare class NodeCsvSelectHeadersComponent implements OnInit {
19
23
  private csv;
20
24
  private keys?;
21
25
  private includeDefaultCSV;
22
- headersChanged: EventEmitter<string[]>;
26
+ private headersChanged;
27
+ loading: boolean;
23
28
  headers: IGroupedHeaders;
24
29
  allSelected: boolean;
25
30
  showSelectTermFields: boolean;
26
31
  termFields: string[];
27
32
  termFieldSelected: any;
33
+ showNonIncluded: boolean;
28
34
  constructor(schemaService: HeSchemaService);
29
35
  ngOnInit(): Promise<void>;
30
36
  private isSelected;
@@ -34,7 +40,7 @@ export declare class NodeCsvSelectHeadersComponent implements OnInit {
34
40
  updateGroup(groupKey: string): void;
35
41
  updateGroupHeader(groupKey: string): void;
36
42
  get selectedHeaders(): string[];
37
- reresh(): void;
43
+ refresh(): void;
38
44
  toggleTermField(field: string): void[];
39
45
  static ɵfac: i0.ɵɵFactoryDeclaration<NodeCsvSelectHeadersComponent, never>;
40
46
  static ɵcmp: i0.ɵɵComponentDeclaration<NodeCsvSelectHeadersComponent, "he-node-csv-select-headers", never, { "csv": "csv"; "keys": "keys"; "includeDefaultCSV": "includeDefaultCSV"; }, { "headersChanged": "headersChanged"; }, never, never>;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@hestia-earth/ui-components",
3
- "version": "0.0.20",
3
+ "version": "0.0.23",
4
4
  "description": "Hestia reusable components",
5
5
  "repository": {
6
6
  "type": "git",
@@ -24,9 +24,9 @@
24
24
  "@google/markerclustererplus": "^5.1.3",
25
25
  "@hestia-earth/api": ">=0.9.0",
26
26
  "@hestia-earth/glossary": "^0.2.4",
27
- "@hestia-earth/json-schema": "^7.7.0",
28
- "@hestia-earth/schema": "^7.7.0",
29
- "@hestia-earth/schema-convert": "^7.7.0",
27
+ "@hestia-earth/json-schema": "^7.8.0",
28
+ "@hestia-earth/schema": "^7.8.0",
29
+ "@hestia-earth/schema-convert": "^7.8.0",
30
30
  "@hestia-earth/ui-framework": "^1.11.0",
31
31
  "@hestia-earth/utils": "^0.10.0",
32
32
  "@ng-bootstrap/ng-bootstrap": ">=8.0.4",
@@ -8,6 +8,7 @@ export declare class SitesMapsComponent<C extends JSONLD<T>, T extends NodeType>
8
8
  private map?;
9
9
  private loadPolygons;
10
10
  private sites;
11
+ private selected;
11
12
  private nodes;
12
13
  center: {
13
14
  lat: number;
@@ -20,6 +21,7 @@ export declare class SitesMapsComponent<C extends JSONLD<T>, T extends NodeType>
20
21
  constructor(nodeService: HeNodeService);
21
22
  ngOnInit(): void;
22
23
  ngAfterViewInit(): Promise<void>;
24
+ private isSelected;
23
25
  private loadData;
24
26
  private addMarkers;
25
27
  private addTermsPolygons;
@@ -31,5 +33,5 @@ export declare class SitesMapsComponent<C extends JSONLD<T>, T extends NodeType>
31
33
  private getSites;
32
34
  private termPolygons;
33
35
  static ɵfac: i0.ɵɵFactoryDeclaration<SitesMapsComponent<any, any>, never>;
34
- static ɵcmp: i0.ɵɵComponentDeclaration<SitesMapsComponent<any, any>, "he-sites-maps", never, { "loadPolygons": "loadPolygons"; "sites": "sites"; "nodes": "nodes"; "center": "center"; "zoom": "zoom"; "showNotice": "showNotice"; }, {}, never, never>;
36
+ static ɵcmp: i0.ɵɵComponentDeclaration<SitesMapsComponent<any, any>, "he-sites-maps", never, { "loadPolygons": "loadPolygons"; "sites": "sites"; "selected": "selected"; "nodes": "nodes"; "center": "center"; "zoom": "zoom"; "showNotice": "showNotice"; }, {}, never, never>;
35
37
  }
@@ -10,6 +10,7 @@ declare enum View {
10
10
  export declare class SitesMeasurementsComponent implements OnChanges {
11
11
  originalValues: ISiteJSONLD[];
12
12
  sites: ISiteJSONLD[];
13
+ selected: string[];
13
14
  dataState?: DataState;
14
15
  showDownload: boolean;
15
16
  View: typeof View;
@@ -25,7 +26,8 @@ export declare class SitesMeasurementsComponent implements OnChanges {
25
26
  private update;
26
27
  togglePopover(popover: any, context: any): any;
27
28
  get showAreaTooBig(): boolean;
29
+ isSelected(site: ISiteJSONLD): boolean;
28
30
  static ɵfac: i0.ɵɵFactoryDeclaration<SitesMeasurementsComponent, never>;
29
- static ɵcmp: i0.ɵɵComponentDeclaration<SitesMeasurementsComponent, "he-sites-measurements", never, { "originalValues": "originalValues"; "sites": "sites"; "dataState": "dataState"; }, {}, never, never>;
31
+ static ɵcmp: i0.ɵɵComponentDeclaration<SitesMeasurementsComponent, "he-sites-measurements", never, { "originalValues": "originalValues"; "sites": "sites"; "selected": "selected"; "dataState": "dataState"; }, {}, never, never>;
30
32
  }
31
33
  export {};
@@ -1,23 +0,0 @@
1
- import { FormBuilder } from '@angular/forms';
2
- import { Observable } from 'rxjs';
3
- import { HeNodeService } from '../../node/node.service';
4
- import { HeSearchService } from '../../search/search.service';
5
- import * as i0 from "@angular/core";
6
- export declare class CyclesSuggestFormComponent {
7
- private formBuilder;
8
- private nodeService;
9
- private searchService;
10
- private cycles;
11
- private cycleAdded;
12
- form: import("@angular/forms").FormGroup;
13
- loading: boolean;
14
- suggesting: boolean;
15
- formatter: ({ "@id": id }: any) => any;
16
- suggestCycle: (text$: Observable<string>) => Observable<any[]>;
17
- constructor(formBuilder: FormBuilder, nodeService: HeNodeService, searchService: HeSearchService);
18
- private suggest;
19
- private loadCycle;
20
- submit(): Promise<void>;
21
- static ɵfac: i0.ɵɵFactoryDeclaration<CyclesSuggestFormComponent, never>;
22
- static ɵcmp: i0.ɵɵComponentDeclaration<CyclesSuggestFormComponent, "he-cycles-suggest-form", never, { "cycles": "cycles"; }, { "cycleAdded": "cycleAdded"; }, never, never>;
23
- }
@@ -1,83 +0,0 @@
1
- import { __awaiter } from "tslib";
2
- import { Component, EventEmitter, Input, Output } from '@angular/core';
3
- import { Validators } from '@angular/forms';
4
- import { NodeType } from '@hestia-earth/schema';
5
- import { of } from 'rxjs';
6
- import { debounceTime, distinctUntilChanged, switchMap, tap } from 'rxjs/operators';
7
- import { matchType, matchExactQuery, matchPhraseQuery, matchPhrasePrefixQuery, matchBoolPrefixQuery, matchAggregatedQuery } from '../../search/search.model';
8
- import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/forms";
10
- import * as i2 from "../../node/node.service";
11
- import * as i3 from "../../search/search.service";
12
- import * as i4 from "@fortawesome/angular-fontawesome";
13
- import * as i5 from "@ng-bootstrap/ng-bootstrap";
14
- import * as i6 from "@angular/common";
15
- const MIN_TYPEAHEAD_LENGTH = 1;
16
- export class CyclesSuggestFormComponent {
17
- constructor(formBuilder, nodeService, searchService) {
18
- this.formBuilder = formBuilder;
19
- this.nodeService = nodeService;
20
- this.searchService = searchService;
21
- this.cycles = [];
22
- this.cycleAdded = new EventEmitter();
23
- this.form = this.formBuilder.group({
24
- search: ['', Validators.required]
25
- });
26
- this.loading = false;
27
- this.suggesting = false;
28
- this.formatter = ({ '@id': id }) => id;
29
- this.suggestCycle = (text$) => text$.pipe(debounceTime(300), distinctUntilChanged(), tap(() => this.suggesting = true), switchMap(term => this.suggest(term)), tap(() => this.suggesting = false));
30
- }
31
- suggest(term) {
32
- return term.length < MIN_TYPEAHEAD_LENGTH ?
33
- of([]) :
34
- this.searchService.suggest(term, NodeType.Cycle, [], {
35
- bool: {
36
- must: [
37
- matchType(NodeType.Cycle),
38
- matchAggregatedQuery
39
- ],
40
- must_not: this.cycles.map(({ '@id': id }) => matchExactQuery('@id', id)),
41
- should: [
42
- matchPhraseQuery(term, 100, '@id', 'name'),
43
- matchPhrasePrefixQuery(term, 20, '@id', 'name'),
44
- matchBoolPrefixQuery(term, 10, '@id', 'name')
45
- ],
46
- minimum_should_match: 1
47
- }
48
- }, 10, ['name', 'site.country.name', 'products.name', 'endDate']);
49
- }
50
- loadCycle(id) {
51
- return this.nodeService.get({
52
- '@type': NodeType.Cycle,
53
- '@id': id
54
- }, false);
55
- }
56
- submit() {
57
- var _a;
58
- return __awaiter(this, void 0, void 0, function* () {
59
- this.loading = true;
60
- const { search: { '@id': id } } = this.form.value;
61
- const cycle = yield this.loadCycle(id);
62
- this.cycleAdded.emit(cycle);
63
- (_a = this.form.get('search')) === null || _a === void 0 ? void 0 : _a.setValue('');
64
- this.form.updateValueAndValidity();
65
- this.loading = false;
66
- });
67
- }
68
- }
69
- CyclesSuggestFormComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: CyclesSuggestFormComponent, deps: [{ token: i1.FormBuilder }, { token: i2.HeNodeService }, { token: i3.HeSearchService }], target: i0.ɵɵFactoryTarget.Component });
70
- CyclesSuggestFormComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: CyclesSuggestFormComponent, selector: "he-cycles-suggest-form", inputs: { cycles: "cycles" }, outputs: { cycleAdded: "cycleAdded" }, ngImport: i0, template: "<form class=\"mt-2\" [formGroup]=\"form\" (submit)=\"form.valid && submit()\">\n <div class=\"field has-addons\">\n <div class=\"control\">\n <span class=\"button is-small is-static\">Compare with Aggregated Cycle</span>\n </div>\n <div class=\"control is-expanded\" [class.has-icons-right]=\"suggesting || loading\">\n <input class=\"input is-small\"\n placeholder=\"Search by name or id\"\n formControlName=\"search\" name=\"search\"\n\n [ngbTypeahead]=\"suggestCycle\"\n [inputFormatter]=\"formatter\"\n [resultTemplate]=\"suggestion\"\n [focusFirst]=\"true\"\n >\n <span class=\"icon is-small is-right has-text-grey-dark\" [class.is-hidden]=\"!(suggesting || loading)\">\n <fa-icon icon=\"spinner\" [pulse]=\"true\" size=\"sm\"></fa-icon>\n </span>\n </div>\n <div class=\"control\">\n <button class=\"button is-small\" type=\"submit\" [disabled]=\"suggesting || loading\">\n <fa-icon icon=\"plus\"></fa-icon>\n </button>\n </div>\n </div>\n</form>\n\n<ng-template #suggestion let-cycle=\"result\" let-t=\"term\">\n <div class=\"is-block\">\n <ngb-highlight [result]=\"cycle.name\" [term]=\"t\"></ngb-highlight>\n </div>\n <div class=\"columns is-flex\">\n <div class=\"column\" *ngIf=\"cycle.site?.country?.name\">\n <span class=\"pr-1 has-text-underline\">Country:</span>\n <span class=\"is-inline-flex\"><ngb-highlight [result]=\"cycle.site.country.name\" [term]=\"t\"></ngb-highlight></span>\n </div>\n <!-- <div class=\"column\" *ngIf=\"impact.product\">\n <span class=\"pr-1 has-text-underline\">Product:</span>\n <span class=\"is-inline-flex\"><ngb-highlight [result]=\"impact.product.name\" [term]=\"t\"></ngb-highlight></span>\n </div> -->\n <div class=\"column\" *ngIf=\"cycle.endDate\">\n <span class=\"pr-1 has-text-underline\">Date:</span>\n <span class=\"is-inline-flex\"><ngb-highlight [result]=\"cycle.endDate\" [term]=\"t\"></ngb-highlight></span>\n </div>\n </div>\n</ng-template>\n", styles: [""], components: [{ type: i4.FaIconComponent, selector: "fa-icon", inputs: ["classes", "icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }, { type: i5.NgbHighlight, selector: "ngb-highlight", inputs: ["highlightClass", "result", "term"] }], directives: [{ type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.NgbTypeahead, selector: "input[ngbTypeahead]", inputs: ["autocomplete", "placement", "container", "editable", "focusFirst", "showHint", "inputFormatter", "ngbTypeahead", "resultFormatter", "resultTemplate"], outputs: ["selectItem"], exportAs: ["ngbTypeahead"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
71
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: CyclesSuggestFormComponent, decorators: [{
72
- type: Component,
73
- args: [{
74
- selector: 'he-cycles-suggest-form',
75
- templateUrl: './cycles-suggest-form.component.html',
76
- styleUrls: ['./cycles-suggest-form.component.scss']
77
- }]
78
- }], ctorParameters: function () { return [{ type: i1.FormBuilder }, { type: i2.HeNodeService }, { type: i3.HeSearchService }]; }, propDecorators: { cycles: [{
79
- type: Input
80
- }], cycleAdded: [{
81
- type: Output
82
- }] } });
83
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cycles-suggest-form.component.js","sourceRoot":"","sources":["../../../../src/cycles/cycles-suggest-form/cycles-suggest-form.component.ts","../../../../src/cycles/cycles-suggest-form/cycles-suggest-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output } from '@angular/core';\nimport { FormBuilder, Validators } from '@angular/forms';\nimport { ICycleJSONLD, NodeType } from '@hestia-earth/schema';\nimport { Observable, of } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, switchMap, tap } from 'rxjs/operators';\n\nimport { HeNodeService } from '../../node/node.service';\nimport { HeSearchService } from '../../search/search.service';\nimport {\n  matchType, matchExactQuery, matchPhraseQuery, matchPhrasePrefixQuery, matchBoolPrefixQuery, matchAggregatedQuery\n} from '../../search/search.model';\n\nconst MIN_TYPEAHEAD_LENGTH = 1;\n\n@Component({\n  selector: 'he-cycles-suggest-form',\n  templateUrl: './cycles-suggest-form.component.html',\n  styleUrls: ['./cycles-suggest-form.component.scss']\n})\nexport class CyclesSuggestFormComponent {\n  @Input()\n  private cycles: ICycleJSONLD[] = [];\n  @Output()\n  private cycleAdded = new EventEmitter<ICycleJSONLD>();\n\n  public form = this.formBuilder.group({\n    search: ['', Validators.required]\n  });\n  public loading = false;\n  public suggesting = false;\n  public formatter = ({ '@id': id }: any) => id;\n  public suggestCycle = (text$: Observable<string>) =>\n    text$.pipe(\n      debounceTime(300),\n      distinctUntilChanged(),\n      tap(() => this.suggesting = true),\n      switchMap(term => this.suggest(term)),\n      tap(() => this.suggesting = false)\n    );\n\n  constructor(\n    private formBuilder: FormBuilder,\n    private nodeService: HeNodeService,\n    private searchService: HeSearchService\n  ) { }\n\n  private suggest(term: string) {\n    return term.length < MIN_TYPEAHEAD_LENGTH ?\n      of([]) :\n      this.searchService.suggest(term, NodeType.Cycle, [], {\n        bool: {\n          must: [\n            matchType(NodeType.Cycle),\n            matchAggregatedQuery\n          ],\n          must_not: this.cycles.map(({ '@id': id }) => matchExactQuery('@id', id)),\n          should: [\n            matchPhraseQuery(term, 100, '@id', 'name'),\n            matchPhrasePrefixQuery(term, 20, '@id', 'name'),\n            matchBoolPrefixQuery(term, 10, '@id', 'name')\n          ],\n          minimum_should_match: 1\n        }\n      }, 10, ['name', 'site.country.name', 'products.name', 'endDate']);\n  }\n\n  private loadCycle(id: string) {\n    return this.nodeService.get<ICycleJSONLD>({\n      '@type': NodeType.Cycle,\n      '@id': id\n    }, false);\n  }\n\n  public async submit() {\n    this.loading = true;\n    const { search: { '@id': id } } = this.form.value;\n    const cycle = await this.loadCycle(id);\n    this.cycleAdded.emit(cycle);\n    this.form.get('search')?.setValue('');\n    this.form.updateValueAndValidity();\n    this.loading = false;\n  }\n}\n","<form class=\"mt-2\" [formGroup]=\"form\" (submit)=\"form.valid && submit()\">\n  <div class=\"field has-addons\">\n    <div class=\"control\">\n      <span class=\"button is-small is-static\">Compare with Aggregated Cycle</span>\n    </div>\n    <div class=\"control is-expanded\" [class.has-icons-right]=\"suggesting || loading\">\n      <input class=\"input is-small\"\n        placeholder=\"Search by name or id\"\n        formControlName=\"search\" name=\"search\"\n\n        [ngbTypeahead]=\"suggestCycle\"\n        [inputFormatter]=\"formatter\"\n        [resultTemplate]=\"suggestion\"\n        [focusFirst]=\"true\"\n      >\n      <span class=\"icon is-small is-right has-text-grey-dark\" [class.is-hidden]=\"!(suggesting || loading)\">\n        <fa-icon icon=\"spinner\" [pulse]=\"true\" size=\"sm\"></fa-icon>\n      </span>\n    </div>\n    <div class=\"control\">\n      <button class=\"button is-small\" type=\"submit\" [disabled]=\"suggesting || loading\">\n        <fa-icon icon=\"plus\"></fa-icon>\n      </button>\n    </div>\n  </div>\n</form>\n\n<ng-template #suggestion let-cycle=\"result\" let-t=\"term\">\n  <div class=\"is-block\">\n    <ngb-highlight [result]=\"cycle.name\" [term]=\"t\"></ngb-highlight>\n  </div>\n  <div class=\"columns is-flex\">\n    <div class=\"column\" *ngIf=\"cycle.site?.country?.name\">\n      <span class=\"pr-1 has-text-underline\">Country:</span>\n      <span class=\"is-inline-flex\"><ngb-highlight [result]=\"cycle.site.country.name\" [term]=\"t\"></ngb-highlight></span>\n    </div>\n    <!-- <div class=\"column\" *ngIf=\"impact.product\">\n      <span class=\"pr-1 has-text-underline\">Product:</span>\n      <span class=\"is-inline-flex\"><ngb-highlight [result]=\"impact.product.name\" [term]=\"t\"></ngb-highlight></span>\n    </div> -->\n    <div class=\"column\" *ngIf=\"cycle.endDate\">\n      <span class=\"pr-1 has-text-underline\">Date:</span>\n      <span class=\"is-inline-flex\"><ngb-highlight [result]=\"cycle.endDate\" [term]=\"t\"></ngb-highlight></span>\n    </div>\n  </div>\n</ng-template>\n"]}