@hestia-earth/ui-components 0.27.62 → 0.27.63
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/cycles/cycles-completeness/cycles-completeness.component.d.ts +27 -27
- package/cycles/cycles-nodes/cycles-nodes.component.d.ts +47 -46
- package/esm2022/cycles/cycles-completeness/cycles-completeness.component.mjs +14 -8
- package/esm2022/cycles/cycles-nodes/cycles-nodes.component.mjs +13 -6
- package/esm2022/files/files-error.model.mjs +6 -1
- package/esm2022/impact-assessments/impact-assessments-products/impact-assessments-products.component.mjs +13 -6
- package/esm2022/sites/sites-nodes/sites-nodes.component.mjs +17 -9
- package/fesm2022/hestia-earth-ui-components.mjs +55 -22
- package/fesm2022/hestia-earth-ui-components.mjs.map +1 -1
- package/impact-assessments/impact-assessments-products/impact-assessments-products.component.d.ts +38 -37
- package/package.json +1 -1
- package/sites/sites-nodes/sites-nodes.component.d.ts +39 -38
|
@@ -7,34 +7,33 @@ declare enum View {
|
|
|
7
7
|
logs = "Recalculations logs"
|
|
8
8
|
}
|
|
9
9
|
export declare class CyclesCompletenessComponent {
|
|
10
|
-
private
|
|
10
|
+
private readonly modalService;
|
|
11
|
+
private readonly nodeStoreService;
|
|
11
12
|
protected readonly faDownload: IconDefinition;
|
|
12
|
-
protected dataState: import("@angular/core").InputSignal<DataState>;
|
|
13
|
-
protected schemaBaseUrl: string;
|
|
14
|
-
protected defaultLabel: (node?: any) => any;
|
|
15
|
-
protected keyToLabel: (key: string) => string;
|
|
16
|
-
protected getCompleteness: (cycle: any) => any;
|
|
17
|
-
protected
|
|
18
|
-
protected
|
|
19
|
-
protected
|
|
20
|
-
protected View: typeof View;
|
|
21
|
-
protected viewIcon: {
|
|
13
|
+
protected readonly dataState: import("@angular/core").InputSignal<DataState>;
|
|
14
|
+
protected readonly schemaBaseUrl: string;
|
|
15
|
+
protected readonly defaultLabel: (node?: any) => any;
|
|
16
|
+
protected readonly keyToLabel: (key: string) => string;
|
|
17
|
+
protected readonly getCompleteness: (cycle: any) => any;
|
|
18
|
+
protected readonly nodeKey = NonBlankNodesKey.completeness;
|
|
19
|
+
protected readonly View: typeof View;
|
|
20
|
+
protected readonly viewIcon: {
|
|
22
21
|
"Table view": IconDefinition;
|
|
23
22
|
"Recalculations logs": IconDefinition;
|
|
24
23
|
};
|
|
25
|
-
private showView;
|
|
26
|
-
protected views: import("@angular/core").Signal<View[]>;
|
|
27
|
-
protected selectedView: import("@angular/core").WritableSignal<View>;
|
|
28
|
-
private originalCycles;
|
|
29
|
-
private _allCycles;
|
|
30
|
-
protected cycles: import("@angular/core").Signal<ICycleJSONLD[]>;
|
|
31
|
-
private selectedIndex;
|
|
32
|
-
private ogirinalSelectedCycle;
|
|
33
|
-
private selectedCycle;
|
|
34
|
-
protected selectedLogsKey: import("@angular/core").Signal<any>;
|
|
35
|
-
protected selectedOriginalValues: import("@angular/core").Signal<any>;
|
|
36
|
-
protected selectedRecalculatedValues: import("@angular/core").Signal<any>;
|
|
37
|
-
protected selectedNode: import("@angular/core").Signal<{
|
|
24
|
+
private readonly showView;
|
|
25
|
+
protected readonly views: import("@angular/core").Signal<View[]>;
|
|
26
|
+
protected readonly selectedView: import("@angular/core").WritableSignal<View>;
|
|
27
|
+
private readonly originalCycles;
|
|
28
|
+
private readonly _allCycles;
|
|
29
|
+
protected readonly cycles: import("@angular/core").Signal<ICycleJSONLD[]>;
|
|
30
|
+
private readonly selectedIndex;
|
|
31
|
+
private readonly ogirinalSelectedCycle;
|
|
32
|
+
private readonly selectedCycle;
|
|
33
|
+
protected readonly selectedLogsKey: import("@angular/core").Signal<any>;
|
|
34
|
+
protected readonly selectedOriginalValues: import("@angular/core").Signal<any>;
|
|
35
|
+
protected readonly selectedRecalculatedValues: import("@angular/core").Signal<any>;
|
|
36
|
+
protected readonly selectedNode: import("@angular/core").Signal<{
|
|
38
37
|
'@type': NodeType;
|
|
39
38
|
type: NodeType;
|
|
40
39
|
dataState: DataState;
|
|
@@ -89,9 +88,9 @@ export declare class CyclesCompletenessComponent {
|
|
|
89
88
|
'@id': string;
|
|
90
89
|
name: string;
|
|
91
90
|
}>;
|
|
92
|
-
protected hasData: import("@angular/core").Signal<number>;
|
|
93
|
-
protected isOriginal: import("@angular/core").Signal<boolean>;
|
|
94
|
-
protected completenessKeys: import("@angular/core").Signal<string[]>;
|
|
91
|
+
protected readonly hasData: import("@angular/core").Signal<number>;
|
|
92
|
+
protected readonly isOriginal: import("@angular/core").Signal<boolean>;
|
|
93
|
+
protected readonly completenessKeys: import("@angular/core").Signal<string[]>;
|
|
95
94
|
constructor();
|
|
96
95
|
protected trackById(_index: number, item: ICycleJSONLD): string;
|
|
97
96
|
protected selectIndex({ target: { value } }: {
|
|
@@ -99,6 +98,7 @@ export declare class CyclesCompletenessComponent {
|
|
|
99
98
|
value: any;
|
|
100
99
|
};
|
|
101
100
|
}): void;
|
|
101
|
+
protected showDownload(): void;
|
|
102
102
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesCompletenessComponent, never>;
|
|
103
103
|
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesCompletenessComponent, "he-cycles-completeness", never, { "dataState": { "alias": "dataState"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
|
|
104
104
|
}
|
|
@@ -18,42 +18,42 @@ export declare enum CycleNodesKeyGroup {
|
|
|
18
18
|
}
|
|
19
19
|
type groupedNode = Animal | Transformation;
|
|
20
20
|
export declare class CyclesNodesComponent {
|
|
21
|
+
private readonly modalService;
|
|
21
22
|
private nodeStoreService;
|
|
22
23
|
protected readonly faDownload: IconDefinition;
|
|
23
|
-
protected dataState: import("@angular/core").InputSignal<DataState>;
|
|
24
|
-
protected nodeKeys: import("@angular/core").InputSignal<BlankNodesKey[]>;
|
|
25
|
-
protected nodeKeyGroup: import("@angular/core").InputSignal<CycleNodesKeyGroup>;
|
|
26
|
-
protected BlankNodesKey: typeof BlankNodesKey;
|
|
27
|
-
protected firstNodeKey: import("@angular/core").Signal<BlankNodesKey>;
|
|
28
|
-
protected selectedNodeKey: import("@angular/core").WritableSignal<BlankNodesKey>;
|
|
29
|
-
protected selectedGroupTerm: import("@angular/core").WritableSignal<Term>;
|
|
30
|
-
protected schemaBaseUrl: string;
|
|
31
|
-
protected propertyValue: (value: import("@hestia-earth/utils/dist/term").propertyValueType | import("@hestia-earth/utils/dist/term").propertyValueType[], termId?: string) => import("@hestia-earth/utils/dist/term").propertyValueType;
|
|
32
|
-
protected defaultLabel: (node?: any) => any;
|
|
33
|
-
protected
|
|
34
|
-
protected
|
|
35
|
-
protected
|
|
36
|
-
protected viewIcon: {
|
|
24
|
+
protected readonly dataState: import("@angular/core").InputSignal<DataState>;
|
|
25
|
+
protected readonly nodeKeys: import("@angular/core").InputSignal<BlankNodesKey[]>;
|
|
26
|
+
protected readonly nodeKeyGroup: import("@angular/core").InputSignal<CycleNodesKeyGroup>;
|
|
27
|
+
protected readonly BlankNodesKey: typeof BlankNodesKey;
|
|
28
|
+
protected readonly firstNodeKey: import("@angular/core").Signal<BlankNodesKey>;
|
|
29
|
+
protected readonly selectedNodeKey: import("@angular/core").WritableSignal<BlankNodesKey>;
|
|
30
|
+
protected readonly selectedGroupTerm: import("@angular/core").WritableSignal<Term>;
|
|
31
|
+
protected readonly schemaBaseUrl: string;
|
|
32
|
+
protected readonly propertyValue: (value: import("@hestia-earth/utils/dist/term").propertyValueType | import("@hestia-earth/utils/dist/term").propertyValueType[], termId?: string) => import("@hestia-earth/utils/dist/term").propertyValueType;
|
|
33
|
+
protected readonly defaultLabel: (node?: any) => any;
|
|
34
|
+
protected readonly headerKeys: import("@angular/core").Signal<string[]>;
|
|
35
|
+
protected readonly View: typeof View;
|
|
36
|
+
protected readonly viewIcon: {
|
|
37
37
|
"Table view": IconDefinition;
|
|
38
38
|
"Chart view": IconDefinition;
|
|
39
39
|
"Operations Timeline": IconDefinition;
|
|
40
40
|
"Recalculations logs": IconDefinition;
|
|
41
41
|
};
|
|
42
|
-
private showView;
|
|
43
|
-
protected views: import("@angular/core").Signal<View[]>;
|
|
44
|
-
protected selectedView: import("@angular/core").WritableSignal<View>;
|
|
45
|
-
private _allNodes;
|
|
46
|
-
private originalNodes;
|
|
47
|
-
private currentNodes;
|
|
48
|
-
protected originalCycles: import("@angular/core").Signal<ICycleJSONLD[] | groupedNode[]>;
|
|
49
|
-
protected cycles: import("@angular/core").Signal<ICycleJSONLD[] | groupedNode[]>;
|
|
50
|
-
private selectedIndex;
|
|
51
|
-
private ogirinalSelectedCycle;
|
|
52
|
-
private selectedCycle;
|
|
53
|
-
protected selectedLogsKey: import("@angular/core").Signal<any>;
|
|
54
|
-
protected selectedOriginalValues: import("@angular/core").Signal<any>;
|
|
55
|
-
protected selectedRecalculatedValues: import("@angular/core").Signal<any>;
|
|
56
|
-
protected selectedNode: import("@angular/core").Signal<{
|
|
42
|
+
private readonly showView;
|
|
43
|
+
protected readonly views: import("@angular/core").Signal<View[]>;
|
|
44
|
+
protected readonly selectedView: import("@angular/core").WritableSignal<View>;
|
|
45
|
+
private readonly _allNodes;
|
|
46
|
+
private readonly originalNodes;
|
|
47
|
+
private readonly currentNodes;
|
|
48
|
+
protected readonly originalCycles: import("@angular/core").Signal<ICycleJSONLD[] | groupedNode[]>;
|
|
49
|
+
protected readonly cycles: import("@angular/core").Signal<ICycleJSONLD[] | groupedNode[]>;
|
|
50
|
+
private readonly selectedIndex;
|
|
51
|
+
private readonly ogirinalSelectedCycle;
|
|
52
|
+
private readonly selectedCycle;
|
|
53
|
+
protected readonly selectedLogsKey: import("@angular/core").Signal<any>;
|
|
54
|
+
protected readonly selectedOriginalValues: import("@angular/core").Signal<any>;
|
|
55
|
+
protected readonly selectedRecalculatedValues: import("@angular/core").Signal<any>;
|
|
56
|
+
protected readonly selectedNode: import("@angular/core").Signal<{
|
|
57
57
|
'@type': NodeType;
|
|
58
58
|
type: NodeType;
|
|
59
59
|
dataState: DataState;
|
|
@@ -161,25 +161,25 @@ export declare class CyclesNodesComponent {
|
|
|
161
161
|
updatedVersion?: string[];
|
|
162
162
|
id?: string;
|
|
163
163
|
}>;
|
|
164
|
-
private isOriginal;
|
|
165
|
-
private originalValues;
|
|
166
|
-
private hasRecalculatedNodes;
|
|
167
|
-
protected showSwitchToRecalculated: import("@angular/core").Signal<boolean>;
|
|
168
|
-
protected timelineValues: import("@angular/core").Signal<blankNodesType[]>;
|
|
169
|
-
private enableTimeline;
|
|
170
|
-
protected isNodeKeyAllowed: import("@angular/core").Signal<boolean>;
|
|
171
|
-
private groupedNodes;
|
|
172
|
-
protected groupNodeTerms: import("@angular/core").Signal<Term[]>;
|
|
173
|
-
protected isGroupNode: import("@angular/core").Signal<boolean>;
|
|
174
|
-
protected isEmission: import("@angular/core").Signal<boolean>;
|
|
175
|
-
protected data: import("@angular/core").Signal<groupedEmissions | {
|
|
164
|
+
private readonly isOriginal;
|
|
165
|
+
private readonly originalValues;
|
|
166
|
+
private readonly hasRecalculatedNodes;
|
|
167
|
+
protected readonly showSwitchToRecalculated: import("@angular/core").Signal<boolean>;
|
|
168
|
+
protected readonly timelineValues: import("@angular/core").Signal<blankNodesType[]>;
|
|
169
|
+
private readonly enableTimeline;
|
|
170
|
+
protected readonly isNodeKeyAllowed: import("@angular/core").Signal<boolean>;
|
|
171
|
+
private readonly groupedNodes;
|
|
172
|
+
protected readonly groupNodeTerms: import("@angular/core").Signal<Term[]>;
|
|
173
|
+
protected readonly isGroupNode: import("@angular/core").Signal<boolean>;
|
|
174
|
+
protected readonly isEmission: import("@angular/core").Signal<boolean>;
|
|
175
|
+
protected readonly data: import("@angular/core").Signal<groupedEmissions | {
|
|
176
176
|
[k: string]: IGroupedKeys<Product>[];
|
|
177
177
|
}>;
|
|
178
|
-
protected dataKeys: import("@angular/core").Signal<string[]>;
|
|
179
|
-
protected hasData: import("@angular/core").Signal<boolean>;
|
|
180
|
-
protected filterTermTypes: import("@angular/core").Signal<TermTermType[]>;
|
|
181
|
-
protected filterTerm: import("@angular/core").WritableSignal<string>;
|
|
182
|
-
protected csvFilename: import("@angular/core").Signal<string>;
|
|
178
|
+
protected readonly dataKeys: import("@angular/core").Signal<string[]>;
|
|
179
|
+
protected readonly hasData: import("@angular/core").Signal<boolean>;
|
|
180
|
+
protected readonly filterTermTypes: import("@angular/core").Signal<TermTermType[]>;
|
|
181
|
+
protected readonly filterTerm: import("@angular/core").WritableSignal<string>;
|
|
182
|
+
protected readonly csvFilename: import("@angular/core").Signal<string>;
|
|
183
183
|
constructor();
|
|
184
184
|
private groupNodesByKey;
|
|
185
185
|
private groupEmissions;
|
|
@@ -190,6 +190,7 @@ export declare class CyclesNodesComponent {
|
|
|
190
190
|
};
|
|
191
191
|
}): void;
|
|
192
192
|
protected cycleNode(cycle: ICycleJSONLD | groupedNode): Term | ICycleJSONLD | groupedNode;
|
|
193
|
+
protected showDownload(): void;
|
|
193
194
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesNodesComponent, never>;
|
|
194
195
|
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesNodesComponent, "he-cycles-nodes", never, { "dataState": { "alias": "dataState"; "required": false; "isSignal": true; }; "nodeKeys": { "alias": "nodeKeys"; "required": true; "isSignal": true; }; "nodeKeyGroup": { "alias": "nodeKeyGroup"; "required": false; "isSignal": true; }; }, {}, never, never, true, never>;
|
|
195
196
|
}
|
|
@@ -3,7 +3,7 @@ import { toSignal } from '@angular/core/rxjs-interop';
|
|
|
3
3
|
import { FormsModule } from '@angular/forms';
|
|
4
4
|
import { FaIconComponent } from '@fortawesome/angular-fontawesome';
|
|
5
5
|
import { faCalculator, faDownload, faList } from '@fortawesome/free-solid-svg-icons';
|
|
6
|
-
import { NgbTooltip } from '@ng-bootstrap/ng-bootstrap';
|
|
6
|
+
import { NgbModal, NgbTooltip } from '@ng-bootstrap/ng-bootstrap';
|
|
7
7
|
import { DataState } from '@hestia-earth/api';
|
|
8
8
|
import { NodeType, NonBlankNodesKey } from '@hestia-earth/schema';
|
|
9
9
|
import { keyToLabel } from '@hestia-earth/utils';
|
|
@@ -33,6 +33,7 @@ const headerKeys = ['cycle.id', 'cycle.@id', 'cycle.completeness.'];
|
|
|
33
33
|
const getCompleteness = (cycle) => cycle?.completeness || cycle?.dataCompleteness || {};
|
|
34
34
|
export class CyclesCompletenessComponent {
|
|
35
35
|
constructor() {
|
|
36
|
+
this.modalService = inject(NgbModal);
|
|
36
37
|
this.nodeStoreService = inject(HeNodeStoreService);
|
|
37
38
|
this.faDownload = faDownload;
|
|
38
39
|
this.dataState = input(DataState.original);
|
|
@@ -40,8 +41,6 @@ export class CyclesCompletenessComponent {
|
|
|
40
41
|
this.defaultLabel = defaultLabel;
|
|
41
42
|
this.keyToLabel = keyToLabel;
|
|
42
43
|
this.getCompleteness = getCompleteness;
|
|
43
|
-
this.headerKeys = headerKeys;
|
|
44
|
-
this.showDownload = false;
|
|
45
44
|
this.nodeKey = NonBlankNodesKey.completeness;
|
|
46
45
|
this.View = View;
|
|
47
46
|
this.viewIcon = viewIcon;
|
|
@@ -84,8 +83,16 @@ export class CyclesCompletenessComponent {
|
|
|
84
83
|
selectIndex({ target: { value } }) {
|
|
85
84
|
this.selectedIndex.set(+value);
|
|
86
85
|
}
|
|
86
|
+
showDownload() {
|
|
87
|
+
const instance = this.modalService.open(NodeCsvExportConfirmComponent);
|
|
88
|
+
const component = instance.componentInstance;
|
|
89
|
+
component.nodes.set(this.cycles());
|
|
90
|
+
component.filename.set('completeness.csv');
|
|
91
|
+
component.isUpload.set(false);
|
|
92
|
+
component.headerKeys.set(headerKeys);
|
|
93
|
+
}
|
|
87
94
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: CyclesCompletenessComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
88
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: CyclesCompletenessComponent, isStandalone: true, selector: "he-cycles-completeness", inputs: { dataState: { classPropertyName: "dataState", publicName: "dataState", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"columns is-variable is-align-items-center is-2 m-0\">\n <div class=\"column\">\n @if (selectedView() === View.table) {\n <button
|
|
95
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: CyclesCompletenessComponent, isStandalone: true, selector: "he-cycles-completeness", inputs: { dataState: { classPropertyName: "dataState", publicName: "dataState", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<div class=\"columns is-variable is-align-items-center is-2 m-0\">\n <div class=\"column\">\n @if (selectedView() === View.table) {\n <button class=\"button is-small is-ghost\" (click)=\"showDownload()\">\n <fa-icon [icon]=\"faDownload\" size=\"lg\"></fa-icon>\n </button>\n }\n </div>\n @if (views()?.length > 1) {\n <div class=\"column is-narrow\">\n <div class=\"field has-addons\">\n @for (view of views(); track view) {\n <div class=\"control\">\n <button\n class=\"button is-small\"\n [class.is-selected]=\"selectedView() === view\"\n (click)=\"selectedView.set(view)\">\n <span class=\"icon is-small\">\n <fa-icon [icon]=\"viewIcon[view]\" aria-hidden=\"true\"></fa-icon>\n </span>\n <span class=\"is-hidden-mobile\">{{ view }}</span>\n </button>\n </div>\n }\n </div>\n </div>\n }\n</div>\n\n@switch (selectedView()) {\n @case (View.table) {\n <div class=\"px-3 pb-3\">\n @if (hasData()) {\n <he-data-table class=\"mb-1 is-small\" [small]=\"true\" maxHeight=\"320\">\n <table class=\"table is-narrow is-striped\">\n <thead>\n <tr class=\"has-text-weight-semibold\">\n <th class=\"width-auto has-border-right\"></th>\n @for (completeness of completenessKeys(); track completeness) {\n <th [attr.title]=\"completeness\">\n <a [href]=\"schemaBaseUrl + '/Completeness#' + completeness\" target=\"_blank\">\n {{ keyToLabel(completeness) }}\n </a>\n </th>\n }\n </tr>\n </thead>\n <tbody>\n @for (cycle of cycles(); track trackById(i, cycle); let i = $index) {\n <tr>\n <td class=\"width-auto has-border-right\" [attr.title]=\"defaultLabel(cycle)\">\n <he-node-link [node]=\"cycle\">\n <span>{{ i + 1 }}. {{ defaultLabel(cycle) }}</span>\n </he-node-link>\n </td>\n @for (key of completenessKeys(); track key) {\n <td class=\"is-nowrap\">\n <span>{{ getCompleteness(cycle)[key] ? 'Complete' : 'Incomplete' }}</span>\n <he-blank-node-state\n class=\"ml-1\"\n [dataState]=\"dataState()\"\n [node]=\"getCompleteness(cycle)\"\n [key]=\"key\"></he-blank-node-state>\n </td>\n }\n </tr>\n }\n </tbody>\n </table>\n </he-data-table>\n <he-blank-node-state-notice [dataState]=\"dataState()\"></he-blank-node-state-notice>\n } @else {\n <div class=\"panel-block\">\n <span>No completeness data</span>\n </div>\n }\n </div>\n }\n @case (View.logs) {\n @if (cycles().length > 1) {\n <div class=\"field has-addons pt-2 px-3\">\n <div class=\"control\">\n <span class=\"button is-small is-static is-secondary\">Select a Cycle</span>\n </div>\n <div class=\"control is-expanded\">\n <div class=\"select is-small is-fullwidth is-secondary\">\n <select (change)=\"selectIndex($event)\">\n @for (value of cycles(); track value; let i = $index) {\n <option [value]=\"i\">{{ i + 1 }}. {{ defaultLabel(value) }}</option>\n }\n </select>\n </div>\n </div>\n </div>\n }\n @if (selectedNode()) {\n <he-node-logs-models\n [node]=\"selectedNode()\"\n [nodeKey]=\"nodeKey\"\n [logsKey]=\"selectedLogsKey()\"\n [originalValues]=\"selectedOriginalValues()\"\n [recalculatedValues]=\"selectedRecalculatedValues()\"></he-node-logs-models>\n }\n }\n}\n", styles: [""], 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: "component", type: DataTableComponent, selector: "he-data-table", inputs: ["minHeight", "maxHeight", "small"] }, { kind: "component", type: NodeLinkComponent, selector: "he-node-link", inputs: ["node", "showExternalLink", "linkClass"] }, { kind: "component", type: BlankNodeStateComponent, selector: "he-blank-node-state", inputs: ["dataState", "nodeType", "dataKey", "key", "node", "state", "linkClass"] }, { kind: "component", type: BlankNodeStateNoticeComponent, selector: "he-blank-node-state-notice", inputs: ["dataState", "showDeleted"] }, { 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: NodeLogsModelsComponent, selector: "he-node-logs-models", inputs: ["node", "nodeKey", "originalValues", "recalculatedValues", "terms", "filterTermTypes", "filterTermTypesLabel", "logsKey", "noDataMessage"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
89
96
|
}
|
|
90
97
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: CyclesCompletenessComponent, decorators: [{
|
|
91
98
|
type: Component,
|
|
@@ -97,8 +104,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
97
104
|
BlankNodeStateComponent,
|
|
98
105
|
BlankNodeStateNoticeComponent,
|
|
99
106
|
FormsModule,
|
|
100
|
-
NodeLogsModelsComponent
|
|
101
|
-
|
|
102
|
-
], template: "<div class=\"columns is-variable is-align-items-center is-2 m-0\">\n <div class=\"column\">\n @if (selectedView() === View.table) {\n <button\n class=\"button is-small is-ghost\"\n (click)=\"showDownload = true\"\n ngbTooltip=\"Download as CSV\"\n [disableTooltip]=\"showDownload\"\n placement=\"bottom\">\n <fa-icon [icon]=\"faDownload\" size=\"lg\"></fa-icon>\n </button>\n }\n </div>\n @if (views()?.length > 1) {\n <div class=\"column is-narrow\">\n <div class=\"field has-addons\">\n @for (view of views(); track view) {\n <div class=\"control\">\n <button\n class=\"button is-small\"\n [class.is-selected]=\"selectedView() === view\"\n (click)=\"selectedView.set(view)\">\n <span class=\"icon is-small\">\n <fa-icon [icon]=\"viewIcon[view]\" aria-hidden=\"true\"></fa-icon>\n </span>\n <span class=\"is-hidden-mobile\">{{ view }}</span>\n </button>\n </div>\n }\n </div>\n </div>\n }\n</div>\n\n@switch (selectedView()) {\n @case (View.table) {\n <div class=\"px-3 pb-3\">\n @if (hasData()) {\n <he-data-table class=\"mb-1 is-small\" [small]=\"true\" maxHeight=\"320\">\n <table class=\"table is-narrow is-striped\">\n <thead>\n <tr class=\"has-text-weight-semibold\">\n <th class=\"width-auto has-border-right\"></th>\n @for (completeness of completenessKeys(); track completeness) {\n <th [attr.title]=\"completeness\">\n <a [href]=\"schemaBaseUrl + '/Completeness#' + completeness\" target=\"_blank\">\n {{ keyToLabel(completeness) }}\n </a>\n </th>\n }\n </tr>\n </thead>\n <tbody>\n @for (cycle of cycles(); track trackById(i, cycle); let i = $index) {\n <tr>\n <td class=\"width-auto has-border-right\" [attr.title]=\"defaultLabel(cycle)\">\n <he-node-link [node]=\"cycle\">\n <span>{{ i + 1 }}. {{ defaultLabel(cycle) }}</span>\n </he-node-link>\n </td>\n @for (key of completenessKeys(); track key) {\n <td class=\"is-nowrap\">\n <span>{{ getCompleteness(cycle)[key] ? 'Complete' : 'Incomplete' }}</span>\n <he-blank-node-state\n class=\"ml-1\"\n [dataState]=\"dataState()\"\n [node]=\"getCompleteness(cycle)\"\n [key]=\"key\"></he-blank-node-state>\n </td>\n }\n </tr>\n }\n </tbody>\n </table>\n </he-data-table>\n <he-blank-node-state-notice [dataState]=\"dataState()\"></he-blank-node-state-notice>\n } @else {\n <div class=\"panel-block\">\n <span>No completeness data</span>\n </div>\n }\n </div>\n }\n @case (View.logs) {\n @if (cycles().length > 1) {\n <div class=\"field has-addons pt-2 px-3\">\n <div class=\"control\">\n <span class=\"button is-small is-static is-secondary\">Select a Cycle</span>\n </div>\n <div class=\"control is-expanded\">\n <div class=\"select is-small is-fullwidth is-secondary\">\n <select (change)=\"selectIndex($event)\">\n @for (value of cycles(); track value; let i = $index) {\n <option [value]=\"i\">{{ i + 1 }}. {{ defaultLabel(value) }}</option>\n }\n </select>\n </div>\n </div>\n </div>\n }\n @if (selectedNode()) {\n <he-node-logs-models\n [node]=\"selectedNode()\"\n [nodeKey]=\"nodeKey\"\n [logsKey]=\"selectedLogsKey()\"\n [originalValues]=\"selectedOriginalValues()\"\n [recalculatedValues]=\"selectedRecalculatedValues()\"></he-node-logs-models>\n }\n }\n}\n\n@if (showDownload) {\n <he-node-csv-export-confirm\n [nodes]=\"cycles()\"\n filename=\"completeness.csv\"\n [isUpload]=\"false\"\n [headerKeys]=\"headerKeys\"\n (closed)=\"showDownload = false\"></he-node-csv-export-confirm>\n}\n" }]
|
|
107
|
+
NodeLogsModelsComponent
|
|
108
|
+
], template: "<div class=\"columns is-variable is-align-items-center is-2 m-0\">\n <div class=\"column\">\n @if (selectedView() === View.table) {\n <button class=\"button is-small is-ghost\" (click)=\"showDownload()\">\n <fa-icon [icon]=\"faDownload\" size=\"lg\"></fa-icon>\n </button>\n }\n </div>\n @if (views()?.length > 1) {\n <div class=\"column is-narrow\">\n <div class=\"field has-addons\">\n @for (view of views(); track view) {\n <div class=\"control\">\n <button\n class=\"button is-small\"\n [class.is-selected]=\"selectedView() === view\"\n (click)=\"selectedView.set(view)\">\n <span class=\"icon is-small\">\n <fa-icon [icon]=\"viewIcon[view]\" aria-hidden=\"true\"></fa-icon>\n </span>\n <span class=\"is-hidden-mobile\">{{ view }}</span>\n </button>\n </div>\n }\n </div>\n </div>\n }\n</div>\n\n@switch (selectedView()) {\n @case (View.table) {\n <div class=\"px-3 pb-3\">\n @if (hasData()) {\n <he-data-table class=\"mb-1 is-small\" [small]=\"true\" maxHeight=\"320\">\n <table class=\"table is-narrow is-striped\">\n <thead>\n <tr class=\"has-text-weight-semibold\">\n <th class=\"width-auto has-border-right\"></th>\n @for (completeness of completenessKeys(); track completeness) {\n <th [attr.title]=\"completeness\">\n <a [href]=\"schemaBaseUrl + '/Completeness#' + completeness\" target=\"_blank\">\n {{ keyToLabel(completeness) }}\n </a>\n </th>\n }\n </tr>\n </thead>\n <tbody>\n @for (cycle of cycles(); track trackById(i, cycle); let i = $index) {\n <tr>\n <td class=\"width-auto has-border-right\" [attr.title]=\"defaultLabel(cycle)\">\n <he-node-link [node]=\"cycle\">\n <span>{{ i + 1 }}. {{ defaultLabel(cycle) }}</span>\n </he-node-link>\n </td>\n @for (key of completenessKeys(); track key) {\n <td class=\"is-nowrap\">\n <span>{{ getCompleteness(cycle)[key] ? 'Complete' : 'Incomplete' }}</span>\n <he-blank-node-state\n class=\"ml-1\"\n [dataState]=\"dataState()\"\n [node]=\"getCompleteness(cycle)\"\n [key]=\"key\"></he-blank-node-state>\n </td>\n }\n </tr>\n }\n </tbody>\n </table>\n </he-data-table>\n <he-blank-node-state-notice [dataState]=\"dataState()\"></he-blank-node-state-notice>\n } @else {\n <div class=\"panel-block\">\n <span>No completeness data</span>\n </div>\n }\n </div>\n }\n @case (View.logs) {\n @if (cycles().length > 1) {\n <div class=\"field has-addons pt-2 px-3\">\n <div class=\"control\">\n <span class=\"button is-small is-static is-secondary\">Select a Cycle</span>\n </div>\n <div class=\"control is-expanded\">\n <div class=\"select is-small is-fullwidth is-secondary\">\n <select (change)=\"selectIndex($event)\">\n @for (value of cycles(); track value; let i = $index) {\n <option [value]=\"i\">{{ i + 1 }}. {{ defaultLabel(value) }}</option>\n }\n </select>\n </div>\n </div>\n </div>\n }\n @if (selectedNode()) {\n <he-node-logs-models\n [node]=\"selectedNode()\"\n [nodeKey]=\"nodeKey\"\n [logsKey]=\"selectedLogsKey()\"\n [originalValues]=\"selectedOriginalValues()\"\n [recalculatedValues]=\"selectedRecalculatedValues()\"></he-node-logs-models>\n }\n }\n}\n" }]
|
|
103
109
|
}], ctorParameters: () => [] });
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cycles-completeness.component.js","sourceRoot":"","sources":["../../../../src/cycles/cycles-completeness/cycles-completeness.component.ts","../../../../src/cycles/cycles-completeness/cycles-completeness.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, effect, inject, input, signal } from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { FormsModule } from '@angular/forms';\nimport { FaIconComponent } from '@fortawesome/angular-fontawesome';\nimport { IconDefinition, faCalculator, faDownload, faList } from '@fortawesome/free-solid-svg-icons';\nimport { NgbTooltip } from '@ng-bootstrap/ng-bootstrap';\nimport { DataState } from '@hestia-earth/api';\nimport { ICycleJSONLD, NodeType, NonBlankNodesKey } from '@hestia-earth/schema';\nimport { keyToLabel } from '@hestia-earth/utils';\n\nimport { HeNodeStoreService } from '../../node/node-store.service';\nimport { isValidKey } from '../../common/node-utils';\nimport { defaultLabel, schemaBaseUrl } from '../../common/utils';\nimport { logsKey } from '../cycles.model';\nimport { NodeCsvExportConfirmComponent } from '../../node/node-csv-export-confirm/node-csv-export-confirm.component';\nimport { NodeLogsModelsComponent } from '../../node/node-logs-models/node-logs-models.component';\nimport { BlankNodeStateNoticeComponent } from '../../common/blank-node-state-notice/blank-node-state-notice.component';\nimport { BlankNodeStateComponent } from '../../common/blank-node-state/blank-node-state.component';\nimport { NodeLinkComponent } from '../../node/node-link/node-link.component';\nimport { DataTableComponent } from '../../common/data-table/data-table.component';\n\nenum View {\n  table = 'Table view',\n  logs = 'Recalculations logs'\n}\n\nconst viewIcon: {\n  [view in View]: IconDefinition;\n} = {\n  [View.logs]: faCalculator,\n  [View.table]: faList\n};\n\nconst headerKeys = ['cycle.id', 'cycle.@id', 'cycle.completeness.'];\n\n// backward compatibility with schema version < 14\nconst getCompleteness = (cycle: any) => cycle?.completeness || cycle?.dataCompleteness || {};\n\n@Component({\n  selector: 'he-cycles-completeness',\n  templateUrl: './cycles-completeness.component.html',\n  styleUrls: ['./cycles-completeness.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgbTooltip,\n    FaIconComponent,\n    DataTableComponent,\n    NodeLinkComponent,\n    BlankNodeStateComponent,\n    BlankNodeStateNoticeComponent,\n    FormsModule,\n    NodeLogsModelsComponent,\n    NodeCsvExportConfirmComponent\n  ]\n})\nexport class CyclesCompletenessComponent {\n  private nodeStoreService = inject(HeNodeStoreService);\n\n  protected readonly faDownload = faDownload;\n\n  protected dataState = input(DataState.original);\n\n  protected schemaBaseUrl = schemaBaseUrl();\n  protected defaultLabel = defaultLabel;\n  protected keyToLabel = keyToLabel;\n  protected getCompleteness = getCompleteness;\n  protected headerKeys = headerKeys;\n  protected showDownload = false;\n  protected nodeKey = NonBlankNodesKey.completeness;\n\n  protected View = View;\n  protected viewIcon = viewIcon;\n  private showView = computed(\n    () =>\n      ({\n        [View.logs]: !this.isOriginal(),\n        [View.table]: true\n      }) as { [view in View]: boolean }\n  );\n  protected views = computed(() => Object.values(View).filter(view => this.showView()[view]) ?? []);\n  protected selectedView = signal(View.table);\n\n  private originalCycles = toSignal(\n    this.nodeStoreService.findByState$<ICycleJSONLD>(NodeType.Cycle, DataState.original)\n  );\n  private _allCycles = toSignal(this.nodeStoreService.find$<ICycleJSONLD>(NodeType.Cycle));\n  protected cycles = computed(() => this._allCycles()?.map(data => data[this.dataState()]) || []);\n\n  private selectedIndex = signal(0);\n  private ogirinalSelectedCycle = computed(() => this.originalCycles()?.[this.selectedIndex()]);\n  private selectedCycle = computed(() => this.cycles()?.[this.selectedIndex()]);\n  protected selectedLogsKey = computed(() => logsKey(this.selectedCycle()));\n  protected selectedOriginalValues = computed(() => getCompleteness(this.ogirinalSelectedCycle()));\n  protected selectedRecalculatedValues = computed(() => getCompleteness(this.selectedCycle()));\n  protected selectedNode = computed(() =>\n    this.selectedCycle()\n      ? {\n          ...this.selectedCycle(),\n          '@type': NodeType.Cycle,\n          type: NodeType.Cycle,\n          dataState: DataState.recalculated\n        }\n      : null\n  );\n\n  protected hasData = computed(() => this.cycles().length);\n  protected isOriginal = computed(() => this.dataState() === DataState.original);\n\n  protected completenessKeys = computed(() =>\n    Object.keys(getCompleteness(this.selectedCycle())).filter(isValidKey).sort()\n  );\n\n  constructor() {\n    effect(() => {\n      // make sure logs does not remain displayed when switching back to original view\n      if (this.isOriginal() && this.selectedView() === View.logs) {\n        this.selectedView.set(View.table);\n      }\n    });\n  }\n\n  protected trackById(_index: number, item: ICycleJSONLD) {\n    return item['@id'];\n  }\n\n  protected selectIndex({ target: { value } }) {\n    this.selectedIndex.set(+value);\n  }\n}\n","<div class=\"columns is-variable is-align-items-center is-2 m-0\">\n  <div class=\"column\">\n    @if (selectedView() === View.table) {\n      <button\n        class=\"button is-small is-ghost\"\n        (click)=\"showDownload = true\"\n        ngbTooltip=\"Download as CSV\"\n        [disableTooltip]=\"showDownload\"\n        placement=\"bottom\">\n        <fa-icon [icon]=\"faDownload\" size=\"lg\"></fa-icon>\n      </button>\n    }\n  </div>\n  @if (views()?.length > 1) {\n    <div class=\"column is-narrow\">\n      <div class=\"field has-addons\">\n        @for (view of views(); track view) {\n          <div class=\"control\">\n            <button\n              class=\"button is-small\"\n              [class.is-selected]=\"selectedView() === view\"\n              (click)=\"selectedView.set(view)\">\n              <span class=\"icon is-small\">\n                <fa-icon [icon]=\"viewIcon[view]\" aria-hidden=\"true\"></fa-icon>\n              </span>\n              <span class=\"is-hidden-mobile\">{{ view }}</span>\n            </button>\n          </div>\n        }\n      </div>\n    </div>\n  }\n</div>\n\n@switch (selectedView()) {\n  @case (View.table) {\n    <div class=\"px-3 pb-3\">\n      @if (hasData()) {\n        <he-data-table class=\"mb-1 is-small\" [small]=\"true\" maxHeight=\"320\">\n          <table class=\"table is-narrow is-striped\">\n            <thead>\n              <tr class=\"has-text-weight-semibold\">\n                <th class=\"width-auto has-border-right\"></th>\n                @for (completeness of completenessKeys(); track completeness) {\n                  <th [attr.title]=\"completeness\">\n                    <a [href]=\"schemaBaseUrl + '/Completeness#' + completeness\" target=\"_blank\">\n                      {{ keyToLabel(completeness) }}\n                    </a>\n                  </th>\n                }\n              </tr>\n            </thead>\n            <tbody>\n              @for (cycle of cycles(); track trackById(i, cycle); let i = $index) {\n                <tr>\n                  <td class=\"width-auto has-border-right\" [attr.title]=\"defaultLabel(cycle)\">\n                    <he-node-link [node]=\"cycle\">\n                      <span>{{ i + 1 }}. {{ defaultLabel(cycle) }}</span>\n                    </he-node-link>\n                  </td>\n                  @for (key of completenessKeys(); track key) {\n                    <td class=\"is-nowrap\">\n                      <span>{{ getCompleteness(cycle)[key] ? 'Complete' : 'Incomplete' }}</span>\n                      <he-blank-node-state\n                        class=\"ml-1\"\n                        [dataState]=\"dataState()\"\n                        [node]=\"getCompleteness(cycle)\"\n                        [key]=\"key\"></he-blank-node-state>\n                    </td>\n                  }\n                </tr>\n              }\n            </tbody>\n          </table>\n        </he-data-table>\n        <he-blank-node-state-notice [dataState]=\"dataState()\"></he-blank-node-state-notice>\n      } @else {\n        <div class=\"panel-block\">\n          <span>No completeness data</span>\n        </div>\n      }\n    </div>\n  }\n  @case (View.logs) {\n    @if (cycles().length > 1) {\n      <div class=\"field has-addons pt-2 px-3\">\n        <div class=\"control\">\n          <span class=\"button is-small is-static is-secondary\">Select a Cycle</span>\n        </div>\n        <div class=\"control is-expanded\">\n          <div class=\"select is-small is-fullwidth is-secondary\">\n            <select (change)=\"selectIndex($event)\">\n              @for (value of cycles(); track value; let i = $index) {\n                <option [value]=\"i\">{{ i + 1 }}. {{ defaultLabel(value) }}</option>\n              }\n            </select>\n          </div>\n        </div>\n      </div>\n    }\n    @if (selectedNode()) {\n      <he-node-logs-models\n        [node]=\"selectedNode()\"\n        [nodeKey]=\"nodeKey\"\n        [logsKey]=\"selectedLogsKey()\"\n        [originalValues]=\"selectedOriginalValues()\"\n        [recalculatedValues]=\"selectedRecalculatedValues()\"></he-node-logs-models>\n    }\n  }\n}\n\n@if (showDownload) {\n  <he-node-csv-export-confirm\n    [nodes]=\"cycles()\"\n    filename=\"completeness.csv\"\n    [isUpload]=\"false\"\n    [headerKeys]=\"headerKeys\"\n    (closed)=\"showDownload = false\"></he-node-csv-export-confirm>\n}\n"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cycles-completeness.component.js","sourceRoot":"","sources":["../../../../src/cycles/cycles-completeness/cycles-completeness.component.ts","../../../../src/cycles/cycles-completeness/cycles-completeness.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAC5G,OAAO,EAAE,QAAQ,EAAE,MAAM,4BAA4B,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAkB,YAAY,EAAE,UAAU,EAAE,MAAM,EAAE,MAAM,mCAAmC,CAAC;AACrG,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAC;AAClE,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAC9C,OAAO,EAAgB,QAAQ,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAChF,OAAO,EAAE,UAAU,EAAE,MAAM,qBAAqB,CAAC;AAEjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AACnE,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,6BAA6B,EAAE,MAAM,sEAAsE,CAAC;AACrH,OAAO,EAAE,uBAAuB,EAAE,MAAM,wDAAwD,CAAC;AACjG,OAAO,EAAE,6BAA6B,EAAE,MAAM,wEAAwE,CAAC;AACvH,OAAO,EAAE,uBAAuB,EAAE,MAAM,0DAA0D,CAAC;AACnG,OAAO,EAAE,iBAAiB,EAAE,MAAM,0CAA0C,CAAC;AAC7E,OAAO,EAAE,kBAAkB,EAAE,MAAM,8CAA8C,CAAC;;;AAElF,IAAK,IAGJ;AAHD,WAAK,IAAI;IACP,4BAAoB,CAAA;IACpB,oCAA4B,CAAA;AAC9B,CAAC,EAHI,IAAI,KAAJ,IAAI,QAGR;AAED,MAAM,QAAQ,GAEV;IACF,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,YAAY;IACzB,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,MAAM;CACrB,CAAC;AAEF,MAAM,UAAU,GAAG,CAAC,UAAU,EAAE,WAAW,EAAE,qBAAqB,CAAC,CAAC;AAEpE,kDAAkD;AAClD,MAAM,eAAe,GAAG,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,EAAE,YAAY,IAAI,KAAK,EAAE,gBAAgB,IAAI,EAAE,CAAC;AAmB7F,MAAM,OAAO,2BAA2B;IAwDtC;QAvDiB,iBAAY,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;QAChC,qBAAgB,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QAE5C,eAAU,GAAG,UAAU,CAAC;QAExB,cAAS,GAAG,KAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;QAEtC,kBAAa,GAAG,aAAa,EAAE,CAAC;QAChC,iBAAY,GAAG,YAAY,CAAC;QAC5B,eAAU,GAAG,UAAU,CAAC;QACxB,oBAAe,GAAG,eAAe,CAAC;QAClC,YAAO,GAAG,gBAAgB,CAAC,YAAY,CAAC;QAExC,SAAI,GAAG,IAAI,CAAC;QACZ,aAAQ,GAAG,QAAQ,CAAC;QACtB,aAAQ,GAAG,QAAQ,CAClC,GAAG,EAAE,CACH,CAAC;YACC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE;YAC/B,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,IAAI;SACnB,CAAgC,CACpC,CAAC;QACiB,UAAK,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;QACxF,iBAAY,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAEpC,mBAAc,GAAG,QAAQ,CACxC,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAe,QAAQ,CAAC,KAAK,EAAE,SAAS,CAAC,QAAQ,CAAC,CACrF,CAAC;QACe,eAAU,GAAG,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAe,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QAC/E,WAAM,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;QAExF,kBAAa,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;QAC1B,0BAAqB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;QACtF,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;QACpE,oBAAe,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;QAChE,2BAAsB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAC;QACvF,+BAA0B,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC;QACnF,iBAAY,GAAG,QAAQ,CAAC,GAAG,EAAE,CAC9C,IAAI,CAAC,aAAa,EAAE;YAClB,CAAC,CAAC;gBACE,GAAG,IAAI,CAAC,aAAa,EAAE;gBACvB,OAAO,EAAE,QAAQ,CAAC,KAAK;gBACvB,IAAI,EAAE,QAAQ,CAAC,KAAK;gBACpB,SAAS,EAAE,SAAS,CAAC,YAAY;aAClC;YACH,CAAC,CAAC,IAAI,CACT,CAAC;QAEiB,YAAO,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,MAAM,CAAC,CAAC;QAC/C,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,SAAS,CAAC,QAAQ,CAAC,CAAC;QAErE,qBAAgB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAClD,MAAM,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,IAAI,EAAE,CAC7E,CAAC;QAGA,MAAM,CAAC,GAAG,EAAE;YACV,gFAAgF;YAChF,IAAI,IAAI,CAAC,UAAU,EAAE,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,IAAI,CAAC,IAAI,EAAE,CAAC;gBAC3D,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACpC,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAES,SAAS,CAAC,MAAc,EAAE,IAAkB;QACpD,OAAO,IAAI,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC;IAES,WAAW,CAAC,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,EAAE;QACzC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC,CAAC;IACjC,CAAC;IAES,YAAY;QACpB,MAAM,QAAQ,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,6BAA6B,CAAC,CAAC;QACvE,MAAM,SAAS,GAAG,QAAQ,CAAC,iBAAkD,CAAC;QAC9E,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;QACnC,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;QAC3C,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC9B,SAAS,CAAC,UAAU,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACvC,CAAC;+GAhFU,2BAA2B;mGAA3B,2BAA2B,kOCvDxC,68HAyGA,0DD3DI,eAAe,kPACf,kBAAkB,uGAClB,iBAAiB,4GACjB,uBAAuB,mJACvB,6BAA6B,4GAC7B,WAAW,4OACX,uBAAuB;;4FAGd,2BAA2B;kBAjBvC,SAAS;+BACE,wBAAwB,mBAGjB,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACP,UAAU;wBACV,eAAe;wBACf,kBAAkB;wBAClB,iBAAiB;wBACjB,uBAAuB;wBACvB,6BAA6B;wBAC7B,WAAW;wBACX,uBAAuB;qBACxB","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, effect, inject, input, signal } from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { FormsModule } from '@angular/forms';\nimport { FaIconComponent } from '@fortawesome/angular-fontawesome';\nimport { IconDefinition, faCalculator, faDownload, faList } from '@fortawesome/free-solid-svg-icons';\nimport { NgbModal, NgbTooltip } from '@ng-bootstrap/ng-bootstrap';\nimport { DataState } from '@hestia-earth/api';\nimport { ICycleJSONLD, NodeType, NonBlankNodesKey } from '@hestia-earth/schema';\nimport { keyToLabel } from '@hestia-earth/utils';\n\nimport { HeNodeStoreService } from '../../node/node-store.service';\nimport { isValidKey } from '../../common/node-utils';\nimport { defaultLabel, schemaBaseUrl } from '../../common/utils';\nimport { logsKey } from '../cycles.model';\nimport { NodeCsvExportConfirmComponent } from '../../node/node-csv-export-confirm/node-csv-export-confirm.component';\nimport { NodeLogsModelsComponent } from '../../node/node-logs-models/node-logs-models.component';\nimport { BlankNodeStateNoticeComponent } from '../../common/blank-node-state-notice/blank-node-state-notice.component';\nimport { BlankNodeStateComponent } from '../../common/blank-node-state/blank-node-state.component';\nimport { NodeLinkComponent } from '../../node/node-link/node-link.component';\nimport { DataTableComponent } from '../../common/data-table/data-table.component';\n\nenum View {\n  table = 'Table view',\n  logs = 'Recalculations logs'\n}\n\nconst viewIcon: {\n  [view in View]: IconDefinition;\n} = {\n  [View.logs]: faCalculator,\n  [View.table]: faList\n};\n\nconst headerKeys = ['cycle.id', 'cycle.@id', 'cycle.completeness.'];\n\n// backward compatibility with schema version < 14\nconst getCompleteness = (cycle: any) => cycle?.completeness || cycle?.dataCompleteness || {};\n\n@Component({\n  selector: 'he-cycles-completeness',\n  templateUrl: './cycles-completeness.component.html',\n  styleUrls: ['./cycles-completeness.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgbTooltip,\n    FaIconComponent,\n    DataTableComponent,\n    NodeLinkComponent,\n    BlankNodeStateComponent,\n    BlankNodeStateNoticeComponent,\n    FormsModule,\n    NodeLogsModelsComponent\n  ]\n})\nexport class CyclesCompletenessComponent {\n  private readonly modalService = inject(NgbModal);\n  private readonly nodeStoreService = inject(HeNodeStoreService);\n\n  protected readonly faDownload = faDownload;\n\n  protected readonly dataState = input(DataState.original);\n\n  protected readonly schemaBaseUrl = schemaBaseUrl();\n  protected readonly defaultLabel = defaultLabel;\n  protected readonly keyToLabel = keyToLabel;\n  protected readonly getCompleteness = getCompleteness;\n  protected readonly nodeKey = NonBlankNodesKey.completeness;\n\n  protected readonly View = View;\n  protected readonly viewIcon = viewIcon;\n  private readonly showView = computed(\n    () =>\n      ({\n        [View.logs]: !this.isOriginal(),\n        [View.table]: true\n      }) as { [view in View]: boolean }\n  );\n  protected readonly views = computed(() => Object.values(View).filter(view => this.showView()[view]) ?? []);\n  protected readonly selectedView = signal(View.table);\n\n  private readonly originalCycles = toSignal(\n    this.nodeStoreService.findByState$<ICycleJSONLD>(NodeType.Cycle, DataState.original)\n  );\n  private readonly _allCycles = toSignal(this.nodeStoreService.find$<ICycleJSONLD>(NodeType.Cycle));\n  protected readonly cycles = computed(() => this._allCycles()?.map(data => data[this.dataState()]) || []);\n\n  private readonly selectedIndex = signal(0);\n  private readonly ogirinalSelectedCycle = computed(() => this.originalCycles()?.[this.selectedIndex()]);\n  private readonly selectedCycle = computed(() => this.cycles()?.[this.selectedIndex()]);\n  protected readonly selectedLogsKey = computed(() => logsKey(this.selectedCycle()));\n  protected readonly selectedOriginalValues = computed(() => getCompleteness(this.ogirinalSelectedCycle()));\n  protected readonly selectedRecalculatedValues = computed(() => getCompleteness(this.selectedCycle()));\n  protected readonly selectedNode = computed(() =>\n    this.selectedCycle()\n      ? {\n          ...this.selectedCycle(),\n          '@type': NodeType.Cycle,\n          type: NodeType.Cycle,\n          dataState: DataState.recalculated\n        }\n      : null\n  );\n\n  protected readonly hasData = computed(() => this.cycles().length);\n  protected readonly isOriginal = computed(() => this.dataState() === DataState.original);\n\n  protected readonly completenessKeys = computed(() =>\n    Object.keys(getCompleteness(this.selectedCycle())).filter(isValidKey).sort()\n  );\n\n  constructor() {\n    effect(() => {\n      // make sure logs does not remain displayed when switching back to original view\n      if (this.isOriginal() && this.selectedView() === View.logs) {\n        this.selectedView.set(View.table);\n      }\n    });\n  }\n\n  protected trackById(_index: number, item: ICycleJSONLD) {\n    return item['@id'];\n  }\n\n  protected selectIndex({ target: { value } }) {\n    this.selectedIndex.set(+value);\n  }\n\n  protected showDownload() {\n    const instance = this.modalService.open(NodeCsvExportConfirmComponent);\n    const component = instance.componentInstance as NodeCsvExportConfirmComponent;\n    component.nodes.set(this.cycles());\n    component.filename.set('completeness.csv');\n    component.isUpload.set(false);\n    component.headerKeys.set(headerKeys);\n  }\n}\n","<div class=\"columns is-variable is-align-items-center is-2 m-0\">\n  <div class=\"column\">\n    @if (selectedView() === View.table) {\n      <button class=\"button is-small is-ghost\" (click)=\"showDownload()\">\n        <fa-icon [icon]=\"faDownload\" size=\"lg\"></fa-icon>\n      </button>\n    }\n  </div>\n  @if (views()?.length > 1) {\n    <div class=\"column is-narrow\">\n      <div class=\"field has-addons\">\n        @for (view of views(); track view) {\n          <div class=\"control\">\n            <button\n              class=\"button is-small\"\n              [class.is-selected]=\"selectedView() === view\"\n              (click)=\"selectedView.set(view)\">\n              <span class=\"icon is-small\">\n                <fa-icon [icon]=\"viewIcon[view]\" aria-hidden=\"true\"></fa-icon>\n              </span>\n              <span class=\"is-hidden-mobile\">{{ view }}</span>\n            </button>\n          </div>\n        }\n      </div>\n    </div>\n  }\n</div>\n\n@switch (selectedView()) {\n  @case (View.table) {\n    <div class=\"px-3 pb-3\">\n      @if (hasData()) {\n        <he-data-table class=\"mb-1 is-small\" [small]=\"true\" maxHeight=\"320\">\n          <table class=\"table is-narrow is-striped\">\n            <thead>\n              <tr class=\"has-text-weight-semibold\">\n                <th class=\"width-auto has-border-right\"></th>\n                @for (completeness of completenessKeys(); track completeness) {\n                  <th [attr.title]=\"completeness\">\n                    <a [href]=\"schemaBaseUrl + '/Completeness#' + completeness\" target=\"_blank\">\n                      {{ keyToLabel(completeness) }}\n                    </a>\n                  </th>\n                }\n              </tr>\n            </thead>\n            <tbody>\n              @for (cycle of cycles(); track trackById(i, cycle); let i = $index) {\n                <tr>\n                  <td class=\"width-auto has-border-right\" [attr.title]=\"defaultLabel(cycle)\">\n                    <he-node-link [node]=\"cycle\">\n                      <span>{{ i + 1 }}. {{ defaultLabel(cycle) }}</span>\n                    </he-node-link>\n                  </td>\n                  @for (key of completenessKeys(); track key) {\n                    <td class=\"is-nowrap\">\n                      <span>{{ getCompleteness(cycle)[key] ? 'Complete' : 'Incomplete' }}</span>\n                      <he-blank-node-state\n                        class=\"ml-1\"\n                        [dataState]=\"dataState()\"\n                        [node]=\"getCompleteness(cycle)\"\n                        [key]=\"key\"></he-blank-node-state>\n                    </td>\n                  }\n                </tr>\n              }\n            </tbody>\n          </table>\n        </he-data-table>\n        <he-blank-node-state-notice [dataState]=\"dataState()\"></he-blank-node-state-notice>\n      } @else {\n        <div class=\"panel-block\">\n          <span>No completeness data</span>\n        </div>\n      }\n    </div>\n  }\n  @case (View.logs) {\n    @if (cycles().length > 1) {\n      <div class=\"field has-addons pt-2 px-3\">\n        <div class=\"control\">\n          <span class=\"button is-small is-static is-secondary\">Select a Cycle</span>\n        </div>\n        <div class=\"control is-expanded\">\n          <div class=\"select is-small is-fullwidth is-secondary\">\n            <select (change)=\"selectIndex($event)\">\n              @for (value of cycles(); track value; let i = $index) {\n                <option [value]=\"i\">{{ i + 1 }}. {{ defaultLabel(value) }}</option>\n              }\n            </select>\n          </div>\n        </div>\n      </div>\n    }\n    @if (selectedNode()) {\n      <he-node-logs-models\n        [node]=\"selectedNode()\"\n        [nodeKey]=\"nodeKey\"\n        [logsKey]=\"selectedLogsKey()\"\n        [originalValues]=\"selectedOriginalValues()\"\n        [recalculatedValues]=\"selectedRecalculatedValues()\"></he-node-logs-models>\n    }\n  }\n}\n"]}
|