@hestia-earth/ui-components 0.23.23 → 0.24.0-0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (68) hide show
  1. package/common/node-utils.d.ts +22 -3
  2. package/cycles/cycles-completeness/cycles-completeness.component.d.ts +90 -24
  3. package/cycles/cycles-functional-unit-measure/cycles-functional-unit-measure.component.d.ts +4 -2
  4. package/cycles/cycles-nodes/cycles-nodes.component.d.ts +193 -0
  5. package/cycles/cycles-nodes-timeline/cycles-nodes-timeline.component.d.ts +20 -0
  6. package/cycles/cycles.module.d.ts +12 -19
  7. package/cycles/index.d.ts +2 -9
  8. package/engine/engine.service.d.ts +2 -1
  9. package/esm2022/common/node-utils.mjs +19 -1
  10. package/esm2022/cycles/cycles-completeness/cycles-completeness.component.mjs +68 -50
  11. package/esm2022/cycles/cycles-functional-unit-measure/cycles-functional-unit-measure.component.mjs +9 -4
  12. package/esm2022/cycles/cycles-nodes/cycles-nodes.component.mjs +211 -0
  13. package/esm2022/cycles/cycles-nodes-timeline/cycles-nodes-timeline.component.mjs +50 -0
  14. package/esm2022/cycles/cycles.module.mjs +11 -39
  15. package/esm2022/cycles/index.mjs +3 -10
  16. package/esm2022/engine/engine.service.mjs +9 -10
  17. package/esm2022/files/files-form/files-form.component.mjs +1 -1
  18. package/esm2022/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.mjs +99 -87
  19. package/esm2022/impact-assessments/impact-assessments-products/impact-assessments-products.component.mjs +85 -111
  20. package/esm2022/impact-assessments/impact-assessments.module.mjs +1 -5
  21. package/esm2022/impact-assessments/index.mjs +1 -2
  22. package/esm2022/node/index.mjs +2 -1
  23. package/esm2022/node/node-logs-models/node-logs-models.component.mjs +172 -118
  24. package/esm2022/node/node-logs-models/node-logs-models.model.mjs +5 -8
  25. package/esm2022/node/node-store.service.mjs +108 -0
  26. package/esm2022/search/search.service.mjs +6 -4
  27. package/esm2022/sites/index.mjs +1 -2
  28. package/esm2022/sites/sites-maps/sites-maps.component.mjs +36 -39
  29. package/esm2022/sites/sites-measurements/sites-measurements.component.mjs +71 -72
  30. package/esm2022/sites/sites.module.mjs +3 -4
  31. package/fesm2022/hestia-earth-ui-components.mjs +942 -1222
  32. package/fesm2022/hestia-earth-ui-components.mjs.map +1 -1
  33. package/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.d.ts +23 -15
  34. package/impact-assessments/impact-assessments-products/impact-assessments-products.component.d.ts +91 -47
  35. package/impact-assessments/impact-assessments.module.d.ts +8 -9
  36. package/impact-assessments/index.d.ts +0 -1
  37. package/node/index.d.ts +1 -0
  38. package/node/node-logs-models/node-logs-models.component.d.ts +78 -57
  39. package/node/node-logs-models/node-logs-models.model.d.ts +6 -9
  40. package/node/node-store.service.d.ts +38 -0
  41. package/package.json +1 -1
  42. package/search/search.service.d.ts +1 -0
  43. package/sites/index.d.ts +0 -1
  44. package/sites/sites-maps/sites-maps.component.d.ts +18 -11
  45. package/sites/sites-measurements/sites-measurements.component.d.ts +79 -25
  46. package/sites/sites.module.d.ts +6 -7
  47. package/cycles/cycles-activity/cycles-activity.component.d.ts +0 -44
  48. package/cycles/cycles-activity-logs/cycles-activity-logs.component.d.ts +0 -69
  49. package/cycles/cycles-animals/cycles-animals.component.d.ts +0 -27
  50. package/cycles/cycles-completeness-logs/cycles-completeness-logs.component.d.ts +0 -62
  51. package/cycles/cycles-emissions/cycles-emissions.component.d.ts +0 -51
  52. package/cycles/cycles-emissions-logs/cycles-emissions-logs.component.d.ts +0 -70
  53. package/cycles/cycles-practices/cycles-practices.component.d.ts +0 -44
  54. package/cycles/cycles-practices-logs/cycles-practices-logs.component.d.ts +0 -70
  55. package/cycles/cycles-practices-timeline/cycles-practices-timeline.component.d.ts +0 -18
  56. package/esm2022/cycles/cycles-activity/cycles-activity.component.mjs +0 -118
  57. package/esm2022/cycles/cycles-activity-logs/cycles-activity-logs.component.mjs +0 -44
  58. package/esm2022/cycles/cycles-animals/cycles-animals.component.mjs +0 -79
  59. package/esm2022/cycles/cycles-completeness-logs/cycles-completeness-logs.component.mjs +0 -35
  60. package/esm2022/cycles/cycles-emissions/cycles-emissions.component.mjs +0 -127
  61. package/esm2022/cycles/cycles-emissions-logs/cycles-emissions-logs.component.mjs +0 -58
  62. package/esm2022/cycles/cycles-practices/cycles-practices.component.mjs +0 -116
  63. package/esm2022/cycles/cycles-practices-logs/cycles-practices-logs.component.mjs +0 -58
  64. package/esm2022/cycles/cycles-practices-timeline/cycles-practices-timeline.component.mjs +0 -42
  65. package/esm2022/impact-assessments/impact-assessments-products-logs/impact-assessments-products-logs.component.mjs +0 -64
  66. package/esm2022/sites/sites-measurements-logs/sites-measurements-logs.component.mjs +0 -53
  67. package/impact-assessments/impact-assessments-products-logs/impact-assessments-products-logs.component.d.ts +0 -64
  68. package/sites/sites-measurements-logs/sites-measurements-logs.component.d.ts +0 -66
