@hestia-earth/ui-components 0.0.1
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.
- package/README.md +24 -0
- package/auth/auth.service.d.ts +10 -0
- package/auth/public-api.d.ts +1 -0
- package/bibliographies/bibliographies-search-confirm/bibliographies-search-confirm.component.d.ts +40 -0
- package/bibliographies/bibliographies.module.d.ts +10 -0
- package/bibliographies/public-api.d.ts +2 -0
- package/bundles/hestia-earth-ui-components.umd.js +7570 -0
- package/bundles/hestia-earth-ui-components.umd.js.map +1 -0
- package/common/bind-once.directive.d.ts +10 -0
- package/common/blank-node-diffs/blank-node-diffs.component.d.ts +18 -0
- package/common/blank-node-state/blank-node-state.component.d.ts +36 -0
- package/common/blank-node-state-notice/blank-node-state-notice.component.d.ts +9 -0
- package/common/blank-node-value-delta/blank-node-value-delta.component.d.ts +13 -0
- package/common/click-outside.directive.d.ts +10 -0
- package/common/clipboard/clipboard.component.d.ts +16 -0
- package/common/common.module.d.ts +37 -0
- package/common/common.service.d.ts +11 -0
- package/common/default.pipe.d.ts +7 -0
- package/common/ellipsis.pipe.d.ts +7 -0
- package/common/get.pipe.d.ts +7 -0
- package/common/key-to-label.pipe.d.ts +7 -0
- package/common/keys.pipe.d.ts +7 -0
- package/common/link-key-value/link-key-value.component.d.ts +16 -0
- package/common/logs-utils.d.ts +17 -0
- package/common/maps-drawing-confirm/maps-drawing-confirm.component.d.ts +28 -0
- package/common/maps-utils.d.ts +70 -0
- package/common/pluralize.pipe.d.ts +7 -0
- package/common/popover/popover.component.d.ts +16 -0
- package/common/popover-confirm/popover-confirm.component.d.ts +15 -0
- package/common/precision.pipe.d.ts +7 -0
- package/common/public-api.d.ts +30 -0
- package/common/schema-version-link/schema-version-link.component.d.ts +10 -0
- package/common/skeleton-text/skeleton-text.component.d.ts +11 -0
- package/common/social-tags/social-tags.component.d.ts +12 -0
- package/common/tags-input.directive.d.ts +20 -0
- package/common/times.pipe.d.ts +7 -0
- package/common/toast/toast.component.d.ts +19 -0
- package/common/toast.service.d.ts +16 -0
- package/common/unit-converter/unit-converter.component.d.ts +25 -0
- package/common/utils.d.ts +88 -0
- package/cycles/cycles-activity/cycles-activity.component.d.ts +31 -0
- package/cycles/cycles-activity-logs/cycles-activity-logs.component.d.ts +25 -0
- package/cycles/cycles-completeness/cycles-completeness.component.d.ts +14 -0
- package/cycles/cycles-emissions/cycles-emissions.component.d.ts +40 -0
- package/cycles/cycles-emissions-chart/cycles-emissions-chart.component.d.ts +18 -0
- package/cycles/cycles-emissions-logs/cycles-emissions-logs.component.d.ts +23 -0
- package/cycles/cycles-functional-unit-measure/cycles-functional-unit-measure.component.d.ts +8 -0
- package/cycles/cycles-result/cycles-result.component.d.ts +13 -0
- package/cycles/cycles-suggest-form/cycles-suggest-form.component.d.ts +24 -0
- package/cycles/cycles.model.d.ts +7 -0
- package/cycles/cycles.module.d.ts +19 -0
- package/cycles/public-api.d.ts +10 -0
- package/engine/aggregation-engine.service.d.ts +71 -0
- package/engine/engine.service.d.ts +61 -0
- package/engine/public-api.d.ts +2 -0
- package/esm2015/auth/auth.service.js +19 -0
- package/esm2015/auth/public-api.js +2 -0
- package/esm2015/bibliographies/bibliographies-search-confirm/bibliographies-search-confirm.component.js +100 -0
- package/esm2015/bibliographies/bibliographies.module.js +30 -0
- package/esm2015/bibliographies/public-api.js +3 -0
- package/esm2015/common/bind-once.directive.js +23 -0
- package/esm2015/common/blank-node-diffs/blank-node-diffs.component.js +47 -0
- package/esm2015/common/blank-node-state/blank-node-state.component.js +90 -0
- package/esm2015/common/blank-node-state-notice/blank-node-state-notice.component.js +27 -0
- package/esm2015/common/blank-node-value-delta/blank-node-value-delta.component.js +41 -0
- package/esm2015/common/click-outside.directive.js +28 -0
- package/esm2015/common/clipboard/clipboard.component.js +69 -0
- package/esm2015/common/common.module.js +144 -0
- package/esm2015/common/common.service.js +29 -0
- package/esm2015/common/default.pipe.js +23 -0
- package/esm2015/common/ellipsis.pipe.js +17 -0
- package/esm2015/common/get.pipe.js +17 -0
- package/esm2015/common/key-to-label.pipe.js +18 -0
- package/esm2015/common/keys.pipe.js +20 -0
- package/esm2015/common/link-key-value/link-key-value.component.js +55 -0
- package/esm2015/common/logs-utils.js +49 -0
- package/esm2015/common/maps-drawing-confirm/maps-drawing-confirm.component.js +89 -0
- package/esm2015/common/maps-utils.js +101 -0
- package/esm2015/common/pluralize.pipe.js +17 -0
- package/esm2015/common/popover/popover.component.js +37 -0
- package/esm2015/common/popover-confirm/popover-confirm.component.js +38 -0
- package/esm2015/common/precision.pipe.js +20 -0
- package/esm2015/common/public-api.js +31 -0
- package/esm2015/common/schema-version-link/schema-version-link.component.js +39 -0
- package/esm2015/common/skeleton-text/skeleton-text.component.js +44 -0
- package/esm2015/common/social-tags/social-tags.component.js +37 -0
- package/esm2015/common/tags-input.directive.js +74 -0
- package/esm2015/common/times.pipe.js +16 -0
- package/esm2015/common/toast/toast.component.js +37 -0
- package/esm2015/common/toast.service.js +36 -0
- package/esm2015/common/unit-converter/unit-converter.component.js +73 -0
- package/esm2015/common/utils.js +245 -0
- package/esm2015/cycles/cycles-activity/cycles-activity.component.js +92 -0
- package/esm2015/cycles/cycles-activity-logs/cycles-activity-logs.component.js +48 -0
- package/esm2015/cycles/cycles-completeness/cycles-completeness.component.js +41 -0
- package/esm2015/cycles/cycles-emissions/cycles-emissions.component.js +121 -0
- package/esm2015/cycles/cycles-emissions-chart/cycles-emissions-chart.component.js +93 -0
- package/esm2015/cycles/cycles-emissions-logs/cycles-emissions-logs.component.js +63 -0
- package/esm2015/cycles/cycles-functional-unit-measure/cycles-functional-unit-measure.component.js +22 -0
- package/esm2015/cycles/cycles-result/cycles-result.component.js +92 -0
- package/esm2015/cycles/cycles-suggest-form/cycles-suggest-form.component.js +83 -0
- package/esm2015/cycles/cycles.model.js +2 -0
- package/esm2015/cycles/cycles.module.js +66 -0
- package/esm2015/cycles/public-api.js +11 -0
- package/esm2015/engine/aggregation-engine.service.js +126 -0
- package/esm2015/engine/engine.service.js +78 -0
- package/esm2015/engine/public-api.js +3 -0
- package/esm2015/files/files-error.model.js +180 -0
- package/esm2015/files/files-form/files-form.component.js +439 -0
- package/esm2015/files/files-form.model.js +548 -0
- package/esm2015/files/files.module.js +42 -0
- package/esm2015/files/public-api.js +3 -0
- package/esm2015/fontawesome/fontawesome.module.js +36 -0
- package/esm2015/fontawesome/public-api.js +2 -0
- package/esm2015/hestia-earth-ui-components.js +5 -0
- package/esm2015/impact-assessments/impact-assessments-indicator-breakdown-chart/impact-assessments-indicator-breakdown-chart.component.js +161 -0
- package/esm2015/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.js +142 -0
- package/esm2015/impact-assessments/impact-assessments-products/impact-assessments-products.component.js +252 -0
- package/esm2015/impact-assessments/impact-assessments-products-logs/impact-assessments-products-logs.component.js +68 -0
- package/esm2015/impact-assessments/impact-assessments.model.js +2 -0
- package/esm2015/impact-assessments/impact-assessments.module.js +47 -0
- package/esm2015/impact-assessments/public-api.js +7 -0
- package/esm2015/mendeley/mendeley.service.js +35 -0
- package/esm2015/mendeley/public-api.js +2 -0
- package/esm2015/node/node-csv-export-confirm/node-csv-export-confirm.component.js +65 -0
- package/esm2015/node/node-csv-select-headers/node-csv-select-headers.component.js +119 -0
- package/esm2015/node/node-csv.service.js +24 -0
- package/esm2015/node/node-diffs/node-diffs.component.js +67 -0
- package/esm2015/node/node-diffs/node-diffs.model.js +6 -0
- package/esm2015/node/node-icon/node-icon.component.js +37 -0
- package/esm2015/node/node-link/node-link.component.js +33 -0
- package/esm2015/node/node-logs-file/node-logs-file.component.js +63 -0
- package/esm2015/node/node-logs-models/node-logs-models.component.js +188 -0
- package/esm2015/node/node-missing-lookup-factors/node-missing-lookup-factors.component.js +34 -0
- package/esm2015/node/node-value-details/node-value-details.component.js +46 -0
- package/esm2015/node/node.module.js +67 -0
- package/esm2015/node/node.service.js +113 -0
- package/esm2015/node/public-api.js +13 -0
- package/esm2015/public-api.js +16 -0
- package/esm2015/schema/public-api.js +2 -0
- package/esm2015/schema/schema.service.js +167 -0
- package/esm2015/search/public-api.js +4 -0
- package/esm2015/search/search.model.js +204 -0
- package/esm2015/search/search.module.js +13 -0
- package/esm2015/search/search.service.js +99 -0
- package/esm2015/sites/public-api.js +6 -0
- package/esm2015/sites/sites-maps/sites-maps.component.js +162 -0
- package/esm2015/sites/sites-measurements/sites-measurements.component.js +78 -0
- package/esm2015/sites/sites-measurements-logs/sites-measurements-logs.component.js +63 -0
- package/esm2015/sites/sites.model.js +10 -0
- package/esm2015/sites/sites.module.js +42 -0
- package/esm2015/terms/public-api.js +2 -0
- package/esm2015/terms/terms.model.js +184 -0
- package/esm2015/users/public-api.js +2 -0
- package/esm2015/users/users.service.js +17 -0
- package/fesm2015/hestia-earth-ui-components.js +5920 -0
- package/fesm2015/hestia-earth-ui-components.js.map +1 -0
- package/files/files-error.model.d.ts +40 -0
- package/files/files-form/files-form.component.d.ts +94 -0
- package/files/files-form.model.d.ts +113 -0
- package/files/files.module.d.ts +13 -0
- package/files/public-api.d.ts +2 -0
- package/fontawesome/fontawesome.module.d.ts +10 -0
- package/fontawesome/public-api.d.ts +1 -0
- package/hestia-earth-ui-components.d.ts +5 -0
- package/impact-assessments/impact-assessments-indicator-breakdown-chart/impact-assessments-indicator-breakdown-chart.component.d.ts +28 -0
- package/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.d.ts +25 -0
- package/impact-assessments/impact-assessments-products/impact-assessments-products.component.d.ts +77 -0
- package/impact-assessments/impact-assessments-products-logs/impact-assessments-products-logs.component.d.ts +25 -0
- package/impact-assessments/impact-assessments.model.d.ts +6 -0
- package/impact-assessments/impact-assessments.module.d.ts +15 -0
- package/impact-assessments/public-api.d.ts +6 -0
- package/mendeley/mendeley.service.d.ts +25 -0
- package/mendeley/public-api.d.ts +1 -0
- package/node/node-csv-export-confirm/node-csv-export-confirm.component.d.ts +32 -0
- package/node/node-csv-select-headers/node-csv-select-headers.component.d.ts +42 -0
- package/node/node-csv.service.d.ts +9 -0
- package/node/node-diffs/node-diffs.component.d.ts +23 -0
- package/node/node-diffs/node-diffs.model.d.ts +4 -0
- package/node/node-icon/node-icon.component.d.ts +8 -0
- package/node/node-link/node-link.component.d.ts +11 -0
- package/node/node-logs-file/node-logs-file.component.d.ts +31 -0
- package/node/node-logs-models/node-logs-models.component.d.ts +72 -0
- package/node/node-missing-lookup-factors/node-missing-lookup-factors.component.d.ts +14 -0
- package/node/node-value-details/node-value-details.component.d.ts +17 -0
- package/node/node.module.d.ts +20 -0
- package/node/node.service.d.ts +70 -0
- package/node/public-api.d.ts +12 -0
- package/package.json +53 -0
- package/public-api.d.ts +15 -0
- package/schema/public-api.d.ts +1 -0
- package/schema/schema.service.d.ts +51 -0
- package/search/public-api.d.ts +3 -0
- package/search/search.model.d.ts +243 -0
- package/search/search.module.d.ts +7 -0
- package/search/search.service.d.ts +129 -0
- package/sites/public-api.d.ts +5 -0
- package/sites/sites-maps/sites-maps.component.d.ts +35 -0
- package/sites/sites-measurements/sites-measurements.component.d.ts +31 -0
- package/sites/sites-measurements-logs/sites-measurements-logs.component.d.ts +23 -0
- package/sites/sites.model.d.ts +10 -0
- package/sites/sites.module.d.ts +13 -0
- package/styles.scss +197 -0
- package/terms/public-api.d.ts +1 -0
- package/terms/terms.model.d.ts +21 -0
- package/users/public-api.d.ts +1 -0
- package/users/users.service.d.ts +7 -0
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { HeCommonModule } from '../common/common.module';
|
|
5
|
+
import { HeNodeModule } from '../node/node.module';
|
|
6
|
+
import { HeBibliographiesModule } from '../bibliographies/bibliographies.module';
|
|
7
|
+
import { HeSitesModule } from '../sites/sites.module';
|
|
8
|
+
import { FilesFormComponent } from './files-form/files-form.component';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
const components = [
|
|
11
|
+
FilesFormComponent
|
|
12
|
+
];
|
|
13
|
+
export class HeFilesModule {
|
|
14
|
+
}
|
|
15
|
+
HeFilesModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HeFilesModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
16
|
+
HeFilesModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HeFilesModule, declarations: [FilesFormComponent], imports: [CommonModule, FormsModule,
|
|
17
|
+
HeCommonModule,
|
|
18
|
+
HeNodeModule,
|
|
19
|
+
HeBibliographiesModule,
|
|
20
|
+
HeSitesModule], exports: [FilesFormComponent] });
|
|
21
|
+
HeFilesModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HeFilesModule, imports: [[
|
|
22
|
+
CommonModule, FormsModule,
|
|
23
|
+
HeCommonModule,
|
|
24
|
+
HeNodeModule,
|
|
25
|
+
HeBibliographiesModule,
|
|
26
|
+
HeSitesModule
|
|
27
|
+
]] });
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HeFilesModule, decorators: [{
|
|
29
|
+
type: NgModule,
|
|
30
|
+
args: [{
|
|
31
|
+
declarations: components,
|
|
32
|
+
exports: components,
|
|
33
|
+
imports: [
|
|
34
|
+
CommonModule, FormsModule,
|
|
35
|
+
HeCommonModule,
|
|
36
|
+
HeNodeModule,
|
|
37
|
+
HeBibliographiesModule,
|
|
38
|
+
HeSitesModule
|
|
39
|
+
]
|
|
40
|
+
}]
|
|
41
|
+
}] });
|
|
42
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZXMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2ZpbGVzL2ZpbGVzLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFN0MsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNqRixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFdEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7O0FBRXZFLE1BQU0sVUFBVSxHQUFHO0lBQ2pCLGtCQUFrQjtDQUNuQixDQUFDO0FBYUYsTUFBTSxPQUFPLGFBQWE7OzJHQUFiLGFBQWE7NEdBQWIsYUFBYSxpQkFkeEIsa0JBQWtCLGFBT2hCLFlBQVksRUFBRSxXQUFXO1FBQ3pCLGNBQWM7UUFDZCxZQUFZO1FBQ1osc0JBQXNCO1FBQ3RCLGFBQWEsYUFYZixrQkFBa0I7NEdBY1AsYUFBYSxZQVJmO1lBQ1AsWUFBWSxFQUFFLFdBQVc7WUFDekIsY0FBYztZQUNkLFlBQVk7WUFDWixzQkFBc0I7WUFDdEIsYUFBYTtTQUNkOzRGQUVVLGFBQWE7a0JBWHpCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFLFVBQVU7b0JBQ3hCLE9BQU8sRUFBRSxVQUFVO29CQUNuQixPQUFPLEVBQUU7d0JBQ1AsWUFBWSxFQUFFLFdBQVc7d0JBQ3pCLGNBQWM7d0JBQ2QsWUFBWTt3QkFDWixzQkFBc0I7d0JBQ3RCLGFBQWE7cUJBQ2Q7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5pbXBvcnQgeyBIZUNvbW1vbk1vZHVsZSB9IGZyb20gJy4uL2NvbW1vbi9jb21tb24ubW9kdWxlJztcbmltcG9ydCB7IEhlTm9kZU1vZHVsZSB9IGZyb20gJy4uL25vZGUvbm9kZS5tb2R1bGUnO1xuaW1wb3J0IHsgSGVCaWJsaW9ncmFwaGllc01vZHVsZSB9IGZyb20gJy4uL2JpYmxpb2dyYXBoaWVzL2JpYmxpb2dyYXBoaWVzLm1vZHVsZSc7XG5pbXBvcnQgeyBIZVNpdGVzTW9kdWxlIH0gZnJvbSAnLi4vc2l0ZXMvc2l0ZXMubW9kdWxlJztcblxuaW1wb3J0IHsgRmlsZXNGb3JtQ29tcG9uZW50IH0gZnJvbSAnLi9maWxlcy1mb3JtL2ZpbGVzLWZvcm0uY29tcG9uZW50JztcblxuY29uc3QgY29tcG9uZW50cyA9IFtcbiAgRmlsZXNGb3JtQ29tcG9uZW50XG5dO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IGNvbXBvbmVudHMsXG4gIGV4cG9ydHM6IGNvbXBvbmVudHMsXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsIEZvcm1zTW9kdWxlLFxuICAgIEhlQ29tbW9uTW9kdWxlLFxuICAgIEhlTm9kZU1vZHVsZSxcbiAgICBIZUJpYmxpb2dyYXBoaWVzTW9kdWxlLFxuICAgIEhlU2l0ZXNNb2R1bGVcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBIZUZpbGVzTW9kdWxlIHsgfVxuIl19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './files.module';
|
|
2
|
+
export { FilesFormComponent } from './files-form/files-form.component';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9maWxlcy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsZ0JBQWdCLENBQUM7QUFFL0IsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sbUNBQW1DLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2ZpbGVzLm1vZHVsZSc7XG5cbmV4cG9ydCB7IEZpbGVzRm9ybUNvbXBvbmVudCB9IGZyb20gJy4vZmlsZXMtZm9ybS9maWxlcy1mb3JtLmNvbXBvbmVudCc7XG4iXX0=
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { FontAwesomeModule } from '@fortawesome/angular-fontawesome';
|
|
4
|
+
import { faClone as farClone, faCircle as farCircle, faIdBadge as farIdBadge } from '@fortawesome/free-regular-svg-icons';
|
|
5
|
+
import { faAngleDoubleLeft, faAngleDoubleRight, faAngleDown, faAngleLeft, faAngleRight, faBookOpen, faBuilding, faCalculator, faChartBar, faCheck, faClipboard, faClipboardList, faClone, faComments, faDownload, faDrawPolygon, faEdit, faExclamationTriangle, faExternalLinkAlt, faFilter, faList, faLongArrowAltDown, faLongArrowAltUp, faLongArrowAltLeft, faLongArrowAltRight, faMap, faMapMarked, faMapMarkedAlt, faPlus, faPlusCircle, faSearch, faSeedling, faSpellCheck, faSpinner, faTimes, faUser } from '@fortawesome/free-solid-svg-icons';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@fortawesome/angular-fontawesome";
|
|
8
|
+
export class HeFontawesomeModule {
|
|
9
|
+
constructor(library) {
|
|
10
|
+
library.addIcons(
|
|
11
|
+
// free-regular
|
|
12
|
+
farClone, farCircle, farIdBadge,
|
|
13
|
+
// free-solid
|
|
14
|
+
faAngleDoubleLeft, faAngleDoubleRight, faAngleDown, faAngleLeft, faAngleRight, faBookOpen, faBuilding, faCalculator, faChartBar, faCheck, faClipboard, faClipboardList, faClone, faComments, faDownload, faDrawPolygon, faEdit, faExclamationTriangle, faExternalLinkAlt, faFilter, faList, faLongArrowAltDown, faLongArrowAltUp, faLongArrowAltLeft, faLongArrowAltRight, faMap, faMapMarked, faMapMarkedAlt, faPlus, faPlusCircle, faSearch, faSeedling, faSpellCheck, faSpinner, faTimes, faUser);
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
HeFontawesomeModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HeFontawesomeModule, deps: [{ token: i1.FaIconLibrary }], target: i0.ɵɵFactoryTarget.NgModule });
|
|
18
|
+
HeFontawesomeModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HeFontawesomeModule, imports: [CommonModule,
|
|
19
|
+
FontAwesomeModule], exports: [FontAwesomeModule] });
|
|
20
|
+
HeFontawesomeModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HeFontawesomeModule, imports: [[
|
|
21
|
+
CommonModule,
|
|
22
|
+
FontAwesomeModule
|
|
23
|
+
], FontAwesomeModule] });
|
|
24
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HeFontawesomeModule, decorators: [{
|
|
25
|
+
type: NgModule,
|
|
26
|
+
args: [{
|
|
27
|
+
imports: [
|
|
28
|
+
CommonModule,
|
|
29
|
+
FontAwesomeModule
|
|
30
|
+
],
|
|
31
|
+
exports: [
|
|
32
|
+
FontAwesomeModule
|
|
33
|
+
]
|
|
34
|
+
}]
|
|
35
|
+
}], ctorParameters: function () { return [{ type: i1.FaIconLibrary }]; } });
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9udGF3ZXNvbWUubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2ZvbnRhd2Vzb21lL2ZvbnRhd2Vzb21lLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsaUJBQWlCLEVBQWlCLE1BQU0sa0NBQWtDLENBQUM7QUFDcEYsT0FBTyxFQUNMLE9BQU8sSUFBSSxRQUFRLEVBQ25CLFFBQVEsSUFBSSxTQUFTLEVBQ3JCLFNBQVMsSUFBSSxVQUFVLEVBQ3hCLE1BQU0scUNBQXFDLENBQUM7QUFDN0MsT0FBTyxFQUNMLGlCQUFpQixFQUNqQixrQkFBa0IsRUFDbEIsV0FBVyxFQUNYLFdBQVcsRUFDWCxZQUFZLEVBQ1osVUFBVSxFQUNWLFVBQVUsRUFDVixZQUFZLEVBQ1osVUFBVSxFQUNWLE9BQU8sRUFDUCxXQUFXLEVBQ1gsZUFBZSxFQUNmLE9BQU8sRUFDUCxVQUFVLEVBQ1YsVUFBVSxFQUNWLGFBQWEsRUFDYixNQUFNLEVBQ04scUJBQXFCLEVBQ3JCLGlCQUFpQixFQUNqQixRQUFRLEVBQ1IsTUFBTSxFQUNOLGtCQUFrQixFQUNsQixnQkFBZ0IsRUFDaEIsa0JBQWtCLEVBQ2xCLG1CQUFtQixFQUNuQixLQUFLLEVBQ0wsV0FBVyxFQUNYLGNBQWMsRUFDZCxNQUFNLEVBQ04sWUFBWSxFQUNaLFFBQVEsRUFDUixVQUFVLEVBQ1YsWUFBWSxFQUNaLFNBQVMsRUFDVCxPQUFPLEVBQ1AsTUFBTSxFQUNQLE1BQU0sbUNBQW1DLENBQUM7OztBQVczQyxNQUFNLE9BQU8sbUJBQW1CO0lBQzlCLFlBQVksT0FBc0I7UUFDaEMsT0FBTyxDQUFDLFFBQVE7UUFDZCxlQUFlO1FBQ2YsUUFBUSxFQUNSLFNBQVMsRUFDVCxVQUFVO1FBQ1YsYUFBYTtRQUNiLGlCQUFpQixFQUNqQixrQkFBa0IsRUFDbEIsV0FBVyxFQUNYLFdBQVcsRUFDWCxZQUFZLEVBQ1osVUFBVSxFQUNWLFVBQVUsRUFDVixZQUFZLEVBQ1osVUFBVSxFQUNWLE9BQU8sRUFDUCxXQUFXLEVBQ1gsZUFBZSxFQUNmLE9BQU8sRUFDUCxVQUFVLEVBQ1YsVUFBVSxFQUNWLGFBQWEsRUFDYixNQUFNLEVBQ04scUJBQXFCLEVBQ3JCLGlCQUFpQixFQUNqQixRQUFRLEVBQ1IsTUFBTSxFQUNOLGtCQUFrQixFQUNsQixnQkFBZ0IsRUFDaEIsa0JBQWtCLEVBQ2xCLG1CQUFtQixFQUNuQixLQUFLLEVBQ0wsV0FBVyxFQUNYLGNBQWMsRUFDZCxNQUFNLEVBQ04sWUFBWSxFQUNaLFFBQVEsRUFDUixVQUFVLEVBQ1YsWUFBWSxFQUNaLFNBQVMsRUFDVCxPQUFPLEVBQ1AsTUFBTSxDQUNQLENBQUM7SUFDSixDQUFDOztpSEE3Q1UsbUJBQW1CO2tIQUFuQixtQkFBbUIsWUFQNUIsWUFBWTtRQUNaLGlCQUFpQixhQUdqQixpQkFBaUI7a0hBR1IsbUJBQW1CLFlBUnJCO1lBQ1AsWUFBWTtZQUNaLGlCQUFpQjtTQUNsQixFQUVDLGlCQUFpQjs0RkFHUixtQkFBbUI7a0JBVC9CLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osaUJBQWlCO3FCQUNsQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsaUJBQWlCO3FCQUNsQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRm9udEF3ZXNvbWVNb2R1bGUsIEZhSWNvbkxpYnJhcnkgfSBmcm9tICdAZm9ydGF3ZXNvbWUvYW5ndWxhci1mb250YXdlc29tZSc7XG5pbXBvcnQge1xuICBmYUNsb25lIGFzIGZhckNsb25lLFxuICBmYUNpcmNsZSBhcyBmYXJDaXJjbGUsXG4gIGZhSWRCYWRnZSBhcyBmYXJJZEJhZGdlXG59IGZyb20gJ0Bmb3J0YXdlc29tZS9mcmVlLXJlZ3VsYXItc3ZnLWljb25zJztcbmltcG9ydCB7XG4gIGZhQW5nbGVEb3VibGVMZWZ0LFxuICBmYUFuZ2xlRG91YmxlUmlnaHQsXG4gIGZhQW5nbGVEb3duLFxuICBmYUFuZ2xlTGVmdCxcbiAgZmFBbmdsZVJpZ2h0LFxuICBmYUJvb2tPcGVuLFxuICBmYUJ1aWxkaW5nLFxuICBmYUNhbGN1bGF0b3IsXG4gIGZhQ2hhcnRCYXIsXG4gIGZhQ2hlY2ssXG4gIGZhQ2xpcGJvYXJkLFxuICBmYUNsaXBib2FyZExpc3QsXG4gIGZhQ2xvbmUsXG4gIGZhQ29tbWVudHMsXG4gIGZhRG93bmxvYWQsXG4gIGZhRHJhd1BvbHlnb24sXG4gIGZhRWRpdCxcbiAgZmFFeGNsYW1hdGlvblRyaWFuZ2xlLFxuICBmYUV4dGVybmFsTGlua0FsdCxcbiAgZmFGaWx0ZXIsXG4gIGZhTGlzdCxcbiAgZmFMb25nQXJyb3dBbHREb3duLFxuICBmYUxvbmdBcnJvd0FsdFVwLFxuICBmYUxvbmdBcnJvd0FsdExlZnQsXG4gIGZhTG9uZ0Fycm93QWx0UmlnaHQsXG4gIGZhTWFwLFxuICBmYU1hcE1hcmtlZCxcbiAgZmFNYXBNYXJrZWRBbHQsXG4gIGZhUGx1cyxcbiAgZmFQbHVzQ2lyY2xlLFxuICBmYVNlYXJjaCxcbiAgZmFTZWVkbGluZyxcbiAgZmFTcGVsbENoZWNrLFxuICBmYVNwaW5uZXIsXG4gIGZhVGltZXMsXG4gIGZhVXNlclxufSBmcm9tICdAZm9ydGF3ZXNvbWUvZnJlZS1zb2xpZC1zdmctaWNvbnMnO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvbnRBd2Vzb21lTW9kdWxlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBGb250QXdlc29tZU1vZHVsZVxuICBdXG59KVxuZXhwb3J0IGNsYXNzIEhlRm9udGF3ZXNvbWVNb2R1bGUge1xuICBjb25zdHJ1Y3RvcihsaWJyYXJ5OiBGYUljb25MaWJyYXJ5KSB7XG4gICAgbGlicmFyeS5hZGRJY29ucyhcbiAgICAgIC8vIGZyZWUtcmVndWxhclxuICAgICAgZmFyQ2xvbmUsXG4gICAgICBmYXJDaXJjbGUsXG4gICAgICBmYXJJZEJhZGdlLFxuICAgICAgLy8gZnJlZS1zb2xpZFxuICAgICAgZmFBbmdsZURvdWJsZUxlZnQsXG4gICAgICBmYUFuZ2xlRG91YmxlUmlnaHQsXG4gICAgICBmYUFuZ2xlRG93bixcbiAgICAgIGZhQW5nbGVMZWZ0LFxuICAgICAgZmFBbmdsZVJpZ2h0LFxuICAgICAgZmFCb29rT3BlbixcbiAgICAgIGZhQnVpbGRpbmcsXG4gICAgICBmYUNhbGN1bGF0b3IsXG4gICAgICBmYUNoYXJ0QmFyLFxuICAgICAgZmFDaGVjayxcbiAgICAgIGZhQ2xpcGJvYXJkLFxuICAgICAgZmFDbGlwYm9hcmRMaXN0LFxuICAgICAgZmFDbG9uZSxcbiAgICAgIGZhQ29tbWVudHMsXG4gICAgICBmYURvd25sb2FkLFxuICAgICAgZmFEcmF3UG9seWdvbixcbiAgICAgIGZhRWRpdCxcbiAgICAgIGZhRXhjbGFtYXRpb25UcmlhbmdsZSxcbiAgICAgIGZhRXh0ZXJuYWxMaW5rQWx0LFxuICAgICAgZmFGaWx0ZXIsXG4gICAgICBmYUxpc3QsXG4gICAgICBmYUxvbmdBcnJvd0FsdERvd24sXG4gICAgICBmYUxvbmdBcnJvd0FsdFVwLFxuICAgICAgZmFMb25nQXJyb3dBbHRMZWZ0LFxuICAgICAgZmFMb25nQXJyb3dBbHRSaWdodCxcbiAgICAgIGZhTWFwLFxuICAgICAgZmFNYXBNYXJrZWQsXG4gICAgICBmYU1hcE1hcmtlZEFsdCxcbiAgICAgIGZhUGx1cyxcbiAgICAgIGZhUGx1c0NpcmNsZSxcbiAgICAgIGZhU2VhcmNoLFxuICAgICAgZmFTZWVkbGluZyxcbiAgICAgIGZhU3BlbGxDaGVjayxcbiAgICAgIGZhU3Bpbm5lcixcbiAgICAgIGZhVGltZXMsXG4gICAgICBmYVVzZXJcbiAgICApO1xuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './fontawesome.module';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9mb250YXdlc29tZS9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsc0JBQXNCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2ZvbnRhd2Vzb21lLm1vZHVsZSc7XG4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './public-api';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVzdGlhLWVhcnRoLXVpLWNvbXBvbmVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaGVzdGlhLWVhcnRoLXVpLWNvbXBvbmVudHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
|
@@ -0,0 +1,161 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
2
|
+
import { Component, Input, ViewChild } from '@angular/core';
|
|
3
|
+
import { of } from 'rxjs';
|
|
4
|
+
import { filter, groupBy, map, mergeAll, mergeMap, toArray } from 'rxjs/operators';
|
|
5
|
+
import { Chart } from 'chart.js';
|
|
6
|
+
import ChartDataLabels from 'chartjs-plugin-datalabels';
|
|
7
|
+
import { DataState } from '@hestia-earth/api';
|
|
8
|
+
import { NodeType, TermTermType } from '@hestia-earth/schema';
|
|
9
|
+
import { toPrecision } from '@hestia-earth/utils';
|
|
10
|
+
import { matchTermType, matchType } from '../../search/search.model';
|
|
11
|
+
import { Level, parseLines, parseMessage } from '../../common/logs-utils';
|
|
12
|
+
import { listColor } from '../../common/utils';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
import * as i1 from "@angular/platform-browser";
|
|
15
|
+
import * as i2 from "../../search/search.service";
|
|
16
|
+
import * as i3 from "../../node/node.service";
|
|
17
|
+
import * as i4 from "@fortawesome/angular-fontawesome";
|
|
18
|
+
import * as i5 from "@angular/forms";
|
|
19
|
+
import * as i6 from "@angular/common";
|
|
20
|
+
const parseLog = (data) => ({
|
|
21
|
+
indicator: data['key/term'],
|
|
22
|
+
emission: data.node,
|
|
23
|
+
value: +data.value * +data.coefficient
|
|
24
|
+
});
|
|
25
|
+
const filterTermTypes = [
|
|
26
|
+
TermTermType.emission,
|
|
27
|
+
TermTermType.characterisedIndicator
|
|
28
|
+
];
|
|
29
|
+
const toCsv = (logs) => [
|
|
30
|
+
[
|
|
31
|
+
'Indicator',
|
|
32
|
+
'Emission',
|
|
33
|
+
'Value'
|
|
34
|
+
].join(','),
|
|
35
|
+
...logs
|
|
36
|
+
.sort((a, b) => a.indicator.localeCompare(b.indicator))
|
|
37
|
+
.map(({ indicator, emission, value }) => [indicator, emission, value].join(','))
|
|
38
|
+
].join('\n');
|
|
39
|
+
export class ImpactAssessmentsIndicatorBreakdownChartComponent {
|
|
40
|
+
constructor(domSanitizer, searchService, nodeService) {
|
|
41
|
+
this.domSanitizer = domSanitizer;
|
|
42
|
+
this.searchService = searchService;
|
|
43
|
+
this.nodeService = nodeService;
|
|
44
|
+
this.logs = [];
|
|
45
|
+
this.emissions = [];
|
|
46
|
+
this.indicators = [];
|
|
47
|
+
this.loading = true;
|
|
48
|
+
this.terms = [];
|
|
49
|
+
this.noData = false;
|
|
50
|
+
}
|
|
51
|
+
ngOnInit() {
|
|
52
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
53
|
+
this.terms = this.indicators.map(({ term }) => term);
|
|
54
|
+
this.logs = (yield of(Object.assign(Object.assign({}, this.impactAssessment), { dataState: DataState.recalculated })).pipe(mergeMap(node => this.nodeService.getLog(node)), map(value => value ? parseLines(value) : []), mergeAll(), filter(({ data }) => data.logger === 'hestia_earth.models' && data.level === Level.debug), map(({ data }) => parseMessage(data.message)), filter(message => 'node' in message), map(parseLog), filter(log => !isNaN(log.value) && log.value > 0), groupBy(log => [log.indicator, log.emission].join('/')), mergeMap(group => group.pipe(toArray())), map(values => {
|
|
55
|
+
const total = values.reduce((prev, curr) => prev + curr.value, 0);
|
|
56
|
+
return Object.assign(Object.assign({}, values[0]), { value: total });
|
|
57
|
+
}), toArray()).toPromise());
|
|
58
|
+
this.csvContent = this.domSanitizer.bypassSecurityTrustResourceUrl(`data:text/html;charset=utf-8,${encodeURIComponent(toCsv(this.logs))}`);
|
|
59
|
+
const { results: emissions } = yield this.searchService.search({
|
|
60
|
+
fields: ['@type', '@id', 'name'],
|
|
61
|
+
limit: 1000,
|
|
62
|
+
query: {
|
|
63
|
+
bool: {
|
|
64
|
+
must: [
|
|
65
|
+
matchType(NodeType.Term)
|
|
66
|
+
],
|
|
67
|
+
should: filterTermTypes.map(termType => matchTermType(termType)),
|
|
68
|
+
minimum_should_match: 1
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
});
|
|
72
|
+
this.emissions = emissions;
|
|
73
|
+
this.loading = false;
|
|
74
|
+
this.selectedTerm = this.terms[0];
|
|
75
|
+
this.updateChart();
|
|
76
|
+
});
|
|
77
|
+
}
|
|
78
|
+
get id() {
|
|
79
|
+
return this.impactAssessment['@id'] || this.impactAssessment.id;
|
|
80
|
+
}
|
|
81
|
+
updateChart() {
|
|
82
|
+
var _a, _b, _c;
|
|
83
|
+
const logs = this.logs
|
|
84
|
+
.filter(({ indicator }) => indicator === this.selectedTerm['@id'])
|
|
85
|
+
.sort((a, b) => b.value - a.value);
|
|
86
|
+
this.noData = logs.length === 0;
|
|
87
|
+
const labels = logs.map(({ emission }) => { var _a; return ((_a = this.emissions.find(v => v['@id'] === emission)) === null || _a === void 0 ? void 0 : _a.name) || emission; });
|
|
88
|
+
const datasets = [{
|
|
89
|
+
label: (_b = (_a = this.selectedTerm) === null || _a === void 0 ? void 0 : _a.name) !== null && _b !== void 0 ? _b : '',
|
|
90
|
+
data: logs.map(({ value }) => value),
|
|
91
|
+
backgroundColor: logs.map(listColor),
|
|
92
|
+
borderColor: logs.map(listColor)
|
|
93
|
+
}];
|
|
94
|
+
const total = logs.reduce((prev, curr) => prev + curr.value, 0);
|
|
95
|
+
if (this.chart) {
|
|
96
|
+
this.chart.destroy();
|
|
97
|
+
}
|
|
98
|
+
this.chart = new Chart((_c = this.chartRef) === null || _c === void 0 ? void 0 : _c.nativeElement, {
|
|
99
|
+
type: 'horizontalBar',
|
|
100
|
+
data: {
|
|
101
|
+
labels,
|
|
102
|
+
datasets
|
|
103
|
+
},
|
|
104
|
+
plugins: [ChartDataLabels],
|
|
105
|
+
options: {
|
|
106
|
+
plugins: {
|
|
107
|
+
datalabels: {
|
|
108
|
+
color: 'black',
|
|
109
|
+
formatter: (value) => {
|
|
110
|
+
const ratio = toPrecision(value * 100 / total, 2);
|
|
111
|
+
return `${toPrecision(value, 3)} (${ratio}%)`;
|
|
112
|
+
},
|
|
113
|
+
align: 'end'
|
|
114
|
+
}
|
|
115
|
+
},
|
|
116
|
+
responsive: true,
|
|
117
|
+
maintainAspectRatio: false,
|
|
118
|
+
legend: {
|
|
119
|
+
display: false
|
|
120
|
+
},
|
|
121
|
+
tooltips: {
|
|
122
|
+
enabled: false,
|
|
123
|
+
callbacks: {
|
|
124
|
+
title: (tooltipItems, data) => { var _a; return ((_a = data.datasets[tooltipItems[0].datasetIndex]) === null || _a === void 0 ? void 0 : _a.label) || ''; },
|
|
125
|
+
label: (tooltipItem) => {
|
|
126
|
+
const value = +(tooltipItem.value || '0');
|
|
127
|
+
const ratio = toPrecision(value * 100 / total, 2);
|
|
128
|
+
return `${toPrecision(value, 3)} (${ratio}%)`;
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
},
|
|
132
|
+
scales: {
|
|
133
|
+
xAxes: [{
|
|
134
|
+
display: true
|
|
135
|
+
}],
|
|
136
|
+
yAxes: [{
|
|
137
|
+
position: 'left'
|
|
138
|
+
}]
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
ImpactAssessmentsIndicatorBreakdownChartComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ImpactAssessmentsIndicatorBreakdownChartComponent, deps: [{ token: i1.DomSanitizer }, { token: i2.HeSearchService }, { token: i3.HeNodeService }], target: i0.ɵɵFactoryTarget.Component });
|
|
145
|
+
ImpactAssessmentsIndicatorBreakdownChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: ImpactAssessmentsIndicatorBreakdownChartComponent, selector: "he-impact-assessments-indicator-breakdown-chart", inputs: { impactAssessment: "impactAssessment", indicators: "indicators" }, viewQueries: [{ propertyName: "chartRef", first: true, predicate: ["chart"], descendants: true }], ngImport: i0, template: "<div class=\"p-3\" [class.is-hidden]=\"loading || !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\">Select an Indicator</span>\n </div>\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth is-small\">\n <select (change)=\"updateChart()\" [(ngModel)]=\"selectedTerm\" id=\"selectedTerm\">\n <option *ngFor=\"let term of terms\" [ngValue]=\"term\">{{term.name}} ({{term.units}})</option>\n </select>\n </div>\n </div>\n </div>\n </div>\n <div class=\"column is-narrow\">\n <a class=\"button is-dark is-outlined is-small\" [href]=\"csvContent\" [download]=\"id + '-logs.csv'\">\n <fa-icon icon=\"download\"></fa-icon>\n <span class=\"pl-2\">Download All (CSV)</span>\n </a>\n </div>\n </div>\n\n <div class=\"mt-1\">\n <p *ngIf=\"noData\" class=\"has-text-centered\">No breakdown available for {{selectedTerm?.name}}.</p>\n <div class=\"chart-container h-100\">\n <canvas #chart></canvas>\n </div>\n </div>\n</div>\n\n<ng-container *ngIf=\"loading\">\n <div class=\"has-text-center py-3\">\n <fa-icon icon=\"spinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n </div>\n</ng-container>\n", styles: [":host{display:block;overflow:visible}.chart-container{height:400px;position:relative}\n"], 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"] }], directives: [{ type: i5.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i5.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i5.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
146
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ImpactAssessmentsIndicatorBreakdownChartComponent, decorators: [{
|
|
147
|
+
type: Component,
|
|
148
|
+
args: [{
|
|
149
|
+
selector: 'he-impact-assessments-indicator-breakdown-chart',
|
|
150
|
+
templateUrl: './impact-assessments-indicator-breakdown-chart.component.html',
|
|
151
|
+
styleUrls: ['./impact-assessments-indicator-breakdown-chart.component.scss']
|
|
152
|
+
}]
|
|
153
|
+
}], ctorParameters: function () { return [{ type: i1.DomSanitizer }, { type: i2.HeSearchService }, { type: i3.HeNodeService }]; }, propDecorators: { chartRef: [{
|
|
154
|
+
type: ViewChild,
|
|
155
|
+
args: ['chart']
|
|
156
|
+
}], impactAssessment: [{
|
|
157
|
+
type: Input
|
|
158
|
+
}], indicators: [{
|
|
159
|
+
type: Input
|
|
160
|
+
}] } });
|
|
161
|
+
//# 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 { Component, ElementRef, Input, OnInit, ViewChild } from '@angular/core';\nimport { DomSanitizer, SafeResourceUrl } from '@angular/platform-browser';\nimport { of } from 'rxjs';\nimport { filter, groupBy, map, mergeAll, mergeMap, toArray } from 'rxjs/operators';\nimport { Chart } 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 } from '@hestia-earth/utils';\n\nimport { matchTermType, matchType } from '../../search/search.model';\nimport { HeSearchService } from '../../search/search.service';\nimport { HeNodeService } from '../../node/node.service';\nimport { Level, parseLines, parseMessage } from '../../common/logs-utils';\nimport { listColor } from '../../common/utils';\n\ninterface ILog {\n  indicator: string;\n  emission: string;\n  value: number;\n}\n\nconst parseLog = (data: any): ILog => ({\n  indicator: data['key/term'],\n  emission: data.node,\n  value: +data.value * +data.coefficient\n});\n\nconst filterTermTypes = [\n  TermTermType.emission,\n  TermTermType.characterisedIndicator\n];\n\nconst toCsv = (logs: ILog[]) => [\n  [\n    'Indicator',\n    'Emission',\n    'Value'\n  ].join(','),\n  ...logs\n    .sort((a, b) => a.indicator.localeCompare(b.indicator))\n    .map(({ indicator, emission, value }) => [indicator, emission, value].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})\nexport class ImpactAssessmentsIndicatorBreakdownChartComponent implements OnInit {\n  private logs: ILog[] = [];\n  private emissions: ITermJSONLD[] = [];\n\n  @ViewChild('chart')\n  private chartRef?: ElementRef;\n  private chart: any;\n\n  @Input()\n  public impactAssessment?: IImpactAssessmentJSONLD;\n  @Input()\n  public indicators: Indicator[] = [];\n\n  public loading = true;\n  public terms: Term[] = [];\n  public selectedTerm?: Term;\n  public noData = false;\n  public csvContent?: SafeResourceUrl;\n\n  constructor(\n    private domSanitizer: DomSanitizer,\n    private searchService: HeSearchService,\n    private nodeService: HeNodeService\n  ) { }\n\n  async ngOnInit() {\n    this.terms = this.indicators.map(({ term }) => term!);\n\n    this.logs = (await of({\n      ...this.impactAssessment,\n      dataState: DataState.recalculated\n    }).pipe(\n      mergeMap(node => this.nodeService.getLog(node)),\n      map(value => value ? parseLines(value) : []),\n      mergeAll(),\n      filter(({ data }) => data.logger === 'hestia_earth.models' && data.level === Level.debug),\n      map(({ data }) => parseMessage(data.message)),\n      filter(message => 'node' in message),\n      map(parseLog),\n      filter(log => !isNaN(log.value) && log.value > 0),\n      groupBy(log => [log.indicator, log.emission].join('/')),\n      mergeMap(group => group.pipe(toArray())),\n      map(values => {\n        const total = values.reduce((prev, curr) => prev + curr.value, 0);\n        return { ...values[0], value: total };\n      }),\n      toArray()\n    ).toPromise()) as ILog[];\n    this.csvContent = this.domSanitizer.bypassSecurityTrustResourceUrl(\n      `data:text/html;charset=utf-8,${encodeURIComponent(toCsv(this.logs))}`\n    );\n\n    const { results: emissions } = await this.searchService.search<ITermJSONLD, NodeType.Term>({\n      fields: ['@type', '@id', 'name'],\n      limit: 1000,\n      query: {\n        bool: {\n          must: [\n            matchType(NodeType.Term)\n          ],\n          should: filterTermTypes.map(termType => matchTermType(termType)),\n          minimum_should_match: 1\n        }\n      }\n    });\n    this.emissions = emissions;\n\n    this.loading = false;\n\n    this.selectedTerm = this.terms[0];\n    this.updateChart();\n  }\n\n  public get id() {\n    return this.impactAssessment!['@id'] || (this.impactAssessment as any).id;\n  }\n\n  public updateChart() {\n    const logs = this.logs\n      .filter(({ indicator }) => indicator === this.selectedTerm!['@id'])\n      .sort((a, b) => b.value - a.value);\n    this.noData = logs.length === 0;\n\n    const labels = logs.map(({ emission }) => this.emissions.find(v => v['@id'] === emission)?.name || emission);\n    const datasets = [{\n      label: this.selectedTerm?.name ?? '',\n      data: logs.map(({ value }) => value),\n      backgroundColor: logs.map(listColor),\n      borderColor: logs.map(listColor)\n    }];\n    const total = logs.reduce((prev, curr) => prev + curr.value, 0);\n\n    if (this.chart) {\n      this.chart.destroy();\n    }\n    this.chart = new Chart(this.chartRef?.nativeElement, {\n      type: 'horizontalBar',\n      data: {\n        labels,\n        datasets\n      },\n      plugins: [ChartDataLabels],\n      options: {\n        plugins: {\n          datalabels: {\n            color: 'black',\n            formatter: (value) => {\n              const ratio = toPrecision(value * 100 / total, 2);\n              return `${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 / total, 2);\n              return `${toPrecision(value, 3)} (${ratio}%)`;\n            }\n          }\n        },\n        scales: {\n          xAxes: [{\n            display: true\n          }],\n          yAxes: [{\n            position: 'left'\n          }]\n        }\n      }\n    });\n  }\n}\n","<div class=\"p-3\" [class.is-hidden]=\"loading || !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\">Select an Indicator</span>\n        </div>\n        <div class=\"control is-expanded\">\n          <div class=\"select is-fullwidth is-small\">\n            <select (change)=\"updateChart()\" [(ngModel)]=\"selectedTerm\" id=\"selectedTerm\">\n              <option *ngFor=\"let term of terms\" [ngValue]=\"term\">{{term.name}} ({{term.units}})</option>\n            </select>\n          </div>\n        </div>\n      </div>\n    </div>\n    <div class=\"column is-narrow\">\n      <a class=\"button is-dark is-outlined is-small\" [href]=\"csvContent\" [download]=\"id + '-logs.csv'\">\n        <fa-icon icon=\"download\"></fa-icon>\n        <span class=\"pl-2\">Download All (CSV)</span>\n      </a>\n    </div>\n  </div>\n\n  <div class=\"mt-1\">\n    <p *ngIf=\"noData\" class=\"has-text-centered\">No breakdown available for {{selectedTerm?.name}}.</p>\n    <div class=\"chart-container h-100\">\n      <canvas #chart></canvas>\n    </div>\n  </div>\n</div>\n\n<ng-container *ngIf=\"loading\">\n  <div class=\"has-text-center py-3\">\n    <fa-icon icon=\"spinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n  </div>\n</ng-container>\n"]}
|
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
import { Component, Input, ViewChild } from '@angular/core';
|
|
2
|
+
import { Chart } from 'chart.js';
|
|
3
|
+
import { groupNodesByTerm, defaultLabel, itemColor, listColor } from '../../common/utils';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@angular/forms";
|
|
6
|
+
import * as i2 from "@angular/common";
|
|
7
|
+
const impactValue = (impact, values) => { var _a; return (((_a = values[impact['@id']]) === null || _a === void 0 ? void 0 : _a.nodes[0]) || { value: 0 }).value; };
|
|
8
|
+
const impactName = (impact, index) => `${index + 1}. ${defaultLabel(impact)}`;
|
|
9
|
+
const impactAssessmentDataset = (values) => (impact, index) => {
|
|
10
|
+
const label = impactName(impact, index);
|
|
11
|
+
const color = itemColor(index);
|
|
12
|
+
const data = [impactValue(impact, values)];
|
|
13
|
+
return {
|
|
14
|
+
label,
|
|
15
|
+
axis: 'y',
|
|
16
|
+
data,
|
|
17
|
+
backgroundColor: color,
|
|
18
|
+
borderColor: color
|
|
19
|
+
};
|
|
20
|
+
};
|
|
21
|
+
export class ImpactAssessmentsIndicatorsChartComponent {
|
|
22
|
+
constructor() {
|
|
23
|
+
this.impactAssessments = [];
|
|
24
|
+
this.key = 'impacts';
|
|
25
|
+
this.indicatorPerImpactAssessment = {};
|
|
26
|
+
this.terms = [];
|
|
27
|
+
}
|
|
28
|
+
ngAfterViewInit() {
|
|
29
|
+
return this.init();
|
|
30
|
+
}
|
|
31
|
+
ngOnChanges(changes) {
|
|
32
|
+
if ('impactAssessments' in changes && !changes.impactAssessments.firstChange) {
|
|
33
|
+
return this.init();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
termAllowed(term) {
|
|
37
|
+
var _a;
|
|
38
|
+
return !((_a = this.filterTermTypes) === null || _a === void 0 ? void 0 : _a.length) || (this.filterTermTypes || []).includes(term === null || term === void 0 ? void 0 : term.termType);
|
|
39
|
+
}
|
|
40
|
+
init() {
|
|
41
|
+
this.indicatorPerImpactAssessment = groupNodesByTerm(this.impactAssessments, this.key);
|
|
42
|
+
this.terms = Object.values(this.indicatorPerImpactAssessment)
|
|
43
|
+
.filter(({ term, values }) => this.termAllowed(term) && Object.values(values).some(({ nodes: [{ value }] }) => value > 0))
|
|
44
|
+
.map(({ term }) => term);
|
|
45
|
+
this.selectedTerm = this.terms.includes(this.selectedTerm) ? this.selectedTerm : this.terms[0];
|
|
46
|
+
return this.selectedTerm ? this.updateCharts() : null;
|
|
47
|
+
}
|
|
48
|
+
updateBarChart() {
|
|
49
|
+
var _a, _b, _c;
|
|
50
|
+
const labels = [(_b = (_a = this.selectedTerm) === null || _a === void 0 ? void 0 : _a.name) !== null && _b !== void 0 ? _b : ''];
|
|
51
|
+
const { values } = this.indicatorPerImpactAssessment[this.selectedTerm['@id']];
|
|
52
|
+
const datasets = this.impactAssessments.map(impactAssessmentDataset(values));
|
|
53
|
+
if (this.barChart) {
|
|
54
|
+
this.barChart.destroy();
|
|
55
|
+
}
|
|
56
|
+
this.barChart = new Chart((_c = this.barChartRef) === null || _c === void 0 ? void 0 : _c.nativeElement, {
|
|
57
|
+
type: 'bar',
|
|
58
|
+
data: {
|
|
59
|
+
labels,
|
|
60
|
+
datasets
|
|
61
|
+
},
|
|
62
|
+
options: {
|
|
63
|
+
responsive: true,
|
|
64
|
+
maintainAspectRatio: false,
|
|
65
|
+
legend: {
|
|
66
|
+
display: false
|
|
67
|
+
},
|
|
68
|
+
scales: {
|
|
69
|
+
xAxes: [{
|
|
70
|
+
display: false
|
|
71
|
+
}],
|
|
72
|
+
yAxes: [{
|
|
73
|
+
position: 'left',
|
|
74
|
+
ticks: {
|
|
75
|
+
min: 0
|
|
76
|
+
}
|
|
77
|
+
}]
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
updatePieChart() {
|
|
83
|
+
var _a, _b, _c;
|
|
84
|
+
const { values } = this.indicatorPerImpactAssessment[this.selectedTerm['@id']];
|
|
85
|
+
const labels = this.impactAssessments.map(impactName);
|
|
86
|
+
const colors = this.impactAssessments.map(listColor);
|
|
87
|
+
const data = this.impactAssessments.map(impact => impactValue(impact, values));
|
|
88
|
+
const datasets = [{
|
|
89
|
+
label: (_b = (_a = this.selectedTerm) === null || _a === void 0 ? void 0 : _a.name) !== null && _b !== void 0 ? _b : '',
|
|
90
|
+
data,
|
|
91
|
+
backgroundColor: colors,
|
|
92
|
+
hoverOffset: 4
|
|
93
|
+
}];
|
|
94
|
+
if (this.pieChart) {
|
|
95
|
+
this.pieChart.destroy();
|
|
96
|
+
}
|
|
97
|
+
this.pieChart = new Chart((_c = this.pieChartRef) === null || _c === void 0 ? void 0 : _c.nativeElement, {
|
|
98
|
+
type: 'pie',
|
|
99
|
+
data: {
|
|
100
|
+
labels,
|
|
101
|
+
datasets
|
|
102
|
+
},
|
|
103
|
+
options: {
|
|
104
|
+
responsive: true,
|
|
105
|
+
maintainAspectRatio: false,
|
|
106
|
+
legend: {
|
|
107
|
+
display: false
|
|
108
|
+
},
|
|
109
|
+
layout: {
|
|
110
|
+
padding: 0
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
updateCharts() {
|
|
116
|
+
this.updateBarChart();
|
|
117
|
+
this.updatePieChart();
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
ImpactAssessmentsIndicatorsChartComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ImpactAssessmentsIndicatorsChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
121
|
+
ImpactAssessmentsIndicatorsChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: ImpactAssessmentsIndicatorsChartComponent, selector: "he-impact-assessments-indicators-chart", inputs: { impactAssessments: "impactAssessments", key: "key", filterTermTypes: "filterTermTypes" }, viewQueries: [{ propertyName: "barChartRef", first: true, predicate: ["barChart"], descendants: true }, { propertyName: "pieChartRef", first: true, predicate: ["pieChart"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"p-3\" [class.is-hidden]=\"!terms?.length\">\n <div class=\"field is-horizontal\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"selectedTerm\">\n <span>Select a column</span>\n </label>\n </div>\n <div class=\"field-body\">\n <div class=\"control\">\n <div class=\"select is-small\">\n <select (change)=\"updateCharts()\" [(ngModel)]=\"selectedTerm\" id=\"selectedTerm\">\n <option *ngFor=\"let term of terms\" [ngValue]=\"term\">{{term.name}}</option>\n </select>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"mt-1\">\n <div class=\"columns h-100\">\n <div class=\"column is-12 chart-container\">\n <canvas #barChart></canvas>\n </div>\n <div class=\"column is-4 chart-container is-hidden\">\n <canvas #pieChart></canvas>\n </div>\n </div>\n </div>\n</div>\n", styles: [":host{display:block;overflow:visible}.chart-container{height:400px;position:relative}\n"], directives: [{ type: i1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }] });
|
|
122
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ImpactAssessmentsIndicatorsChartComponent, decorators: [{
|
|
123
|
+
type: Component,
|
|
124
|
+
args: [{
|
|
125
|
+
selector: 'he-impact-assessments-indicators-chart',
|
|
126
|
+
templateUrl: './impact-assessments-indicators-chart.component.html',
|
|
127
|
+
styleUrls: ['./impact-assessments-indicators-chart.component.scss']
|
|
128
|
+
}]
|
|
129
|
+
}], propDecorators: { barChartRef: [{
|
|
130
|
+
type: ViewChild,
|
|
131
|
+
args: ['barChart']
|
|
132
|
+
}], pieChartRef: [{
|
|
133
|
+
type: ViewChild,
|
|
134
|
+
args: ['pieChart']
|
|
135
|
+
}], impactAssessments: [{
|
|
136
|
+
type: Input
|
|
137
|
+
}], key: [{
|
|
138
|
+
type: Input
|
|
139
|
+
}], filterTermTypes: [{
|
|
140
|
+
type: Input
|
|
141
|
+
}] } });
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"impact-assessments-indicators-chart.component.js","sourceRoot":"","sources":["../../../../src/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.ts","../../../../src/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, AfterViewInit, OnChanges, ViewChild, SimpleChanges, ElementRef } from '@angular/core';\nimport { IImpactAssessmentJSONLD, Indicator, Term, TermTermType } from '@hestia-earth/schema';\nimport { Chart } from 'chart.js';\n\nimport {\n  IGroupedNodes, groupNodesByTerm, defaultLabel, itemColor, listColor, IGroupedNodesValues\n} from '../../common/utils';\n\nconst impactValue = (impact: IImpactAssessmentJSONLD, values: IGroupedNodesValues<Indicator>) =>\n  (values[impact['@id']]?.nodes[0] || { value: 0 }).value;\n\nconst impactName = (impact: IImpactAssessmentJSONLD, index: number) => `${index + 1}. ${defaultLabel(impact)}`;\n\nconst impactAssessmentDataset = (values: IGroupedNodesValues<Indicator>) => (\n  impact: IImpactAssessmentJSONLD, index: number\n) => {\n  const label = impactName(impact, index);\n  const color = itemColor(index);\n  const data = [impactValue(impact, values)];\n  return {\n    label,\n    axis: 'y',\n    data,\n    backgroundColor: color,\n    borderColor: color\n  };\n};\n\n@Component({\n  selector: 'he-impact-assessments-indicators-chart',\n  templateUrl: './impact-assessments-indicators-chart.component.html',\n  styleUrls: ['./impact-assessments-indicators-chart.component.scss']\n})\nexport class ImpactAssessmentsIndicatorsChartComponent implements AfterViewInit, OnChanges {\n  @ViewChild('barChart')\n  private barChartRef?: ElementRef;\n  private barChart: any;\n\n  @ViewChild('pieChart')\n  private pieChartRef?: ElementRef;\n  private pieChart: any;\n\n  @Input()\n  private impactAssessments: IImpactAssessmentJSONLD[] = [];\n  @Input()\n  private key: 'impacts' | 'emissionsResourceUse' = 'impacts';\n  @Input()\n  public filterTermTypes?: TermTermType[];\n\n  public indicatorPerImpactAssessment: IGroupedNodes<Indicator> = {};\n  public terms: Term[] = [];\n  public selectedTerm?: Term;\n\n  ngAfterViewInit() {\n    return this.init();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if ('impactAssessments' in changes && !changes.impactAssessments.firstChange) {\n      return this.init();\n    }\n  }\n\n  private termAllowed(term?: Term) {\n    return !this.filterTermTypes?.length || (this.filterTermTypes || []).includes(term?.termType!);\n  }\n\n  private init() {\n    this.indicatorPerImpactAssessment = groupNodesByTerm<IImpactAssessmentJSONLD, Indicator>(\n      this.impactAssessments, this.key\n    );\n    this.terms = Object.values(this.indicatorPerImpactAssessment)\n      .filter(({ term, values }: any) =>\n        this.termAllowed(term) && Object.values(values).some(({ nodes: [{ value }] }: any) => value > 0)\n      )\n      .map(({ term }: any) => term);\n    this.selectedTerm = this.terms.includes(this.selectedTerm!) ? this.selectedTerm : this.terms[0];\n    return this.selectedTerm ? this.updateCharts() : null;\n  }\n\n  private updateBarChart() {\n    const labels = [this.selectedTerm?.name ?? ''];\n    const { values } = this.indicatorPerImpactAssessment[this.selectedTerm!['@id']];\n    const datasets = this.impactAssessments.map(impactAssessmentDataset(values));\n\n    if (this.barChart) {\n      this.barChart.destroy();\n    }\n    this.barChart = new Chart(this.barChartRef?.nativeElement, {\n      type: 'bar',\n      data: {\n        labels,\n        datasets\n      },\n      options: {\n        responsive: true,\n        maintainAspectRatio: false,\n        legend: {\n          display: false\n        },\n        scales: {\n          xAxes: [{\n            display: false\n          }],\n          yAxes: [{\n            position: 'left',\n            ticks: {\n              min: 0\n            }\n          }]\n        }\n      }\n    });\n  }\n\n  private updatePieChart() {\n    const { values } = this.indicatorPerImpactAssessment[this.selectedTerm!['@id']];\n    const labels = this.impactAssessments.map(impactName);\n    const colors = this.impactAssessments.map(listColor);\n    const data = this.impactAssessments.map(impact => impactValue(impact, values));\n    const datasets = [{\n      label: this.selectedTerm?.name ?? '',\n      data,\n      backgroundColor: colors as string[],\n      hoverOffset: 4\n    }];\n\n    if (this.pieChart) {\n      this.pieChart.destroy();\n    }\n    this.pieChart = new Chart(this.pieChartRef?.nativeElement, {\n      type: 'pie',\n      data: {\n        labels,\n        datasets\n      },\n      options: {\n        responsive: true,\n        maintainAspectRatio: false,\n        legend: {\n          display: false\n        },\n        layout: {\n          padding: 0\n        }\n      }\n    });\n  }\n\n  public updateCharts() {\n    this.updateBarChart();\n    this.updatePieChart();\n  }\n}\n","<div class=\"p-3\" [class.is-hidden]=\"!terms?.length\">\n  <div class=\"field is-horizontal\">\n    <div class=\"field-label is-normal\">\n      <label class=\"label\" for=\"selectedTerm\">\n        <span>Select a column</span>\n      </label>\n    </div>\n    <div class=\"field-body\">\n      <div class=\"control\">\n        <div class=\"select is-small\">\n          <select (change)=\"updateCharts()\" [(ngModel)]=\"selectedTerm\" id=\"selectedTerm\">\n            <option *ngFor=\"let term of terms\" [ngValue]=\"term\">{{term.name}}</option>\n          </select>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"mt-1\">\n    <div class=\"columns h-100\">\n      <div class=\"column is-12 chart-container\">\n        <canvas #barChart></canvas>\n      </div>\n      <div class=\"column is-4 chart-container is-hidden\">\n        <canvas #pieChart></canvas>\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|