@hestia-earth/ui-components 0.27.18 → 0.27.20

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.
@@ -19,5 +19,5 @@ export declare class BarChartComponent {
19
19
  protected dataConfig: Signal<ChartData>;
20
20
  protected configuration: Signal<Partial<ChartConfiguration>>;
21
21
  static ɵfac: i0.ɵɵFactoryDeclaration<BarChartComponent, never>;
22
- static ɵcmp: i0.ɵɵComponentDeclaration<BarChartComponent, "he-bar-chart", never, { "data": { "alias": "data"; "required": true; "isSignal": true; }; "max": { "alias": "max"; "required": false; "isSignal": true; }; "datasets": { "alias": "datasets"; "required": false; "isSignal": true; }; "config": { "alias": "config"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
22
+ static ɵcmp: i0.ɵɵComponentDeclaration<BarChartComponent, "he-bar-chart", never, { "data": { "alias": "data"; "required": false; "isSignal": true; }; "max": { "alias": "max"; "required": false; "isSignal": true; }; "datasets": { "alias": "datasets"; "required": false; "isSignal": true; }; "config": { "alias": "config"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
23
23
  }
@@ -1,5 +1,7 @@
1
1
  import { Term, ICycleJSONLD, ISiteJSONLD, IImpactAssessmentJSONLD, EmissionMethodTier, ITermJSONLD, Indicator, Animal, Transformation, blankNodesType, blankNodesKey } from '@hestia-earth/schema';
2
2
  import { propertyValueType } from '@hestia-earth/utils/dist/term';
3
+ export declare const formatDate: (date: string, isStart?: boolean) => Date;
4
+ export declare const getDatesBetween: (startDate: string, endDate: string) => Date[];
3
5
  export declare const filterBlankNode: (filterTerm: string) => ({ term }: blankNodesType) => boolean;
4
6
  export declare const ignoreKeys: string[];
5
7
  export declare const isValidKey: (key: string) => boolean;
@@ -36,7 +36,7 @@ const defaultDatasets = {
36
36
  };
37
37
  export class BarChartComponent {
38
38
  constructor() {
39
- this.data = input.required();
39
+ this.data = input([]);
40
40
  this.max = input();
41
41
  this.datasets = input([]);
42
42
  this.config = input({});
@@ -88,10 +88,10 @@ export class BarChartComponent {
88
88
  this.configuration = computed(() => merge(defaultSettings, this.defaultConfig(), this.config()));
89
89
  }
90
90
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: BarChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
91
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.8", type: BarChartComponent, isStandalone: true, selector: "he-bar-chart", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: true, transformFunction: null }, max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: false, transformFunction: null }, datasets: { classPropertyName: "datasets", publicName: "datasets", isSignal: true, isRequired: false, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<he-chart [data]=\"dataConfig()\" [config]=\"configuration()\"></he-chart>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "component", type: ChartComponent, selector: "he-chart", inputs: ["data", "config"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
91
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.8", type: BarChartComponent, isStandalone: true, selector: "he-bar-chart", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: false, transformFunction: null }, max: { classPropertyName: "max", publicName: "max", isSignal: true, isRequired: false, transformFunction: null }, datasets: { classPropertyName: "datasets", publicName: "datasets", isSignal: true, isRequired: false, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<he-chart [data]=\"dataConfig()\" [config]=\"configuration()\"></he-chart>\n", styles: [":host{display:block}\n"], dependencies: [{ kind: "component", type: ChartComponent, selector: "he-chart", inputs: ["data", "config"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
92
92
  }
93
93
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: BarChartComponent, decorators: [{
94
94
  type: Component,
95
95
  args: [{ selector: 'he-bar-chart', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ChartComponent], template: "<he-chart [data]=\"dataConfig()\" [config]=\"configuration()\"></he-chart>\n", styles: [":host{display:block}\n"] }]
96
96
  }] });
97
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyLWNoYXJ0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jaGFydC9iYXItY2hhcnQvYmFyLWNoYXJ0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uL3NyYy9jaGFydC9iYXItY2hhcnQvYmFyLWNoYXJ0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUU1RixPQUFPLEtBQUssTUFBTSxjQUFjLENBQUM7QUFFakMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG9CQUFvQixDQUFDOztBQVVwRCxNQUFNLGVBQWUsR0FBZ0M7SUFDbkQsSUFBSSxFQUFFLGVBQWU7SUFDckIsT0FBTyxFQUFFO1FBQ1AsTUFBTSxFQUFFLEVBQUU7UUFDVixTQUFTLEVBQUU7WUFDVCxRQUFRLEVBQUUsQ0FBQztTQUNaO1FBQ0QsUUFBUSxFQUFFO1lBQ1IsT0FBTyxFQUFFLEtBQUs7U0FDZjtRQUNELE1BQU0sRUFBRTtZQUNOLEtBQUssRUFBRTtnQkFDTDtvQkFDRSxPQUFPLEVBQUUsSUFBSTtvQkFDYixRQUFRLEVBQUUsTUFBTTtvQkFDaEIsU0FBUyxFQUFFO3dCQUNULE9BQU8sRUFBRSxLQUFLO3FCQUNmO29CQUNELEtBQUssRUFBRTt3QkFDTCxVQUFVLEVBQUUsUUFBUTtxQkFDZDtpQkFDVDthQUNGO1NBQ0Y7S0FDRjtDQUNGLENBQUM7QUFFRixNQUFNLGVBQWUsR0FBa0I7SUFDckMsYUFBYTtJQUNiLGFBQWEsRUFBRSxHQUFHO0lBQ2xCLFlBQVksRUFBRSxDQUFDO0lBQ2YsZUFBZSxFQUFFLEVBQUU7Q0FDcEIsQ0FBQztBQVVGLE1BQU0sT0FBTyxpQkFBaUI7SUFSOUI7UUFTWSxTQUFJLEdBQUcsS0FBSyxDQUFDLFFBQVEsRUFBbUIsQ0FBQztRQUN6QyxRQUFHLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFDdEIsYUFBUSxHQUFHLEtBQUssQ0FBMkIsRUFBRSxDQUFDLENBQUM7UUFDL0MsV0FBTSxHQUFHLEtBQUssQ0FBOEIsRUFBRSxDQUFDLENBQUM7UUFFbEQsY0FBUyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxHQUFHLEVBQUUsSUFBSSxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDcEUsa0JBQWEsR0FBd0MsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUM7WUFDM0UsT0FBTyxFQUFFO2dCQUNQLE1BQU0sRUFBRTtvQkFDTixLQUFLLEVBQUUsT0FBTztpQkFDZjtnQkFDRCxNQUFNLEVBQUU7b0JBQ04sS0FBSyxFQUFFO3dCQUNMOzRCQUNFLE9BQU8sRUFBRSxLQUFLOzRCQUNkLEtBQUssRUFBRTtnQ0FDTCxHQUFHLEVBQUUsQ0FBQztnQ0FDTixHQUFHLElBQUksQ0FBQyxTQUFTLEVBQUU7NkJBQ3BCO3lCQUNGO3FCQUNGO29CQUNELEtBQUssRUFBRTt3QkFDTDs0QkFDRSxLQUFLLEVBQUU7Z0NBQ0wsU0FBUyxFQUFFLFNBQVM7Z0NBQ3BCLFVBQVUsRUFBRSxNQUFNO2dDQUNsQixRQUFRLEVBQUUsRUFBRTtnQ0FDWixTQUFTLEVBQUUsS0FBSzs2QkFDakI7eUJBQ0Y7cUJBQ0Y7aUJBQ0Y7YUFDRjtTQUNGLENBQUMsQ0FBQyxDQUFDO1FBRUksb0JBQWUsR0FBcUMsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUN4RSxJQUFJLENBQUMsUUFBUSxFQUFFLEVBQUUsTUFBTTtZQUNyQixDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNqQixDQUFDLENBQUM7Z0JBQ0U7b0JBQ0UsZUFBZTtvQkFDZixlQUFlLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsZUFBZSxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQyxlQUFlLElBQUksS0FBSyxDQUFDO29CQUMxRixXQUFXLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQyxXQUFXLElBQUksS0FBSyxDQUFDO29CQUM5RSxJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQztpQkFDNUM7YUFDRixDQUNOLENBQUM7UUFFUSxlQUFVLEdBQXNCLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDO1lBQ3hELElBQUksRUFBRTtnQkFDSixRQUFRLEVBQUUsSUFBSSxDQUFDLGVBQWUsRUFBRTtnQkFDaEMsTUFBTSxFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQyxLQUFLLENBQUM7YUFDOUM7U0FDRixDQUFDLENBQUMsQ0FBQztRQUNNLGtCQUFhLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLEtBQUssQ0FBQyxlQUFlLEVBQUUsSUFBSSxDQUFDLGFBQWEsRUFBRSxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUM7S0FDdkc7OEdBeERZLGlCQUFpQjtrR0FBakIsaUJBQWlCLHNqQkN4RDlCLDhFQUNBLGdGRHFEWSxjQUFjOzsyRkFFYixpQkFBaUI7a0JBUjdCLFNBQVM7K0JBQ0UsY0FBYyxtQkFHUCx1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUksV0FDUCxDQUFDLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGNvbXB1dGVkLCBpbnB1dCwgU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDaGFydENvbmZpZ3VyYXRpb24sIENoYXJ0RGF0YSwgQ2hhcnREYXRhU2V0cyB9IGZyb20gJ2NoYXJ0LmpzJztcbmltcG9ydCBtZXJnZSBmcm9tICdsb2Rhc2gubWVyZ2UnO1xuXG5pbXBvcnQgeyBDaGFydENvbXBvbmVudCB9IGZyb20gJy4uL2NoYXJ0LmNvbXBvbmVudCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2hhcnREYXRhSXRlbSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGNvdW50OiBudW1iZXI7XG4gIGNvbG9yPzogc3RyaW5nO1xuICBiYWNrZ3JvdW5kQ29sb3I/OiBzdHJpbmc7XG4gIGJvcmRlckNvbG9yPzogc3RyaW5nO1xufVxuXG5jb25zdCBkZWZhdWx0U2V0dGluZ3M6IFBhcnRpYWw8Q2hhcnRDb25maWd1cmF0aW9uPiA9IHtcbiAgdHlwZTogJ2hvcml6b250YWxCYXInLFxuICBvcHRpb25zOiB7XG4gICAgZXZlbnRzOiBbXSxcbiAgICBhbmltYXRpb246IHtcbiAgICAgIGR1cmF0aW9uOiAwXG4gICAgfSxcbiAgICB0b29sdGlwczoge1xuICAgICAgZW5hYmxlZDogZmFsc2VcbiAgICB9LFxuICAgIHNjYWxlczoge1xuICAgICAgeUF4ZXM6IFtcbiAgICAgICAge1xuICAgICAgICAgIGRpc3BsYXk6IHRydWUsXG4gICAgICAgICAgcG9zaXRpb246ICdsZWZ0JyxcbiAgICAgICAgICBncmlkTGluZXM6IHtcbiAgICAgICAgICAgIGRpc3BsYXk6IGZhbHNlXG4gICAgICAgICAgfSxcbiAgICAgICAgICB0aWNrczoge1xuICAgICAgICAgICAgY3Jvc3NBbGlnbjogJ2NlbnRlcidcbiAgICAgICAgICB9IGFzIGFueVxuICAgICAgICB9XG4gICAgICBdXG4gICAgfVxuICB9XG59O1xuXG5jb25zdCBkZWZhdWx0RGF0YXNldHM6IENoYXJ0RGF0YVNldHMgPSB7XG4gIC8vIGF4aXM6ICd5JyxcbiAgYmFyUGVyY2VudGFnZTogMC41LFxuICBiYXJUaGlja25lc3M6IDgsXG4gIG1heEJhclRoaWNrbmVzczogMTJcbn07XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2hlLWJhci1jaGFydCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9iYXItY2hhcnQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9iYXItY2hhcnQuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDaGFydENvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgQmFyQ2hhcnRDb21wb25lbnQge1xuICBwcm90ZWN0ZWQgZGF0YSA9IGlucHV0LnJlcXVpcmVkPENoYXJ0RGF0YUl0ZW1bXT4oKTtcbiAgcHJvdGVjdGVkIG1heCA9IGlucHV0PG51bWJlcj4oKTtcbiAgcHJvdGVjdGVkIGRhdGFzZXRzID0gaW5wdXQ8UGFydGlhbDxDaGFydERhdGFTZXRzPltdPihbXSk7XG4gIHByb3RlY3RlZCBjb25maWcgPSBpbnB1dDxQYXJ0aWFsPENoYXJ0Q29uZmlndXJhdGlvbj4+KHt9KTtcblxuICBwcml2YXRlIG1heENvbmZpZyA9IGNvbXB1dGVkKCgpID0+ICh0aGlzLm1heCgpID8geyBtYXg6IHRoaXMubWF4KCkgfSA6IHt9KSk7XG4gIHByaXZhdGUgZGVmYXVsdENvbmZpZzogU2lnbmFsPFBhcnRpYWw8Q2hhcnRDb25maWd1cmF0aW9uPj4gPSBjb21wdXRlZCgoKSA9PiAoe1xuICAgIG9wdGlvbnM6IHtcbiAgICAgIGxlZ2VuZDoge1xuICAgICAgICBhbGlnbjogJ3N0YXJ0J1xuICAgICAgfSxcbiAgICAgIHNjYWxlczoge1xuICAgICAgICB4QXhlczogW1xuICAgICAgICAgIHtcbiAgICAgICAgICAgIGRpc3BsYXk6IGZhbHNlLFxuICAgICAgICAgICAgdGlja3M6IHtcbiAgICAgICAgICAgICAgbWluOiAwLFxuICAgICAgICAgICAgICAuLi50aGlzLm1heENvbmZpZygpXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICBdLFxuICAgICAgICB5QXhlczogW1xuICAgICAgICAgIHtcbiAgICAgICAgICAgIHRpY2tzOiB7XG4gICAgICAgICAgICAgIGZvbnRDb2xvcjogJyM0QTRBNEEnLFxuICAgICAgICAgICAgICBmb250RmFtaWx5OiAnTGF0bycsXG4gICAgICAgICAgICAgIGZvbnRTaXplOiAxMCxcbiAgICAgICAgICAgICAgZm9udFN0eWxlOiAnNDAwJ1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1cbiAgICAgICAgXVxuICAgICAgfVxuICAgIH1cbiAgfSkpO1xuXG4gIHByaXZhdGUgZGVmYXVsdERhdGFzZXRzOiBTaWduYWw8UGFydGlhbDxDaGFydERhdGFTZXRzPltdPiA9IGNvbXB1dGVkKCgpID0+XG4gICAgdGhpcy5kYXRhc2V0cygpPy5sZW5ndGhcbiAgICAgID8gdGhpcy5kYXRhc2V0cygpXG4gICAgICA6IFtcbiAgICAgICAgICB7XG4gICAgICAgICAgICBkZWZhdWx0RGF0YXNldHMsXG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6IHRoaXMuZGF0YSgpLm1hcCgoeyBiYWNrZ3JvdW5kQ29sb3IsIGNvbG9yIH0pID0+IGJhY2tncm91bmRDb2xvciB8fCBjb2xvciksXG4gICAgICAgICAgICBib3JkZXJDb2xvcjogdGhpcy5kYXRhKCkubWFwKCh7IGJvcmRlckNvbG9yLCBjb2xvciB9KSA9PiBib3JkZXJDb2xvciB8fCBjb2xvciksXG4gICAgICAgICAgICBkYXRhOiB0aGlzLmRhdGEoKS5tYXAoKHsgY291bnQgfSkgPT4gY291bnQpXG4gICAgICAgICAgfVxuICAgICAgICBdXG4gICk7XG5cbiAgcHJvdGVjdGVkIGRhdGFDb25maWc6IFNpZ25hbDxDaGFydERhdGE+ID0gY29tcHV0ZWQoKCkgPT4gKHtcbiAgICBkYXRhOiB7XG4gICAgICBkYXRhc2V0czogdGhpcy5kZWZhdWx0RGF0YXNldHMoKSxcbiAgICAgIGxhYmVsczogdGhpcy5kYXRhKCkubWFwKCh7IGxhYmVsIH0pID0+IGxhYmVsKVxuICAgIH1cbiAgfSkpO1xuICBwcm90ZWN0ZWQgY29uZmlndXJhdGlvbiA9IGNvbXB1dGVkKCgpID0+IG1lcmdlKGRlZmF1bHRTZXR0aW5ncywgdGhpcy5kZWZhdWx0Q29uZmlnKCksIHRoaXMuY29uZmlnKCkpKTtcbn1cbiIsIjxoZS1jaGFydCBbZGF0YV09XCJkYXRhQ29uZmlnKClcIiBbY29uZmlnXT1cImNvbmZpZ3VyYXRpb24oKVwiPjwvaGUtY2hhcnQ+XG4iXX0=
97
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyLWNoYXJ0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jaGFydC9iYXItY2hhcnQvYmFyLWNoYXJ0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uL3NyYy9jaGFydC9iYXItY2hhcnQvYmFyLWNoYXJ0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUU1RixPQUFPLEtBQUssTUFBTSxjQUFjLENBQUM7QUFFakMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLG9CQUFvQixDQUFDOztBQVVwRCxNQUFNLGVBQWUsR0FBZ0M7SUFDbkQsSUFBSSxFQUFFLGVBQWU7SUFDckIsT0FBTyxFQUFFO1FBQ1AsTUFBTSxFQUFFLEVBQUU7UUFDVixTQUFTLEVBQUU7WUFDVCxRQUFRLEVBQUUsQ0FBQztTQUNaO1FBQ0QsUUFBUSxFQUFFO1lBQ1IsT0FBTyxFQUFFLEtBQUs7U0FDZjtRQUNELE1BQU0sRUFBRTtZQUNOLEtBQUssRUFBRTtnQkFDTDtvQkFDRSxPQUFPLEVBQUUsSUFBSTtvQkFDYixRQUFRLEVBQUUsTUFBTTtvQkFDaEIsU0FBUyxFQUFFO3dCQUNULE9BQU8sRUFBRSxLQUFLO3FCQUNmO29CQUNELEtBQUssRUFBRTt3QkFDTCxVQUFVLEVBQUUsUUFBUTtxQkFDZDtpQkFDVDthQUNGO1NBQ0Y7S0FDRjtDQUNGLENBQUM7QUFFRixNQUFNLGVBQWUsR0FBa0I7SUFDckMsYUFBYTtJQUNiLGFBQWEsRUFBRSxHQUFHO0lBQ2xCLFlBQVksRUFBRSxDQUFDO0lBQ2YsZUFBZSxFQUFFLEVBQUU7Q0FDcEIsQ0FBQztBQVVGLE1BQU0sT0FBTyxpQkFBaUI7SUFSOUI7UUFTWSxTQUFJLEdBQUcsS0FBSyxDQUFrQixFQUFFLENBQUMsQ0FBQztRQUNsQyxRQUFHLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFDdEIsYUFBUSxHQUFHLEtBQUssQ0FBMkIsRUFBRSxDQUFDLENBQUM7UUFDL0MsV0FBTSxHQUFHLEtBQUssQ0FBOEIsRUFBRSxDQUFDLENBQUM7UUFFbEQsY0FBUyxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxHQUFHLEVBQUUsSUFBSSxDQUFDLEdBQUcsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDcEUsa0JBQWEsR0FBd0MsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLENBQUM7WUFDM0UsT0FBTyxFQUFFO2dCQUNQLE1BQU0sRUFBRTtvQkFDTixLQUFLLEVBQUUsT0FBTztpQkFDZjtnQkFDRCxNQUFNLEVBQUU7b0JBQ04sS0FBSyxFQUFFO3dCQUNMOzRCQUNFLE9BQU8sRUFBRSxLQUFLOzRCQUNkLEtBQUssRUFBRTtnQ0FDTCxHQUFHLEVBQUUsQ0FBQztnQ0FDTixHQUFHLElBQUksQ0FBQyxTQUFTLEVBQUU7NkJBQ3BCO3lCQUNGO3FCQUNGO29CQUNELEtBQUssRUFBRTt3QkFDTDs0QkFDRSxLQUFLLEVBQUU7Z0NBQ0wsU0FBUyxFQUFFLFNBQVM7Z0NBQ3BCLFVBQVUsRUFBRSxNQUFNO2dDQUNsQixRQUFRLEVBQUUsRUFBRTtnQ0FDWixTQUFTLEVBQUUsS0FBSzs2QkFDakI7eUJBQ0Y7cUJBQ0Y7aUJBQ0Y7YUFDRjtTQUNGLENBQUMsQ0FBQyxDQUFDO1FBRUksb0JBQWUsR0FBcUMsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUN4RSxJQUFJLENBQUMsUUFBUSxFQUFFLEVBQUUsTUFBTTtZQUNyQixDQUFDLENBQUMsSUFBSSxDQUFDLFFBQVEsRUFBRTtZQUNqQixDQUFDLENBQUM7Z0JBQ0U7b0JBQ0UsZUFBZTtvQkFDZixlQUFlLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsZUFBZSxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQyxlQUFlLElBQUksS0FBSyxDQUFDO29CQUMxRixXQUFXLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQyxXQUFXLElBQUksS0FBSyxDQUFDO29CQUM5RSxJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEVBQUUsS0FBSyxFQUFFLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQztpQkFDNUM7YUFDRixDQUNOLENBQUM7UUFFUSxlQUFVLEdBQXNCLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxDQUFDO1lBQ3hELElBQUksRUFBRTtnQkFDSixRQUFRLEVBQUUsSUFBSSxDQUFDLGVBQWUsRUFBRTtnQkFDaEMsTUFBTSxFQUFFLElBQUksQ0FBQyxJQUFJLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLEtBQUssRUFBRSxFQUFFLEVBQUUsQ0FBQyxLQUFLLENBQUM7YUFDOUM7U0FDRixDQUFDLENBQUMsQ0FBQztRQUNNLGtCQUFhLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLEtBQUssQ0FBQyxlQUFlLEVBQUUsSUFBSSxDQUFDLGFBQWEsRUFBRSxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxDQUFDLENBQUM7S0FDdkc7OEdBeERZLGlCQUFpQjtrR0FBakIsaUJBQWlCLHVqQkN4RDlCLDhFQUNBLGdGRHFEWSxjQUFjOzsyRkFFYixpQkFBaUI7a0JBUjdCLFNBQVM7K0JBQ0UsY0FBYyxtQkFHUCx1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUksV0FDUCxDQUFDLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGNvbXB1dGVkLCBpbnB1dCwgU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDaGFydENvbmZpZ3VyYXRpb24sIENoYXJ0RGF0YSwgQ2hhcnREYXRhU2V0cyB9IGZyb20gJ2NoYXJ0LmpzJztcbmltcG9ydCBtZXJnZSBmcm9tICdsb2Rhc2gubWVyZ2UnO1xuXG5pbXBvcnQgeyBDaGFydENvbXBvbmVudCB9IGZyb20gJy4uL2NoYXJ0LmNvbXBvbmVudCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2hhcnREYXRhSXRlbSB7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGNvdW50OiBudW1iZXI7XG4gIGNvbG9yPzogc3RyaW5nO1xuICBiYWNrZ3JvdW5kQ29sb3I/OiBzdHJpbmc7XG4gIGJvcmRlckNvbG9yPzogc3RyaW5nO1xufVxuXG5jb25zdCBkZWZhdWx0U2V0dGluZ3M6IFBhcnRpYWw8Q2hhcnRDb25maWd1cmF0aW9uPiA9IHtcbiAgdHlwZTogJ2hvcml6b250YWxCYXInLFxuICBvcHRpb25zOiB7XG4gICAgZXZlbnRzOiBbXSxcbiAgICBhbmltYXRpb246IHtcbiAgICAgIGR1cmF0aW9uOiAwXG4gICAgfSxcbiAgICB0b29sdGlwczoge1xuICAgICAgZW5hYmxlZDogZmFsc2VcbiAgICB9LFxuICAgIHNjYWxlczoge1xuICAgICAgeUF4ZXM6IFtcbiAgICAgICAge1xuICAgICAgICAgIGRpc3BsYXk6IHRydWUsXG4gICAgICAgICAgcG9zaXRpb246ICdsZWZ0JyxcbiAgICAgICAgICBncmlkTGluZXM6IHtcbiAgICAgICAgICAgIGRpc3BsYXk6IGZhbHNlXG4gICAgICAgICAgfSxcbiAgICAgICAgICB0aWNrczoge1xuICAgICAgICAgICAgY3Jvc3NBbGlnbjogJ2NlbnRlcidcbiAgICAgICAgICB9IGFzIGFueVxuICAgICAgICB9XG4gICAgICBdXG4gICAgfVxuICB9XG59O1xuXG5jb25zdCBkZWZhdWx0RGF0YXNldHM6IENoYXJ0RGF0YVNldHMgPSB7XG4gIC8vIGF4aXM6ICd5JyxcbiAgYmFyUGVyY2VudGFnZTogMC41LFxuICBiYXJUaGlja25lc3M6IDgsXG4gIG1heEJhclRoaWNrbmVzczogMTJcbn07XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2hlLWJhci1jaGFydCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9iYXItY2hhcnQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9iYXItY2hhcnQuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDaGFydENvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgQmFyQ2hhcnRDb21wb25lbnQge1xuICBwcm90ZWN0ZWQgZGF0YSA9IGlucHV0PENoYXJ0RGF0YUl0ZW1bXT4oW10pO1xuICBwcm90ZWN0ZWQgbWF4ID0gaW5wdXQ8bnVtYmVyPigpO1xuICBwcm90ZWN0ZWQgZGF0YXNldHMgPSBpbnB1dDxQYXJ0aWFsPENoYXJ0RGF0YVNldHM+W10+KFtdKTtcbiAgcHJvdGVjdGVkIGNvbmZpZyA9IGlucHV0PFBhcnRpYWw8Q2hhcnRDb25maWd1cmF0aW9uPj4oe30pO1xuXG4gIHByaXZhdGUgbWF4Q29uZmlnID0gY29tcHV0ZWQoKCkgPT4gKHRoaXMubWF4KCkgPyB7IG1heDogdGhpcy5tYXgoKSB9IDoge30pKTtcbiAgcHJpdmF0ZSBkZWZhdWx0Q29uZmlnOiBTaWduYWw8UGFydGlhbDxDaGFydENvbmZpZ3VyYXRpb24+PiA9IGNvbXB1dGVkKCgpID0+ICh7XG4gICAgb3B0aW9uczoge1xuICAgICAgbGVnZW5kOiB7XG4gICAgICAgIGFsaWduOiAnc3RhcnQnXG4gICAgICB9LFxuICAgICAgc2NhbGVzOiB7XG4gICAgICAgIHhBeGVzOiBbXG4gICAgICAgICAge1xuICAgICAgICAgICAgZGlzcGxheTogZmFsc2UsXG4gICAgICAgICAgICB0aWNrczoge1xuICAgICAgICAgICAgICBtaW46IDAsXG4gICAgICAgICAgICAgIC4uLnRoaXMubWF4Q29uZmlnKClcbiAgICAgICAgICAgIH1cbiAgICAgICAgICB9XG4gICAgICAgIF0sXG4gICAgICAgIHlBeGVzOiBbXG4gICAgICAgICAge1xuICAgICAgICAgICAgdGlja3M6IHtcbiAgICAgICAgICAgICAgZm9udENvbG9yOiAnIzRBNEE0QScsXG4gICAgICAgICAgICAgIGZvbnRGYW1pbHk6ICdMYXRvJyxcbiAgICAgICAgICAgICAgZm9udFNpemU6IDEwLFxuICAgICAgICAgICAgICBmb250U3R5bGU6ICc0MDAnXG4gICAgICAgICAgICB9XG4gICAgICAgICAgfVxuICAgICAgICBdXG4gICAgICB9XG4gICAgfVxuICB9KSk7XG5cbiAgcHJpdmF0ZSBkZWZhdWx0RGF0YXNldHM6IFNpZ25hbDxQYXJ0aWFsPENoYXJ0RGF0YVNldHM+W10+ID0gY29tcHV0ZWQoKCkgPT5cbiAgICB0aGlzLmRhdGFzZXRzKCk/Lmxlbmd0aFxuICAgICAgPyB0aGlzLmRhdGFzZXRzKClcbiAgICAgIDogW1xuICAgICAgICAgIHtcbiAgICAgICAgICAgIGRlZmF1bHREYXRhc2V0cyxcbiAgICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogdGhpcy5kYXRhKCkubWFwKCh7IGJhY2tncm91bmRDb2xvciwgY29sb3IgfSkgPT4gYmFja2dyb3VuZENvbG9yIHx8IGNvbG9yKSxcbiAgICAgICAgICAgIGJvcmRlckNvbG9yOiB0aGlzLmRhdGEoKS5tYXAoKHsgYm9yZGVyQ29sb3IsIGNvbG9yIH0pID0+IGJvcmRlckNvbG9yIHx8IGNvbG9yKSxcbiAgICAgICAgICAgIGRhdGE6IHRoaXMuZGF0YSgpLm1hcCgoeyBjb3VudCB9KSA9PiBjb3VudClcbiAgICAgICAgICB9XG4gICAgICAgIF1cbiAgKTtcblxuICBwcm90ZWN0ZWQgZGF0YUNvbmZpZzogU2lnbmFsPENoYXJ0RGF0YT4gPSBjb21wdXRlZCgoKSA9PiAoe1xuICAgIGRhdGE6IHtcbiAgICAgIGRhdGFzZXRzOiB0aGlzLmRlZmF1bHREYXRhc2V0cygpLFxuICAgICAgbGFiZWxzOiB0aGlzLmRhdGEoKS5tYXAoKHsgbGFiZWwgfSkgPT4gbGFiZWwpXG4gICAgfVxuICB9KSk7XG4gIHByb3RlY3RlZCBjb25maWd1cmF0aW9uID0gY29tcHV0ZWQoKCkgPT4gbWVyZ2UoZGVmYXVsdFNldHRpbmdzLCB0aGlzLmRlZmF1bHRDb25maWcoKSwgdGhpcy5jb25maWcoKSkpO1xufVxuIiwiPGhlLWNoYXJ0IFtkYXRhXT1cImRhdGFDb25maWcoKVwiIFtjb25maWddPVwiY29uZmlndXJhdGlvbigpXCI+PC9oZS1jaGFydD5cbiJdfQ==
@@ -21,10 +21,10 @@ export class ChartComponent {
21
21
  }));
22
22
  }
23
23
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: ChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
24
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.8", type: ChartComponent, isStandalone: true, selector: "he-chart", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: false, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"chart-container\" #container>\n <canvas [chartConfiguration]=\"configuration()\" [chartContainer]=\"container\"></canvas>\n</div>\n", styles: [":host{display:block;overflow:visible}.chart-container{height:100%;min-height:50px;position:relative}\n"], dependencies: [{ kind: "directive", type: ChartConfigurationDirective, selector: "[chartConfiguration]", inputs: ["chartConfiguration", "chartContainer"], exportAs: ["chart"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
24
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.3.8", type: ChartComponent, isStandalone: true, selector: "he-chart", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: false, transformFunction: null }, config: { classPropertyName: "config", publicName: "config", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"chart-container\" #container>\n <canvas [chartConfiguration]=\"configuration()\" [chartContainer]=\"container\"></canvas>\n</div>\n", styles: [":host{display:block;height:100%;overflow:visible}.chart-container{height:100%;min-height:50px;position:relative}\n"], dependencies: [{ kind: "directive", type: ChartConfigurationDirective, selector: "[chartConfiguration]", inputs: ["chartConfiguration", "chartContainer"], exportAs: ["chart"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
25
25
  }
26
26
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: ChartComponent, decorators: [{
27
27
  type: Component,
28
- args: [{ selector: 'he-chart', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ChartConfigurationDirective], template: "<div class=\"chart-container\" #container>\n <canvas [chartConfiguration]=\"configuration()\" [chartContainer]=\"container\"></canvas>\n</div>\n", styles: [":host{display:block;overflow:visible}.chart-container{height:100%;min-height:50px;position:relative}\n"] }]
28
+ args: [{ selector: 'he-chart', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [ChartConfigurationDirective], template: "<div class=\"chart-container\" #container>\n <canvas [chartConfiguration]=\"configuration()\" [chartContainer]=\"container\"></canvas>\n</div>\n", styles: [":host{display:block;height:100%;overflow:visible}.chart-container{height:100%;min-height:50px;position:relative}\n"] }]
29
29
  }] });
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NoYXJ0L2NoYXJ0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uL3NyYy9jaGFydC9jaGFydC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFcEYsT0FBTyxLQUFLLE1BQU0sY0FBYyxDQUFDO0FBRWpDLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOztBQUU5RSxNQUFNLGVBQWUsR0FBZ0M7SUFDbkQsT0FBTyxFQUFFO1FBQ1AsVUFBVSxFQUFFLElBQUk7UUFDaEIsbUJBQW1CLEVBQUUsS0FBSztRQUMxQixNQUFNLEVBQUU7WUFDTixPQUFPLEVBQUUsS0FBSztTQUNmO0tBQ0Y7Q0FDRixDQUFDO0FBVUYsTUFBTSxPQUFPLGNBQWM7SUFSM0I7UUFTWSxTQUFJLEdBQUcsS0FBSyxDQUFZLEVBQUUsQ0FBQyxDQUFDO1FBQzVCLFdBQU0sR0FBRyxLQUFLLENBQThCLEVBQUUsQ0FBQyxDQUFDO1FBRWhELGtCQUFhLEdBQUcsUUFBUSxDQUNoQyxHQUF1QixFQUFFLENBQUMsQ0FBQztZQUN6QixHQUFHLEtBQUssQ0FBQyxlQUFlLEVBQUUsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ3hDLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFO1NBQ2xCLENBQUMsQ0FDSCxDQUFDO0tBQ0g7OEdBVlksY0FBYztrR0FBZCxjQUFjLGdVQ3hCM0IsbUpBR0EsZ0tEbUJZLDJCQUEyQjs7MkZBRTFCLGNBQWM7a0JBUjFCLFNBQVM7K0JBQ0UsVUFBVSxtQkFHSCx1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUksV0FDUCxDQUFDLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgY29tcHV0ZWQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDaGFydENvbmZpZ3VyYXRpb24sIENoYXJ0RGF0YSB9IGZyb20gJ2NoYXJ0LmpzJztcbmltcG9ydCBtZXJnZSBmcm9tICdsb2Rhc2gubWVyZ2UnO1xuXG5pbXBvcnQgeyBDaGFydENvbmZpZ3VyYXRpb25EaXJlY3RpdmUgfSBmcm9tICcuL2NoYXJ0LWNvbmZpZ3VyYXRpb24uZGlyZWN0aXZlJztcblxuY29uc3QgZGVmYXVsdFNldHRpbmdzOiBQYXJ0aWFsPENoYXJ0Q29uZmlndXJhdGlvbj4gPSB7XG4gIG9wdGlvbnM6IHtcbiAgICByZXNwb25zaXZlOiB0cnVlLFxuICAgIG1haW50YWluQXNwZWN0UmF0aW86IGZhbHNlLFxuICAgIGxlZ2VuZDoge1xuICAgICAgZGlzcGxheTogZmFsc2VcbiAgICB9XG4gIH1cbn07XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2hlLWNoYXJ0JyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NoYXJ0LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY2hhcnQuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDaGFydENvbmZpZ3VyYXRpb25EaXJlY3RpdmVdXG59KVxuZXhwb3J0IGNsYXNzIENoYXJ0Q29tcG9uZW50IHtcbiAgcHJvdGVjdGVkIGRhdGEgPSBpbnB1dDxDaGFydERhdGE+KHt9KTtcbiAgcHJvdGVjdGVkIGNvbmZpZyA9IGlucHV0PFBhcnRpYWw8Q2hhcnRDb25maWd1cmF0aW9uPj4oe30pO1xuXG4gIHByb3RlY3RlZCBjb25maWd1cmF0aW9uID0gY29tcHV0ZWQoXG4gICAgKCk6IENoYXJ0Q29uZmlndXJhdGlvbiA9PiAoe1xuICAgICAgLi4ubWVyZ2UoZGVmYXVsdFNldHRpbmdzLCB0aGlzLmNvbmZpZygpKSxcbiAgICAgIGRhdGE6IHRoaXMuZGF0YSgpXG4gICAgfSlcbiAgKTtcbn1cbiIsIjxkaXYgY2xhc3M9XCJjaGFydC1jb250YWluZXJcIiAjY29udGFpbmVyPlxuICA8Y2FudmFzIFtjaGFydENvbmZpZ3VyYXRpb25dPVwiY29uZmlndXJhdGlvbigpXCIgW2NoYXJ0Q29udGFpbmVyXT1cImNvbnRhaW5lclwiPjwvY2FudmFzPlxuPC9kaXY+XG4iXX0=
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhcnQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NoYXJ0L2NoYXJ0LmNvbXBvbmVudC50cyIsIi4uLy4uLy4uL3NyYy9jaGFydC9jaGFydC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFcEYsT0FBTyxLQUFLLE1BQU0sY0FBYyxDQUFDO0FBRWpDLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDOztBQUU5RSxNQUFNLGVBQWUsR0FBZ0M7SUFDbkQsT0FBTyxFQUFFO1FBQ1AsVUFBVSxFQUFFLElBQUk7UUFDaEIsbUJBQW1CLEVBQUUsS0FBSztRQUMxQixNQUFNLEVBQUU7WUFDTixPQUFPLEVBQUUsS0FBSztTQUNmO0tBQ0Y7Q0FDRixDQUFDO0FBVUYsTUFBTSxPQUFPLGNBQWM7SUFSM0I7UUFTWSxTQUFJLEdBQUcsS0FBSyxDQUFZLEVBQUUsQ0FBQyxDQUFDO1FBQzVCLFdBQU0sR0FBRyxLQUFLLENBQThCLEVBQUUsQ0FBQyxDQUFDO1FBRWhELGtCQUFhLEdBQUcsUUFBUSxDQUNoQyxHQUF1QixFQUFFLENBQUMsQ0FBQztZQUN6QixHQUFHLEtBQUssQ0FBQyxlQUFlLEVBQUUsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ3hDLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFO1NBQ2xCLENBQUMsQ0FDSCxDQUFDO0tBQ0g7OEdBVlksY0FBYztrR0FBZCxjQUFjLGdVQ3hCM0IsbUpBR0EsNEtEbUJZLDJCQUEyQjs7MkZBRTFCLGNBQWM7a0JBUjFCLFNBQVM7K0JBQ0UsVUFBVSxtQkFHSCx1QkFBdUIsQ0FBQyxNQUFNLGNBQ25DLElBQUksV0FDUCxDQUFDLDJCQUEyQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgY29tcHV0ZWQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDaGFydENvbmZpZ3VyYXRpb24sIENoYXJ0RGF0YSB9IGZyb20gJ2NoYXJ0LmpzJztcbmltcG9ydCBtZXJnZSBmcm9tICdsb2Rhc2gubWVyZ2UnO1xuXG5pbXBvcnQgeyBDaGFydENvbmZpZ3VyYXRpb25EaXJlY3RpdmUgfSBmcm9tICcuL2NoYXJ0LWNvbmZpZ3VyYXRpb24uZGlyZWN0aXZlJztcblxuY29uc3QgZGVmYXVsdFNldHRpbmdzOiBQYXJ0aWFsPENoYXJ0Q29uZmlndXJhdGlvbj4gPSB7XG4gIG9wdGlvbnM6IHtcbiAgICByZXNwb25zaXZlOiB0cnVlLFxuICAgIG1haW50YWluQXNwZWN0UmF0aW86IGZhbHNlLFxuICAgIGxlZ2VuZDoge1xuICAgICAgZGlzcGxheTogZmFsc2VcbiAgICB9XG4gIH1cbn07XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2hlLWNoYXJ0JyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NoYXJ0LmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vY2hhcnQuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDaGFydENvbmZpZ3VyYXRpb25EaXJlY3RpdmVdXG59KVxuZXhwb3J0IGNsYXNzIENoYXJ0Q29tcG9uZW50IHtcbiAgcHJvdGVjdGVkIGRhdGEgPSBpbnB1dDxDaGFydERhdGE+KHt9KTtcbiAgcHJvdGVjdGVkIGNvbmZpZyA9IGlucHV0PFBhcnRpYWw8Q2hhcnRDb25maWd1cmF0aW9uPj4oe30pO1xuXG4gIHByb3RlY3RlZCBjb25maWd1cmF0aW9uID0gY29tcHV0ZWQoXG4gICAgKCk6IENoYXJ0Q29uZmlndXJhdGlvbiA9PiAoe1xuICAgICAgLi4ubWVyZ2UoZGVmYXVsdFNldHRpbmdzLCB0aGlzLmNvbmZpZygpKSxcbiAgICAgIGRhdGE6IHRoaXMuZGF0YSgpXG4gICAgfSlcbiAgKTtcbn1cbiIsIjxkaXYgY2xhc3M9XCJjaGFydC1jb250YWluZXJcIiAjY29udGFpbmVyPlxuICA8Y2FudmFzIFtjaGFydENvbmZpZ3VyYXRpb25dPVwiY29uZmlndXJhdGlvbigpXCIgW2NoYXJ0Q29udGFpbmVyXT1cImNvbnRhaW5lclwiPjwvY2FudmFzPlxuPC9kaXY+XG4iXX0=
@@ -2,6 +2,30 @@ import get from 'lodash.get';
2
2
  import { EmissionMethodTier } from '@hestia-earth/schema';
3
3
  import { propertyValue } from '@hestia-earth/utils/dist/term';
4
4
  import { getDefaultModelId } from '@hestia-earth/glossary';
5
+ /* eslint-disable-next-line complexity */
6
+ export const formatDate = (date, isStart = false) => date?.length === 4
7
+ ? isStart
8
+ ? new Date(`${date}-01-01`)
9
+ : new Date(`${date}-12-31`)
10
+ : date?.length === 7
11
+ ? isStart
12
+ ? new Date(`${date}-15`)
13
+ : new Date(`${date}-14`)
14
+ : date
15
+ ? new Date(date)
16
+ : undefined;
17
+ export const getDatesBetween = (startDate, endDate) => {
18
+ const start = formatDate(startDate, true);
19
+ const end = formatDate(endDate, false);
20
+ const dates = [];
21
+ let date = new Date(start);
22
+ while (date <= end) {
23
+ dates.push(date);
24
+ date = new Date(date);
25
+ date.setMonth(date.getMonth() + 1);
26
+ }
27
+ return dates;
28
+ };
5
29
  export const filterBlankNode = (filterTerm) => ({ term }) => !filterTerm || term?.name?.toLowerCase()?.includes(filterTerm.toLowerCase());
6
30
  export const ignoreKeys = ['@type', 'type', 'added', 'updated', 'addedVersion', 'updatedVersion'];
7
31
  export const isValidKey = (key) => !ignoreKeys.includes(key);
@@ -91,4 +115,4 @@ export const groupNodesByTerm = (nodes = [], key, originalValues = [], includeNo
91
115
  });
92
116
  return groups;
93
117
  };
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-utils.js","sourceRoot":"","sources":["../../../src/common/node-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import get from 'lodash.get';\nimport {\n  Term,\n  ICycleJSONLD,\n  ISiteJSONLD,\n  IImpactAssessmentJSONLD,\n  EmissionMethodTier,\n  ITermJSONLD,\n  Indicator,\n  Animal,\n  Transformation,\n  blankNodesType,\n  blankNodesKey\n} from '@hestia-earth/schema';\nimport { propertyValue, propertyValueType } from '@hestia-earth/utils/dist/term';\nimport { getDefaultModelId } from '@hestia-earth/glossary';\n\nexport const filterBlankNode =\n  (filterTerm: string) =>\n  ({ term }: blankNodesType) =>\n    !filterTerm || term?.name?.toLowerCase()?.includes(filterTerm.toLowerCase());\n\nexport const ignoreKeys = ['@type', 'type', 'added', 'updated', 'addedVersion', 'updatedVersion'];\n\nexport const isValidKey = (key: string) => !ignoreKeys.includes(key);\n\nexport const isMethodModelAllowed = (filterMethod?: Term) => (node: Indicator) =>\n  node.methodModel?.['@id'] === (filterMethod ? filterMethod['@id'] : getDefaultModelId(node.term?.['@id']));\n\nexport enum NodeKeyState {\n  added = 'added',\n  updated = 'updated',\n  deleted = 'deleted',\n  unchanged = 'unchanged'\n}\n\nexport const isState = (node: blankNodesType, key: string, state: NodeKeyState) =>\n  state in node! && (typeof node![state] === 'boolean' ? node![state] : node![state].includes(key));\n\nexport interface IGroupedNode<T> {\n  // store the node with the highest \"state\"\n  node: T;\n  nodes: T[];\n  index: number;\n  value: propertyValueType[];\n  dates?: any[];\n  sd?: number[];\n  min?: number[];\n  max?: number[];\n  inputs?: any[];\n  depthUpper?: number[];\n  depthLower?: number[];\n  startDate?: string[];\n  endDate?: string[];\n}\n\nexport interface IGroupedNodesValues<T> {\n  [nodeId: string]: IGroupedNode<T>;\n}\n\nexport interface IGroupedNodesValue<T> {\n  term: ITermJSONLD;\n  methodTier?: EmissionMethodTier;\n  /**\n   * Enable ordering ny methodTier\n   */\n  methodTierOrder: number;\n  values: IGroupedNodesValues<T>;\n  originalValues: {\n    [nodeId: string]: {\n      value: propertyValueType;\n    };\n  };\n}\n\nexport interface IGroupedNodes<T> {\n  [termId: string]: IGroupedNodesValue<T>;\n}\n\nexport interface IGroupedKeys<T> {\n  key: string;\n  value: IGroupedNodesValue<T>;\n}\n\nexport const grouppedKeys = <T>(values: { [key: string]: T }): { key: string; value: T }[] =>\n  Object.entries(values).map(([key, value]) => ({ key, value }));\n\nconst concatBlankNodeValue = (value: any, newValue: any) => {\n  const valueArray = Array.isArray(value) ? value : [value];\n  const newValueArray = Array.isArray(newValue) ? newValue : [newValue];\n  return [...valueArray, ...newValueArray];\n};\n\nexport const methodTierOrder = (methodTier: EmissionMethodTier) =>\n  [\n    EmissionMethodTier.measured,\n    EmissionMethodTier['tier 3'],\n    EmissionMethodTier['tier 2'],\n    EmissionMethodTier['tier 1'],\n    EmissionMethodTier.background,\n    EmissionMethodTier['not relevant']\n  ].indexOf(methodTier);\n\nexport const grouppedValueKeys = [\n  'dates',\n  'sd',\n  'min',\n  'max',\n  'inputs',\n  'depthUpper',\n  'depthLower',\n  'startDate',\n  'endDate',\n  'methodTier',\n  'methodModel',\n  'model',\n  'method'\n];\n\nconst isHigherState = (sourceNode: blankNodesType, newNode: blankNodesType) =>\n  !sourceNode ||\n  isState(newNode, 'value', NodeKeyState.updated) ||\n  (!isState(sourceNode, 'value', NodeKeyState.updated) && isState(newNode, 'value', NodeKeyState.added));\n\nconst groupNodeKey = ({ term }: any) => term?.name || term?.['@id'];\n\nexport const groupNodesByTerm = <\n  T extends ICycleJSONLD | IImpactAssessmentJSONLD | ISiteJSONLD | Animal | Transformation,\n  R\n>(\n  nodes: T[] = [],\n  key: blankNodesKey,\n  originalValues: T[] = [],\n  includeNode = (_node: any) => true\n): IGroupedNodes<R> => {\n  const groups: IGroupedNodes<R> = nodes.reduce(\n    (prev, node, index) =>\n      (node[key] || []).reduce((group, blankNode) => {\n        // skip node based on condition\n        if (!includeNode(blankNode)) {\n          return group;\n        }\n\n        const nodeId = node['@id'];\n        const groupedKey = groupNodeKey(blankNode);\n        group[groupedKey] = group[groupedKey] || {\n          term: blankNode.term,\n          methodTier: blankNode.methodTier,\n          methodTierOrder: methodTierOrder(blankNode.methodTier),\n          values: {},\n          originalValues: {}\n        };\n        group[groupedKey].values[nodeId] = group[groupedKey].values[nodeId] || { index, nodes: [], value: [] };\n        group[groupedKey].values[nodeId].node = isHigherState(group[groupedKey].values[nodeId].node, blankNode)\n          ? blankNode\n          : group[groupedKey].values[nodeId].node;\n        group[groupedKey].values[nodeId].nodes.push(blankNode);\n        group[groupedKey].values[nodeId].value = concatBlankNodeValue(\n          group[groupedKey].values[nodeId].value,\n          blankNode.value\n        );\n        grouppedValueKeys.forEach(arrayKey => {\n          const newValue = get(blankNode, arrayKey, []);\n          group[groupedKey].values[nodeId][arrayKey] = [\n            ...(group[groupedKey].values[nodeId][arrayKey] || []),\n            ...(Array.isArray(newValue) ? newValue : [newValue])\n          ];\n        });\n        return group;\n      }, prev),\n    {} as IGroupedNodes<R>\n  );\n\n  // compile original values\n  Object.values(groups).map(group => {\n    Object.keys(group.values).map(nodeId => {\n      const { index } = group.values[nodeId];\n      const termId = group.term['@id'];\n      const originalValue = get(originalValues, `[${index}].${key}`, []).filter(\n        (val: any) => val.term['@id'] === termId\n      );\n      if (originalValue.length > 0) {\n        const value = originalValue.reduce((array: any[], curr: any) => concatBlankNodeValue(array, curr.value), []);\n        group.originalValues[nodeId] = { value: propertyValue(value, termId) };\n      }\n    });\n  });\n\n  return groups;\n};\n"]}
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-utils.js","sourceRoot":"","sources":["../../../src/common/node-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import get from 'lodash.get';\nimport {\n  Term,\n  ICycleJSONLD,\n  ISiteJSONLD,\n  IImpactAssessmentJSONLD,\n  EmissionMethodTier,\n  ITermJSONLD,\n  Indicator,\n  Animal,\n  Transformation,\n  blankNodesType,\n  blankNodesKey\n} from '@hestia-earth/schema';\nimport { propertyValue, propertyValueType } from '@hestia-earth/utils/dist/term';\nimport { getDefaultModelId } from '@hestia-earth/glossary';\n\n/* eslint-disable-next-line complexity */\nexport const formatDate = (date: string, isStart = false) =>\n  date?.length === 4\n    ? isStart\n      ? new Date(`${date}-01-01`)\n      : new Date(`${date}-12-31`)\n    : date?.length === 7\n      ? isStart\n        ? new Date(`${date}-15`)\n        : new Date(`${date}-14`)\n      : date\n        ? new Date(date)\n        : undefined;\n\nexport const getDatesBetween = (startDate: string, endDate: string) => {\n  const start = formatDate(startDate, true);\n  const end = formatDate(endDate, false);\n  const dates: Date[] = [];\n\n  let date = new Date(start);\n  while (date <= end) {\n    dates.push(date);\n    date = new Date(date);\n    date.setMonth(date.getMonth() + 1);\n  }\n\n  return dates;\n};\n\nexport const filterBlankNode =\n  (filterTerm: string) =>\n  ({ term }: blankNodesType) =>\n    !filterTerm || term?.name?.toLowerCase()?.includes(filterTerm.toLowerCase());\n\nexport const ignoreKeys = ['@type', 'type', 'added', 'updated', 'addedVersion', 'updatedVersion'];\n\nexport const isValidKey = (key: string) => !ignoreKeys.includes(key);\n\nexport const isMethodModelAllowed = (filterMethod?: Term) => (node: Indicator) =>\n  node.methodModel?.['@id'] === (filterMethod ? filterMethod['@id'] : getDefaultModelId(node.term?.['@id']));\n\nexport enum NodeKeyState {\n  added = 'added',\n  updated = 'updated',\n  deleted = 'deleted',\n  unchanged = 'unchanged'\n}\n\nexport const isState = (node: blankNodesType, key: string, state: NodeKeyState) =>\n  state in node! && (typeof node![state] === 'boolean' ? node![state] : node![state].includes(key));\n\nexport interface IGroupedNode<T> {\n  // store the node with the highest \"state\"\n  node: T;\n  nodes: T[];\n  index: number;\n  value: propertyValueType[];\n  dates?: any[];\n  sd?: number[];\n  min?: number[];\n  max?: number[];\n  inputs?: any[];\n  depthUpper?: number[];\n  depthLower?: number[];\n  startDate?: string[];\n  endDate?: string[];\n}\n\nexport interface IGroupedNodesValues<T> {\n  [nodeId: string]: IGroupedNode<T>;\n}\n\nexport interface IGroupedNodesValue<T> {\n  term: ITermJSONLD;\n  methodTier?: EmissionMethodTier;\n  /**\n   * Enable ordering ny methodTier\n   */\n  methodTierOrder: number;\n  values: IGroupedNodesValues<T>;\n  originalValues: {\n    [nodeId: string]: {\n      value: propertyValueType;\n    };\n  };\n}\n\nexport interface IGroupedNodes<T> {\n  [termId: string]: IGroupedNodesValue<T>;\n}\n\nexport interface IGroupedKeys<T> {\n  key: string;\n  value: IGroupedNodesValue<T>;\n}\n\nexport const grouppedKeys = <T>(values: { [key: string]: T }): { key: string; value: T }[] =>\n  Object.entries(values).map(([key, value]) => ({ key, value }));\n\nconst concatBlankNodeValue = (value: any, newValue: any) => {\n  const valueArray = Array.isArray(value) ? value : [value];\n  const newValueArray = Array.isArray(newValue) ? newValue : [newValue];\n  return [...valueArray, ...newValueArray];\n};\n\nexport const methodTierOrder = (methodTier: EmissionMethodTier) =>\n  [\n    EmissionMethodTier.measured,\n    EmissionMethodTier['tier 3'],\n    EmissionMethodTier['tier 2'],\n    EmissionMethodTier['tier 1'],\n    EmissionMethodTier.background,\n    EmissionMethodTier['not relevant']\n  ].indexOf(methodTier);\n\nexport const grouppedValueKeys = [\n  'dates',\n  'sd',\n  'min',\n  'max',\n  'inputs',\n  'depthUpper',\n  'depthLower',\n  'startDate',\n  'endDate',\n  'methodTier',\n  'methodModel',\n  'model',\n  'method'\n];\n\nconst isHigherState = (sourceNode: blankNodesType, newNode: blankNodesType) =>\n  !sourceNode ||\n  isState(newNode, 'value', NodeKeyState.updated) ||\n  (!isState(sourceNode, 'value', NodeKeyState.updated) && isState(newNode, 'value', NodeKeyState.added));\n\nconst groupNodeKey = ({ term }: any) => term?.name || term?.['@id'];\n\nexport const groupNodesByTerm = <\n  T extends ICycleJSONLD | IImpactAssessmentJSONLD | ISiteJSONLD | Animal | Transformation,\n  R\n>(\n  nodes: T[] = [],\n  key: blankNodesKey,\n  originalValues: T[] = [],\n  includeNode = (_node: any) => true\n): IGroupedNodes<R> => {\n  const groups: IGroupedNodes<R> = nodes.reduce(\n    (prev, node, index) =>\n      (node[key] || []).reduce((group, blankNode) => {\n        // skip node based on condition\n        if (!includeNode(blankNode)) {\n          return group;\n        }\n\n        const nodeId = node['@id'];\n        const groupedKey = groupNodeKey(blankNode);\n        group[groupedKey] = group[groupedKey] || {\n          term: blankNode.term,\n          methodTier: blankNode.methodTier,\n          methodTierOrder: methodTierOrder(blankNode.methodTier),\n          values: {},\n          originalValues: {}\n        };\n        group[groupedKey].values[nodeId] = group[groupedKey].values[nodeId] || { index, nodes: [], value: [] };\n        group[groupedKey].values[nodeId].node = isHigherState(group[groupedKey].values[nodeId].node, blankNode)\n          ? blankNode\n          : group[groupedKey].values[nodeId].node;\n        group[groupedKey].values[nodeId].nodes.push(blankNode);\n        group[groupedKey].values[nodeId].value = concatBlankNodeValue(\n          group[groupedKey].values[nodeId].value,\n          blankNode.value\n        );\n        grouppedValueKeys.forEach(arrayKey => {\n          const newValue = get(blankNode, arrayKey, []);\n          group[groupedKey].values[nodeId][arrayKey] = [\n            ...(group[groupedKey].values[nodeId][arrayKey] || []),\n            ...(Array.isArray(newValue) ? newValue : [newValue])\n          ];\n        });\n        return group;\n      }, prev),\n    {} as IGroupedNodes<R>\n  );\n\n  // compile original values\n  Object.values(groups).map(group => {\n    Object.keys(group.values).map(nodeId => {\n      const { index } = group.values[nodeId];\n      const termId = group.term['@id'];\n      const originalValue = get(originalValues, `[${index}].${key}`, []).filter(\n        (val: any) => val.term['@id'] === termId\n      );\n      if (originalValue.length > 0) {\n        const value = originalValue.reduce((array: any[], curr: any) => concatBlankNodeValue(array, curr.value), []);\n        group.originalValues[nodeId] = { value: propertyValue(value, termId) };\n      }\n    });\n  });\n\n  return groups;\n};\n"]}
@@ -192,10 +192,10 @@ export class ImpactAssessmentsIndicatorBreakdownChartComponent {
192
192
  this.selectedMethod.set(term);
193
193
  }
194
194
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: ImpactAssessmentsIndicatorBreakdownChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
195
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: ImpactAssessmentsIndicatorBreakdownChartComponent, isStandalone: true, selector: "he-impact-assessments-indicator-breakdown-chart", inputs: { impactAssessment: { classPropertyName: "impactAssessment", publicName: "impactAssessment", isSignal: true, isRequired: false, transformFunction: null }, indicators: { classPropertyName: "indicators", publicName: "indicators", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "@if (loading()) {\n <div class=\"has-text-center py-3\">\n <fa-icon [icon]=\"faSpinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n </div>\n} @else {\n <div class=\"p-3\" [class.is-hidden]=\"!terms()?.length\">\n <div class=\"columns\">\n <div class=\"column\">\n <div class=\"field has-addons\">\n <div class=\"control\">\n <span class=\"button is-small is-static is-secondary\">Select an Indicator</span>\n </div>\n @if (terms()?.length) {\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth is-small is-secondary\">\n <select (change)=\"selectTerm($event)\">\n @for (term of terms(); track term) {\n <option [value]=\"term['@id']\">{{ term.name }} ({{ term.units }})</option>\n }\n </select>\n </div>\n </div>\n }\n @if (methods()?.length) {\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth is-small is-secondary\">\n <select (change)=\"selectMethod($event)\">\n <option [ngValue]=\"undefined\">Filter Model</option>\n @for (term of methods(); track term) {\n <option [value]=\"term['@id']\">{{ term.name }}</option>\n }\n </select>\n </div>\n </div>\n }\n </div>\n </div>\n <div class=\"column is-narrow\">\n <a\n class=\"button is-ghost is-small\"\n [href]=\"csvContent()\"\n [download]=\"downloadFilename()\"\n nbgTooltip=\"Download as CSV\"\n placement=\"bottom\">\n <fa-icon [icon]=\"faDownload\"></fa-icon>\n </a>\n </div>\n </div>\n @if (!selectedMethod()) {\n <p class=\"is-size-7\">\n <i>Selecting a Model is recommended to avoid duplicated entries.</i>\n </p>\n }\n </div>\n}\n\n<div class=\"is-mt-1\">\n @if (!loading() && noData()) {\n <p class=\"has-text-centered\">\n <span>No breakdown available for</span>\n @if (selectedTerm()) {\n <span class=\"is-pl-1\">{{ selectedTerm().name }}</span>\n }\n @if (selectedMethod()) {\n <span class=\"is-pl-1\">({{ selectedMethod().name }})</span>\n }\n <span>.</span>\n </p>\n }\n <he-chart class=\"is-relative\" [data]=\"chartData()\" [config]=\"chartConfig()\"></he-chart>\n</div>\n", styles: [":host{display:block;overflow:visible}he-chart{height:100%}he-chart::ng-deep .chart-container{min-height:400px}\n"], dependencies: [{ kind: "component", type: FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "classes", "transform", "a11yRole"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "component", type: ChartComponent, selector: "he-chart", inputs: ["data", "config"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
195
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.8", type: ImpactAssessmentsIndicatorBreakdownChartComponent, isStandalone: true, selector: "he-impact-assessments-indicator-breakdown-chart", inputs: { impactAssessment: { classPropertyName: "impactAssessment", publicName: "impactAssessment", isSignal: true, isRequired: false, transformFunction: null }, indicators: { classPropertyName: "indicators", publicName: "indicators", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "@if (loading()) {\n <div class=\"has-text-center py-3\">\n <fa-icon [icon]=\"faSpinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n </div>\n} @else {\n <div class=\"p-3\" [class.is-hidden]=\"!terms()?.length\">\n <div class=\"columns\">\n <div class=\"column\">\n <div class=\"field has-addons\">\n <div class=\"control\">\n <span class=\"button is-small is-static is-secondary\">Select an Indicator</span>\n </div>\n @if (terms()?.length) {\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth is-small is-secondary\">\n <select (change)=\"selectTerm($event)\">\n @for (term of terms(); track term) {\n <option [value]=\"term['@id']\">{{ term.name }} ({{ term.units }})</option>\n }\n </select>\n </div>\n </div>\n }\n @if (methods()?.length) {\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth is-small is-secondary\">\n <select (change)=\"selectMethod($event)\">\n <option [ngValue]=\"undefined\">Filter Model</option>\n @for (term of methods(); track term) {\n <option [value]=\"term['@id']\">{{ term.name }}</option>\n }\n </select>\n </div>\n </div>\n }\n </div>\n </div>\n <div class=\"column is-narrow\">\n <a\n class=\"button is-ghost is-small\"\n [href]=\"csvContent()\"\n [download]=\"downloadFilename()\"\n ngbTooltip=\"Download as CSV\"\n placement=\"bottom\">\n <fa-icon [icon]=\"faDownload\"></fa-icon>\n </a>\n </div>\n </div>\n @if (!selectedMethod()) {\n <p class=\"is-size-7\">\n <i>Selecting a Model is recommended to avoid duplicated entries.</i>\n </p>\n }\n </div>\n}\n\n<div class=\"is-mt-1\">\n @if (!loading() && noData()) {\n <p class=\"has-text-centered\">\n <span>No breakdown available for</span>\n @if (selectedTerm()) {\n <span class=\"is-pl-1\">{{ selectedTerm().name }}</span>\n }\n @if (selectedMethod()) {\n <span class=\"is-pl-1\">({{ selectedMethod().name }})</span>\n }\n <span>.</span>\n </p>\n }\n <he-chart class=\"is-relative\" [data]=\"chartData()\" [config]=\"chartConfig()\"></he-chart>\n</div>\n", styles: [":host{display:block;overflow:visible}he-chart{height:100%}he-chart::ng-deep .chart-container{min-height:400px}\n"], dependencies: [{ kind: "component", type: FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "classes", "transform", "a11yRole"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "component", type: ChartComponent, selector: "he-chart", inputs: ["data", "config"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
196
196
  }
197
197
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: ImpactAssessmentsIndicatorBreakdownChartComponent, decorators: [{
198
198
  type: Component,
199
- args: [{ selector: 'he-impact-assessments-indicator-breakdown-chart', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [FaIconComponent, FormsModule, ChartComponent], template: "@if (loading()) {\n <div class=\"has-text-center py-3\">\n <fa-icon [icon]=\"faSpinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n </div>\n} @else {\n <div class=\"p-3\" [class.is-hidden]=\"!terms()?.length\">\n <div class=\"columns\">\n <div class=\"column\">\n <div class=\"field has-addons\">\n <div class=\"control\">\n <span class=\"button is-small is-static is-secondary\">Select an Indicator</span>\n </div>\n @if (terms()?.length) {\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth is-small is-secondary\">\n <select (change)=\"selectTerm($event)\">\n @for (term of terms(); track term) {\n <option [value]=\"term['@id']\">{{ term.name }} ({{ term.units }})</option>\n }\n </select>\n </div>\n </div>\n }\n @if (methods()?.length) {\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth is-small is-secondary\">\n <select (change)=\"selectMethod($event)\">\n <option [ngValue]=\"undefined\">Filter Model</option>\n @for (term of methods(); track term) {\n <option [value]=\"term['@id']\">{{ term.name }}</option>\n }\n </select>\n </div>\n </div>\n }\n </div>\n </div>\n <div class=\"column is-narrow\">\n <a\n class=\"button is-ghost is-small\"\n [href]=\"csvContent()\"\n [download]=\"downloadFilename()\"\n nbgTooltip=\"Download as CSV\"\n placement=\"bottom\">\n <fa-icon [icon]=\"faDownload\"></fa-icon>\n </a>\n </div>\n </div>\n @if (!selectedMethod()) {\n <p class=\"is-size-7\">\n <i>Selecting a Model is recommended to avoid duplicated entries.</i>\n </p>\n }\n </div>\n}\n\n<div class=\"is-mt-1\">\n @if (!loading() && noData()) {\n <p class=\"has-text-centered\">\n <span>No breakdown available for</span>\n @if (selectedTerm()) {\n <span class=\"is-pl-1\">{{ selectedTerm().name }}</span>\n }\n @if (selectedMethod()) {\n <span class=\"is-pl-1\">({{ selectedMethod().name }})</span>\n }\n <span>.</span>\n </p>\n }\n <he-chart class=\"is-relative\" [data]=\"chartData()\" [config]=\"chartConfig()\"></he-chart>\n</div>\n", styles: [":host{display:block;overflow:visible}he-chart{height:100%}he-chart::ng-deep .chart-container{min-height:400px}\n"] }]
199
+ args: [{ selector: 'he-impact-assessments-indicator-breakdown-chart', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [FaIconComponent, FormsModule, ChartComponent], template: "@if (loading()) {\n <div class=\"has-text-center py-3\">\n <fa-icon [icon]=\"faSpinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n </div>\n} @else {\n <div class=\"p-3\" [class.is-hidden]=\"!terms()?.length\">\n <div class=\"columns\">\n <div class=\"column\">\n <div class=\"field has-addons\">\n <div class=\"control\">\n <span class=\"button is-small is-static is-secondary\">Select an Indicator</span>\n </div>\n @if (terms()?.length) {\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth is-small is-secondary\">\n <select (change)=\"selectTerm($event)\">\n @for (term of terms(); track term) {\n <option [value]=\"term['@id']\">{{ term.name }} ({{ term.units }})</option>\n }\n </select>\n </div>\n </div>\n }\n @if (methods()?.length) {\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth is-small is-secondary\">\n <select (change)=\"selectMethod($event)\">\n <option [ngValue]=\"undefined\">Filter Model</option>\n @for (term of methods(); track term) {\n <option [value]=\"term['@id']\">{{ term.name }}</option>\n }\n </select>\n </div>\n </div>\n }\n </div>\n </div>\n <div class=\"column is-narrow\">\n <a\n class=\"button is-ghost is-small\"\n [href]=\"csvContent()\"\n [download]=\"downloadFilename()\"\n ngbTooltip=\"Download as CSV\"\n placement=\"bottom\">\n <fa-icon [icon]=\"faDownload\"></fa-icon>\n </a>\n </div>\n </div>\n @if (!selectedMethod()) {\n <p class=\"is-size-7\">\n <i>Selecting a Model is recommended to avoid duplicated entries.</i>\n </p>\n }\n </div>\n}\n\n<div class=\"is-mt-1\">\n @if (!loading() && noData()) {\n <p class=\"has-text-centered\">\n <span>No breakdown available for</span>\n @if (selectedTerm()) {\n <span class=\"is-pl-1\">{{ selectedTerm().name }}</span>\n }\n @if (selectedMethod()) {\n <span class=\"is-pl-1\">({{ selectedMethod().name }})</span>\n }\n <span>.</span>\n </p>\n }\n <he-chart class=\"is-relative\" [data]=\"chartData()\" [config]=\"chartConfig()\"></he-chart>\n</div>\n", styles: [":host{display:block;overflow:visible}he-chart{height:100%}he-chart::ng-deep .chart-container{min-height:400px}\n"] }]
200
200
  }], ctorParameters: () => [] });
201
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"impact-assessments-indicator-breakdown-chart.component.js","sourceRoot":"","sources":["../../../../src/impact-assessments/impact-assessments-indicator-breakdown-chart/impact-assessments-indicator-breakdown-chart.component.ts","../../../../src/impact-assessments/impact-assessments-indicator-breakdown-chart/impact-assessments-indicator-breakdown-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Signal, computed, effect, inject, input, signal } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { filter, groupBy, map, mergeAll, mergeMap, take, tap, toArray } from 'rxjs/operators';\nimport { ChartConfiguration, ChartData } from 'chart.js';\nimport ChartDataLabels from 'chartjs-plugin-datalabels';\nimport { DataState } from '@hestia-earth/api';\nimport { IImpactAssessmentJSONLD, Indicator, ITermJSONLD, NodeType, Term, TermTermType } from '@hestia-earth/schema';\nimport { toPrecision, unique } from '@hestia-earth/utils';\nimport { FormsModule } from '@angular/forms';\nimport { FaIconComponent } from '@fortawesome/angular-fontawesome';\nimport { faDownload, faSpinner } from '@fortawesome/free-solid-svg-icons';\nimport { of } from 'rxjs';\n\nimport { matchTermType, matchType } from '../../search/search.model';\nimport { HeSearchService } from '../../search/search.service';\nimport { HeNodeService } from '../../node/node.service';\nimport { distinctUntilChangedDeep } from '../../common/rxjs-utils';\nimport { Level, parseLines, parseMessage } from '../../common/logs-utils';\nimport { listColor } from '../../common/color';\nimport { ChartComponent } from '../../chart/chart.component';\n\ninterface ILog {\n  modelId: string;\n  impactTermId: string;\n  impactTermUnits?: string;\n  blankNodeTermId: string;\n  coefficient: number;\n  value: number;\n  // store all indicators with inputs\n  inputs?: {\n    name: string;\n    value: number;\n  }[];\n  inputsValue?: number;\n}\n\nconst parseLog = (data: any): ILog => ({\n  modelId: data.model,\n  impactTermId: data['key/term'] || data.term || data.indicator,\n  blankNodeTermId: data.node,\n  coefficient: +data.coefficient,\n  value: +data.value * +data.coefficient\n});\n\nconst filterTermTypes = [TermTermType.emission, TermTermType.characterisedIndicator];\n\nconst csvHeaders = [\n  'Impact',\n  'Impact Unit',\n  'Method',\n  'Emission',\n  'Value',\n  'Inputs',\n  'Inputs value',\n  'Functional Unit'\n];\n\nconst logToCsv = (logs: ILog[], impact: IImpactAssessmentJSONLD) =>\n  [\n    csvHeaders.join(','),\n    ...logs\n      .sort((a, b) => a.impactTermId.localeCompare(b.impactTermId))\n      .flatMap(({ impactTermId, impactTermUnits, modelId, blankNodeTermId, value, inputs }) => [\n        [impactTermId, impactTermUnits, modelId, blankNodeTermId, value, '', ''],\n        ...inputs.map(v => [impactTermId, impactTermUnits, modelId, blankNodeTermId, '', v.name, v.value])\n      ])\n      .map(v => [...v, impact.product?.term?.units].join(','))\n  ].join('\\n');\n\n@Component({\n  selector: 'he-impact-assessments-indicator-breakdown-chart',\n  templateUrl: './impact-assessments-indicator-breakdown-chart.component.html',\n  styleUrls: ['./impact-assessments-indicator-breakdown-chart.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [FaIconComponent, FormsModule, ChartComponent]\n})\nexport class ImpactAssessmentsIndicatorBreakdownChartComponent {\n  private domSanitizer = inject(DomSanitizer);\n  private searchService = inject(HeSearchService);\n  private nodeService = inject(HeNodeService);\n\n  protected readonly faSpinner = faSpinner;\n  protected readonly faDownload = faDownload;\n\n  protected impactAssessment = input(undefined as IImpactAssessmentJSONLD);\n  private impactAssessment$ = toObservable(this.impactAssessment);\n\n  protected indicators = input([] as Indicator[]);\n\n  private allLogs = signal([] as ILog[]);\n  private logs = computed(() =>\n    this.allLogs()\n      .filter(\n        ({ impactTermId, modelId }) =>\n          impactTermId === this.selectedTerm()?.['@id'] &&\n          (!this.selectedMethod() || modelId === this.selectedMethod()?.['@id'])\n      )\n      .sort((a, b) => b.value - a.value)\n  );\n\n  private emissions = toSignal(\n    this.searchService\n      .search$<ITermJSONLD, NodeType.Term>({\n        fields: ['@type', '@id', 'name'],\n        limit: 1000,\n        query: {\n          bool: {\n            must: [matchType(NodeType.Term)],\n            should: filterTermTypes.map(termType => matchTermType(termType)),\n            minimum_should_match: 1\n          }\n        }\n      })\n      .pipe(map(({ results }) => results))\n  );\n\n  protected loading = signal(true);\n\n  protected selectedTerm = signal(undefined as Term);\n  protected terms = computed(() =>\n    unique(\n      (this.indicators() || [])\n        .map(({ term }) => term!)\n        .filter(Boolean)\n        .sort((a, b) => a.name.localeCompare(b.name))\n    )\n  );\n\n  protected selectedMethod = signal(undefined as Term);\n  protected methods = computed(() =>\n    unique((this.indicators() || []).map(({ methodModel }) => methodModel!).filter(Boolean))\n  );\n\n  private impacts = computed(() => [\n    ...(this.impactAssessment()?.impacts || []),\n    ...(this.impactAssessment()?.endpoints || [])\n  ]);\n  protected noData = computed(() => this.logs()?.length === 0);\n\n  protected csvContent = computed(() =>\n    this.domSanitizer.bypassSecurityTrustResourceUrl(\n      `data:text/html;charset=utf-8,${encodeURIComponent(logToCsv(this.logs(), this.impactAssessment()))}`\n    )\n  );\n  private id = computed(() => this.impactAssessment()?.['@id'] || (this.impactAssessment() as any)?.id);\n  protected downloadFilename = computed(() => `${this.id()}-logs.csv`);\n\n  private total = computed(() => this.logs().reduce((prev, curr) => prev + curr.value, 0));\n  private labels = computed(() =>\n    this.logs().map(\n      ({ blankNodeTermId }) => this.emissions()?.find(v => v['@id'] === blankNodeTermId)?.name || blankNodeTermId\n    )\n  );\n  private datasets = computed(() => [\n    {\n      label: this.selectedTerm()?.name ?? '',\n      data: this.logs().map(({ value }) => value),\n      backgroundColor: this.logs().map(listColor),\n      borderColor: this.logs().map(listColor)\n    }\n  ]);\n\n  protected chartData: Signal<ChartData> = computed(() => ({\n    datasets: this.datasets(),\n    labels: this.labels()\n  }));\n  protected chartConfig: Signal<Partial<ChartConfiguration>> = computed(() => ({\n    type: 'horizontalBar',\n    plugins: [ChartDataLabels],\n    options: {\n      plugins: {\n        datalabels: {\n          color: 'black',\n          formatter: value => {\n            const ratio = toPrecision((value * 100) / this.total(), 2);\n            return value > 0 ? `${toPrecision(value, 3)} (${ratio}%)` : '';\n          },\n          align: 'end'\n        }\n      },\n      responsive: true,\n      maintainAspectRatio: false,\n      legend: {\n        display: false\n      },\n      tooltips: {\n        enabled: false,\n        callbacks: {\n          title: (tooltipItems, data) => data.datasets![tooltipItems[0].datasetIndex!]?.label || '',\n          label: tooltipItem => {\n            const value = +(tooltipItem.value || '0');\n            const ratio = toPrecision((value * 100) / this.total(), 2);\n            return value > 0 ? `${toPrecision(value, 3)} (${ratio}%)` : '';\n          }\n        }\n      },\n      scales: {\n        xAxes: [\n          {\n            display: true\n          }\n        ],\n        yAxes: [\n          {\n            position: 'left'\n          }\n        ]\n      }\n    }\n  }));\n\n  constructor() {\n    this.impactAssessment$\n      .pipe(\n        filter(v => !!v),\n        distinctUntilChangedDeep(),\n        take(1),\n        tap(() => this.loading.set(true)),\n        mergeMap(node => (node ? this.nodeService.getLog({ ...node, dataState: DataState.recalculated }) : of(''))),\n        map(value => (value ? parseLines(value) : [])),\n        mergeAll(),\n        filter(({ data }) => data.logger === 'hestia_earth.models' && data.level === Level.debug),\n        filter(({ data: { message } }) => !!message),\n        map(({ data: { message } }) => parseMessage(message)),\n        filter(message => 'node' in message),\n        map(parseLog),\n        filter(log => !!log.impactTermId && !!log.blankNodeTermId && !isNaN(log.value) && log.value > 0),\n        groupBy(log => [log.impactTermId, log.blankNodeTermId, log.modelId].join('/')),\n        mergeMap(group => group.pipe(toArray())),\n        map((values: ILog[]) => {\n          const log = values[0];\n          const total = values.reduce((prev, curr) => prev + curr.value, 0);\n          const blankNodes = [\n            ...(this.impactAssessment()?.emissionsResourceUse ?? []),\n            ...(this.impactAssessment()?.impacts ?? [])\n          ].filter(v => v.term['@id'] === log.blankNodeTermId);\n\n          const inputs = blankNodes\n            .filter(v => v.inputs?.length)\n            .map(v => ({ name: v.inputs.map(i => i['@id']).join(';'), value: v.value * log.coefficient }));\n          const inputsValue = inputs.reduce((prev, curr) => prev + curr.value, 0);\n\n          const impact = this.impacts().find(v => v.term['@id'] === log.impactTermId);\n\n          // logs might exist but impact was not added => skip logs\n          return impact\n            ? {\n                ...log,\n                impactTermUnits: impact.term?.units,\n                value: total,\n                inputs,\n                inputsValue\n              }\n            : null;\n        }),\n        filter(log => !!log),\n        toArray(),\n        tap(() => this.loading.set(false))\n      )\n      .subscribe((logs: ILog[]) => this.allLogs.set(logs));\n\n    effect(\n      () => {\n        // make sure selected term exists\n        const terms = this.terms();\n        const selectedTermId = this.selectedTerm()?.['@id'];\n        if (!selectedTermId || !terms.find(term => term['@id'] === selectedTermId)) {\n          this.selectedTerm.set(terms[0]);\n        }\n      },\n      { allowSignalWrites: true }\n    );\n  }\n\n  protected selectTerm({ target: { value } }) {\n    const term = this.terms().find(term => term['@id'] === value);\n    this.selectedTerm.set(term);\n  }\n\n  protected selectMethod({ target: { value } }) {\n    const term = this.methods().find(term => term['@id'] === value);\n    this.selectedMethod.set(term);\n  }\n}\n","@if (loading()) {\n  <div class=\"has-text-center py-3\">\n    <fa-icon [icon]=\"faSpinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n  </div>\n} @else {\n  <div class=\"p-3\" [class.is-hidden]=\"!terms()?.length\">\n    <div class=\"columns\">\n      <div class=\"column\">\n        <div class=\"field has-addons\">\n          <div class=\"control\">\n            <span class=\"button is-small is-static is-secondary\">Select an Indicator</span>\n          </div>\n          @if (terms()?.length) {\n            <div class=\"control is-expanded\">\n              <div class=\"select is-fullwidth is-small is-secondary\">\n                <select (change)=\"selectTerm($event)\">\n                  @for (term of terms(); track term) {\n                    <option [value]=\"term['@id']\">{{ term.name }} ({{ term.units }})</option>\n                  }\n                </select>\n              </div>\n            </div>\n          }\n          @if (methods()?.length) {\n            <div class=\"control is-expanded\">\n              <div class=\"select is-fullwidth is-small is-secondary\">\n                <select (change)=\"selectMethod($event)\">\n                  <option [ngValue]=\"undefined\">Filter Model</option>\n                  @for (term of methods(); track term) {\n                    <option [value]=\"term['@id']\">{{ term.name }}</option>\n                  }\n                </select>\n              </div>\n            </div>\n          }\n        </div>\n      </div>\n      <div class=\"column is-narrow\">\n        <a\n          class=\"button is-ghost is-small\"\n          [href]=\"csvContent()\"\n          [download]=\"downloadFilename()\"\n          nbgTooltip=\"Download as CSV\"\n          placement=\"bottom\">\n          <fa-icon [icon]=\"faDownload\"></fa-icon>\n        </a>\n      </div>\n    </div>\n    @if (!selectedMethod()) {\n      <p class=\"is-size-7\">\n        <i>Selecting a Model is recommended to avoid duplicated entries.</i>\n      </p>\n    }\n  </div>\n}\n\n<div class=\"is-mt-1\">\n  @if (!loading() && noData()) {\n    <p class=\"has-text-centered\">\n      <span>No breakdown available for</span>\n      @if (selectedTerm()) {\n        <span class=\"is-pl-1\">{{ selectedTerm().name }}</span>\n      }\n      @if (selectedMethod()) {\n        <span class=\"is-pl-1\">({{ selectedMethod().name }})</span>\n      }\n      <span>.</span>\n    </p>\n  }\n  <he-chart class=\"is-relative\" [data]=\"chartData()\" [config]=\"chartConfig()\"></he-chart>\n</div>\n"]}
201
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"impact-assessments-indicator-breakdown-chart.component.js","sourceRoot":"","sources":["../../../../src/impact-assessments/impact-assessments-indicator-breakdown-chart/impact-assessments-indicator-breakdown-chart.component.ts","../../../../src/impact-assessments/impact-assessments-indicator-breakdown-chart/impact-assessments-indicator-breakdown-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, Signal, computed, effect, inject, input, signal } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { filter, groupBy, map, mergeAll, mergeMap, take, tap, toArray } from 'rxjs/operators';\nimport { ChartConfiguration, ChartData } from 'chart.js';\nimport ChartDataLabels from 'chartjs-plugin-datalabels';\nimport { DataState } from '@hestia-earth/api';\nimport { IImpactAssessmentJSONLD, Indicator, ITermJSONLD, NodeType, Term, TermTermType } from '@hestia-earth/schema';\nimport { toPrecision, unique } from '@hestia-earth/utils';\nimport { FormsModule } from '@angular/forms';\nimport { FaIconComponent } from '@fortawesome/angular-fontawesome';\nimport { faDownload, faSpinner } from '@fortawesome/free-solid-svg-icons';\nimport { of } from 'rxjs';\n\nimport { matchTermType, matchType } from '../../search/search.model';\nimport { HeSearchService } from '../../search/search.service';\nimport { HeNodeService } from '../../node/node.service';\nimport { distinctUntilChangedDeep } from '../../common/rxjs-utils';\nimport { Level, parseLines, parseMessage } from '../../common/logs-utils';\nimport { listColor } from '../../common/color';\nimport { ChartComponent } from '../../chart/chart.component';\n\ninterface ILog {\n  modelId: string;\n  impactTermId: string;\n  impactTermUnits?: string;\n  blankNodeTermId: string;\n  coefficient: number;\n  value: number;\n  // store all indicators with inputs\n  inputs?: {\n    name: string;\n    value: number;\n  }[];\n  inputsValue?: number;\n}\n\nconst parseLog = (data: any): ILog => ({\n  modelId: data.model,\n  impactTermId: data['key/term'] || data.term || data.indicator,\n  blankNodeTermId: data.node,\n  coefficient: +data.coefficient,\n  value: +data.value * +data.coefficient\n});\n\nconst filterTermTypes = [TermTermType.emission, TermTermType.characterisedIndicator];\n\nconst csvHeaders = [\n  'Impact',\n  'Impact Unit',\n  'Method',\n  'Emission',\n  'Value',\n  'Inputs',\n  'Inputs value',\n  'Functional Unit'\n];\n\nconst logToCsv = (logs: ILog[], impact: IImpactAssessmentJSONLD) =>\n  [\n    csvHeaders.join(','),\n    ...logs\n      .sort((a, b) => a.impactTermId.localeCompare(b.impactTermId))\n      .flatMap(({ impactTermId, impactTermUnits, modelId, blankNodeTermId, value, inputs }) => [\n        [impactTermId, impactTermUnits, modelId, blankNodeTermId, value, '', ''],\n        ...inputs.map(v => [impactTermId, impactTermUnits, modelId, blankNodeTermId, '', v.name, v.value])\n      ])\n      .map(v => [...v, impact.product?.term?.units].join(','))\n  ].join('\\n');\n\n@Component({\n  selector: 'he-impact-assessments-indicator-breakdown-chart',\n  templateUrl: './impact-assessments-indicator-breakdown-chart.component.html',\n  styleUrls: ['./impact-assessments-indicator-breakdown-chart.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [FaIconComponent, FormsModule, ChartComponent]\n})\nexport class ImpactAssessmentsIndicatorBreakdownChartComponent {\n  private domSanitizer = inject(DomSanitizer);\n  private searchService = inject(HeSearchService);\n  private nodeService = inject(HeNodeService);\n\n  protected readonly faSpinner = faSpinner;\n  protected readonly faDownload = faDownload;\n\n  protected impactAssessment = input(undefined as IImpactAssessmentJSONLD);\n  private impactAssessment$ = toObservable(this.impactAssessment);\n\n  protected indicators = input([] as Indicator[]);\n\n  private allLogs = signal([] as ILog[]);\n  private logs = computed(() =>\n    this.allLogs()\n      .filter(\n        ({ impactTermId, modelId }) =>\n          impactTermId === this.selectedTerm()?.['@id'] &&\n          (!this.selectedMethod() || modelId === this.selectedMethod()?.['@id'])\n      )\n      .sort((a, b) => b.value - a.value)\n  );\n\n  private emissions = toSignal(\n    this.searchService\n      .search$<ITermJSONLD, NodeType.Term>({\n        fields: ['@type', '@id', 'name'],\n        limit: 1000,\n        query: {\n          bool: {\n            must: [matchType(NodeType.Term)],\n            should: filterTermTypes.map(termType => matchTermType(termType)),\n            minimum_should_match: 1\n          }\n        }\n      })\n      .pipe(map(({ results }) => results))\n  );\n\n  protected loading = signal(true);\n\n  protected selectedTerm = signal(undefined as Term);\n  protected terms = computed(() =>\n    unique(\n      (this.indicators() || [])\n        .map(({ term }) => term!)\n        .filter(Boolean)\n        .sort((a, b) => a.name.localeCompare(b.name))\n    )\n  );\n\n  protected selectedMethod = signal(undefined as Term);\n  protected methods = computed(() =>\n    unique((this.indicators() || []).map(({ methodModel }) => methodModel!).filter(Boolean))\n  );\n\n  private impacts = computed(() => [\n    ...(this.impactAssessment()?.impacts || []),\n    ...(this.impactAssessment()?.endpoints || [])\n  ]);\n  protected noData = computed(() => this.logs()?.length === 0);\n\n  protected csvContent = computed(() =>\n    this.domSanitizer.bypassSecurityTrustResourceUrl(\n      `data:text/html;charset=utf-8,${encodeURIComponent(logToCsv(this.logs(), this.impactAssessment()))}`\n    )\n  );\n  private id = computed(() => this.impactAssessment()?.['@id'] || (this.impactAssessment() as any)?.id);\n  protected downloadFilename = computed(() => `${this.id()}-logs.csv`);\n\n  private total = computed(() => this.logs().reduce((prev, curr) => prev + curr.value, 0));\n  private labels = computed(() =>\n    this.logs().map(\n      ({ blankNodeTermId }) => this.emissions()?.find(v => v['@id'] === blankNodeTermId)?.name || blankNodeTermId\n    )\n  );\n  private datasets = computed(() => [\n    {\n      label: this.selectedTerm()?.name ?? '',\n      data: this.logs().map(({ value }) => value),\n      backgroundColor: this.logs().map(listColor),\n      borderColor: this.logs().map(listColor)\n    }\n  ]);\n\n  protected chartData: Signal<ChartData> = computed(() => ({\n    datasets: this.datasets(),\n    labels: this.labels()\n  }));\n  protected chartConfig: Signal<Partial<ChartConfiguration>> = computed(() => ({\n    type: 'horizontalBar',\n    plugins: [ChartDataLabels],\n    options: {\n      plugins: {\n        datalabels: {\n          color: 'black',\n          formatter: value => {\n            const ratio = toPrecision((value * 100) / this.total(), 2);\n            return value > 0 ? `${toPrecision(value, 3)} (${ratio}%)` : '';\n          },\n          align: 'end'\n        }\n      },\n      responsive: true,\n      maintainAspectRatio: false,\n      legend: {\n        display: false\n      },\n      tooltips: {\n        enabled: false,\n        callbacks: {\n          title: (tooltipItems, data) => data.datasets![tooltipItems[0].datasetIndex!]?.label || '',\n          label: tooltipItem => {\n            const value = +(tooltipItem.value || '0');\n            const ratio = toPrecision((value * 100) / this.total(), 2);\n            return value > 0 ? `${toPrecision(value, 3)} (${ratio}%)` : '';\n          }\n        }\n      },\n      scales: {\n        xAxes: [\n          {\n            display: true\n          }\n        ],\n        yAxes: [\n          {\n            position: 'left'\n          }\n        ]\n      }\n    }\n  }));\n\n  constructor() {\n    this.impactAssessment$\n      .pipe(\n        filter(v => !!v),\n        distinctUntilChangedDeep(),\n        take(1),\n        tap(() => this.loading.set(true)),\n        mergeMap(node => (node ? this.nodeService.getLog({ ...node, dataState: DataState.recalculated }) : of(''))),\n        map(value => (value ? parseLines(value) : [])),\n        mergeAll(),\n        filter(({ data }) => data.logger === 'hestia_earth.models' && data.level === Level.debug),\n        filter(({ data: { message } }) => !!message),\n        map(({ data: { message } }) => parseMessage(message)),\n        filter(message => 'node' in message),\n        map(parseLog),\n        filter(log => !!log.impactTermId && !!log.blankNodeTermId && !isNaN(log.value) && log.value > 0),\n        groupBy(log => [log.impactTermId, log.blankNodeTermId, log.modelId].join('/')),\n        mergeMap(group => group.pipe(toArray())),\n        map((values: ILog[]) => {\n          const log = values[0];\n          const total = values.reduce((prev, curr) => prev + curr.value, 0);\n          const blankNodes = [\n            ...(this.impactAssessment()?.emissionsResourceUse ?? []),\n            ...(this.impactAssessment()?.impacts ?? [])\n          ].filter(v => v.term['@id'] === log.blankNodeTermId);\n\n          const inputs = blankNodes\n            .filter(v => v.inputs?.length)\n            .map(v => ({ name: v.inputs.map(i => i['@id']).join(';'), value: v.value * log.coefficient }));\n          const inputsValue = inputs.reduce((prev, curr) => prev + curr.value, 0);\n\n          const impact = this.impacts().find(v => v.term['@id'] === log.impactTermId);\n\n          // logs might exist but impact was not added => skip logs\n          return impact\n            ? {\n                ...log,\n                impactTermUnits: impact.term?.units,\n                value: total,\n                inputs,\n                inputsValue\n              }\n            : null;\n        }),\n        filter(log => !!log),\n        toArray(),\n        tap(() => this.loading.set(false))\n      )\n      .subscribe((logs: ILog[]) => this.allLogs.set(logs));\n\n    effect(\n      () => {\n        // make sure selected term exists\n        const terms = this.terms();\n        const selectedTermId = this.selectedTerm()?.['@id'];\n        if (!selectedTermId || !terms.find(term => term['@id'] === selectedTermId)) {\n          this.selectedTerm.set(terms[0]);\n        }\n      },\n      { allowSignalWrites: true }\n    );\n  }\n\n  protected selectTerm({ target: { value } }) {\n    const term = this.terms().find(term => term['@id'] === value);\n    this.selectedTerm.set(term);\n  }\n\n  protected selectMethod({ target: { value } }) {\n    const term = this.methods().find(term => term['@id'] === value);\n    this.selectedMethod.set(term);\n  }\n}\n","@if (loading()) {\n  <div class=\"has-text-center py-3\">\n    <fa-icon [icon]=\"faSpinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n  </div>\n} @else {\n  <div class=\"p-3\" [class.is-hidden]=\"!terms()?.length\">\n    <div class=\"columns\">\n      <div class=\"column\">\n        <div class=\"field has-addons\">\n          <div class=\"control\">\n            <span class=\"button is-small is-static is-secondary\">Select an Indicator</span>\n          </div>\n          @if (terms()?.length) {\n            <div class=\"control is-expanded\">\n              <div class=\"select is-fullwidth is-small is-secondary\">\n                <select (change)=\"selectTerm($event)\">\n                  @for (term of terms(); track term) {\n                    <option [value]=\"term['@id']\">{{ term.name }} ({{ term.units }})</option>\n                  }\n                </select>\n              </div>\n            </div>\n          }\n          @if (methods()?.length) {\n            <div class=\"control is-expanded\">\n              <div class=\"select is-fullwidth is-small is-secondary\">\n                <select (change)=\"selectMethod($event)\">\n                  <option [ngValue]=\"undefined\">Filter Model</option>\n                  @for (term of methods(); track term) {\n                    <option [value]=\"term['@id']\">{{ term.name }}</option>\n                  }\n                </select>\n              </div>\n            </div>\n          }\n        </div>\n      </div>\n      <div class=\"column is-narrow\">\n        <a\n          class=\"button is-ghost is-small\"\n          [href]=\"csvContent()\"\n          [download]=\"downloadFilename()\"\n          ngbTooltip=\"Download as CSV\"\n          placement=\"bottom\">\n          <fa-icon [icon]=\"faDownload\"></fa-icon>\n        </a>\n      </div>\n    </div>\n    @if (!selectedMethod()) {\n      <p class=\"is-size-7\">\n        <i>Selecting a Model is recommended to avoid duplicated entries.</i>\n      </p>\n    }\n  </div>\n}\n\n<div class=\"is-mt-1\">\n  @if (!loading() && noData()) {\n    <p class=\"has-text-centered\">\n      <span>No breakdown available for</span>\n      @if (selectedTerm()) {\n        <span class=\"is-pl-1\">{{ selectedTerm().name }}</span>\n      }\n      @if (selectedMethod()) {\n        <span class=\"is-pl-1\">({{ selectedMethod().name }})</span>\n      }\n      <span>.</span>\n    </p>\n  }\n  <he-chart class=\"is-relative\" [data]=\"chartData()\" [config]=\"chartConfig()\"></he-chart>\n</div>\n"]}