@@ -1,4 +1,24 @@
1
- import { Term, ICycleJSONLD, ISiteJSONLD, IImpactAssessmentJSONLD, EmissionMethodTier, ITermJSONLD, Completeness, Infrastructure, Emission, Measurement, Practice, Product, Input, Property, Indicator } from '@hestia-earth/schema';
1
+ import { Term, ICycleJSONLD, ISiteJSONLD, IImpactAssessmentJSONLD, EmissionMethodTier, ITermJSONLD, Completeness, Emission, Measurement, Practice, Product, Input, Property, Indicator, Animal, Management, Transformation } from '@hestia-earth/schema';
2
+ export type blankNode = Animal | Emission | Input | Product | Property | Practice | Indicator | Measurement | Management;
3
+ export type blankNodesKey = 'animals' | 'emissions' | 'emissionsResourceUse' | 'endpoints' | 'impacts' | 'inputs' | 'management' | 'measurements' | 'products' | 'practices';
4
+ export declare enum BlankNodesKey {
5
+ animals = "animals",
6
+ emissions = "emissions",
7
+ emissionsResourceUse = "emissionsResourceUse",
8
+ endpoints = "endpoints",
9
+ impacts = "impacts",
10
+ inputs = "inputs",
11
+ management = "management",
12
+ measurements = "measurements",
13
+ products = "products",
14
+ practices = "practices"
15
+ }
16
+ export declare const filterBlankNode: (filterTerm: string) => ({ term }: blankNode) => boolean;
17
+ export type nonBlankNode = Completeness;
18
+ export type nonBlankNodesKey = 'completeness';
19
+ export declare enum NonBlankNodesKey {
20
+ completeness = "completeness"
21
+ }
2
22
  export declare const ignoreKeys: string[];
3
23
  export declare const isValidKey: (key: string) => boolean;
4
24
  export declare const isMethodModelAllowed: (filterMethod?: Term) => (node: Indicator) => boolean;
@@ -9,7 +29,6 @@ export declare enum NodeKeyState {
9
29
  deleted = "deleted",
10
30
  unchanged = "unchanged"
11
31
  }
12
- export type blankNode = Completeness | Infrastructure | Input | Emission | Measurement | Practice | Product | Property;
13
32
  export declare const isState: (node: blankNode, key: string, state: NodeKeyState) => any;
