@hestia-earth/ui-components 0.2.12 → 0.3.2
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/bundles/hestia-earth-ui-components.umd.js +474 -473
- package/bundles/hestia-earth-ui-components.umd.js.map +1 -1
- package/common/clipboard/clipboard.component.d.ts +1 -0
- package/cycles/cycles-activity/cycles-activity.component.d.ts +1 -3
- package/cycles/cycles-activity-logs/cycles-activity-logs.component.d.ts +42 -10
- package/cycles/cycles-completeness/cycles-completeness.component.d.ts +1 -3
- package/cycles/cycles-emissions/cycles-emissions.component.d.ts +1 -3
- package/cycles/cycles-emissions-chart/cycles-emissions-chart.component.d.ts +1 -2
- package/cycles/cycles-emissions-logs/cycles-emissions-logs.component.d.ts +42 -6
- package/cycles/cycles-practices/cycles-practices.component.d.ts +1 -3
- package/cycles/cycles-practices-logs/cycles-practices-logs.component.d.ts +42 -10
- package/cycles/cycles-result/cycles-result.component.d.ts +1 -3
- package/cycles/cycles.model.d.ts +3 -4
- package/esm2015/common/clipboard/clipboard.component.js +5 -3
- package/esm2015/cycles/cycles-activity/cycles-activity.component.js +2 -8
- package/esm2015/cycles/cycles-activity-logs/cycles-activity-logs.component.js +11 -21
- package/esm2015/cycles/cycles-completeness/cycles-completeness.component.js +2 -8
- package/esm2015/cycles/cycles-emissions/cycles-emissions.component.js +2 -8
- package/esm2015/cycles/cycles-emissions-chart/cycles-emissions-chart.component.js +4 -9
- package/esm2015/cycles/cycles-emissions-logs/cycles-emissions-logs.component.js +12 -14
- package/esm2015/cycles/cycles-practices/cycles-practices.component.js +2 -8
- package/esm2015/cycles/cycles-practices-logs/cycles-practices-logs.component.js +10 -21
- package/esm2015/cycles/cycles-result/cycles-result.component.js +4 -12
- package/esm2015/cycles/cycles.model.js +4 -5
- package/esm2015/files/files-form/files-form.component.js +1 -1
- package/esm2015/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.js +4 -9
- package/esm2015/impact-assessments/impact-assessments-products/impact-assessments-products.component.js +2 -8
- package/esm2015/impact-assessments/impact-assessments-products-logs/impact-assessments-products-logs.component.js +8 -12
- package/esm2015/node/index.js +2 -1
- package/esm2015/node/node-link/node-link.component.js +2 -2
- package/esm2015/node/node-logs-models/node-logs-models.component.js +56 -326
- package/esm2015/node/node-logs-models/node-logs-models.model.js +370 -0
- package/esm2015/node/node-missing-lookup-factors/node-missing-lookup-factors.component.js +1 -1
- package/esm2015/node/node-value-details/node-value-details.component.js +3 -3
- package/esm2015/node/node.service.js +1 -1
- package/esm2015/sites/sites-maps/sites-maps.component.js +3 -9
- package/esm2015/sites/sites-measurements/sites-measurements.component.js +2 -8
- package/esm2015/sites/sites-measurements-logs/sites-measurements-logs.component.js +8 -12
- package/fesm2015/hestia-earth-ui-components.js +339 -328
- package/fesm2015/hestia-earth-ui-components.js.map +1 -1
- package/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.d.ts +1 -2
- package/impact-assessments/impact-assessments-products/impact-assessments-products.component.d.ts +1 -3
- package/impact-assessments/impact-assessments-products-logs/impact-assessments-products-logs.component.d.ts +37 -6
- package/node/index.d.ts +1 -0
- package/node/node-logs-models/node-logs-models.component.d.ts +24 -88
- package/node/node-logs-models/node-logs-models.model.d.ts +88 -0
- package/node/node-missing-lookup-factors/node-missing-lookup-factors.component.d.ts +2 -1
- package/node/node.service.d.ts +1 -31
- package/package.json +2 -2
- package/sites/sites-maps/sites-maps.component.d.ts +1 -3
- package/sites/sites-measurements/sites-measurements.component.d.ts +1 -3
- package/sites/sites-measurements-logs/sites-measurements-logs.component.d.ts +39 -6
|
@@ -10,7 +10,6 @@ declare enum View {
|
|
|
10
10
|
export declare class CyclesActivityComponent implements OnChanges {
|
|
11
11
|
originalValues: ICycleJSONLD[];
|
|
12
12
|
cycles: ICycleJSONLD[];
|
|
13
|
-
selected: string[];
|
|
14
13
|
dataState?: DataState;
|
|
15
14
|
enableCompare: boolean;
|
|
16
15
|
baseUrl: string;
|
|
@@ -27,13 +26,12 @@ export declare class CyclesActivityComponent implements OnChanges {
|
|
|
27
26
|
get isOriginal(): boolean;
|
|
28
27
|
private update;
|
|
29
28
|
togglePopover(popover: any, context: any): any;
|
|
30
|
-
isSelected(cycle: ICycleJSONLD): boolean;
|
|
31
29
|
selectIndex({ target: { value } }: {
|
|
32
30
|
target: {
|
|
33
31
|
value: any;
|
|
34
32
|
};
|
|
35
33
|
}): void;
|
|
36
34
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesActivityComponent, never>;
|
|
37
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesActivityComponent, "he-cycles-activity", never, { "originalValues": "originalValues"; "cycles": "cycles"; "
|
|
35
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesActivityComponent, "he-cycles-activity", never, { "originalValues": "originalValues"; "cycles": "cycles"; "dataState": "dataState"; "enableCompare": "enableCompare"; }, {}, never, never>;
|
|
38
36
|
}
|
|
39
37
|
export {};
|
|
@@ -1,25 +1,57 @@
|
|
|
1
|
-
import { OnInit } from '@angular/core';
|
|
2
1
|
import { ICycleJSONLD, NodeType } from '@hestia-earth/schema';
|
|
3
|
-
import {
|
|
2
|
+
import { DataState } from '@hestia-earth/api';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
4
|
declare enum Tab {
|
|
6
5
|
inputs = "Inputs",
|
|
7
6
|
products = "Products"
|
|
8
7
|
}
|
|
9
|
-
export declare class CyclesActivityLogsComponent
|
|
10
|
-
private nodeService;
|
|
8
|
+
export declare class CyclesActivityLogsComponent {
|
|
11
9
|
private cycle?;
|
|
12
10
|
original?: ICycleJSONLD;
|
|
13
11
|
recalculated?: ICycleJSONLD;
|
|
14
|
-
loading: boolean;
|
|
15
12
|
NodeType: typeof NodeType;
|
|
16
|
-
logsUrl?: string;
|
|
17
|
-
logs: any;
|
|
18
13
|
Tab: typeof Tab;
|
|
19
14
|
selectedTab: Tab;
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
15
|
+
get node(): {
|
|
16
|
+
'@type': NodeType;
|
|
17
|
+
type: NodeType;
|
|
18
|
+
dataState: DataState;
|
|
19
|
+
description?: string;
|
|
20
|
+
treatment?: string;
|
|
21
|
+
site?: import("@hestia-earth/schema").Site;
|
|
22
|
+
otherSites?: import("@hestia-earth/schema").Site[];
|
|
23
|
+
siteDuration?: number;
|
|
24
|
+
otherSitesDuration?: number[];
|
|
25
|
+
harvestedArea?: number;
|
|
26
|
+
defaultSource?: import("@hestia-earth/schema").Source;
|
|
27
|
+
endDate?: string;
|
|
28
|
+
startDate?: string;
|
|
29
|
+
startDateDefinition?: import("@hestia-earth/schema").CycleStartDateDefinition;
|
|
30
|
+
cycleDuration?: number;
|
|
31
|
+
functionalUnit?: import("@hestia-earth/schema").CycleFunctionalUnit;
|
|
32
|
+
functionalUnitDetails?: string;
|
|
33
|
+
numberOfCycles?: number;
|
|
34
|
+
numberOfReplications?: number;
|
|
35
|
+
dataCompleteness?: import("@hestia-earth/schema").Completeness;
|
|
36
|
+
inputs?: import("@hestia-earth/schema").Input[];
|
|
37
|
+
emissions?: import("@hestia-earth/schema").Emission[];
|
|
38
|
+
products?: import("@hestia-earth/schema").Product[];
|
|
39
|
+
practices?: import("@hestia-earth/schema").Practice[];
|
|
40
|
+
transformations?: import("@hestia-earth/schema").Transformation[];
|
|
41
|
+
originalId?: string;
|
|
42
|
+
schemaVersion?: string;
|
|
43
|
+
added?: string[];
|
|
44
|
+
addedVersion?: string[];
|
|
45
|
+
updated?: string[];
|
|
46
|
+
updatedVersion?: string[];
|
|
47
|
+
aggregated?: boolean;
|
|
48
|
+
aggregatedVersion?: string;
|
|
49
|
+
dataPrivate?: boolean;
|
|
50
|
+
'@context': string | (string | import("@hestia-earth/schema").IContext)[];
|
|
51
|
+
'@id': string;
|
|
52
|
+
name: string;
|
|
53
|
+
};
|
|
54
|
+
get logsKey(): any;
|
|
23
55
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesActivityLogsComponent, never>;
|
|
24
56
|
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesActivityLogsComponent, "he-cycles-activity-logs", never, { "cycle": "cycle"; "original": "original"; "recalculated": "recalculated"; }, {}, never, never>;
|
|
25
57
|
}
|
|
@@ -3,14 +3,12 @@ import { ICycleJSONLD } from '@hestia-earth/schema';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export declare class CyclesCompletenessComponent {
|
|
5
5
|
cycles: ICycleJSONLD[];
|
|
6
|
-
private selected;
|
|
7
6
|
dataState?: DataState;
|
|
8
7
|
baseUrl: string;
|
|
9
8
|
defaultLabel: (node?: any) => any;
|
|
10
9
|
keyToLabel: (key: string) => string;
|
|
11
10
|
trackById(_index: number, item: ICycleJSONLD): string;
|
|
12
11
|
get completenessKeys(): string[];
|
|
13
|
-
isSelected(cycle: ICycleJSONLD): boolean;
|
|
14
12
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesCompletenessComponent, never>;
|
|
15
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesCompletenessComponent, "he-cycles-completeness", never, { "cycles": "cycles"; "
|
|
13
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesCompletenessComponent, "he-cycles-completeness", never, { "cycles": "cycles"; "dataState": "dataState"; }, {}, never, never>;
|
|
16
14
|
}
|
|
@@ -11,7 +11,6 @@ declare enum View {
|
|
|
11
11
|
export declare class CyclesEmissionsComponent implements OnChanges {
|
|
12
12
|
originalValues: ICycleJSONLD[];
|
|
13
13
|
cycles: ICycleJSONLD[];
|
|
14
|
-
selected: string[];
|
|
15
14
|
dataState?: DataState;
|
|
16
15
|
baseUrl: string;
|
|
17
16
|
propertyValue: (value: string | number | (string | number)[], termId?: string) => number;
|
|
@@ -26,7 +25,6 @@ export declare class CyclesEmissionsComponent implements OnChanges {
|
|
|
26
25
|
get isOriginal(): boolean;
|
|
27
26
|
private update;
|
|
28
27
|
togglePopover(popover: any, context: any): any;
|
|
29
|
-
isSelected(cycle: ICycleJSONLD): boolean;
|
|
30
28
|
get isTransformation(): boolean;
|
|
31
29
|
selectIndex({ target: { value } }: {
|
|
32
30
|
target: {
|
|
@@ -34,6 +32,6 @@ export declare class CyclesEmissionsComponent implements OnChanges {
|
|
|
34
32
|
};
|
|
35
33
|
}): void;
|
|
36
34
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesEmissionsComponent, never>;
|
|
37
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesEmissionsComponent, "he-cycles-emissions", never, { "originalValues": "originalValues"; "cycles": "cycles"; "
|
|
35
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesEmissionsComponent, "he-cycles-emissions", never, { "originalValues": "originalValues"; "cycles": "cycles"; "dataState": "dataState"; }, {}, never, never>;
|
|
38
36
|
}
|
|
39
37
|
export {};
|
|
@@ -7,7 +7,6 @@ export declare class CyclesEmissionsChartComponent implements AfterViewInit, OnC
|
|
|
7
7
|
private chartRef?;
|
|
8
8
|
private chart;
|
|
9
9
|
private cycles;
|
|
10
|
-
private selected;
|
|
11
10
|
emissionPerCycle: IGroupedNodes<Emission>;
|
|
12
11
|
terms: ITermJSONLD[];
|
|
13
12
|
selectedTerm?: ITermJSONLD;
|
|
@@ -18,5 +17,5 @@ export declare class CyclesEmissionsChartComponent implements AfterViewInit, OnC
|
|
|
18
17
|
private initChart;
|
|
19
18
|
updateChart(): void;
|
|
20
19
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesEmissionsChartComponent, never>;
|
|
21
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesEmissionsChartComponent, "he-cycles-emissions-chart", never, { "cycles": "cycles";
|
|
20
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesEmissionsChartComponent, "he-cycles-emissions-chart", never, { "cycles": "cycles"; }, {}, never, never>;
|
|
22
21
|
}
|
|
@@ -1,23 +1,59 @@
|
|
|
1
1
|
import { OnInit } from '@angular/core';
|
|
2
|
+
import { DataState } from '@hestia-earth/api';
|
|
2
3
|
import { Emission, ITermJSONLD, NodeType, TermTermType } from '@hestia-earth/schema';
|
|
3
4
|
import { HeSearchService } from '../../search/search.service';
|
|
4
|
-
import { HeNodeService } from '../../node/node.service';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export declare class CyclesEmissionsLogsComponent implements OnInit {
|
|
7
7
|
private searchService;
|
|
8
|
-
private nodeService;
|
|
9
8
|
private cycle?;
|
|
10
9
|
originalValues: Emission[];
|
|
11
10
|
recalculatedValues: Emission[];
|
|
12
11
|
loading: boolean;
|
|
13
12
|
TermTermType: typeof TermTermType;
|
|
14
|
-
logsUrl?: string;
|
|
15
13
|
NodeType: typeof NodeType;
|
|
16
|
-
logs: any;
|
|
17
14
|
emissions: ITermJSONLD[];
|
|
18
|
-
constructor(searchService: HeSearchService
|
|
15
|
+
constructor(searchService: HeSearchService);
|
|
19
16
|
ngOnInit(): Promise<void>;
|
|
20
|
-
|
|
17
|
+
get node(): {
|
|
18
|
+
'@type': NodeType;
|
|
19
|
+
type: NodeType;
|
|
20
|
+
dataState: DataState;
|
|
21
|
+
description?: string;
|
|
22
|
+
treatment?: string;
|
|
23
|
+
site?: import("@hestia-earth/schema").Site;
|
|
24
|
+
otherSites?: import("@hestia-earth/schema").Site[];
|
|
25
|
+
siteDuration?: number;
|
|
26
|
+
otherSitesDuration?: number[];
|
|
27
|
+
harvestedArea?: number;
|
|
28
|
+
defaultSource?: import("@hestia-earth/schema").Source;
|
|
29
|
+
endDate?: string;
|
|
30
|
+
startDate?: string;
|
|
31
|
+
startDateDefinition?: import("@hestia-earth/schema").CycleStartDateDefinition;
|
|
32
|
+
cycleDuration?: number;
|
|
33
|
+
functionalUnit?: import("@hestia-earth/schema").CycleFunctionalUnit;
|
|
34
|
+
functionalUnitDetails?: string;
|
|
35
|
+
numberOfCycles?: number;
|
|
36
|
+
numberOfReplications?: number;
|
|
37
|
+
dataCompleteness?: import("@hestia-earth/schema").Completeness;
|
|
38
|
+
inputs?: import("@hestia-earth/schema").Input[];
|
|
39
|
+
emissions?: Emission[];
|
|
40
|
+
products?: import("@hestia-earth/schema").Product[];
|
|
41
|
+
practices?: import("@hestia-earth/schema").Practice[];
|
|
42
|
+
transformations?: import("@hestia-earth/schema").Transformation[];
|
|
43
|
+
originalId?: string;
|
|
44
|
+
schemaVersion?: string;
|
|
45
|
+
added?: string[];
|
|
46
|
+
addedVersion?: string[];
|
|
47
|
+
updated?: string[];
|
|
48
|
+
updatedVersion?: string[];
|
|
49
|
+
aggregated?: boolean;
|
|
50
|
+
aggregatedVersion?: string;
|
|
51
|
+
dataPrivate?: boolean;
|
|
52
|
+
'@context': string | (string | import("@hestia-earth/schema").IContext)[];
|
|
53
|
+
'@id': string;
|
|
54
|
+
name: string;
|
|
55
|
+
};
|
|
56
|
+
get logsKey(): any;
|
|
21
57
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesEmissionsLogsComponent, never>;
|
|
22
58
|
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesEmissionsLogsComponent, "he-cycles-emissions-logs", never, { "cycle": "cycle"; "originalValues": "originalValues"; "recalculatedValues": "recalculatedValues"; }, {}, never, never>;
|
|
23
59
|
}
|
|
@@ -11,7 +11,6 @@ declare enum View {
|
|
|
11
11
|
export declare class CyclesPracticesComponent implements OnChanges {
|
|
12
12
|
originalValues: ICycleJSONLD[];
|
|
13
13
|
cycles: ICycleJSONLD[];
|
|
14
|
-
selected: string[];
|
|
15
14
|
dataState?: DataState;
|
|
16
15
|
baseUrl: string;
|
|
17
16
|
propertyValue: (value: string | number | (string | number)[], termId?: string) => number;
|
|
@@ -27,7 +26,6 @@ export declare class CyclesPracticesComponent implements OnChanges {
|
|
|
27
26
|
get isOriginal(): boolean;
|
|
28
27
|
private update;
|
|
29
28
|
togglePopover(popover: any, context: any): any;
|
|
30
|
-
isSelected(cycle: ICycleJSONLD): boolean;
|
|
31
29
|
get showTimeline(): boolean;
|
|
32
30
|
selectIndex({ target: { value } }: {
|
|
33
31
|
target: {
|
|
@@ -35,6 +33,6 @@ export declare class CyclesPracticesComponent implements OnChanges {
|
|
|
35
33
|
};
|
|
36
34
|
}): void;
|
|
37
35
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesPracticesComponent, never>;
|
|
38
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesPracticesComponent, "he-cycles-practices", never, { "originalValues": "originalValues"; "cycles": "cycles"; "
|
|
36
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesPracticesComponent, "he-cycles-practices", never, { "originalValues": "originalValues"; "cycles": "cycles"; "dataState": "dataState"; }, {}, never, never>;
|
|
39
37
|
}
|
|
40
38
|
export {};
|
|
@@ -1,20 +1,52 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { DataState } from '@hestia-earth/api';
|
|
2
2
|
import { Practice, ITermJSONLD, NodeType } from '@hestia-earth/schema';
|
|
3
|
-
import { HeNodeService } from '../../node/node.service';
|
|
4
3
|
import * as i0 from "@angular/core";
|
|
5
|
-
export declare class CyclesPracticesLogsComponent
|
|
6
|
-
private nodeService;
|
|
4
|
+
export declare class CyclesPracticesLogsComponent {
|
|
7
5
|
private cycle?;
|
|
8
6
|
originalValues: Practice[];
|
|
9
7
|
recalculatedValues: Practice[];
|
|
10
|
-
loading: boolean;
|
|
11
|
-
logsUrl?: string;
|
|
12
8
|
NodeType: typeof NodeType;
|
|
13
|
-
logs: any;
|
|
14
9
|
models: ITermJSONLD[];
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
10
|
+
get node(): {
|
|
11
|
+
'@type': NodeType;
|
|
12
|
+
type: NodeType;
|
|
13
|
+
dataState: DataState;
|
|
14
|
+
description?: string;
|
|
15
|
+
treatment?: string;
|
|
16
|
+
site?: import("@hestia-earth/schema").Site;
|
|
17
|
+
otherSites?: import("@hestia-earth/schema").Site[];
|
|
18
|
+
siteDuration?: number;
|
|
19
|
+
otherSitesDuration?: number[];
|
|
20
|
+
harvestedArea?: number;
|
|
21
|
+
defaultSource?: import("@hestia-earth/schema").Source;
|
|
22
|
+
endDate?: string;
|
|
23
|
+
startDate?: string;
|
|
24
|
+
startDateDefinition?: import("@hestia-earth/schema").CycleStartDateDefinition;
|
|
25
|
+
cycleDuration?: number;
|
|
26
|
+
functionalUnit?: import("@hestia-earth/schema").CycleFunctionalUnit;
|
|
27
|
+
functionalUnitDetails?: string;
|
|
28
|
+
numberOfCycles?: number;
|
|
29
|
+
numberOfReplications?: number;
|
|
30
|
+
dataCompleteness?: import("@hestia-earth/schema").Completeness;
|
|
31
|
+
inputs?: import("@hestia-earth/schema").Input[];
|
|
32
|
+
emissions?: import("@hestia-earth/schema").Emission[];
|
|
33
|
+
products?: import("@hestia-earth/schema").Product[];
|
|
34
|
+
practices?: Practice[];
|
|
35
|
+
transformations?: import("@hestia-earth/schema").Transformation[];
|
|
36
|
+
originalId?: string;
|
|
37
|
+
schemaVersion?: string;
|
|
38
|
+
added?: string[];
|
|
39
|
+
addedVersion?: string[];
|
|
40
|
+
updated?: string[];
|
|
41
|
+
updatedVersion?: string[];
|
|
42
|
+
aggregated?: boolean;
|
|
43
|
+
aggregatedVersion?: string;
|
|
44
|
+
dataPrivate?: boolean;
|
|
45
|
+
'@context': string | (string | import("@hestia-earth/schema").IContext)[];
|
|
46
|
+
'@id': string;
|
|
47
|
+
name: string;
|
|
48
|
+
};
|
|
49
|
+
get logsKey(): any;
|
|
18
50
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesPracticesLogsComponent, never>;
|
|
19
51
|
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesPracticesLogsComponent, "he-cycles-practices-logs", never, { "cycle": "cycle"; "originalValues": "originalValues"; "recalculatedValues": "recalculatedValues"; }, {}, never, never>;
|
|
20
52
|
}
|
|
@@ -5,13 +5,11 @@ export declare class CyclesResultComponent implements AfterViewInit, OnChanges {
|
|
|
5
5
|
private chartRef?;
|
|
6
6
|
private chart;
|
|
7
7
|
private cycles;
|
|
8
|
-
private selected;
|
|
9
8
|
constructor(ngZone: NgZone);
|
|
10
9
|
ngAfterViewInit(): void;
|
|
11
10
|
ngOnChanges(changes: SimpleChanges): void;
|
|
12
|
-
private isSelected;
|
|
13
11
|
private init;
|
|
14
12
|
private updateChart;
|
|
15
13
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesResultComponent, never>;
|
|
16
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesResultComponent, "he-cycles-result", never, { "cycles": "cycles";
|
|
14
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<CyclesResultComponent, "he-cycles-result", never, { "cycles": "cycles"; }, {}, never, never>;
|
|
17
15
|
}
|
package/cycles/cycles.model.d.ts
CHANGED
|
@@ -6,10 +6,9 @@ export interface ICycleJSONLDExtended extends ICycleJSONLD {
|
|
|
6
6
|
}
|
|
7
7
|
export declare const primaryProduct: ({ products }: Partial<ICycleJSONLD>) => import("@hestia-earth/schema").Product;
|
|
8
8
|
/**
|
|
9
|
-
*
|
|
9
|
+
* If Transformation, return the Transformation Term @id.
|
|
10
10
|
*
|
|
11
|
-
* @param node
|
|
12
|
-
* @param logs
|
|
11
|
+
* @param node Cycle or Transformation
|
|
13
12
|
* @returns
|
|
14
13
|
*/
|
|
15
|
-
export declare const
|
|
14
|
+
export declare const logsKey: (node: any) => any;
|
|
@@ -3,14 +3,16 @@ import { Component, Input, ViewChild } from '@angular/core';
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@fortawesome/angular-fontawesome";
|
|
5
5
|
import * as i2 from "@ng-bootstrap/ng-bootstrap";
|
|
6
|
+
const defaultIcon = 'clipboard';
|
|
6
7
|
export class ClipboardComponent {
|
|
7
8
|
constructor() {
|
|
8
9
|
this.disabled = false;
|
|
9
10
|
this.hideText = false;
|
|
10
|
-
this.icon =
|
|
11
|
+
this.icon = defaultIcon;
|
|
11
12
|
this.size = 'md';
|
|
12
13
|
this.rotate = 0;
|
|
13
14
|
this.clipboardClass = 'no-print px-3';
|
|
15
|
+
this.defaultIcon = defaultIcon;
|
|
14
16
|
}
|
|
15
17
|
onClick($event) {
|
|
16
18
|
$event.stopPropagation();
|
|
@@ -37,7 +39,7 @@ export class ClipboardComponent {
|
|
|
37
39
|
}
|
|
38
40
|
}
|
|
39
41
|
ClipboardComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ClipboardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
40
|
-
ClipboardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: ClipboardComponent, selector: "he-clipboard", inputs: { value: "value", disabled: "disabled", hideText: "hideText", icon: "icon", size: "size", rotate: "rotate", clipboardClass: "clipboardClass" }, viewQueries: [{ propertyName: "valueNode", first: true, predicate: ["valueNode"], descendants: true }, { propertyName: "tooltip", first: true, predicate: ["t"], descendants: true }], ngImport: i0, template: "<span #valueNode [class.is-hidden]=\"hideText\">{{value}}</span>\n\n<span [class]=\"clipboardClass\" pointer (click)=\"!disabled && onClick($event)\"\n ngbTooltip=\"Copied!\" triggers=\"manual\" placement=\"bottom\" container=\"body\" #t=\"ngbTooltip\"\n>\n <fa-icon [icon]=\"icon\" [size]=\"size\" [rotate]=\"rotate\"></fa-icon>\n</span>\n", styles: [""], components: [{ type: i1.FaIconComponent, selector: "fa-icon", inputs: ["classes", "icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }], directives: [{ type: i2.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }] });
|
|
42
|
+
ClipboardComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: ClipboardComponent, selector: "he-clipboard", inputs: { value: "value", disabled: "disabled", hideText: "hideText", icon: "icon", size: "size", rotate: "rotate", clipboardClass: "clipboardClass" }, viewQueries: [{ propertyName: "valueNode", first: true, predicate: ["valueNode"], descendants: true }, { propertyName: "tooltip", first: true, predicate: ["t"], descendants: true }], ngImport: i0, template: "<span #valueNode [class.is-hidden]=\"hideText\">{{value}}</span>\n\n<span [class]=\"clipboardClass\" pointer (click)=\"!disabled && onClick($event)\"\n ngbTooltip=\"Copied!\" triggers=\"manual\" placement=\"bottom\" container=\"body\" #t=\"ngbTooltip\"\n>\n <fa-icon [icon]=\"icon || defaultIcon\" [size]=\"size\" [rotate]=\"rotate\"></fa-icon>\n</span>\n", styles: [""], components: [{ type: i1.FaIconComponent, selector: "fa-icon", inputs: ["classes", "icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }], directives: [{ type: i2.NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }] });
|
|
41
43
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: ClipboardComponent, decorators: [{
|
|
42
44
|
type: Component,
|
|
43
45
|
args: [{
|
|
@@ -66,4 +68,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
66
68
|
}], clipboardClass: [{
|
|
67
69
|
type: Input
|
|
68
70
|
}] } });
|
|
69
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
71
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpcGJvYXJkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21tb24vY2xpcGJvYXJkL2NsaXBib2FyZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvY29tbW9uL2NsaXBib2FyZC9jbGlwYm9hcmQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFNBQVMsRUFBYyxNQUFNLGVBQWUsQ0FBQzs7OztBQUd4RSxNQUFNLFdBQVcsR0FBRyxXQUFXLENBQUM7QUFPaEMsTUFBTSxPQUFPLGtCQUFrQjtJQUwvQjtRQWNTLGFBQVEsR0FBRyxLQUFLLENBQUM7UUFFakIsYUFBUSxHQUFHLEtBQUssQ0FBQztRQUVqQixTQUFJLEdBQUcsV0FBVyxDQUFDO1FBRW5CLFNBQUksR0FBRyxJQUFJLENBQUM7UUFFWixXQUFNLEdBQUcsQ0FBQyxDQUFDO1FBRVgsbUJBQWMsR0FBRyxlQUFlLENBQUM7UUFFakMsZ0JBQVcsR0FBRyxXQUFXLENBQUM7S0F3QmxDO0lBdEJRLE9BQU8sQ0FBQyxNQUFNO1FBQ25CLE1BQU0sQ0FBQyxlQUFlLEVBQUUsQ0FBQztRQUN6QixNQUFNLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDeEIsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO0lBQ25CLENBQUM7SUFFWSxTQUFTOzs7WUFDcEIsTUFBTSxFQUFFLFNBQVMsRUFBRSxHQUFHLE1BQU0sTUFBTSxDQUFDLHNDQUFzQyxDQUFDLGNBQWMsQ0FBQyxDQUFDO1lBQzFGLE1BQU0sS0FBSyxHQUFHLFFBQVEsQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUNyQyxLQUFLLENBQUMsVUFBVSxDQUFDLE1BQUEsSUFBSSxDQUFDLFNBQVMsMENBQUUsYUFBYSxDQUFDLENBQUM7WUFDaEQsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDLFlBQVksRUFBRSxDQUFDO1lBQ3hDLFNBQVUsQ0FBQyxlQUFlLEVBQUUsQ0FBQztZQUM3QixTQUFVLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQzNCLE1BQU0sR0FBRyxHQUFHLE9BQU8sSUFBSSxDQUFDLEtBQUssS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7WUFDOUYsU0FBUyxDQUFDLElBQUksQ0FBQyxHQUFHLElBQUksRUFBRSxDQUFDLENBQUM7WUFDMUIsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLFNBQVUsQ0FBQyxlQUFlLEVBQUUsQ0FBQyxDQUFDO1lBRS9DLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRTtnQkFDaEIsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEVBQUUsQ0FBQztnQkFDcEIsVUFBVSxDQUFDLEdBQUcsRUFBRSxXQUFDLE9BQUEsTUFBQSxJQUFJLENBQUMsT0FBTywwQ0FBRSxLQUFLLEVBQUUsQ0FBQSxFQUFBLEVBQUUsSUFBSSxDQUFDLENBQUM7YUFDL0M7O0tBQ0Y7O2dIQTVDVSxrQkFBa0I7b0dBQWxCLGtCQUFrQixtWUNWL0IsdVdBT0E7NEZER2Esa0JBQWtCO2tCQUw5QixTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSxjQUFjO29CQUN4QixXQUFXLEVBQUUsNEJBQTRCO29CQUN6QyxTQUFTLEVBQUUsQ0FBQyw0QkFBNEIsQ0FBQztpQkFDMUM7OEJBR1MsU0FBUztzQkFEaEIsU0FBUzt1QkFBQyxXQUFXO2dCQUdkLE9BQU87c0JBRGQsU0FBUzt1QkFBQyxHQUFHO2dCQUlQLEtBQUs7c0JBRFgsS0FBSztnQkFHQyxRQUFRO3NCQURkLEtBQUs7Z0JBR0MsUUFBUTtzQkFEZCxLQUFLO2dCQUdDLElBQUk7c0JBRFYsS0FBSztnQkFHQyxJQUFJO3NCQURWLEtBQUs7Z0JBR0MsTUFBTTtzQkFEWixLQUFLO2dCQUdDLGNBQWM7c0JBRHBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBWaWV3Q2hpbGQsIEVsZW1lbnRSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5nYlRvb2x0aXAgfSBmcm9tICdAbmctYm9vdHN0cmFwL25nLWJvb3RzdHJhcCc7XG5cbmNvbnN0IGRlZmF1bHRJY29uID0gJ2NsaXBib2FyZCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2hlLWNsaXBib2FyZCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9jbGlwYm9hcmQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jbGlwYm9hcmQuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBDbGlwYm9hcmRDb21wb25lbnQge1xuICBAVmlld0NoaWxkKCd2YWx1ZU5vZGUnKVxuICBwcml2YXRlIHZhbHVlTm9kZT86IEVsZW1lbnRSZWY7XG4gIEBWaWV3Q2hpbGQoJ3QnKVxuICBwcml2YXRlIHRvb2x0aXA/OiBOZ2JUb29sdGlwO1xuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyB2YWx1ZT86IHN0cmluZztcbiAgQElucHV0KClcbiAgcHVibGljIGRpc2FibGVkID0gZmFsc2U7XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBoaWRlVGV4dCA9IGZhbHNlO1xuICBASW5wdXQoKVxuICBwdWJsaWMgaWNvbiA9IGRlZmF1bHRJY29uO1xuICBASW5wdXQoKVxuICBwdWJsaWMgc2l6ZSA9ICdtZCc7XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyByb3RhdGUgPSAwO1xuICBASW5wdXQoKVxuICBwdWJsaWMgY2xpcGJvYXJkQ2xhc3MgPSAnbm8tcHJpbnQgcHgtMyc7XG5cbiAgcHVibGljIGRlZmF1bHRJY29uID0gZGVmYXVsdEljb247XG5cbiAgcHVibGljIG9uQ2xpY2soJGV2ZW50KSB7XG4gICAgJGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICRldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgIHRoaXMuY2xpcGJvYXJkKCk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgY2xpcGJvYXJkKCkge1xuICAgIGNvbnN0IHsgQ2xpcGJvYXJkIH0gPSBhd2FpdCBpbXBvcnQoLyogd2VicGFja0NodW5rTmFtZTogXCJ0cy1jbGlwYm9hcmRcIiAqLyAndHMtY2xpcGJvYXJkJyk7XG4gICAgY29uc3QgcmFuZ2UgPSBkb2N1bWVudC5jcmVhdGVSYW5nZSgpO1xuICAgIHJhbmdlLnNlbGVjdE5vZGUodGhpcy52YWx1ZU5vZGU/Lm5hdGl2ZUVsZW1lbnQpO1xuICAgIGNvbnN0IHNlbGVjdGlvbiA9IHdpbmRvdy5nZXRTZWxlY3Rpb24oKTtcbiAgICBzZWxlY3Rpb24hLnJlbW92ZUFsbFJhbmdlcygpO1xuICAgIHNlbGVjdGlvbiEuYWRkUmFuZ2UocmFuZ2UpO1xuICAgIGNvbnN0IHZhbCA9IHR5cGVvZiB0aGlzLnZhbHVlID09PSAnb2JqZWN0JyA/IEpTT04uc3RyaW5naWZ5KHRoaXMudmFsdWUsIG51bGwsIDIpIDogdGhpcy52YWx1ZTtcbiAgICBDbGlwYm9hcmQuY29weSh2YWwgfHwgJycpO1xuICAgIHNldFRpbWVvdXQoKCkgPT4gc2VsZWN0aW9uIS5yZW1vdmVBbGxSYW5nZXMoKSk7XG5cbiAgICBpZiAodGhpcy50b29sdGlwKSB7XG4gICAgICB0aGlzLnRvb2x0aXAub3BlbigpO1xuICAgICAgc2V0VGltZW91dCgoKSA9PiB0aGlzLnRvb2x0aXA/LmNsb3NlKCksIDEwMDApO1xuICAgIH1cbiAgfVxufVxuIiwiPHNwYW4gI3ZhbHVlTm9kZSBbY2xhc3MuaXMtaGlkZGVuXT1cImhpZGVUZXh0XCI+e3t2YWx1ZX19PC9zcGFuPlxuXG48c3BhbiBbY2xhc3NdPVwiY2xpcGJvYXJkQ2xhc3NcIiBwb2ludGVyIChjbGljayk9XCIhZGlzYWJsZWQgJiYgb25DbGljaygkZXZlbnQpXCJcbiAgbmdiVG9vbHRpcD1cIkNvcGllZCFcIiB0cmlnZ2Vycz1cIm1hbnVhbFwiIHBsYWNlbWVudD1cImJvdHRvbVwiIGNvbnRhaW5lcj1cImJvZHlcIiAjdD1cIm5nYlRvb2x0aXBcIlxuPlxuICA8ZmEtaWNvbiBbaWNvbl09XCJpY29uIHx8IGRlZmF1bHRJY29uXCIgW3NpemVdPVwic2l6ZVwiIFtyb3RhdGVdPVwicm90YXRlXCI+PC9mYS1pY29uPlxuPC9zcGFuPlxuIl19
|
|
@@ -29,7 +29,6 @@ export class CyclesActivityComponent {
|
|
|
29
29
|
constructor() {
|
|
30
30
|
this.originalValues = [];
|
|
31
31
|
this.cycles = [];
|
|
32
|
-
this.selected = [];
|
|
33
32
|
this.enableCompare = true;
|
|
34
33
|
this.baseUrl = baseUrl();
|
|
35
34
|
this.propertyValue = propertyValue;
|
|
@@ -64,9 +63,6 @@ export class CyclesActivityComponent {
|
|
|
64
63
|
togglePopover(popover, context) {
|
|
65
64
|
return popover.isOpen() ? popover.close() : popover.open(context);
|
|
66
65
|
}
|
|
67
|
-
isSelected(cycle) {
|
|
68
|
-
return this.selected.length === 0 || this.selected.includes(cycle['@id']);
|
|
69
|
-
}
|
|
70
66
|
// Recalculation logs
|
|
71
67
|
selectIndex({ target: { value } }) {
|
|
72
68
|
this.selectedIndex = -1;
|
|
@@ -75,7 +71,7 @@ export class CyclesActivityComponent {
|
|
|
75
71
|
}
|
|
76
72
|
}
|
|
77
73
|
CyclesActivityComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: CyclesActivityComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
78
|
-
CyclesActivityComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: CyclesActivityComponent, selector: "he-cycles-activity", inputs: { originalValues: "originalValues", cycles: "cycles", selected: "selected", dataState: "dataState", enableCompare: "enableCompare" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"columns is-variable is-align-items-center is-2 m-0\">\n <div class=\"column is-hidden-mobile\"></div>\n <ng-container *ngIf=\"selectedView === View.table && (inputs.length || products.length)\">\n <div class=\"column is-narrow\">\n <button class=\"button is-dark is-outlined is-small\" (click)=\"showDownload = true\">\n <fa-icon icon=\"download\"></fa-icon>\n <span class=\"pl-2\">Download (CSV)</span>\n </button>\n </div>\n <div class=\"column is-narrow col-sep\"></div>\n </ng-container>\n <div class=\"column is-narrow\" *ngIf=\"!isOriginal\">\n <div class=\"field has-addons\">\n <div class=\"control\">\n <button class=\"button is-small\" [class.is-active]=\"selectedView === View.table\" (click)=\"selectedView = View.table\">\n <span class=\"icon is-small\">\n <fa-icon icon=\"list\" aria-hidden=\"true\"></fa-icon>\n </span>\n <span>Table view</span>\n </button>\n </div>\n <div class=\"control\">\n <button class=\"button is-small\" [class.is-active]=\"selectedView === View.logs\" (click)=\"selectedView = View.logs\">\n <span class=\"icon is-small\">\n <fa-icon icon=\"calculator\" aria-hidden=\"true\"></fa-icon>\n </span>\n <span>Recalculations logs</span>\n </button>\n </div>\n </div>\n </div>\n</div>\n\n<div class=\"px-3 pb-3\" [class.is-hidden]=\"selectedView !== View.table\">\n <ng-container *ngIf=\"inputs.length || products.length; else emptyTable\">\n <he-data-table class=\"mb-1 is-small\" [small]=\"true\" [nbRows]=\"cycles.length\" maxHeight=\"320\">\n <table class=\"table is-narrow is-striped\">\n <thead>\n <tr>\n <th class=\"width-auto\"></th>\n <th class=\"has-border-right\"></th>\n <th *ngIf=\"products.length\" [attr.colspan]=\"products.length\"\n [class.has-border-right]=\"inputs.length\"\n >Products</th>\n <th *ngIf=\"inputs.length\" [attr.colspan]=\"inputs.length\">Inputs</th>\n </tr>\n <tr>\n <th class=\"width-auto\"></th>\n <th class=\"has-border-right\"></th>\n <th *ngFor=\"let product of products; let pl = last\"\n [attr.title]=\"product.value.term.name\"\n [class.has-border-right]=\"inputs.length && pl\"\n >\n <he-node-link [node]=\"product.value.term\">\n <span>{{product.value.term.name | ellipsis:30}}</span>\n </he-node-link>\n </th>\n <th *ngFor=\"let input of inputs\"\n [attr.title]=\"input.value.term.name\"\n >\n <he-node-link [node]=\"input.value.term\">\n <span>{{input.value.term.name | ellipsis:30}}</span>\n </he-node-link>\n </th>\n </tr>\n <tr>\n <th class=\"width-auto\"></th>\n <th class=\"has-border-right\">\n <a [href]=\"baseUrl + '/schema/Cycle#functionalUnit'\" target=\"_blank\">Functional unit</a>\n </th>\n <th *ngFor=\"let product of products; let pl = last\"\n [attr.title]=\"product.value.term.units\"\n [class.has-border-right]=\"inputs.length && pl\"\n >{{product.value.term.units}}</th>\n <th *ngFor=\"let input of inputs\"\n [attr.title]=\"input.value.term.units\"\n >{{input.value.term.units}}</th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let cycle of cycles; trackBy: trackById; let i = index\">\n <tr *ngIf=\"isSelected(cycle)\">\n <td class=\"width-auto\" [attr.title]=\"defaultLabel(cycle)\">\n <he-node-link [node]=\"cycle.term || cycle\">\n <span class=\"is-nowrap has-text-ellipsis\">{{i + 1}}. {{defaultLabel(cycle)}}</span>\n </he-node-link>\n </td>\n <td class=\"has-border-right\">\n <he-cycles-functional-unit-measure [cycle]=\"cycle\"></he-cycles-functional-unit-measure>\n </td>\n <td class=\"is-nowrap\"\n *ngFor=\"let product of products; let pl = last\"\n [class.has-border-right]=\"inputs.length && pl\"\n >\n <span *ngIf=\"product.value.values[cycle['@id']]; else emptyValue\"\n class=\"trigger-popover\"\n [ngbPopover]=\"details\" [autoClose]=\"'outside'\"\n triggers=\"manual\" #p=\"ngbPopover\" placement=\"left\" container=\"body\"\n (click)=\"togglePopover(p, { data: product.value.values[cycle['@id']], cycle: cycle, key: 'products' })\"\n >\n <span pointer>{{propertyValue(product.value.values[cycle['@id']].value, product.value.term['@id']) | precision:3 | default:'-'}}</span>\n <he-blank-node-state class=\"ml-1\"\n [node]=\"product.value.values[cycle['@id']].node\"\n key=\"value\"\n ></he-blank-node-state>\n </span>\n </td>\n <td class=\"is-nowrap\" *ngFor=\"let input of inputs\">\n <span *ngIf=\"input.value.values[cycle['@id']]; else emptyValue\"\n class=\"trigger-popover\"\n [ngbPopover]=\"details\" [autoClose]=\"'outside'\"\n triggers=\"manual\" #p=\"ngbPopover\" placement=\"left\" container=\"body\"\n (click)=\"togglePopover(p, { data: input.value.values[cycle['@id']], cycle: cycle, key: 'inputs' })\"\n >\n <span pointer>{{propertyValue(input.value.values[cycle['@id']].value, input.value.term['@id']) | precision:3 | default:'-'}}</span>\n <he-blank-node-state class=\"ml-1\"\n [node]=\"input.value.values[cycle['@id']].node\"\n key=\"value\"\n ></he-blank-node-state>\n </span>\n </td>\n </tr>\n </ng-container>\n </tbody>\n </table>\n </he-data-table>\n\n <he-blank-node-state-notice [dataState]=\"dataState\"></he-blank-node-state-notice>\n </ng-container>\n</div>\n\n<ng-container *ngIf=\"selectedView === View.logs && !isOriginal\">\n <div class=\"field has-addons pt-2 px-3\" *ngIf=\"cycles.length > 1\">\n <div class=\"control\">\n <span class=\"button is-small is-static\">Select a Cycle</span>\n </div>\n <div class=\"control is-expanded\">\n <div class=\"select is-small is-fullwidth\">\n <select (change)=\"selectIndex($event)\">\n <option *ngFor=\"let value of cycles; let i = index\" [value]=\"i\">{{i + 1}}. {{defaultLabel(value)}}</option>\n </select>\n </div>\n </div>\n </div>\n\n <he-cycles-activity-logs *ngIf=\"selectedIndex >= 0\"\n [cycle]=\"cycles[selectedIndex]\"\n [original]=\"originalValues[selectedIndex]\"\n [recalculated]=\"cycles[selectedIndex]\"\n ></he-cycles-activity-logs>\n</ng-container>\n\n<he-node-csv-export-confirm *ngIf=\"showDownload\"\n [nodes]=\"cycles\" filename=\"cycle-inputs-products.csv\" [isUpload]=\"false\"\n [headerKeys]=\"['cycle.id', 'cycle.@id', 'cycle.inputs.', 'cycle.products.']\"\n (closed)=\"showDownload = false\"\n></he-node-csv-export-confirm>\n\n<ng-template #emptyTable>\n <div class=\"has-text-centered\">\n <span>No activity data</span>\n </div>\n</ng-template>\n\n<ng-template #emptyValue>\n <span>-</span>\n</ng-template>\n\n<ng-template #details let-node=\"cycle\" let-data=\"data\" let-key=\"key\">\n <p><b>{{defaultLabel(node)}}</b></p>\n <he-node-value-details\n [data]=\"data\" [nodeType]=\"node['@type']\" [dataKey]=\"key\"\n ></he-node-value-details>\n</ng-template>\n", styles: ["fa-icon{display:inline-block;width:10px}he-data-table ::ng-deep .table thead tr th:nth-child(2),he-data-table ::ng-deep .table tbody tr td:nth-child(2){max-width:102px;width:102px}\n"], components: [{ type: i1.FaIconComponent, selector: "fa-icon", inputs: ["classes", "icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }, { type: i2.DataTableComponent, selector: "he-data-table", inputs: ["minHeight", "maxHeight", "nbRows", "small", "height", "width"] }, { type: i3.NodeLinkComponent, selector: "he-node-link", inputs: ["node", "showExternalLink"] }, { type: i4.CyclesFunctionalUnitMeasureComponent, selector: "he-cycles-functional-unit-measure", inputs: ["cycle"] }, { type: i5.BlankNodeStateComponent, selector: "he-blank-node-state", inputs: ["nodeType", "dataKey", "key", "node", "state"] }, { type: i6.BlankNodeStateNoticeComponent, selector: "he-blank-node-state-notice", inputs: ["dataState", "showAggregated", "showDeleted", "showUnchanged"] }, { type: i7.CyclesActivityLogsComponent, selector: "he-cycles-activity-logs", inputs: ["cycle", "original", "recalculated"] }, { type: i8.NodeCsvExportConfirmComponent, selector: "he-node-csv-export-confirm", inputs: ["nodes", "filename", "headerKeys", "extension", "isUpload"], outputs: ["closed"] }, { type: i9.NodeValueDetailsComponent, selector: "he-node-value-details", inputs: ["data", "nodeType", "dataKey"] }], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i11.NgbPopover, selector: "[ngbPopover]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disablePopover", "popoverClass", "openDelay", "closeDelay", "ngbPopover", "popoverTitle"], outputs: ["shown", "hidden"], exportAs: ["ngbPopover"] }, { type: i12.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i12.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }], pipes: { "ellipsis": i13.EllipsisPipe, "default": i14.DefaultPipe, "precision": i15.PrecisionPipe } });
|
|
74
|
+
CyclesActivityComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: CyclesActivityComponent, selector: "he-cycles-activity", inputs: { originalValues: "originalValues", cycles: "cycles", dataState: "dataState", enableCompare: "enableCompare" }, usesOnChanges: true, ngImport: i0, template: "<div class=\"columns is-variable is-align-items-center is-2 m-0\">\n <div class=\"column is-hidden-mobile\"></div>\n <ng-container *ngIf=\"selectedView === View.table && (inputs.length || products.length)\">\n <div class=\"column is-narrow\">\n <button class=\"button is-dark is-outlined is-small\" (click)=\"showDownload = true\">\n <fa-icon icon=\"download\"></fa-icon>\n <span class=\"pl-2\">Download (CSV)</span>\n </button>\n </div>\n <div class=\"column is-narrow col-sep\"></div>\n </ng-container>\n <div class=\"column is-narrow\" *ngIf=\"!isOriginal\">\n <div class=\"field has-addons\">\n <div class=\"control\">\n <button class=\"button is-small\" [class.is-active]=\"selectedView === View.table\" (click)=\"selectedView = View.table\">\n <span class=\"icon is-small\">\n <fa-icon icon=\"list\" aria-hidden=\"true\"></fa-icon>\n </span>\n <span>Table view</span>\n </button>\n </div>\n <div class=\"control\">\n <button class=\"button is-small\" [class.is-active]=\"selectedView === View.logs\" (click)=\"selectedView = View.logs\">\n <span class=\"icon is-small\">\n <fa-icon icon=\"calculator\" aria-hidden=\"true\"></fa-icon>\n </span>\n <span>Recalculations logs</span>\n </button>\n </div>\n </div>\n </div>\n</div>\n\n<div class=\"px-3 pb-3\" [class.is-hidden]=\"selectedView !== View.table\">\n <ng-container *ngIf=\"inputs.length || products.length; else emptyTable\">\n <he-data-table class=\"mb-1 is-small\" [small]=\"true\" [nbRows]=\"cycles.length\" maxHeight=\"320\">\n <table class=\"table is-narrow is-striped\">\n <thead>\n <tr>\n <th class=\"width-auto\"></th>\n <th class=\"has-border-right\"></th>\n <th *ngIf=\"products.length\" [attr.colspan]=\"products.length\"\n [class.has-border-right]=\"inputs.length\"\n >Products</th>\n <th *ngIf=\"inputs.length\" [attr.colspan]=\"inputs.length\">Inputs</th>\n </tr>\n <tr>\n <th class=\"width-auto\"></th>\n <th class=\"has-border-right\"></th>\n <th *ngFor=\"let product of products; let pl = last\"\n [attr.title]=\"product.value.term.name\"\n [class.has-border-right]=\"inputs.length && pl\"\n >\n <he-node-link [node]=\"product.value.term\">\n <span>{{product.value.term.name | ellipsis:30}}</span>\n </he-node-link>\n </th>\n <th *ngFor=\"let input of inputs\"\n [attr.title]=\"input.value.term.name\"\n >\n <he-node-link [node]=\"input.value.term\">\n <span>{{input.value.term.name | ellipsis:30}}</span>\n </he-node-link>\n </th>\n </tr>\n <tr>\n <th class=\"width-auto\"></th>\n <th class=\"has-border-right\">\n <a [href]=\"baseUrl + '/schema/Cycle#functionalUnit'\" target=\"_blank\">Functional unit</a>\n </th>\n <th *ngFor=\"let product of products; let pl = last\"\n [attr.title]=\"product.value.term.units\"\n [class.has-border-right]=\"inputs.length && pl\"\n >{{product.value.term.units}}</th>\n <th *ngFor=\"let input of inputs\"\n [attr.title]=\"input.value.term.units\"\n >{{input.value.term.units}}</th>\n </tr>\n </thead>\n <tbody>\n <ng-container *ngFor=\"let cycle of cycles; trackBy: trackById; let i = index\">\n <tr>\n <td class=\"width-auto\" [attr.title]=\"defaultLabel(cycle)\">\n <he-node-link [node]=\"cycle.term || cycle\">\n <span class=\"is-nowrap has-text-ellipsis\">{{i + 1}}. {{defaultLabel(cycle)}}</span>\n </he-node-link>\n </td>\n <td class=\"has-border-right\">\n <he-cycles-functional-unit-measure [cycle]=\"cycle\"></he-cycles-functional-unit-measure>\n </td>\n <td class=\"is-nowrap\"\n *ngFor=\"let product of products; let pl = last\"\n [class.has-border-right]=\"inputs.length && pl\"\n >\n <span *ngIf=\"product.value.values[cycle['@id']]; else emptyValue\"\n class=\"trigger-popover\"\n [ngbPopover]=\"details\" [autoClose]=\"'outside'\"\n triggers=\"manual\" #p=\"ngbPopover\" placement=\"left\" container=\"body\"\n (click)=\"togglePopover(p, { data: product.value.values[cycle['@id']], cycle: cycle, key: 'products' })\"\n >\n <span pointer>{{propertyValue(product.value.values[cycle['@id']].value, product.value.term['@id']) | precision:3 | default:'-'}}</span>\n <he-blank-node-state class=\"ml-1\"\n [node]=\"product.value.values[cycle['@id']].node\"\n key=\"value\"\n ></he-blank-node-state>\n </span>\n </td>\n <td class=\"is-nowrap\" *ngFor=\"let input of inputs\">\n <span *ngIf=\"input.value.values[cycle['@id']]; else emptyValue\"\n class=\"trigger-popover\"\n [ngbPopover]=\"details\" [autoClose]=\"'outside'\"\n triggers=\"manual\" #p=\"ngbPopover\" placement=\"left\" container=\"body\"\n (click)=\"togglePopover(p, { data: input.value.values[cycle['@id']], cycle: cycle, key: 'inputs' })\"\n >\n <span pointer>{{propertyValue(input.value.values[cycle['@id']].value, input.value.term['@id']) | precision:3 | default:'-'}}</span>\n <he-blank-node-state class=\"ml-1\"\n [node]=\"input.value.values[cycle['@id']].node\"\n key=\"value\"\n ></he-blank-node-state>\n </span>\n </td>\n </tr>\n </ng-container>\n </tbody>\n </table>\n </he-data-table>\n\n <he-blank-node-state-notice [dataState]=\"dataState\"></he-blank-node-state-notice>\n </ng-container>\n</div>\n\n<ng-container *ngIf=\"selectedView === View.logs && !isOriginal\">\n <div class=\"field has-addons pt-2 px-3\" *ngIf=\"cycles.length > 1\">\n <div class=\"control\">\n <span class=\"button is-small is-static\">Select a Cycle</span>\n </div>\n <div class=\"control is-expanded\">\n <div class=\"select is-small is-fullwidth\">\n <select (change)=\"selectIndex($event)\">\n <option *ngFor=\"let value of cycles; let i = index\" [value]=\"i\">{{i + 1}}. {{defaultLabel(value)}}</option>\n </select>\n </div>\n </div>\n </div>\n\n <he-cycles-activity-logs *ngIf=\"selectedIndex >= 0\"\n [cycle]=\"cycles[selectedIndex]\"\n [original]=\"originalValues[selectedIndex]\"\n [recalculated]=\"cycles[selectedIndex]\"\n ></he-cycles-activity-logs>\n</ng-container>\n\n<he-node-csv-export-confirm *ngIf=\"showDownload\"\n [nodes]=\"cycles\" filename=\"cycle-inputs-products.csv\" [isUpload]=\"false\"\n [headerKeys]=\"['cycle.id', 'cycle.@id', 'cycle.inputs.', 'cycle.products.']\"\n (closed)=\"showDownload = false\"\n></he-node-csv-export-confirm>\n\n<ng-template #emptyTable>\n <div class=\"has-text-centered\">\n <span>No activity data</span>\n </div>\n</ng-template>\n\n<ng-template #emptyValue>\n <span>-</span>\n</ng-template>\n\n<ng-template #details let-node=\"cycle\" let-data=\"data\" let-key=\"key\">\n <p><b>{{defaultLabel(node)}}</b></p>\n <he-node-value-details\n [data]=\"data\" [nodeType]=\"node['@type']\" [dataKey]=\"key\"\n ></he-node-value-details>\n</ng-template>\n", styles: ["fa-icon{display:inline-block;width:10px}he-data-table ::ng-deep .table thead tr th:nth-child(2),he-data-table ::ng-deep .table tbody tr td:nth-child(2){max-width:102px;width:102px}\n"], components: [{ type: i1.FaIconComponent, selector: "fa-icon", inputs: ["classes", "icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }, { type: i2.DataTableComponent, selector: "he-data-table", inputs: ["minHeight", "maxHeight", "nbRows", "small", "height", "width"] }, { type: i3.NodeLinkComponent, selector: "he-node-link", inputs: ["node", "showExternalLink"] }, { type: i4.CyclesFunctionalUnitMeasureComponent, selector: "he-cycles-functional-unit-measure", inputs: ["cycle"] }, { type: i5.BlankNodeStateComponent, selector: "he-blank-node-state", inputs: ["nodeType", "dataKey", "key", "node", "state"] }, { type: i6.BlankNodeStateNoticeComponent, selector: "he-blank-node-state-notice", inputs: ["dataState", "showAggregated", "showDeleted", "showUnchanged"] }, { type: i7.CyclesActivityLogsComponent, selector: "he-cycles-activity-logs", inputs: ["cycle", "original", "recalculated"] }, { type: i8.NodeCsvExportConfirmComponent, selector: "he-node-csv-export-confirm", inputs: ["nodes", "filename", "headerKeys", "extension", "isUpload"], outputs: ["closed"] }, { type: i9.NodeValueDetailsComponent, selector: "he-node-value-details", inputs: ["data", "nodeType", "dataKey"] }], directives: [{ type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i10.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i11.NgbPopover, selector: "[ngbPopover]", inputs: ["animation", "autoClose", "placement", "triggers", "container", "disablePopover", "popoverClass", "openDelay", "closeDelay", "ngbPopover", "popoverTitle"], outputs: ["shown", "hidden"], exportAs: ["ngbPopover"] }, { type: i12.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { type: i12.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }], pipes: { "ellipsis": i13.EllipsisPipe, "default": i14.DefaultPipe, "precision": i15.PrecisionPipe } });
|
|
79
75
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: CyclesActivityComponent, decorators: [{
|
|
80
76
|
type: Component,
|
|
81
77
|
args: [{
|
|
@@ -87,11 +83,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
87
83
|
type: Input
|
|
88
84
|
}], cycles: [{
|
|
89
85
|
type: Input
|
|
90
|
-
}], selected: [{
|
|
91
|
-
type: Input
|
|
92
86
|
}], dataState: [{
|
|
93
87
|
type: Input
|
|
94
88
|
}], enableCompare: [{
|
|
95
89
|
type: Input
|
|
96
90
|
}] } });
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cycles-activity.component.js","sourceRoot":"","sources":["../../../../src/cycles/cycles-activity/cycles-activity.component.ts","../../../../src/cycles/cycles-activity/cycles-activity.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, SimpleChanges } from '@angular/core';\nimport { DataState } from '@hestia-earth/api';\nimport { ICycleJSONLD, Input as HestiaInput, Product } from '@hestia-earth/schema';\nconst orderBy = require('lodash.orderby');\nimport { propertyValue } from '@hestia-earth/utils/dist/term';\n\nimport { groupNodesByTerm, IGroupedKeys, grouppedKeys } from '../../common/node-utils';\nimport { baseUrl, defaultLabel } from '../../common/utils';\n\nenum View {\n  table = 'table',\n  logs = 'logs'\n}\n\n@Component({\n  selector: 'he-cycles-activity',\n  templateUrl: './cycles-activity.component.html',\n  styleUrls: ['./cycles-activity.component.scss']\n})\nexport class CyclesActivityComponent implements OnChanges {\n  @Input()\n  public originalValues: ICycleJSONLD[] = [];\n  @Input()\n  public cycles: ICycleJSONLD[] = [];\n  @Input()\n  public selected: string[] = [];\n  @Input()\n  public dataState?: DataState;\n  @Input()\n  public enableCompare = true;\n\n  public baseUrl = baseUrl();\n  public propertyValue = propertyValue;\n  public defaultLabel = defaultLabel;\n  public showDownload = false;\n  public View = View;\n  public selectedView = View.table;\n  public selectedIndex = 0;\n\n  public inputs: IGroupedKeys<HestiaInput>[] = [];\n  public products: IGroupedKeys<Product>[] = [];\n\n  ngOnChanges(changes: SimpleChanges) {\n    if ('cycles' in changes) {\n      return this.update();\n    }\n    if ('dataState' in changes) {\n      this.selectedView = View.table;\n    }\n  }\n\n  public trackById(_index: number, item: ICycleJSONLD) {\n    return item['@id'];\n  }\n\n  public get isOriginal() {\n    return this.dataState === DataState.original;\n  }\n\n  private update() {\n    const inputsPerCycle = groupNodesByTerm<ICycleJSONLD, HestiaInput>(this.cycles, 'inputs', this.originalValues);\n    this.inputs = orderBy(grouppedKeys(inputsPerCycle), ['key'], ['asc']);\n    const productsPerCycle = groupNodesByTerm<ICycleJSONLD, Product>(this.cycles, 'products', this.originalValues);\n    this.products = orderBy(grouppedKeys(productsPerCycle), ['key'], ['asc']);\n  }\n\n  public togglePopover(popover: any, context: any) {\n    return popover.isOpen() ? popover.close() : popover.open(context);\n  }\n\n  public isSelected(cycle: ICycleJSONLD) {\n    return this.selected.length === 0 || this.selected.includes(cycle['@id']);\n  }\n\n  // Recalculation logs\n\n  public selectIndex({ target: { value }}) {\n    this.selectedIndex = -1;\n    // force a refresh of the logs\n    setTimeout(() => (this.selectedIndex = +value));\n  }\n}\n","<div class=\"columns is-variable is-align-items-center is-2 m-0\">\n  <div class=\"column is-hidden-mobile\"></div>\n  <ng-container  *ngIf=\"selectedView === View.table && (inputs.length || products.length)\">\n    <div class=\"column is-narrow\">\n      <button class=\"button is-dark is-outlined is-small\" (click)=\"showDownload = true\">\n        <fa-icon icon=\"download\"></fa-icon>\n        <span class=\"pl-2\">Download (CSV)</span>\n      </button>\n    </div>\n    <div class=\"column is-narrow col-sep\"></div>\n  </ng-container>\n  <div class=\"column is-narrow\" *ngIf=\"!isOriginal\">\n    <div class=\"field has-addons\">\n      <div class=\"control\">\n        <button class=\"button is-small\" [class.is-active]=\"selectedView === View.table\" (click)=\"selectedView = View.table\">\n          <span class=\"icon is-small\">\n            <fa-icon icon=\"list\" aria-hidden=\"true\"></fa-icon>\n          </span>\n          <span>Table view</span>\n        </button>\n      </div>\n      <div class=\"control\">\n        <button class=\"button is-small\" [class.is-active]=\"selectedView === View.logs\" (click)=\"selectedView = View.logs\">\n          <span class=\"icon is-small\">\n            <fa-icon icon=\"calculator\" aria-hidden=\"true\"></fa-icon>\n          </span>\n          <span>Recalculations logs</span>\n        </button>\n      </div>\n    </div>\n  </div>\n</div>\n\n<div class=\"px-3 pb-3\" [class.is-hidden]=\"selectedView !== View.table\">\n  <ng-container *ngIf=\"inputs.length || products.length; else emptyTable\">\n    <he-data-table class=\"mb-1 is-small\" [small]=\"true\" [nbRows]=\"cycles.length\" maxHeight=\"320\">\n      <table class=\"table is-narrow is-striped\">\n        <thead>\n          <tr>\n            <th class=\"width-auto\"></th>\n            <th class=\"has-border-right\"></th>\n            <th *ngIf=\"products.length\" [attr.colspan]=\"products.length\"\n              [class.has-border-right]=\"inputs.length\"\n            >Products</th>\n            <th *ngIf=\"inputs.length\" [attr.colspan]=\"inputs.length\">Inputs</th>\n          </tr>\n          <tr>\n            <th class=\"width-auto\"></th>\n            <th class=\"has-border-right\"></th>\n            <th *ngFor=\"let product of products; let pl = last\"\n              [attr.title]=\"product.value.term.name\"\n              [class.has-border-right]=\"inputs.length && pl\"\n            >\n              <he-node-link [node]=\"product.value.term\">\n                <span>{{product.value.term.name | ellipsis:30}}</span>\n              </he-node-link>\n            </th>\n            <th *ngFor=\"let input of inputs\"\n              [attr.title]=\"input.value.term.name\"\n            >\n              <he-node-link [node]=\"input.value.term\">\n                <span>{{input.value.term.name | ellipsis:30}}</span>\n              </he-node-link>\n            </th>\n          </tr>\n          <tr>\n            <th class=\"width-auto\"></th>\n            <th class=\"has-border-right\">\n              <a [href]=\"baseUrl + '/schema/Cycle#functionalUnit'\" target=\"_blank\">Functional unit</a>\n            </th>\n            <th *ngFor=\"let product of products; let pl = last\"\n              [attr.title]=\"product.value.term.units\"\n              [class.has-border-right]=\"inputs.length && pl\"\n            >{{product.value.term.units}}</th>\n            <th *ngFor=\"let input of inputs\"\n              [attr.title]=\"input.value.term.units\"\n            >{{input.value.term.units}}</th>\n          </tr>\n        </thead>\n        <tbody>\n          <ng-container *ngFor=\"let cycle of cycles; trackBy: trackById; let i = index\">\n            <tr *ngIf=\"isSelected(cycle)\">\n              <td class=\"width-auto\" [attr.title]=\"defaultLabel(cycle)\">\n                <he-node-link [node]=\"cycle.term || cycle\">\n                  <span class=\"is-nowrap has-text-ellipsis\">{{i + 1}}. {{defaultLabel(cycle)}}</span>\n                </he-node-link>\n              </td>\n              <td class=\"has-border-right\">\n                <he-cycles-functional-unit-measure [cycle]=\"cycle\"></he-cycles-functional-unit-measure>\n              </td>\n              <td class=\"is-nowrap\"\n                *ngFor=\"let product of products; let pl = last\"\n                [class.has-border-right]=\"inputs.length && pl\"\n              >\n                <span *ngIf=\"product.value.values[cycle['@id']]; else emptyValue\"\n                  class=\"trigger-popover\"\n                  [ngbPopover]=\"details\" [autoClose]=\"'outside'\"\n                  triggers=\"manual\" #p=\"ngbPopover\" placement=\"left\" container=\"body\"\n                  (click)=\"togglePopover(p, { data: product.value.values[cycle['@id']], cycle: cycle, key: 'products' })\"\n                >\n                  <span pointer>{{propertyValue(product.value.values[cycle['@id']].value, product.value.term['@id']) | precision:3 | default:'-'}}</span>\n                  <he-blank-node-state class=\"ml-1\"\n                    [node]=\"product.value.values[cycle['@id']].node\"\n                    key=\"value\"\n                  ></he-blank-node-state>\n                </span>\n              </td>\n              <td class=\"is-nowrap\" *ngFor=\"let input of inputs\">\n                <span *ngIf=\"input.value.values[cycle['@id']]; else emptyValue\"\n                  class=\"trigger-popover\"\n                  [ngbPopover]=\"details\" [autoClose]=\"'outside'\"\n                  triggers=\"manual\" #p=\"ngbPopover\" placement=\"left\" container=\"body\"\n                  (click)=\"togglePopover(p, { data: input.value.values[cycle['@id']], cycle: cycle, key: 'inputs' })\"\n                >\n                  <span pointer>{{propertyValue(input.value.values[cycle['@id']].value, input.value.term['@id']) | precision:3 | default:'-'}}</span>\n                  <he-blank-node-state class=\"ml-1\"\n                    [node]=\"input.value.values[cycle['@id']].node\"\n                    key=\"value\"\n                  ></he-blank-node-state>\n                </span>\n              </td>\n            </tr>\n          </ng-container>\n        </tbody>\n      </table>\n    </he-data-table>\n\n    <he-blank-node-state-notice [dataState]=\"dataState\"></he-blank-node-state-notice>\n  </ng-container>\n</div>\n\n<ng-container *ngIf=\"selectedView === View.logs && !isOriginal\">\n  <div class=\"field has-addons pt-2 px-3\" *ngIf=\"cycles.length > 1\">\n    <div class=\"control\">\n      <span class=\"button is-small is-static\">Select a Cycle</span>\n    </div>\n    <div class=\"control is-expanded\">\n      <div class=\"select is-small is-fullwidth\">\n        <select (change)=\"selectIndex($event)\">\n          <option *ngFor=\"let value of cycles; let i = index\" [value]=\"i\">{{i + 1}}. {{defaultLabel(value)}}</option>\n        </select>\n      </div>\n    </div>\n  </div>\n\n  <he-cycles-activity-logs *ngIf=\"selectedIndex >= 0\"\n    [cycle]=\"cycles[selectedIndex]\"\n    [original]=\"originalValues[selectedIndex]\"\n    [recalculated]=\"cycles[selectedIndex]\"\n  ></he-cycles-activity-logs>\n</ng-container>\n\n<he-node-csv-export-confirm *ngIf=\"showDownload\"\n  [nodes]=\"cycles\" filename=\"cycle-inputs-products.csv\" [isUpload]=\"false\"\n  [headerKeys]=\"['cycle.id', 'cycle.@id', 'cycle.inputs.', 'cycle.products.']\"\n  (closed)=\"showDownload = false\"\n></he-node-csv-export-confirm>\n\n<ng-template #emptyTable>\n  <div class=\"has-text-centered\">\n    <span>No activity data</span>\n  </div>\n</ng-template>\n\n<ng-template #emptyValue>\n  <span>-</span>\n</ng-template>\n\n<ng-template #details let-node=\"cycle\" let-data=\"data\" let-key=\"key\">\n  <p><b>{{defaultLabel(node)}}</b></p>\n  <he-node-value-details\n    [data]=\"data\" [nodeType]=\"node['@type']\" [dataKey]=\"key\"\n  ></he-node-value-details>\n</ng-template>\n"]}
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cycles-activity.component.js","sourceRoot":"","sources":["../../../../src/cycles/cycles-activity/cycles-activity.component.ts","../../../../src/cycles/cycles-activity/cycles-activity.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, SimpleChanges } from '@angular/core';\nimport { DataState } from '@hestia-earth/api';\nimport { ICycleJSONLD, Input as HestiaInput, Product } from '@hestia-earth/schema';\nconst orderBy = require('lodash.orderby');\nimport { propertyValue } from '@hestia-earth/utils/dist/term';\n\nimport { groupNodesByTerm, IGroupedKeys, grouppedKeys } from '../../common/node-utils';\nimport { baseUrl, defaultLabel } from '../../common/utils';\n\nenum View {\n  table = 'table',\n  logs = 'logs'\n}\n\n@Component({\n  selector: 'he-cycles-activity',\n  templateUrl: './cycles-activity.component.html',\n  styleUrls: ['./cycles-activity.component.scss']\n})\nexport class CyclesActivityComponent implements OnChanges {\n  @Input()\n  public originalValues: ICycleJSONLD[] = [];\n  @Input()\n  public cycles: ICycleJSONLD[] = [];\n  @Input()\n  public dataState?: DataState;\n  @Input()\n  public enableCompare = true;\n\n  public baseUrl = baseUrl();\n  public propertyValue = propertyValue;\n  public defaultLabel = defaultLabel;\n  public showDownload = false;\n  public View = View;\n  public selectedView = View.table;\n  public selectedIndex = 0;\n\n  public inputs: IGroupedKeys<HestiaInput>[] = [];\n  public products: IGroupedKeys<Product>[] = [];\n\n  ngOnChanges(changes: SimpleChanges) {\n    if ('cycles' in changes) {\n      return this.update();\n    }\n    if ('dataState' in changes) {\n      this.selectedView = View.table;\n    }\n  }\n\n  public trackById(_index: number, item: ICycleJSONLD) {\n    return item['@id'];\n  }\n\n  public get isOriginal() {\n    return this.dataState === DataState.original;\n  }\n\n  private update() {\n    const inputsPerCycle = groupNodesByTerm<ICycleJSONLD, HestiaInput>(this.cycles, 'inputs', this.originalValues);\n    this.inputs = orderBy(grouppedKeys(inputsPerCycle), ['key'], ['asc']);\n    const productsPerCycle = groupNodesByTerm<ICycleJSONLD, Product>(this.cycles, 'products', this.originalValues);\n    this.products = orderBy(grouppedKeys(productsPerCycle), ['key'], ['asc']);\n  }\n\n  public togglePopover(popover: any, context: any) {\n    return popover.isOpen() ? popover.close() : popover.open(context);\n  }\n\n  // Recalculation logs\n\n  public selectIndex({ target: { value }}) {\n    this.selectedIndex = -1;\n    // force a refresh of the logs\n    setTimeout(() => (this.selectedIndex = +value));\n  }\n}\n","<div class=\"columns is-variable is-align-items-center is-2 m-0\">\n  <div class=\"column is-hidden-mobile\"></div>\n  <ng-container  *ngIf=\"selectedView === View.table && (inputs.length || products.length)\">\n    <div class=\"column is-narrow\">\n      <button class=\"button is-dark is-outlined is-small\" (click)=\"showDownload = true\">\n        <fa-icon icon=\"download\"></fa-icon>\n        <span class=\"pl-2\">Download (CSV)</span>\n      </button>\n    </div>\n    <div class=\"column is-narrow col-sep\"></div>\n  </ng-container>\n  <div class=\"column is-narrow\" *ngIf=\"!isOriginal\">\n    <div class=\"field has-addons\">\n      <div class=\"control\">\n        <button class=\"button is-small\" [class.is-active]=\"selectedView === View.table\" (click)=\"selectedView = View.table\">\n          <span class=\"icon is-small\">\n            <fa-icon icon=\"list\" aria-hidden=\"true\"></fa-icon>\n          </span>\n          <span>Table view</span>\n        </button>\n      </div>\n      <div class=\"control\">\n        <button class=\"button is-small\" [class.is-active]=\"selectedView === View.logs\" (click)=\"selectedView = View.logs\">\n          <span class=\"icon is-small\">\n            <fa-icon icon=\"calculator\" aria-hidden=\"true\"></fa-icon>\n          </span>\n          <span>Recalculations logs</span>\n        </button>\n      </div>\n    </div>\n  </div>\n</div>\n\n<div class=\"px-3 pb-3\" [class.is-hidden]=\"selectedView !== View.table\">\n  <ng-container *ngIf=\"inputs.length || products.length; else emptyTable\">\n    <he-data-table class=\"mb-1 is-small\" [small]=\"true\" [nbRows]=\"cycles.length\" maxHeight=\"320\">\n      <table class=\"table is-narrow is-striped\">\n        <thead>\n          <tr>\n            <th class=\"width-auto\"></th>\n            <th class=\"has-border-right\"></th>\n            <th *ngIf=\"products.length\" [attr.colspan]=\"products.length\"\n              [class.has-border-right]=\"inputs.length\"\n            >Products</th>\n            <th *ngIf=\"inputs.length\" [attr.colspan]=\"inputs.length\">Inputs</th>\n          </tr>\n          <tr>\n            <th class=\"width-auto\"></th>\n            <th class=\"has-border-right\"></th>\n            <th *ngFor=\"let product of products; let pl = last\"\n              [attr.title]=\"product.value.term.name\"\n              [class.has-border-right]=\"inputs.length && pl\"\n            >\n              <he-node-link [node]=\"product.value.term\">\n                <span>{{product.value.term.name | ellipsis:30}}</span>\n              </he-node-link>\n            </th>\n            <th *ngFor=\"let input of inputs\"\n              [attr.title]=\"input.value.term.name\"\n            >\n              <he-node-link [node]=\"input.value.term\">\n                <span>{{input.value.term.name | ellipsis:30}}</span>\n              </he-node-link>\n            </th>\n          </tr>\n          <tr>\n            <th class=\"width-auto\"></th>\n            <th class=\"has-border-right\">\n              <a [href]=\"baseUrl + '/schema/Cycle#functionalUnit'\" target=\"_blank\">Functional unit</a>\n            </th>\n            <th *ngFor=\"let product of products; let pl = last\"\n              [attr.title]=\"product.value.term.units\"\n              [class.has-border-right]=\"inputs.length && pl\"\n            >{{product.value.term.units}}</th>\n            <th *ngFor=\"let input of inputs\"\n              [attr.title]=\"input.value.term.units\"\n            >{{input.value.term.units}}</th>\n          </tr>\n        </thead>\n        <tbody>\n          <ng-container *ngFor=\"let cycle of cycles; trackBy: trackById; let i = index\">\n            <tr>\n              <td class=\"width-auto\" [attr.title]=\"defaultLabel(cycle)\">\n                <he-node-link [node]=\"cycle.term || cycle\">\n                  <span class=\"is-nowrap has-text-ellipsis\">{{i + 1}}. {{defaultLabel(cycle)}}</span>\n                </he-node-link>\n              </td>\n              <td class=\"has-border-right\">\n                <he-cycles-functional-unit-measure [cycle]=\"cycle\"></he-cycles-functional-unit-measure>\n              </td>\n              <td class=\"is-nowrap\"\n                *ngFor=\"let product of products; let pl = last\"\n                [class.has-border-right]=\"inputs.length && pl\"\n              >\n                <span *ngIf=\"product.value.values[cycle['@id']]; else emptyValue\"\n                  class=\"trigger-popover\"\n                  [ngbPopover]=\"details\" [autoClose]=\"'outside'\"\n                  triggers=\"manual\" #p=\"ngbPopover\" placement=\"left\" container=\"body\"\n                  (click)=\"togglePopover(p, { data: product.value.values[cycle['@id']], cycle: cycle, key: 'products' })\"\n                >\n                  <span pointer>{{propertyValue(product.value.values[cycle['@id']].value, product.value.term['@id']) | precision:3 | default:'-'}}</span>\n                  <he-blank-node-state class=\"ml-1\"\n                    [node]=\"product.value.values[cycle['@id']].node\"\n                    key=\"value\"\n                  ></he-blank-node-state>\n                </span>\n              </td>\n              <td class=\"is-nowrap\" *ngFor=\"let input of inputs\">\n                <span *ngIf=\"input.value.values[cycle['@id']]; else emptyValue\"\n                  class=\"trigger-popover\"\n                  [ngbPopover]=\"details\" [autoClose]=\"'outside'\"\n                  triggers=\"manual\" #p=\"ngbPopover\" placement=\"left\" container=\"body\"\n                  (click)=\"togglePopover(p, { data: input.value.values[cycle['@id']], cycle: cycle, key: 'inputs' })\"\n                >\n                  <span pointer>{{propertyValue(input.value.values[cycle['@id']].value, input.value.term['@id']) | precision:3 | default:'-'}}</span>\n                  <he-blank-node-state class=\"ml-1\"\n                    [node]=\"input.value.values[cycle['@id']].node\"\n                    key=\"value\"\n                  ></he-blank-node-state>\n                </span>\n              </td>\n            </tr>\n          </ng-container>\n        </tbody>\n      </table>\n    </he-data-table>\n\n    <he-blank-node-state-notice [dataState]=\"dataState\"></he-blank-node-state-notice>\n  </ng-container>\n</div>\n\n<ng-container *ngIf=\"selectedView === View.logs && !isOriginal\">\n  <div class=\"field has-addons pt-2 px-3\" *ngIf=\"cycles.length > 1\">\n    <div class=\"control\">\n      <span class=\"button is-small is-static\">Select a Cycle</span>\n    </div>\n    <div class=\"control is-expanded\">\n      <div class=\"select is-small is-fullwidth\">\n        <select (change)=\"selectIndex($event)\">\n          <option *ngFor=\"let value of cycles; let i = index\" [value]=\"i\">{{i + 1}}. {{defaultLabel(value)}}</option>\n        </select>\n      </div>\n    </div>\n  </div>\n\n  <he-cycles-activity-logs *ngIf=\"selectedIndex >= 0\"\n    [cycle]=\"cycles[selectedIndex]\"\n    [original]=\"originalValues[selectedIndex]\"\n    [recalculated]=\"cycles[selectedIndex]\"\n  ></he-cycles-activity-logs>\n</ng-container>\n\n<he-node-csv-export-confirm *ngIf=\"showDownload\"\n  [nodes]=\"cycles\" filename=\"cycle-inputs-products.csv\" [isUpload]=\"false\"\n  [headerKeys]=\"['cycle.id', 'cycle.@id', 'cycle.inputs.', 'cycle.products.']\"\n  (closed)=\"showDownload = false\"\n></he-node-csv-export-confirm>\n\n<ng-template #emptyTable>\n  <div class=\"has-text-centered\">\n    <span>No activity data</span>\n  </div>\n</ng-template>\n\n<ng-template #emptyValue>\n  <span>-</span>\n</ng-template>\n\n<ng-template #details let-node=\"cycle\" let-data=\"data\" let-key=\"key\">\n  <p><b>{{defaultLabel(node)}}</b></p>\n  <he-node-value-details\n    [data]=\"data\" [nodeType]=\"node['@type']\" [dataKey]=\"key\"\n  ></he-node-value-details>\n</ng-template>\n"]}
|