14
33
  export interface IGroupedNode<T> {
15
34
  node: T;
@@ -58,4 +77,4 @@ export declare const grouppedKeys: <T>(values: {
58
77
  }[];
59
78
  export declare const methodTierOrder: (methodTier: EmissionMethodTier) => number;
60
79
  export declare const grouppedValueKeys: string[];
61
- export declare const groupNodesByTerm: <T extends ISiteJSONLD | ICycleJSONLD | IImpactAssessmentJSONLD, R>(nodes: T[], key: 'endpoints' | 'impacts' | 'emissionsResourceUse' | 'inputs' | 'products' | 'practices' | 'emissions' | 'measurements' | 'animals', originalValues?: T[], includeNode?: (_node: any) => boolean) => IGroupedNodes<R>;
80
+ export declare const groupNodesByTerm: <T extends ISiteJSONLD | Transformation | Animal | ICycleJSONLD | IImpactAssessmentJSONLD, R>(nodes: T[], key: blankNodesKey, originalValues?: T[], includeNode?: (_node: any) => boolean) => IGroupedNodes<R>;
@@ -1,35 +1,101 @@
1
- import { OnChanges, SimpleChanges } from '@angular/core';
2
1
  import { DataState } from '@hestia-earth/api';
3
- import { ICycleJSONLD } from '@hestia-earth/schema';
2
+ import { ICycleJSONLD, NodeType } from '@hestia-earth/schema';
3
+ import { HeNodeStoreService } from '../../node/node-store.service';
4
+ import { NonBlankNodesKey } from '../../common/node-utils';
4
5
  import * as i0 from "@angular/core";
5
6
  declare enum View {
6
- table = "table",
7
- logs = "logs"
7
+ table = "Table view",
8
+ logs = "Recalculations logs"
8
9
  }
9
- export declare class CyclesCompletenessComponent implements OnChanges {
10
- originalValues: ICycleJSONLD[];
11
- cycles: ICycleJSONLD[];
12
- dataState?: DataState;
13
- baseUrl: string;
14
- defaultLabel: (node?: any) => any;
15
- keyToLabel: (key: string) => string;
16
- getCompleteness: (cycle: any) => any;
17
- headerKeys: string[];
18
- showDownload: boolean;
19
- View: typeof View;
20
- selectedView: View;
21
- selectedIndex: number;
22
- ngOnChanges(changes: SimpleChanges): void;
23
- trackById(_index: number, item: ICycleJSONLD): string;
24
- get completenessKeys(): string[];
25
- get isOriginal(): boolean;
26
- private updateSelectedIndex;
27
- selectIndex({ target: { value } }: {
10
+ export declare class CyclesCompletenessComponent {
11
+ private nodeStoreService;
12
+ protected _dataState: import("@angular/core").WritableSignal<DataState>;
13
+ set dataState(value: DataState);
14
+ protected baseUrl: string;
15
+ protected defaultLabel: (node?: any) => any;
16
+ protected keyToLabel: (key: string) => string;
17
+ protected getCompleteness: (cycle: any) => any;
18
+ protected headerKeys: string[];
19
+ protected showDownload: boolean;
20
+ protected nodeKey: NonBlankNodesKey;
21
+ protected View: typeof View;
22
+ protected viewIcon: {
23
+ "Table view": string;
24
+ "Recalculations logs": string;
25
+ };
26
+ private showView;
27
+ protected views: import("@angular/core").Signal<View[]>;
28
+ protected selectedView: import("@angular/core").WritableSignal<View>;
29
+ private originalCycles;
30
+ private _allCycles;
31
+ protected cycles: import("@angular/core").Signal<ICycleJSONLD[]>;
32
+ private selectedIndex;
33
+ private ogirinalSelectedCycle;
34
+ private selectedCycle;
35
+ protected selectedLogsKey: import("@angular/core").Signal<any>;
36
+ protected selectedOriginalValues: import("@angular/core").Signal<any>;
37
+ protected selectedRecalculatedValues: import("@angular/core").Signal<any>;
38
+ protected selectedNode: import("@angular/core").Signal<{
39
+ '@type': NodeType;
40
+ type: NodeType;
41
+ dataState: DataState;
42
+ description?: string;
43
+ treatment?: string;
44
+ commercialPracticeTreatment?: boolean;
45
+ endDate?: string;
46
+ startDate?: string;
47
+ startDateDefinition?: import("@hestia-earth/schema").CycleStartDateDefinition;
48
+ cycleDuration?: number;
49
+ site?: import("@hestia-earth/schema").ISiteJSONLD;
50
+ otherSites?: import("@hestia-earth/schema").ISiteJSONLD[];
51
+ siteDuration?: number;
52
+ otherSitesDuration?: number[];
53
+ functionalUnit?: import("@hestia-earth/schema").CycleFunctionalUnit;
54
+ functionalUnitDetails?: string;
55
+ numberOfCycles?: number;
56
+ numberOfReplications?: number;
57
+ sampleWeight?: number;
58
+ harvestedArea?: number;
59
+ defaultMethodClassification?: import("@hestia-earth/schema").CycleDefaultMethodClassification;
60
+ defaultMethodClassificationDescription?: string;
61
+ defaultSource?: import("@hestia-earth/schema").ISourceJSONLD;
62
+ completeness?: import("@hestia-earth/schema").Completeness;
63
+ practices?: import("@hestia-earth/schema").Practice[];
64
+ animals?: import("@hestia-earth/schema").Animal[];
65
+ inputs?: import("@hestia-earth/schema").Input[];
66
+ products?: import("@hestia-earth/schema").Product[];
67
+ transformations?: import("@hestia-earth/schema").Transformation[];
68
+ emissions?: import("@hestia-earth/schema").Emission[];
69
+ dataPrivate?: boolean;
70
+ originalId?: string;
71
+ schemaVersion?: string;
72
+ added?: string[];
73
+ addedVersion?: string[];
74
+ updated?: string[];
75
+ updatedVersion?: string[];
76
+ aggregated?: boolean;
77
+ aggregatedVersion?: string;
78
+ aggregatedQualityScore?: number;
79
+ aggregatedQualityScoreMax?: number;
80
+ aggregatedCycles?: ICycleJSONLD[];
81
+ aggregatedSources?: import("@hestia-earth/schema").ISourceJSONLD[];
82
+ createdAt?: Date;
83
+ updatedAt?: Date;
84
+ '@context': string | (string | import("@hestia-earth/schema").IContext)[];
85
+ '@id': string;
86
+ name: string;
87
+ }>;
88
+ protected hasData: import("@angular/core").Signal<number>;
89
+ protected isOriginal: import("@angular/core").Signal<boolean>;
90
+ protected completenessKeys: import("@angular/core").Signal<string[]>;
91
+ constructor(nodeStoreService: HeNodeStoreService);
92
+ protected trackById(_index: number, item: ICycleJSONLD): string;
93
+ protected selectIndex({ target: { value } }: {
28
94
  target: {
29
95
  value: any;
30
96
  };
31
97
  }): void;
32
98
  static ɵfac: i0.ɵɵFactoryDeclaration<CyclesCompletenessComponent, never>;
33
- static ɵcmp: i0.ɵɵComponentDeclaration<CyclesCompletenessComponent, "he-cycles-completeness", never, { "originalValues": { "alias": "originalValues"; "required": false; }; "cycles": { "alias": "cycles"; "required": false; }; "dataState": { "alias": "dataState"; "required": false; }; }, {}, never, never, false, never>;
99
+ static ɵcmp: i0.ɵɵComponentDeclaration<CyclesCompletenessComponent, "he-cycles-completeness", never, { "dataState": { "alias": "dataState"; "required": false; }; }, {}, never, never, false, never>;
34
100
  }
35
101
  export {};
@@ -1,8 +1,10 @@
1
1
  import { ICycleJSONLD, CycleFunctionalUnit } from '@hestia-earth/schema';
2
2
  import * as i0 from "@angular/core";
3
3
  export declare class CyclesFunctionalUnitMeasureComponent {
4
- cycle?: ICycleJSONLD;
5
- CycleFunctionalUnit: typeof CycleFunctionalUnit;
4
+ private _cycle;
5
+ set cycle(value: ICycleJSONLD);
6
+ protected functionalUnit: import("@angular/core").Signal<CycleFunctionalUnit>;
7
+ protected CycleFunctionalUnit: typeof CycleFunctionalUnit;
6
8
  static ɵfac: i0.ɵɵFactoryDeclaration<CyclesFunctionalUnitMeasureComponent, never>;
7
9
  static ɵcmp: i0.ɵɵComponentDeclaration<CyclesFunctionalUnitMeasureComponent, "he-cycles-functional-unit-measure", never, { "cycle": { "alias": "cycle"; "required": false; }; }, {}, never, never, false, never>;
8
10
  }
@@ -0,0 +1,193 @@
1
+ import { DataState } from '@hestia-earth/api';
2
+ import { ICycleJSONLD, Input as HestiaInput, Product, NodeType, Animal, Emission, Practice, TermTermType, EmissionMethodTier, Term, Transformation } from '@hestia-earth/schema';
3
+ import { BlankNodesKey, blankNode } from '../../common/node-utils';
4
+ import { HeNodeStoreService } from '../../node/node-store.service';
5
+ import { IGroupedKeys } from '../../common/node-utils';
6
+ import * as i0 from "@angular/core";
7
+ declare enum View {
8
+ table = "Table view",
9
+ chart = "Chart view",
10
+ timeline = "Operations Timeline",
11
+ logs = "Recalculations logs"
12
+ }
13
+ type groupedEmissions = {
14
+ [methodTier in EmissionMethodTier]: IGroupedKeys<Emission>[];
15
+ };
16
+ export declare enum CycleNodesKeyGroup {
17
+ animals = "animals",
18
+ transformations = "transformations"
19
+ }
20
+ type groupedNode = Animal | Transformation;
21
+ export declare class CyclesNodesComponent {
22
+ private nodeStoreService;
23
+ protected _dataState: import("@angular/core").WritableSignal<DataState>;
24
+ set dataState(value: DataState);
25
+ protected BlankNodesKey: typeof BlankNodesKey;
26
+ protected firstNodeKey: import("@angular/core").Signal<BlankNodesKey>;
27
+ protected selectedNodeKey: import("@angular/core").WritableSignal<BlankNodesKey>;
28
+ protected _nodeKeys: import("@angular/core").WritableSignal<BlankNodesKey[]>;
29
+ set nodeKeys(value: BlankNodesKey[]);
30
+ protected selectedGroupTerm: import("@angular/core").WritableSignal<Term>;
31
+ protected _nodeKeyGroup: import("@angular/core").WritableSignal<CycleNodesKeyGroup>;
32
+ set nodeKeyGroup(value: CycleNodesKeyGroup);
33
+ protected baseUrl: string;
34
+ protected propertyValue: (value: string | number | (string | number)[], termId?: string) => number;
35
+ protected defaultLabel: (node?: any) => any;
36
+ protected showDownload: boolean;
37
+ protected headerKeys: import("@angular/core").Signal<string[]>;
38
+ protected View: typeof View;
39
+ protected viewIcon: {
40
+ "Table view": string;
41
+ "Chart view": string;
42
+ "Operations Timeline": string;
43
+ "Recalculations logs": string;
44
+ };
45
+ private showView;
46
+ protected views: import("@angular/core").Signal<View[]>;
47
+ protected selectedView: import("@angular/core").WritableSignal<View>;
48
+ private _allNodes;
49
+ private originalNodes;
50
+ private currentNodes;
51
+ protected originalCycles: import("@angular/core").Signal<ICycleJSONLD[] | groupedNode[]>;
52
+ protected cycles: import("@angular/core").Signal<ICycleJSONLD[] | groupedNode[]>;
53
+ private selectedIndex;
54
+ private ogirinalSelectedCycle;
55
+ private selectedCycle;
56
+ protected selectedLogsKey: import("@angular/core").Signal<any>;
57
+ protected selectedOriginalValues: import("@angular/core").Signal<any>;
58
+ protected selectedRecalculatedValues: import("@angular/core").Signal<any>;
59
+ protected selectedNode: import("@angular/core").Signal<{
60
+ '@type': NodeType;
61
+ type: NodeType;
62
+ dataState: DataState;
63
+ description?: string;
64
+ treatment?: string;
65
+ commercialPracticeTreatment?: boolean;
66
+ endDate?: string;
67
+ startDate?: string;
68
+ startDateDefinition?: import("@hestia-earth/schema").CycleStartDateDefinition;
69
+ cycleDuration?: number;
70
+ site?: import("@hestia-earth/schema").ISiteJSONLD;
71
+ otherSites?: import("@hestia-earth/schema").ISiteJSONLD[];
72
+ siteDuration?: number;
73
+ otherSitesDuration?: number[];
74
+ functionalUnit?: import("@hestia-earth/schema").CycleFunctionalUnit;
75
+ functionalUnitDetails?: string;
76
+ numberOfCycles?: number;
77
+ numberOfReplications?: number;
78
+ sampleWeight?: number;
79
+ harvestedArea?: number;
80
+ defaultMethodClassification?: import("@hestia-earth/schema").CycleDefaultMethodClassification;
81
+ defaultMethodClassificationDescription?: string;
82
+ defaultSource?: import("@hestia-earth/schema").ISourceJSONLD;
83
+ completeness?: import("@hestia-earth/schema").Completeness;
84
+ practices?: Practice[];
85
+ animals?: Animal[];
86
+ inputs?: HestiaInput[];
87
+ products?: Product[];
88
+ transformations?: Transformation[];
89
+ emissions?: Emission[];
90
+ dataPrivate?: boolean;
91
+ originalId?: string;
92
+ schemaVersion?: string;
93
+ added?: string[];
94
+ addedVersion?: string[];
95
+ updated?: string[];
96
+ updatedVersion?: string[];
97
+ aggregated?: boolean;
98
+ aggregatedVersion?: string;
99
+ aggregatedQualityScore?: number;
100
+ aggregatedQualityScoreMax?: number;
101
+ aggregatedCycles?: ICycleJSONLD[];
102
+ aggregatedSources?: import("@hestia-earth/schema").ISourceJSONLD[];
103
+ createdAt?: Date;
104
+ updatedAt?: Date;
105
+ '@context': string | (string | import("@hestia-earth/schema").IContext)[];
106
+ '@id': string;
107
+ name: string;
108
+ } | {
109
+ '@type': NodeType;
110
+ type: NodeType;
111
+ dataState: DataState;
112
+ transformationId?: string;
113
+ term?: Term;
114
+ description?: string;
115
+ startDate?: string;
116
+ endDate?: string;
117
+ transformationDuration?: number;
118
+ previousTransformationId?: string;
119
+ transformedShare?: number;
120
+ site?: import("@hestia-earth/schema").Site;
121
+ inputs?: HestiaInput[];
122
+ emissions?: Emission[];
123
+ products?: Product[];
124
+ practices?: Practice[];
125
+ schemaVersion?: string;
126
+ added?: string[];
127
+ addedVersion?: string[];
128
+ updated?: string[];
129
+ updatedVersion?: string[];
130
+ id?: string;
131
+ } | {
132
+ '@type': NodeType;
133
+ type: NodeType;
134
+ dataState: DataState;
135
+ term?: Term;
136
+ description?: string;
137
+ referencePeriod?: import("@hestia-earth/schema").AnimalReferencePeriod;
138
+ value?: number;
139
+ sd?: number;
140
+ min?: number;
141
+ max?: number;
142
+ statsDefinition?: import("@hestia-earth/schema").AnimalStatsDefinition;
143
+ observations?: number;
144
+ price?: number;
145
+ currency?: string;
146
+ methodClassification?: import("@hestia-earth/schema").AnimalMethodClassification;
147
+ methodClassificationDescription?: string;
148
+ source?: import("@hestia-earth/schema").Source;
149
+ properties?: import("@hestia-earth/schema").Property[];
150
+ inputs?: HestiaInput[];
151
+ practices?: Practice[];
152
+ schemaVersion?: string;
153
+ added?: string[];
154
+ addedVersion?: string[];
155
+ updated?: string[];
156
+ updatedVersion?: string[];
157
+ aggregated?: string[];
158
+ aggregatedVersion?: string[];
159
+ id?: string;
160
+ }>;
161
+ private isOriginal;
162
+ private originalValues;
163
+ protected showSwitchToRecalculated: import("@angular/core").Signal<boolean>;
164
+ protected timelineValues: import("@angular/core").Signal<blankNode[]>;
165
+ private enableTimeline;
166
+ protected isNodeKeyAllowed: import("@angular/core").Signal<boolean>;
167
+ private groupedNodes;
168
+ protected groupNodeTerms: import("@angular/core").Signal<Term[]>;
169
+ protected isGroupNode: import("@angular/core").Signal<boolean>;
170
+ protected isEmission: import("@angular/core").Signal<boolean>;
171
+ protected data: import("@angular/core").Signal<groupedEmissions | {
172
+ [k: string]: IGroupedKeys<Product>[];
173
+ }>;
174
+ protected dataKeys: import("@angular/core").Signal<string[]>;
175
+ protected hasData: import("@angular/core").Signal<boolean>;
176
+ protected filterTermTypes: import("@angular/core").Signal<TermTermType[]>;
177
+ protected filterTerm: import("@angular/core").WritableSignal<string>;
178
+ protected csvFilename: import("@angular/core").Signal<string>;
179
+ constructor(nodeStoreService: HeNodeStoreService);
180
+ private groupNodesByKey;
181
+ private groupEmissions;
182
+ protected trackById(_index: number, item: ICycleJSONLD): string;
183
+ protected togglePopover(popover: any, context: any): any;
184
+ protected filterByTerm(term: string): void;
185
+ protected selectIndex({ target: { value } }: {
186
+ target: {
187
+ value: any;
188
+ };
189
+ }): void;
190
+ static ɵfac: i0.ɵɵFactoryDeclaration<CyclesNodesComponent, never>;
191
+ static ɵcmp: i0.ɵɵComponentDeclaration<CyclesNodesComponent, "he-cycles-nodes", never, { "dataState": { "alias": "dataState"; "required": false; }; "nodeKeys": { "alias": "nodeKeys"; "required": false; }; "nodeKeyGroup": { "alias": "nodeKeyGroup"; "required": false; }; }, {}, never, never, false, never>;
192
+ }
193
+ export {};
@@ -0,0 +1,20 @@
1
+ import { ElementRef } from '@angular/core';
2
+ import { DataState } from '@hestia-earth/api';
3
+ import { TermTermType } from '@hestia-earth/schema';
4
+ import { blankNode } from '../../common/node-utils';
5
+ import * as i0 from "@angular/core";
6
+ export declare class CyclesNodesTimelineComponent {
7
+ private el;
8
+ private _recalculatedValues;
9
+ set recalculatedValues(value: blankNode[]);
10
+ protected _dataState: import("@angular/core").WritableSignal<DataState>;
11
+ set dataState(value: DataState);
12
+ protected now: Date;
13
+ protected TermTermType: typeof TermTermType;
14
+ protected blankNodes: import("@angular/core").Signal<blankNode[]>;
15
+ constructor(el: ElementRef);
16
+ trackByBlankNode(_index: number, { term }: blankNode): any;
17
+ get lineWidth(): number;
18
+ static ɵfac: i0.ɵɵFactoryDeclaration<CyclesNodesTimelineComponent, never>;
19
+ static ɵcmp: i0.ɵɵComponentDeclaration<CyclesNodesTimelineComponent, "he-cycles-nodes-timeline", never, { "recalculatedValues": { "alias": "recalculatedValues"; "required": false; }; "dataState": { "alias": "dataState"; "required": false; }; }, {}, never, never, false, never>;
20
+ }
@@ -1,24 +1,17 @@
1
1
  import * as i0 from "@angular/core";
2
- import * as i1 from "./cycles-activity/cycles-activity.component";
3
- import * as i2 from "./cycles-activity-logs/cycles-activity-logs.component";
4
- import * as i3 from "./cycles-animals/cycles-animals.component";
5
- import * as i4 from "./cycles-completeness/cycles-completeness.component";
6
- import * as i5 from "./cycles-completeness-logs/cycles-completeness-logs.component";
7
- import * as i6 from "./cycles-emissions/cycles-emissions.component";
8
- import * as i7 from "./cycles-emissions-chart/cycles-emissions-chart.component";
9
- import * as i8 from "./cycles-emissions-logs/cycles-emissions-logs.component";
10
- import * as i9 from "./cycles-functional-unit-measure/cycles-functional-unit-measure.component";
11
- import * as i10 from "./cycles-practices/cycles-practices.component";
12
- import * as i11 from "./cycles-practices-logs/cycles-practices-logs.component";
13
- import * as i12 from "./cycles-practices-timeline/cycles-practices-timeline.component";
14
- import * as i13 from "./cycles-result/cycles-result.component";
15
- import * as i14 from "@angular/common";
16
- import * as i15 from "@angular/forms";
17
- import * as i16 from "../common/common.module";
18
- import * as i17 from "../node/node.module";
19
- import * as i18 from "../terms/terms.module";
2
+ import * as i1 from "./cycles-completeness/cycles-completeness.component";
3
+ import * as i2 from "./cycles-emissions-chart/cycles-emissions-chart.component";
4
+ import * as i3 from "./cycles-functional-unit-measure/cycles-functional-unit-measure.component";
5
+ import * as i4 from "./cycles-nodes/cycles-nodes.component";
6
+ import * as i5 from "./cycles-nodes-timeline/cycles-nodes-timeline.component";
7
+ import * as i6 from "./cycles-result/cycles-result.component";
8
+ import * as i7 from "@angular/common";
9
+ import * as i8 from "@angular/forms";
10
+ import * as i9 from "../common/common.module";
11
+ import * as i10 from "../node/node.module";
12
+ import * as i11 from "../terms/terms.module";
20
13
  export declare class HeCyclesModule {
21
14
  static ɵfac: i0.ɵɵFactoryDeclaration<HeCyclesModule, never>;
22
- static ɵmod: i0.ɵɵNgModuleDeclaration<HeCyclesModule, [typeof i1.CyclesActivityComponent, typeof i2.CyclesActivityLogsComponent, typeof i3.CyclesAnimalsComponent, typeof i4.CyclesCompletenessComponent, typeof i5.CyclesCompletenessLogsComponent, typeof i6.CyclesEmissionsComponent, typeof i7.CyclesEmissionsChartComponent, typeof i8.CyclesEmissionsLogsComponent, typeof i9.CyclesFunctionalUnitMeasureComponent, typeof i10.CyclesPracticesComponent, typeof i11.CyclesPracticesLogsComponent, typeof i12.CyclesPracticesTimelineComponent, typeof i13.CyclesResultComponent], [typeof i14.CommonModule, typeof i15.FormsModule, typeof i16.HeCommonModule, typeof i17.HeNodeModule, typeof i18.HeTermsModule], [typeof i1.CyclesActivityComponent, typeof i2.CyclesActivityLogsComponent, typeof i3.CyclesAnimalsComponent, typeof i4.CyclesCompletenessComponent, typeof i5.CyclesCompletenessLogsComponent, typeof i6.CyclesEmissionsComponent, typeof i7.CyclesEmissionsChartComponent, typeof i8.CyclesEmissionsLogsComponent, typeof i9.CyclesFunctionalUnitMeasureComponent, typeof i10.CyclesPracticesComponent, typeof i11.CyclesPracticesLogsComponent, typeof i12.CyclesPracticesTimelineComponent, typeof i13.CyclesResultComponent]>;
15
+ static ɵmod: i0.ɵɵNgModuleDeclaration<HeCyclesModule, [typeof i1.CyclesCompletenessComponent, typeof i2.CyclesEmissionsChartComponent, typeof i3.CyclesFunctionalUnitMeasureComponent, typeof i4.CyclesNodesComponent, typeof i5.CyclesNodesTimelineComponent, typeof i6.CyclesResultComponent], [typeof i7.CommonModule, typeof i8.FormsModule, typeof i9.HeCommonModule, typeof i10.HeNodeModule, typeof i11.HeTermsModule], [typeof i1.CyclesCompletenessComponent, typeof i2.CyclesEmissionsChartComponent, typeof i3.CyclesFunctionalUnitMeasureComponent, typeof i4.CyclesNodesComponent, typeof i5.CyclesNodesTimelineComponent, typeof i6.CyclesResultComponent]>;
23
16
  static ɵinj: i0.ɵɵInjectorDeclaration<HeCyclesModule>;
24
17
  }
package/cycles/index.d.ts CHANGED
@@ -1,15 +1,8 @@
1
1
  export * from './cycles.model';
2
2
  export * from './cycles.module';
3
- export { CyclesActivityComponent } from './cycles-activity/cycles-activity.component';
4
- export { CyclesActivityLogsComponent } from './cycles-activity-logs/cycles-activity-logs.component';
5
- export { CyclesAnimalsComponent } from './cycles-animals/cycles-animals.component';
6
3
  export { CyclesCompletenessComponent } from './cycles-completeness/cycles-completeness.component';
7
- export { CyclesCompletenessLogsComponent } from './cycles-completeness-logs/cycles-completeness-logs.component';
8
4
  export { CyclesEmissionsChartComponent } from './cycles-emissions-chart/cycles-emissions-chart.component';
9
- export { CyclesEmissionsLogsComponent } from './cycles-emissions-logs/cycles-emissions-logs.component';
10
- export { CyclesEmissionsComponent } from './cycles-emissions/cycles-emissions.component';
11
5
  export { CyclesFunctionalUnitMeasureComponent } from './cycles-functional-unit-measure/cycles-functional-unit-measure.component';
12
- export { CyclesPracticesComponent } from './cycles-practices/cycles-practices.component';
13
- export { CyclesPracticesLogsComponent } from './cycles-practices-logs/cycles-practices-logs.component';
14
- export { CyclesPracticesTimelineComponent } from './cycles-practices-timeline/cycles-practices-timeline.component';
6
+ export { CyclesNodesComponent, CycleNodesKeyGroup } from './cycles-nodes/cycles-nodes.component';
7
+ export { CyclesNodesTimelineComponent } from './cycles-nodes-timeline/cycles-nodes-timeline.component';
15
8
  export { CyclesResultComponent } from './cycles-result/cycles-result.component';
@@ -102,7 +102,7 @@ export declare class HeEngineService {
102
102
  private init;
103
103
  private loadModels;
104
104
  private get models$();
105
- models(includeEcoinvent?: boolean): Promise<IModel[]>;
105
+ allModels$(includeEcoinvent?: boolean): Observable<IModel[]>;
106
106
  model$(model: Partial<IModel>): Observable<IModel>;
107
107
  nodeModel$(node: Partial<blankNode>, key?: string): Observable<IModel>;
108
108
  model(model: Partial<IModel>): Promise<IModel>;
@@ -115,6 +115,7 @@ export declare class HeEngineService {
115
115
  getTermIds$(params: ICalculationsRequirementsParams): Observable<string[]>;
116
116
  getTermIds(params: ICalculationsRequirementsParams): Promise<any[] | string[]>;
117
117
  orchestratorConfigUrl(type?: NodeType): string;
118
+ ochestratorConfig$(type: NodeType, id?: string): Observable<IOrchestratorConfig>;
118
119
  ochestratorConfig(type: NodeType, id?: string): Promise<IOrchestratorConfig>;
119
120
  static ɵfac: i0.ɵɵFactoryDeclaration<HeEngineService, never>;
120
121
  static ɵprov: i0.ɵɵInjectableDeclaration<HeEngineService>;
@@ -2,6 +2,24 @@ import get from 'lodash.get';
2
2
  import { EmissionMethodTier } from '@hestia-earth/schema';
3
3
  import { propertyValue } from '@hestia-earth/utils/dist/term';
4
4
  import { getDefaultModelId } from '@hestia-earth/glossary';
5
+ export var BlankNodesKey;
6
+ (function (BlankNodesKey) {
7
+ BlankNodesKey["animals"] = "animals";
8
+ BlankNodesKey["emissions"] = "emissions";
9
+ BlankNodesKey["emissionsResourceUse"] = "emissionsResourceUse";
10
+ BlankNodesKey["endpoints"] = "endpoints";
11
+ BlankNodesKey["impacts"] = "impacts";
12
+ BlankNodesKey["inputs"] = "inputs";
13
+ BlankNodesKey["management"] = "management";
14
+ BlankNodesKey["measurements"] = "measurements";
15
+ BlankNodesKey["products"] = "products";
16
+ BlankNodesKey["practices"] = "practices";
17
+ })(BlankNodesKey || (BlankNodesKey = {}));
18
+ export const filterBlankNode = (filterTerm) => ({ term }) => !filterTerm || term?.name?.toLowerCase()?.includes(filterTerm.toLowerCase());
19
+ export var NonBlankNodesKey;
20
+ (function (NonBlankNodesKey) {
21
+ NonBlankNodesKey["completeness"] = "completeness";
22
+ })(NonBlankNodesKey || (NonBlankNodesKey = {}));
5
23
  export const ignoreKeys = ['@type', 'type', 'added', 'updated', 'addedVersion', 'updatedVersion'];
6
24
  export const isValidKey = (key) => !ignoreKeys.includes(key);
7
25
  export const isMethodModelAllowed = (filterMethod) => (node) => node.methodModel?.['@id'] === (filterMethod ? filterMethod['@id'] : getDefaultModelId(node.term?.['@id']));
@@ -91,4 +109,4 @@ export const groupNodesByTerm = (nodes = [], key, originalValues = [], includeNo
91
109
  });
92
110
  return groups;
93
111
  };
94
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-utils.js","sourceRoot":"","sources":["../../../src/common/node-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import get from 'lodash.get';\nimport {\n  Term,\n  ICycleJSONLD,\n  ISiteJSONLD,\n  IImpactAssessmentJSONLD,\n  EmissionMethodTier,\n  ITermJSONLD,\n  Completeness,\n  Infrastructure,\n  Emission,\n  Measurement,\n  Practice,\n  Product,\n  Input,\n  Property,\n  Indicator\n} from '@hestia-earth/schema';\nimport { propertyValue } from '@hestia-earth/utils/dist/term';\nimport { getDefaultModelId } from '@hestia-earth/glossary';\n\nexport const ignoreKeys = ['@type', 'type', 'added', 'updated', 'addedVersion', 'updatedVersion'];\n\nexport const isValidKey = (key: string) => !ignoreKeys.includes(key);\n\nexport const isMethodModelAllowed = (filterMethod?: Term) => (node: Indicator) =>\n  node.methodModel?.['@id'] === (filterMethod ? filterMethod['@id'] : getDefaultModelId(node.term?.['@id']));\n\nexport enum NodeKeyState {\n  added = 'added',\n  updated = 'updated',\n  aggregated = 'aggregated',\n  deleted = 'deleted',\n  unchanged = 'unchanged'\n}\n\nexport type blankNode = Completeness | Infrastructure | Input | Emission | Measurement | Practice | Product | Property;\n\nexport const isState = (node: blankNode, key: string, state: NodeKeyState) =>\n  state in node! && (typeof node![state] === 'boolean' ? node![state] : node![state].includes(key));\n\nexport interface IGroupedNode<T> {\n  // store the node with the highest \"state\"\n  node: T;\n  nodes: T[];\n  index: number;\n  value: number[];\n  dates?: any[];\n  sd?: number[];\n  min?: number[];\n  max?: number[];\n  inputs?: any[];\n  depthUpper?: number[];\n  depthLower?: number[];\n  startDate?: string[];\n  endDate?: string[];\n}\n\nexport interface IGroupedNodesValues<T> {\n  [nodeId: string]: IGroupedNode<T>;\n}\n\nexport interface IGroupedNodesValue<T> {\n  term: ITermJSONLD;\n  methodTier?: EmissionMethodTier;\n  /**\n   * Enable ordering ny methodTier\n   */\n  methodTierOrder: number;\n  values: IGroupedNodesValues<T>;\n  originalValues: {\n    [nodeId: string]: {\n      value: number;\n    };\n  };\n}\n\nexport interface IGroupedNodes<T> {\n  [termId: string]: IGroupedNodesValue<T>;\n}\n\nexport interface IGroupedKeys<T> {\n  key: string;\n  value: IGroupedNodesValue<T>;\n}\n\nexport const grouppedKeys = <T>(values: { [key: string]: T }): { key: string; value: T }[] =>\n  Object.entries(values).map(([key, value]) => ({ key, value }));\n\nconst concatBlankNodeValue = (value: any, newValue: any) => {\n  const valueArray = Array.isArray(value) ? value : [value];\n  const newValueArray = Array.isArray(newValue) ? newValue : [newValue];\n  return [...valueArray, ...newValueArray];\n};\n\nexport const methodTierOrder = (methodTier: EmissionMethodTier) =>\n  [\n    EmissionMethodTier.measured,\n    EmissionMethodTier['tier 3'],\n    EmissionMethodTier['tier 2'],\n    EmissionMethodTier['tier 1'],\n    EmissionMethodTier.background,\n    EmissionMethodTier['not relevant']\n  ].indexOf(methodTier);\n\nexport const grouppedValueKeys = [\n  'dates',\n  'sd',\n  'min',\n  'max',\n  'inputs',\n  'depthUpper',\n  'depthLower',\n  'startDate',\n  'endDate',\n  'methodTier',\n  'methodModel',\n  'model',\n  'method'\n];\n\nconst isHigherState = (sourceNode: blankNode, newNode: blankNode) =>\n  !sourceNode ||\n  isState(newNode, 'value', NodeKeyState.updated) ||\n  (!isState(sourceNode, 'value', NodeKeyState.updated) && isState(newNode, 'value', NodeKeyState.added));\n\nconst groupNodeKey = ({ term }: any) => term?.name || term?.['@id'];\n\nexport const groupNodesByTerm = <T extends ICycleJSONLD | IImpactAssessmentJSONLD | ISiteJSONLD, R>(\n  nodes: T[] = [],\n  key:\n    | 'endpoints'\n    | 'impacts'\n    | 'emissionsResourceUse'\n    | 'inputs'\n    | 'products'\n    | 'practices'\n    | 'emissions'\n    | 'measurements'\n    | 'animals',\n  originalValues: T[] = [],\n  includeNode = (_node: any) => true\n): IGroupedNodes<R> => {\n  const groups: IGroupedNodes<R> = nodes.reduce(\n    (prev, node, index) =>\n      (node[key] || []).reduce((group, blankNode) => {\n        // skip node based on condition\n        if (!includeNode(blankNode)) {\n          return group;\n        }\n\n        const nodeId = node['@id'];\n        const groupedKey = groupNodeKey(blankNode);\n        group[groupedKey] = group[groupedKey] || {\n          term: blankNode.term,\n          methodTier: blankNode.methodTier,\n          methodTierOrder: methodTierOrder(blankNode.methodTier),\n          values: {},\n          originalValues: {}\n        };\n        group[groupedKey].values[nodeId] = group[groupedKey].values[nodeId] || { index, nodes: [], value: [] };\n        group[groupedKey].values[nodeId].node = isHigherState(group[groupedKey].values[nodeId].node, blankNode)\n          ? blankNode\n          : group[groupedKey].values[nodeId].node;\n        group[groupedKey].values[nodeId].nodes.push(blankNode);\n        group[groupedKey].values[nodeId].value = concatBlankNodeValue(\n          group[groupedKey].values[nodeId].value,\n          blankNode.value\n        );\n        grouppedValueKeys.forEach(arrayKey => {\n          const newValue = get(blankNode, arrayKey, []);\n          group[groupedKey].values[nodeId][arrayKey] = [\n            ...(group[groupedKey].values[nodeId][arrayKey] || []),\n            ...(Array.isArray(newValue) ? newValue : [newValue])\n          ];\n        });\n        return group;\n      }, prev),\n    {} as IGroupedNodes<R>\n  );\n\n  // compile original values\n  Object.values(groups).map(group => {\n    Object.keys(group.values).map(nodeId => {\n      const { index } = group.values[nodeId];\n      const termId = group.term['@id'];\n      const originalValue = get(originalValues, `[${index}].${key}`, []).filter(\n        (val: any) => val.term['@id'] === termId\n      );\n      if (originalValue.length > 0) {\n        const value = originalValue.reduce((array: any[], curr: any) => concatBlankNodeValue(array, curr.value), []);\n        group.originalValues[nodeId] = { value: propertyValue(value, termId) };\n      }\n    });\n  });\n\n  return groups;\n};\n"]}
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-utils.js","sourceRoot":"","sources":["../../../src/common/node-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import get from 'lodash.get';\nimport {\n  Term,\n  ICycleJSONLD,\n  ISiteJSONLD,\n  IImpactAssessmentJSONLD,\n  EmissionMethodTier,\n  ITermJSONLD,\n  Completeness,\n  Emission,\n  Measurement,\n  Practice,\n  Product,\n  Input,\n  Property,\n  Indicator,\n  Animal,\n  Management,\n  Transformation\n} from '@hestia-earth/schema';\nimport { propertyValue } from '@hestia-earth/utils/dist/term';\nimport { getDefaultModelId } from '@hestia-earth/glossary';\n\nexport type blankNode =\n  | Animal\n  | Emission\n  | Input\n  | Product\n  | Property\n  | Practice\n  | Indicator\n  | Measurement\n  | Management;\n\nexport type blankNodesKey =\n  | 'animals'\n  | 'emissions'\n  | 'emissionsResourceUse'\n  | 'endpoints'\n  | 'impacts'\n  | 'inputs'\n  | 'management'\n  | 'measurements'\n  | 'products'\n  | 'practices';\n\nexport enum BlankNodesKey {\n  animals = 'animals',\n  emissions = 'emissions',\n  emissionsResourceUse = 'emissionsResourceUse',\n  endpoints = 'endpoints',\n  impacts = 'impacts',\n  inputs = 'inputs',\n  management = 'management',\n  measurements = 'measurements',\n  products = 'products',\n  practices = 'practices'\n}\n\nexport const filterBlankNode =\n  (filterTerm: string) =>\n  ({ term }: blankNode) =>\n    !filterTerm || term?.name?.toLowerCase()?.includes(filterTerm.toLowerCase());\n\nexport type nonBlankNode = Completeness;\nexport type nonBlankNodesKey = 'completeness';\n\nexport enum NonBlankNodesKey {\n  completeness = 'completeness'\n}\n\nexport const ignoreKeys = ['@type', 'type', 'added', 'updated', 'addedVersion', 'updatedVersion'];\n\nexport const isValidKey = (key: string) => !ignoreKeys.includes(key);\n\nexport const isMethodModelAllowed = (filterMethod?: Term) => (node: Indicator) =>\n  node.methodModel?.['@id'] === (filterMethod ? filterMethod['@id'] : getDefaultModelId(node.term?.['@id']));\n\nexport enum NodeKeyState {\n  added = 'added',\n  updated = 'updated',\n  aggregated = 'aggregated',\n  deleted = 'deleted',\n  unchanged = 'unchanged'\n}\n\nexport const isState = (node: blankNode, key: string, state: NodeKeyState) =>\n  state in node! && (typeof node![state] === 'boolean' ? node![state] : node![state].includes(key));\n\nexport interface IGroupedNode<T> {\n  // store the node with the highest \"state\"\n  node: T;\n  nodes: T[];\n  index: number;\n  value: number[];\n  dates?: any[];\n  sd?: number[];\n  min?: number[];\n  max?: number[];\n  inputs?: any[];\n  depthUpper?: number[];\n  depthLower?: number[];\n  startDate?: string[];\n  endDate?: string[];\n}\n\nexport interface IGroupedNodesValues<T> {\n  [nodeId: string]: IGroupedNode<T>;\n}\n\nexport interface IGroupedNodesValue<T> {\n  term: ITermJSONLD;\n  methodTier?: EmissionMethodTier;\n  /**\n   * Enable ordering ny methodTier\n   */\n  methodTierOrder: number;\n  values: IGroupedNodesValues<T>;\n  originalValues: {\n    [nodeId: string]: {\n      value: number;\n    };\n  };\n}\n\nexport interface IGroupedNodes<T> {\n  [termId: string]: IGroupedNodesValue<T>;\n}\n\nexport interface IGroupedKeys<T> {\n  key: string;\n  value: IGroupedNodesValue<T>;\n}\n\nexport const grouppedKeys = <T>(values: { [key: string]: T }): { key: string; value: T }[] =>\n  Object.entries(values).map(([key, value]) => ({ key, value }));\n\nconst concatBlankNodeValue = (value: any, newValue: any) => {\n  const valueArray = Array.isArray(value) ? value : [value];\n  const newValueArray = Array.isArray(newValue) ? newValue : [newValue];\n  return [...valueArray, ...newValueArray];\n};\n\nexport const methodTierOrder = (methodTier: EmissionMethodTier) =>\n  [\n    EmissionMethodTier.measured,\n    EmissionMethodTier['tier 3'],\n    EmissionMethodTier['tier 2'],\n    EmissionMethodTier['tier 1'],\n    EmissionMethodTier.background,\n    EmissionMethodTier['not relevant']\n  ].indexOf(methodTier);\n\nexport const grouppedValueKeys = [\n  'dates',\n  'sd',\n  'min',\n  'max',\n  'inputs',\n  'depthUpper',\n  'depthLower',\n  'startDate',\n  'endDate',\n  'methodTier',\n  'methodModel',\n  'model',\n  'method'\n];\n\nconst isHigherState = (sourceNode: blankNode, newNode: blankNode) =>\n  !sourceNode ||\n  isState(newNode, 'value', NodeKeyState.updated) ||\n  (!isState(sourceNode, 'value', NodeKeyState.updated) && isState(newNode, 'value', NodeKeyState.added));\n\nconst groupNodeKey = ({ term }: any) => term?.name || term?.['@id'];\n\nexport const groupNodesByTerm = <\n  T extends ICycleJSONLD | IImpactAssessmentJSONLD | ISiteJSONLD | Animal | Transformation,\n  R\n>(\n  nodes: T[] = [],\n  key: blankNodesKey,\n  originalValues: T[] = [],\n  includeNode = (_node: any) => true\n): IGroupedNodes<R> => {\n  const groups: IGroupedNodes<R> = nodes.reduce(\n    (prev, node, index) =>\n      (node[key] || []).reduce((group, blankNode) => {\n        // skip node based on condition\n        if (!includeNode(blankNode)) {\n          return group;\n        }\n\n        const nodeId = node['@id'];\n        const groupedKey = groupNodeKey(blankNode);\n        group[groupedKey] = group[groupedKey] || {\n          term: blankNode.term,\n          methodTier: blankNode.methodTier,\n          methodTierOrder: methodTierOrder(blankNode.methodTier),\n          values: {},\n          originalValues: {}\n        };\n        group[groupedKey].values[nodeId] = group[groupedKey].values[nodeId] || { index, nodes: [], value: [] };\n        group[groupedKey].values[nodeId].node = isHigherState(group[groupedKey].values[nodeId].node, blankNode)\n          ? blankNode\n          : group[groupedKey].values[nodeId].node;\n        group[groupedKey].values[nodeId].nodes.push(blankNode);\n        group[groupedKey].values[nodeId].value = concatBlankNodeValue(\n          group[groupedKey].values[nodeId].value,\n          blankNode.value\n        );\n        grouppedValueKeys.forEach(arrayKey => {\n          const newValue = get(blankNode, arrayKey, []);\n          group[groupedKey].values[nodeId][arrayKey] = [\n            ...(group[groupedKey].values[nodeId][arrayKey] || []),\n            ...(Array.isArray(newValue) ? newValue : [newValue])\n          ];\n        });\n        return group;\n      }, prev),\n    {} as IGroupedNodes<R>\n  );\n\n  // compile original values\n  Object.values(groups).map(group => {\n    Object.keys(group.values).map(nodeId => {\n      const { index } = group.values[nodeId];\n      const termId = group.term['@id'];\n      const originalValue = get(originalValues, `[${index}].${key}`, []).filter(\n        (val: any) => val.term['@id'] === termId\n      );\n      if (originalValue.length > 0) {\n        const value = originalValue.reduce((array: any[], curr: any) => concatBlankNodeValue(array, curr.value), []);\n        group.originalValues[nodeId] = { value: propertyValue(value, termId) };\n      }\n    });\n  });\n\n  return groups;\n};\n"]}