@hestia-earth/ui-components 0.3.1 → 0.3.4
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 +151 -102
- package/bundles/hestia-earth-ui-components.umd.js.map +1 -1
- package/common/link-key-value/link-key-value.component.d.ts +1 -0
- package/esm2015/common/link-key-value/link-key-value.component.js +9 -3
- package/esm2015/files/files-error.model.js +5 -3
- package/esm2015/node/index.js +2 -1
- package/esm2015/node/node-link/node-link.component.js +6 -2
- package/esm2015/node/node-logs-models/node-logs-models.component.js +8 -5
- package/esm2015/node/node-logs-models/node-logs-models.model.js +386 -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 +8 -4
- package/esm2015/node/node.service.js +3 -3
- package/fesm2015/hestia-earth-ui-components.js +62 -28
- package/fesm2015/hestia-earth-ui-components.js.map +1 -1
- package/node/index.d.ts +1 -0
- package/node/node-logs-models/node-logs-models.component.d.ts +3 -1
- package/node/{node-logs.model.d.ts → node-logs-models/node-logs-models.model.d.ts} +3 -2
- package/node/node-missing-lookup-factors/node-missing-lookup-factors.component.d.ts +1 -1
- package/node/node-value-details/node-value-details.component.d.ts +2 -1
- package/node/node.service.d.ts +6 -2
- package/package.json +1 -1
- package/esm2015/node/node-logs.model.js +0 -370
package/node/index.d.ts
CHANGED
|
@@ -2,6 +2,7 @@ export * from './node-csv.service';
|
|
|
2
2
|
export * from './node.module';
|
|
3
3
|
export * from './node.service';
|
|
4
4
|
export * from './node-diffs/node-diffs.model';
|
|
5
|
+
export * from './node-logs-models/node-logs-models.model';
|
|
5
6
|
export { NodeCsvExportConfirmComponent } from './node-csv-export-confirm/node-csv-export-confirm.component';
|
|
6
7
|
export { NodeCsvSelectHeadersComponent } from './node-csv-select-headers/node-csv-select-headers.component';
|
|
7
8
|
export { NodeDiffsComponent } from './node-diffs/node-diffs.component';
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { OnInit } from '@angular/core';
|
|
2
2
|
import { Observable } from 'rxjs';
|
|
3
|
-
import { IBlankNodeLogSubValue, IBlankNodeLog, LogStatus, IConfigModel } from '
|
|
3
|
+
import { IBlankNodeLogSubValue, IBlankNodeLog, LogStatus, IConfigModel } from './node-logs-models.model';
|
|
4
4
|
import { HeNodeService } from '../node.service';
|
|
5
5
|
import { HeEngineService } from '../../engine/engine.service';
|
|
6
6
|
import { HeSearchService } from '../../search/search.service';
|
|
@@ -9,6 +9,7 @@ export declare class NodeLogsModelsComponent implements OnInit {
|
|
|
9
9
|
private nodeService;
|
|
10
10
|
private searchService;
|
|
11
11
|
private engineService;
|
|
12
|
+
private logs;
|
|
12
13
|
private allTerms;
|
|
13
14
|
private allBlankNodes;
|
|
14
15
|
private node?;
|
|
@@ -57,6 +58,7 @@ export declare class NodeLogsModelsComponent implements OnInit {
|
|
|
57
58
|
suggestTerm: (text$: Observable<string>) => Observable<string[]>;
|
|
58
59
|
constructor(nodeService: HeNodeService, searchService: HeSearchService, engineService: HeEngineService);
|
|
59
60
|
ngOnInit(): Promise<void>;
|
|
61
|
+
private getLogs;
|
|
60
62
|
private suggestByTerm;
|
|
61
63
|
trackByBlankNode(_index: number, node: IBlankNodeLog): string;
|
|
62
64
|
get filteredType(): string;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Emission, ITermJSONLD, Product, Input as HestiaInput, NodeType, TermTermType, Property, SchemaType } from '@hestia-earth/schema';
|
|
2
|
-
import { IOrchestratorConfig, IModel } from '
|
|
2
|
+
import { IOrchestratorConfig, IModel } from '../../engine/engine.service';
|
|
3
3
|
export interface INodeMissingLookupLog {
|
|
4
4
|
filename: string;
|
|
5
5
|
termId: string;
|
|
@@ -26,7 +26,8 @@ export interface INodeTermLog {
|
|
|
26
26
|
export interface INodeTermLogs {
|
|
27
27
|
[modelKey: string]: any | INodeTermLog;
|
|
28
28
|
models: string[];
|
|
29
|
-
isKey
|
|
29
|
+
isKey?: boolean;
|
|
30
|
+
isProperty?: boolean;
|
|
30
31
|
}
|
|
31
32
|
export interface INodeLogs {
|
|
32
33
|
[term: string]: INodeTermLogs;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { OnInit } from '@angular/core';
|
|
2
2
|
import { JSONLD, NodeType } from '@hestia-earth/schema';
|
|
3
|
-
import { INodeMissingLookupLog } from '../node-logs.model';
|
|
3
|
+
import { INodeMissingLookupLog } from '../node-logs-models/node-logs-models.model';
|
|
4
4
|
import { HeNodeService } from '../node.service';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export declare class NodeMissingLookupFactorsComponent implements OnInit {
|
|
@@ -10,8 +10,9 @@ export declare class NodeValueDetailsComponent<T> implements OnInit {
|
|
|
10
10
|
keys: string[];
|
|
11
11
|
additionalKeys: string[];
|
|
12
12
|
tableKeys: string[];
|
|
13
|
-
get type(): any;
|
|
14
13
|
ngOnInit(): void;
|
|
14
|
+
get type(): any;
|
|
15
|
+
get showInline(): boolean;
|
|
15
16
|
static ɵfac: i0.ɵɵFactoryDeclaration<NodeValueDetailsComponent<any>, never>;
|
|
16
17
|
static ɵcmp: i0.ɵɵComponentDeclaration<NodeValueDetailsComponent<any>, "he-node-value-details", never, { "data": "data"; "nodeType": "nodeType"; "dataKey": "dataKey"; }, {}, never, never>;
|
|
17
18
|
}
|
package/node/node.service.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { HttpClient } from '@angular/common/http';
|
|
2
2
|
import { DataState } from '@hestia-earth/api';
|
|
3
3
|
import { ICycleJSONLD, IImpactAssessmentJSONLD, ISiteJSONLD, NodeType, TermTermType } from '@hestia-earth/schema';
|
|
4
|
-
import { INodeMissingLookupLog } from './node-logs.model';
|
|
4
|
+
import { INodeMissingLookupLog } from './node-logs-models/node-logs-models.model';
|
|
5
5
|
import { HeCommonService } from '../common/common.service';
|
|
6
6
|
import { HeAuthService } from '../auth/auth.service';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
@@ -33,6 +33,10 @@ export interface IJSONData {
|
|
|
33
33
|
[NodeType.Site]?: ISiteJSONLD[];
|
|
34
34
|
[NodeType.ImpactAssessment]?: IImpactAssessmentJSONLD[];
|
|
35
35
|
}
|
|
36
|
+
export interface INodeErrorLog {
|
|
37
|
+
error: string;
|
|
38
|
+
stack?: string;
|
|
39
|
+
}
|
|
36
40
|
export declare class HeNodeService {
|
|
37
41
|
protected http: HttpClient;
|
|
38
42
|
protected authService: HeAuthService;
|
|
@@ -42,7 +46,7 @@ export declare class HeNodeService {
|
|
|
42
46
|
get<T>(node: IJSONNode, defaultForState?: boolean): Promise<T>;
|
|
43
47
|
getLog({ dataState, ...node }: IJSONNode): import("rxjs").Observable<string>;
|
|
44
48
|
getMissingLookupsLog({ dataState, ...node }: IJSONNode): Promise<INodeMissingLookupLog[]>;
|
|
45
|
-
|
|
49
|
+
getErrorLog({ dataState, ...node }: IJSONNode): Promise<INodeErrorLog>;
|
|
46
50
|
triggerPipeline({ dataState, ...node }: IJSONNode): Promise<Object>;
|
|
47
51
|
downloadRaw<T = any>(url: string, responseType?: any): Promise<T>;
|
|
48
52
|
nodeTypeUrl(type: any): string;
|
package/package.json
CHANGED
|
@@ -1,370 +0,0 @@
|
|
|
1
|
-
import { __rest } from "tslib";
|
|
2
|
-
/* eslint-disable complexity */
|
|
3
|
-
import { from } from 'rxjs';
|
|
4
|
-
import { distinct, toArray, map } from 'rxjs/operators';
|
|
5
|
-
import { fileToExt, SupportedExtensions } from '@hestia-earth/api';
|
|
6
|
-
import { EmissionMethodTier, TermTermType, SchemaType, isTypeNode } from '@hestia-earth/schema';
|
|
7
|
-
import { unique, isUndefined } from '@hestia-earth/utils';
|
|
8
|
-
import { propertyValue } from '@hestia-earth/utils/dist/term';
|
|
9
|
-
const get = require('lodash.get');
|
|
10
|
-
const set = require('lodash.set');
|
|
11
|
-
const orderBy = require('lodash.orderby');
|
|
12
|
-
import { findConfigModels, findModels, findMatchingModel, modelParams, modelKeyParams } from '../engine/engine.service';
|
|
13
|
-
const termTypes = Object.values(TermTermType);
|
|
14
|
-
const blankNodeTypes = Object.values(SchemaType).filter(t => !isTypeNode(t));
|
|
15
|
-
const schemaTypesLowerCase = Object.values(SchemaType).map(v => v.toLowerCase());
|
|
16
|
-
const blankNodeTypesLowerCase = blankNodeTypes.map(v => v.toLowerCase());
|
|
17
|
-
const missingLookupPrefix = 'Missing lookup';
|
|
18
|
-
const parseFilename = (filepath) => {
|
|
19
|
-
const [filename] = filepath.split('.');
|
|
20
|
-
const ext = termTypes.includes(filename) ? SupportedExtensions.xlsx : SupportedExtensions.csv;
|
|
21
|
-
return fileToExt(filename, ext);
|
|
22
|
-
};
|
|
23
|
-
const parseLookup = ({ column, termid, [missingLookupPrefix]: missingLookup }) => ({
|
|
24
|
-
filename: parseFilename(missingLookup), termId: termid, column
|
|
25
|
-
});
|
|
26
|
-
const csvValue = (value) => (value || '').replace('[', '').replace(']', '');
|
|
27
|
-
const parseMessage = (message) => {
|
|
28
|
-
try {
|
|
29
|
-
const data = JSON.parse(message);
|
|
30
|
-
return data.message.split(',').reduce((prev, parts) => {
|
|
31
|
-
const [key, value] = parts.split('=');
|
|
32
|
-
const val = csvValue(value);
|
|
33
|
-
return Object.assign(Object.assign({}, prev), (key && val ? { [key.trim()]: val } : {}));
|
|
34
|
-
}, { logger: data.logger });
|
|
35
|
-
}
|
|
36
|
-
catch (err) {
|
|
37
|
-
// make sure it works even if one log is malformed
|
|
38
|
-
return {};
|
|
39
|
-
}
|
|
40
|
-
};
|
|
41
|
-
const omitLogKeys = (log) => Object.fromEntries(Object.entries(log).filter(([key]) => !schemaTypesLowerCase.includes(key)));
|
|
42
|
-
const includeBlankNodes = (logs, log) => Object
|
|
43
|
-
.keys(log)
|
|
44
|
-
.filter(key => blankNodeTypesLowerCase.includes(key))
|
|
45
|
-
.reduce((prev, key) => (Object.assign(Object.assign({}, prev), { [key]: unique([
|
|
46
|
-
...((typeof prev[key] === 'string' ? [prev[key]] : prev[key]) || []),
|
|
47
|
-
log[key]
|
|
48
|
-
]) })), logs);
|
|
49
|
-
const groupLog = (group, _a) => {
|
|
50
|
-
var { logger, term, model, key, should_run, run_required, property } = _a, log = __rest(_a, ["logger", "term", "model", "key", "should_run", "run_required", "property"]);
|
|
51
|
-
const isOrchestrator = logger.includes('orchestrator');
|
|
52
|
-
const isKey = !isOrchestrator && !!key;
|
|
53
|
-
const parentLogKey = [`["${term}"]`, !isOrchestrator && key || property].filter(Boolean).join('.');
|
|
54
|
-
const logModelKey = [parentLogKey, model].filter(Boolean).join('.');
|
|
55
|
-
set(group, `${parentLogKey}.models`, unique([
|
|
56
|
-
...get(group, `${parentLogKey}.models`, []),
|
|
57
|
-
model
|
|
58
|
-
]));
|
|
59
|
-
set(group, `${parentLogKey}.isKey`, isKey);
|
|
60
|
-
let data = get(group, logModelKey, {});
|
|
61
|
-
data = includeBlankNodes(data, log);
|
|
62
|
-
if (typeof should_run !== 'undefined') {
|
|
63
|
-
const shouldRun = should_run === 'True';
|
|
64
|
-
data = isOrchestrator ? Object.assign(Object.assign({}, data), { shouldRunOrchestrator: shouldRun }) : Object.assign(Object.assign(Object.assign({}, data), omitLogKeys(log)), { shouldRun });
|
|
65
|
-
}
|
|
66
|
-
else if (typeof run_required !== 'undefined') {
|
|
67
|
-
const runRequired = run_required === 'True';
|
|
68
|
-
data = Object.assign(Object.assign(Object.assign({}, data), (runRequired ? {} : omitLogKeys(log))), { // no need to save logs if we need to run the model
|
|
69
|
-
runRequired });
|
|
70
|
-
}
|
|
71
|
-
else if ('requirements' in log) {
|
|
72
|
-
const { requirements } = log, logData = __rest(log, ["requirements"]);
|
|
73
|
-
data.requirements = Object.assign(Object.assign({}, (data.requirements || {})), logData);
|
|
74
|
-
}
|
|
75
|
-
else if (missingLookupPrefix in log) {
|
|
76
|
-
data.missingLookups = unique([
|
|
77
|
-
...(data.missingLookups || []),
|
|
78
|
-
parseLookup(log)
|
|
79
|
-
]);
|
|
80
|
-
}
|
|
81
|
-
else if (!isOrchestrator) {
|
|
82
|
-
data.logs = Object.assign(Object.assign({}, (data.logs || {})), omitLogKeys(log));
|
|
83
|
-
}
|
|
84
|
-
set(group, logModelKey, data);
|
|
85
|
-
return group;
|
|
86
|
-
};
|
|
87
|
-
const groupLogSubValue = (group, log, key) => {
|
|
88
|
-
const id = log[key];
|
|
89
|
-
const data = groupLog(group[id] || {}, log);
|
|
90
|
-
group[id] = data;
|
|
91
|
-
if (key === 'transformation') {
|
|
92
|
-
// add value to the same term/model on parent group
|
|
93
|
-
Object.entries(group[id]).map(([term, models]) => Object.keys(models).map(model => {
|
|
94
|
-
var _a;
|
|
95
|
-
if ((_a = group === null || group === void 0 ? void 0 : group[term]) === null || _a === void 0 ? void 0 : _a[model]) {
|
|
96
|
-
group[term][model][key] = unique([
|
|
97
|
-
...(group[term][model][key] || []),
|
|
98
|
-
id
|
|
99
|
-
]);
|
|
100
|
-
}
|
|
101
|
-
}));
|
|
102
|
-
}
|
|
103
|
-
return group;
|
|
104
|
-
};
|
|
105
|
-
const subValueKeys = [
|
|
106
|
-
'transformation'
|
|
107
|
-
];
|
|
108
|
-
export const groupLogsByModel = (data) => data.split('\n')
|
|
109
|
-
.map(parseMessage)
|
|
110
|
-
.filter(v => !!(v === null || v === void 0 ? void 0 : v.term) && (v === null || v === void 0 ? void 0 : v.term) !== 'None' && !!(v === null || v === void 0 ? void 0 : v.model))
|
|
111
|
-
.reduce((group, log) => {
|
|
112
|
-
const subValue = subValueKeys.find(v => !!log[v]);
|
|
113
|
-
return subValue ?
|
|
114
|
-
subValue === 'transformation' ?
|
|
115
|
-
// for transformation, do not add to top-level model
|
|
116
|
-
groupLogSubValue(group, log, subValue) :
|
|
117
|
-
groupLog(groupLogSubValue(group, log, subValue), log)
|
|
118
|
-
: groupLog(group, log);
|
|
119
|
-
});
|
|
120
|
-
export const computeTerms = (originalValues, recalculatedValues, terms, filterTermTypes) => from((terms === null || terms === void 0 ? void 0 : terms.length) ?
|
|
121
|
-
terms :
|
|
122
|
-
[
|
|
123
|
-
...(originalValues || []).map(({ term }) => term),
|
|
124
|
-
...(recalculatedValues || []).map(({ term }) => term)
|
|
125
|
-
].filter(node => !(filterTermTypes === null || filterTermTypes === void 0 ? void 0 : filterTermTypes.length) || filterTermTypes.includes(node.termType))).pipe(distinct(v => v['@id']), toArray(), map(v => orderBy(v, ['name'], ['asc']))).toPromise();
|
|
126
|
-
export var LogStatus;
|
|
127
|
-
(function (LogStatus) {
|
|
128
|
-
LogStatus["success"] = "successful";
|
|
129
|
-
LogStatus["error"] = "failed";
|
|
130
|
-
LogStatus["skipHierarchy"] = "not run (model higher up hierarchy run instead)";
|
|
131
|
-
LogStatus["dataProvided"] = "not run (user provided data retained)";
|
|
132
|
-
LogStatus["notRequired"] = "not relevant";
|
|
133
|
-
})(LogStatus || (LogStatus = {}));
|
|
134
|
-
const hasLogDetails = (data, logs) => {
|
|
135
|
-
var _a;
|
|
136
|
-
return [
|
|
137
|
-
LogStatus.success,
|
|
138
|
-
LogStatus.error
|
|
139
|
-
].includes(logStatus(data, logs)) && ((logs === null || logs === void 0 ? void 0 : logs.requirements) || (logs === null || logs === void 0 ? void 0 : logs.logs) || ((_a = logs === null || logs === void 0 ? void 0 : logs.missingLookups) === null || _a === void 0 ? void 0 : _a.length));
|
|
140
|
-
};
|
|
141
|
-
const logStatus = (data, logs) => hasLog(logs)
|
|
142
|
-
? (!data.isRequired
|
|
143
|
-
? LogStatus.notRequired
|
|
144
|
-
: isRunOrchestrator(logs)
|
|
145
|
-
? ('shouldRun' in logs
|
|
146
|
-
? logs.shouldRun
|
|
147
|
-
? data.isRecalculated
|
|
148
|
-
? LogStatus.success
|
|
149
|
-
: LogStatus.dataProvided
|
|
150
|
-
: LogStatus.error
|
|
151
|
-
: LogStatus.dataProvided)
|
|
152
|
-
: data.isRecalculated
|
|
153
|
-
? LogStatus.skipHierarchy
|
|
154
|
-
: LogStatus.dataProvided)
|
|
155
|
-
: ([
|
|
156
|
-
typeof data.originalValue === 'undefined',
|
|
157
|
-
data.isRecalculated // is recalculated
|
|
158
|
-
].every(Boolean)
|
|
159
|
-
? LogStatus.skipHierarchy
|
|
160
|
-
: LogStatus.dataProvided);
|
|
161
|
-
const reduceValues = (values, termId) => {
|
|
162
|
-
const propertyValues = values
|
|
163
|
-
.map(({ value }) => propertyValue(value, termId))
|
|
164
|
-
// propertyValue may return null if the value is null or undefined, therefore remove them from total
|
|
165
|
-
.filter(v => v !== null);
|
|
166
|
-
return propertyValues.length ? propertyValues.reduce((p, v) => p + v, 0) : undefined;
|
|
167
|
-
};
|
|
168
|
-
const isRunOrchestrator = (log) => !('shouldRunOrchestrator' in log) || log.shouldRunOrchestrator;
|
|
169
|
-
const isBackground = (log) => (log === null || log === void 0 ? void 0 : log.methodTier) === EmissionMethodTier.background;
|
|
170
|
-
const hasLog = (log, withOrchestrator = true) => !!log && ('shouldRun' in log ||
|
|
171
|
-
'runRequired' in log ||
|
|
172
|
-
(withOrchestrator && 'shouldRunOrchestrator' in log));
|
|
173
|
-
const isRecalculated = (values, key = 'value') => values.some(v => ([
|
|
174
|
-
...(v.added || []),
|
|
175
|
-
...(v.updated || [])
|
|
176
|
-
]).includes(key));
|
|
177
|
-
const blankNodeValueByKey = {
|
|
178
|
-
property: (values, _k, id) => {
|
|
179
|
-
var _a;
|
|
180
|
-
return !!id && (values === null || values === void 0 ? void 0 : values.length)
|
|
181
|
-
? ((_a = (values[0].properties || []).find(p => p.term['@id'] === id)) === null || _a === void 0 ? void 0 : _a.value) || ''
|
|
182
|
-
: '';
|
|
183
|
-
},
|
|
184
|
-
input: (values, _k, id) => {
|
|
185
|
-
var _a;
|
|
186
|
-
return !!id && (values === null || values === void 0 ? void 0 : values.length)
|
|
187
|
-
? propertyValue((_a = values.find(({ inputs }) => (inputs || []).some(input => input['@id'] === id))) === null || _a === void 0 ? void 0 : _a.value, id)
|
|
188
|
-
: '';
|
|
189
|
-
},
|
|
190
|
-
default: (blankNodes, key) => {
|
|
191
|
-
const value = (blankNodes === null || blankNodes === void 0 ? void 0 : blankNodes.length) ? blankNodes[0][key] : null;
|
|
192
|
-
return ['string', 'number', 'boolean', 'undefined'].includes(typeof value)
|
|
193
|
-
? isUndefined(value)
|
|
194
|
-
? ''
|
|
195
|
-
: value
|
|
196
|
-
: null;
|
|
197
|
-
}
|
|
198
|
-
};
|
|
199
|
-
const blankNodeValue = (blankNodes, key, id) => blankNodeValueByKey[key in blankNodeValueByKey ? key : 'default'](blankNodes, key, id);
|
|
200
|
-
const logSubValue = (logs, key, prop) => logs[key][prop] ? (Array.isArray(logs[key][prop]) ?
|
|
201
|
-
logs[key][prop].map(id => ({ key: prop, id })) :
|
|
202
|
-
{ key: prop, id: logs[key][prop] }) : undefined;
|
|
203
|
-
const logProperties = (nodes, models) => nodes.flatMap(node => (node.properties || []).map(({ term }) => term['@id'])).map(id => ({ key: 'property', id, configModels: findModels(models, id).map(({ model }) => model) }));
|
|
204
|
-
const logSubValues = (allLogs, logs, original, recalculated, models, { nodeType, type, termId }) => unique([
|
|
205
|
-
...Object.keys(logs).flatMap(key => [
|
|
206
|
-
logSubValue(logs, key, 'input'),
|
|
207
|
-
logSubValue(logs, key, 'property')
|
|
208
|
-
]
|
|
209
|
-
.flat()
|
|
210
|
-
.filter(Boolean)
|
|
211
|
-
.map(v => (Object.assign(Object.assign({}, v), { configModels: [key] })))),
|
|
212
|
-
...logProperties(original, models),
|
|
213
|
-
...logProperties(recalculated, models)
|
|
214
|
-
])
|
|
215
|
-
.map(v => {
|
|
216
|
-
const originalValue = blankNodeValue(original, v.key, v.id);
|
|
217
|
-
const recalculatedValue = blankNodeValue(recalculated, v.key, v.id);
|
|
218
|
-
return Object.assign(Object.assign({}, v), { configModels: v.configModels.map(configModelWithDocs(models, { nodeType, type, termId }, v)), originalValue,
|
|
219
|
-
recalculatedValue, isRecalculated: !isUndefined(recalculatedValue) && recalculatedValue !== originalValue, isRequired: true });
|
|
220
|
-
})
|
|
221
|
-
.filter(v => v.configModels.length > 0)
|
|
222
|
-
.map(dataWithConfigModelLogs(allLogs));
|
|
223
|
-
// const hasKey = (blankNodes: blankNode[], key: string) => (blankNodes || []).some(n => key in n);
|
|
224
|
-
const logKeys = (logs, original, recalculated, models, { nodeType, type, termId }) => Object.keys(logs)
|
|
225
|
-
.filter(key => logs[key].isKey)
|
|
226
|
-
.map(key => ({
|
|
227
|
-
key,
|
|
228
|
-
configModels: (logs[key].models || [])
|
|
229
|
-
.map(configModelWithDocs(models, { nodeType, type, termId }, { key }))
|
|
230
|
-
// only take those we found a matching model (avoid matching key on wrong node type)
|
|
231
|
-
.filter(v => !!v.model),
|
|
232
|
-
originalValue: blankNodeValue(original, key),
|
|
233
|
-
recalculatedValue: blankNodeValue(recalculated, key),
|
|
234
|
-
isRecalculated: isRecalculated(recalculated, key),
|
|
235
|
-
isRequired: true
|
|
236
|
-
}))
|
|
237
|
-
.filter(v => v.configModels.length > 0)
|
|
238
|
-
.map(dataWithConfigModelLogs(logs));
|
|
239
|
-
const isBackgroundNoInput = (logs) => logs.methodTier === EmissionMethodTier.background && !logs.input;
|
|
240
|
-
const isModelLog = (logs) => [
|
|
241
|
-
!isBackgroundNoInput(logs),
|
|
242
|
-
!logs.isKey,
|
|
243
|
-
!logs.input,
|
|
244
|
-
!logs.property
|
|
245
|
-
].every(Boolean) && [
|
|
246
|
-
'shouldRun' in logs,
|
|
247
|
-
'shouldRunOrchestrator' in logs,
|
|
248
|
-
'runRequired' in logs
|
|
249
|
-
].some(Boolean);
|
|
250
|
-
const modelConfigOrder = (models, termId, modelKey, model) => {
|
|
251
|
-
const indexes = models.map((m, index) => {
|
|
252
|
-
const arrayIndex = Array.isArray(m) ? modelConfigOrder(m, termId, modelKey, model) : '';
|
|
253
|
-
return Array.isArray(m)
|
|
254
|
-
? arrayIndex
|
|
255
|
-
? [index, arrayIndex].join('.')
|
|
256
|
-
: ''
|
|
257
|
-
: [termId === m.value, modelKey === m.key, model === m.model].every(Boolean)
|
|
258
|
-
? `${index}`
|
|
259
|
-
: '';
|
|
260
|
-
}).filter(Boolean);
|
|
261
|
-
return indexes.length ? indexes[0] : '';
|
|
262
|
-
};
|
|
263
|
-
const configModelWithDocs = (models, { nodeType, type, termId }, subValue) => (methodId) => {
|
|
264
|
-
const node = {
|
|
265
|
-
'@type': nodeType,
|
|
266
|
-
term: { '@id': (subValue === null || subValue === void 0 ? void 0 : subValue.id) || termId },
|
|
267
|
-
methodModel: { '@id': methodId }
|
|
268
|
-
};
|
|
269
|
-
return {
|
|
270
|
-
methodId,
|
|
271
|
-
model: findMatchingModel(models, modelParams(node)) ||
|
|
272
|
-
findMatchingModel(models, modelKeyParams(node, `${subValue === null || subValue === void 0 ? void 0 : subValue.key}.${methodId}`)) ||
|
|
273
|
-
// handle "input.price"
|
|
274
|
-
findMatchingModel(models, modelKeyParams(node, `${type.toLowerCase()}.${subValue === null || subValue === void 0 ? void 0 : subValue.key}`)) ||
|
|
275
|
-
// handle "input.hestiaAggregatedData"
|
|
276
|
-
findMatchingModel(models, modelKeyParams(node, `${type.toLowerCase()}.${methodId}`))
|
|
277
|
-
};
|
|
278
|
-
};
|
|
279
|
-
const configModelWithLogs = (data, logs) => (model) => (Object.assign(Object.assign({}, model), { logs: logs === null || logs === void 0 ? void 0 : logs[model.methodId], status: logStatus(data, logs === null || logs === void 0 ? void 0 : logs[model.methodId]), showLogs: hasLogDetails(data, logs === null || logs === void 0 ? void 0 : logs[model.methodId]) }));
|
|
280
|
-
const dataWithConfigModelLogs = (logs) => (data) => {
|
|
281
|
-
const subLogKey = data.id || data.key ?
|
|
282
|
-
data.id || data.key : null;
|
|
283
|
-
const log = subLogKey ? logs[subLogKey] : logs;
|
|
284
|
-
return Object.assign(Object.assign({}, data), { configModels: data.configModels.map(model => Array.isArray(model) ? model.map(configModelWithLogs(data, log)) : configModelWithLogs(data, log)(model)) });
|
|
285
|
-
};
|
|
286
|
-
/**
|
|
287
|
-
* Group models running in parallel under the same array, as they should appear vertically.
|
|
288
|
-
*
|
|
289
|
-
* @param config The configuration.
|
|
290
|
-
* @param models The list of models
|
|
291
|
-
*/
|
|
292
|
-
const groupParallelModels = (config, termId, modelKey, models) => {
|
|
293
|
-
const modelsWithOrder = models.map(model => ({
|
|
294
|
-
model,
|
|
295
|
-
order: modelConfigOrder(config.models, termId, modelKey, model.methodId)
|
|
296
|
-
}));
|
|
297
|
-
return modelsWithOrder
|
|
298
|
-
.reduce((prev, { model, order }) => {
|
|
299
|
-
const isArray = order.includes('.');
|
|
300
|
-
const arrayIndex = isArray ? order.split('.')[0] : prev.length;
|
|
301
|
-
prev[arrayIndex] = isArray ? [...(prev[arrayIndex] || []), model] : model;
|
|
302
|
-
return prev;
|
|
303
|
-
}, [])
|
|
304
|
-
.filter(Boolean)
|
|
305
|
-
.map(v => v.length === 1 ? v[0] : v);
|
|
306
|
-
};
|
|
307
|
-
const allParallel = (models) => models.length === 1 && Array.isArray(models[0]) && models[0].length > 1;
|
|
308
|
-
const valueByMethodId = (values, methodId, termId) => { var _a; return propertyValue((_a = values.find(v => { var _a; return ((_a = v.methodModel) === null || _a === void 0 ? void 0 : _a['@id']) === methodId; })) === null || _a === void 0 ? void 0 : _a.value, termId); };
|
|
309
|
-
const groupParallelValues = (values, models, termId) => Array.isArray(models)
|
|
310
|
-
? Object.fromEntries(models.map(model => [model.methodId, valueByMethodId(values, model.methodId, termId)]))
|
|
311
|
-
: {};
|
|
312
|
-
export const groupLogsByTerm = (nodeType, logs, models, config, allOriginalValues, allRecalculatedValues, nodeKey) => {
|
|
313
|
-
const originalValues = (allOriginalValues || []).filter(value => !value.deleted);
|
|
314
|
-
const recalculatedValues = (allRecalculatedValues || []).filter(value => !value.deleted);
|
|
315
|
-
const type = originalValues.length ?
|
|
316
|
-
originalValues[0]['@type'] || originalValues[0].type :
|
|
317
|
-
recalculatedValues.length ?
|
|
318
|
-
recalculatedValues[0]['@type'] || recalculatedValues[0].type :
|
|
319
|
-
undefined;
|
|
320
|
-
return (term) => {
|
|
321
|
-
const termId = term['@id'];
|
|
322
|
-
const termLogs = get(logs, termId, {});
|
|
323
|
-
const original = originalValues.filter(v => termId === v.term['@id']);
|
|
324
|
-
const recalculated = recalculatedValues.filter(v => termId === v.term['@id']);
|
|
325
|
-
const hasData = !!original.length || !!recalculated.length || Object.keys(termLogs).length > 0;
|
|
326
|
-
const configModelsData = { nodeType, type, termId };
|
|
327
|
-
const configModels = groupParallelModels(config, termId, nodeKey, unique([
|
|
328
|
-
...(termLogs.models || []).filter(key => isModelLog(termLogs[key])),
|
|
329
|
-
...findConfigModels(config, termId, nodeKey, models).map(({ model }) => model)
|
|
330
|
-
]).map(configModelWithDocs(models, configModelsData)));
|
|
331
|
-
const keys = logKeys(termLogs, original, recalculated, models, configModelsData);
|
|
332
|
-
const subValues = logSubValues(logs, termLogs, original, recalculated, models, configModelsData);
|
|
333
|
-
const isRequired = !Object.values(termLogs)
|
|
334
|
-
.filter(v => typeof v === 'object' && !Array.isArray(v))
|
|
335
|
-
// ignore models that were never going to run
|
|
336
|
-
.filter(isRunOrchestrator)
|
|
337
|
-
.every(v => v.runRequired === false);
|
|
338
|
-
return dataWithConfigModelLogs(termLogs)({
|
|
339
|
-
isOpen: true,
|
|
340
|
-
canOpen: keys.length > 0 || subValues.length > 0,
|
|
341
|
-
termId,
|
|
342
|
-
term,
|
|
343
|
-
type,
|
|
344
|
-
configModels,
|
|
345
|
-
original,
|
|
346
|
-
originalValue: reduceValues(original, termId),
|
|
347
|
-
recalculated,
|
|
348
|
-
recalculatedValue: reduceValues(recalculated, termId),
|
|
349
|
-
isOriginal: !!original.length,
|
|
350
|
-
isRecalculated: isRecalculated(recalculated),
|
|
351
|
-
hasData,
|
|
352
|
-
isRequired,
|
|
353
|
-
logs: termLogs,
|
|
354
|
-
keys,
|
|
355
|
-
subValues,
|
|
356
|
-
allParallel: allParallel(configModels),
|
|
357
|
-
originalValueByMethodId: groupParallelValues(original, configModels[0], termId),
|
|
358
|
-
recalculatedValueByMethodId: groupParallelValues(recalculated, configModels[0], termId)
|
|
359
|
-
});
|
|
360
|
-
};
|
|
361
|
-
};
|
|
362
|
-
export const modelCount = (blankNodeLogs) => Math.max.apply(Math.max, [
|
|
363
|
-
0,
|
|
364
|
-
...blankNodeLogs.flatMap(v => [
|
|
365
|
-
v.configModels.length,
|
|
366
|
-
...v.subValues.map(s => { var _a, _b; return (_b = (_a = s.configModels) === null || _a === void 0 ? void 0 : _a.length) !== null && _b !== void 0 ? _b : 0; }),
|
|
367
|
-
v.keys.length ? 1 : 0
|
|
368
|
-
])
|
|
369
|
-
]);
|
|
370
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-logs.model.js","sourceRoot":"","sources":["../../../src/node/node-logs.model.ts"],"names":[],"mappings":";AAAA,+BAA+B;AAC/B,OAAO,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC;AAC5B,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACnE,OAAO,EACK,kBAAkB,EAClB,YAAY,EAAY,UAAU,EAAE,UAAU,EACzD,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,+BAA+B,CAAC;AAC9D,MAAM,GAAG,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;AAClC,MAAM,GAAG,GAAG,OAAO,CAAC,YAAY,CAAC,CAAC;AAClC,MAAM,OAAO,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;AAE1C,OAAO,EAC0C,gBAAgB,EAAE,UAAU,EAC3E,iBAAiB,EAAE,WAAW,EAAE,cAAc,EAC/C,MAAM,0BAA0B,CAAC;AAmClC,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;AAE9C,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC;AAE7E,MAAM,oBAAoB,GAAG,MAAM,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;AAEjF,MAAM,uBAAuB,GAAG,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;AAEzE,MAAM,mBAAmB,GAAG,gBAAgB,CAAC;AAE7C,MAAM,aAAa,GAAG,CAAC,QAAgB,EAAE,EAAE;IACzC,MAAM,CAAC,QAAQ,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IACvC,MAAM,GAAG,GAAG,SAAS,CAAC,QAAQ,CAAC,QAAe,CAAC,CAAC,CAAC,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC,mBAAmB,CAAC,GAAG,CAAC;IACrG,OAAO,SAAS,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;AAClC,CAAC,CAAC;AAEF,MAAM,WAAW,GAAG,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,mBAAmB,CAAC,EAAE,aAAa,EAAE,EAAE,EAAE,CAAC,CAAC;IACjF,QAAQ,EAAE,aAAa,CAAC,aAAa,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;CAC/D,CAAC,CAAC;AAEH,MAAM,QAAQ,GAAG,CAAC,KAAa,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;AAEpF,MAAM,YAAY,GAAG,CAAC,OAAe,EAAE,EAAE;IACvC,IAAI;QACF,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACjC,OAAO,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YACpD,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YACtC,MAAM,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;YAC5B,uCACK,IAAI,GACJ,CAAC,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAC5C;QACJ,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;KAC7B;IACD,OAAO,GAAG,EAAE;QACV,kDAAkD;QAClD,OAAO,EAAE,CAAC;KACX;AACH,CAAC,CAAC;AAEF,MAAM,WAAW,GAAG,CAAC,GAAQ,EAAE,EAAE,CAC/B,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,oBAAoB,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;AAEjG,MAAM,iBAAiB,GAAG,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,CACtC,MAAM;KACH,IAAI,CAAC,GAAG,CAAC;KACT,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,uBAAuB,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;KACpD,MAAM,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,CAAC,iCAClB,IAAI,KACP,CAAC,GAAG,CAAC,EAAE,MAAM,CAAC;QACZ,GAAG,CAAC,CAAC,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC;QACpE,GAAG,CAAC,GAAG,CAAC;KACT,CAAC,IACF,EAAE,IAAI,CAAC,CAAC;AAEd,MAAM,QAAQ,GAAG,CAAC,KAAK,EAAE,EAA6E,EAAE,EAAE;QAAjF,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,UAAU,EAAE,YAAY,EAAE,QAAQ,OAAe,EAAV,GAAG,cAAtE,4EAAwE,CAAF;IAC7F,MAAM,cAAc,GAAG,MAAM,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;IACvD,MAAM,KAAK,GAAG,CAAC,cAAc,IAAI,CAAC,CAAC,GAAG,CAAC;IACvC,MAAM,YAAY,GAAG,CAAC,KAAK,IAAI,IAAI,EAAE,CAAC,cAAc,IAAI,GAAG,IAAI,QAAQ,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACnG,MAAM,WAAW,GAAG,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAEpE,GAAG,CAAC,KAAK,EAAE,GAAG,YAAY,SAAS,EAAE,MAAM,CAAC;QAC1C,GAAG,GAAG,CAAC,KAAK,EAAE,GAAG,YAAY,SAAS,EAAE,EAAE,CAAC;QAC3C,KAAK;KACN,CAAC,CAAC,CAAC;IACJ,GAAG,CAAC,KAAK,EAAE,GAAG,YAAY,QAAQ,EAAE,KAAK,CAAC,CAAC;IAE3C,IAAI,IAAI,GAAG,GAAG,CAAC,KAAK,EAAE,WAAW,EAAE,EAAE,CAAC,CAAC;IAEvC,IAAI,GAAG,iBAAiB,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IAEpC,IAAI,OAAO,UAAU,KAAK,WAAW,EAAE;QACrC,MAAM,SAAS,GAAG,UAAU,KAAK,MAAM,CAAC;QAExC,IAAI,GAAG,cAAc,CAAC,CAAC,iCAEhB,IAAI,KACP,qBAAqB,EAAE,SAAS,IAChC,CAAC,+CAEE,IAAI,GACJ,WAAW,CAAC,GAAG,CAAC,KACnB,SAAS,GACV,CAAC;KACL;SACI,IAAI,OAAO,YAAY,KAAK,WAAW,EAAE;QAC5C,MAAM,WAAW,GAAG,YAAY,KAAK,MAAM,CAAC;QAE5C,IAAI,iDACC,IAAI,GACJ,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,KAAE,mDAAmD;YAC7F,WAAW,GACZ,CAAC;KACH;SACI,IAAI,cAAc,IAAI,GAAG,EAAE;QAC9B,MAAM,EAAE,YAAY,KAAiB,GAAG,EAAf,OAAO,UAAK,GAAG,EAAlC,gBAA4B,CAAM,CAAC;QAEzC,IAAI,CAAC,YAAY,mCACZ,CAAC,IAAI,CAAC,YAAY,IAAI,EAAE,CAAC,GACzB,OAAO,CACX,CAAC;KACH;SACI,IAAI,mBAAmB,IAAI,GAAG,EAAE;QACnC,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;YAC3B,GAAG,CAAC,IAAI,CAAC,cAAc,IAAI,EAAE,CAAC;YAC9B,WAAW,CAAC,GAAG,CAAC;SACjB,CAAC,CAAC;KACJ;SACI,IAAI,CAAC,cAAc,EAAE;QACxB,IAAI,CAAC,IAAI,mCACJ,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC,GACjB,WAAW,CAAC,GAAG,CAAC,CACpB,CAAC;KACH;IAED,GAAG,CAAC,KAAK,EAAE,WAAW,EAAE,IAAI,CAAC,CAAC;IAC9B,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAEF,MAAM,gBAAgB,GAAG,CAAC,KAAK,EAAE,GAAG,EAAE,GAAW,EAAE,EAAE;IACnD,MAAM,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC;IACpB,MAAM,IAAI,GAAG,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,EAAE,EAAE,GAAG,CAAC,CAAC;IAC5C,KAAK,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC;IAEjB,IAAI,GAAG,KAAK,gBAAgB,EAAE;QAC5B,mDAAmD;QACnD,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,MAAM,CAAC,EAAE,EAAE,CAC/C,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;;YAC9B,IAAI,MAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAG,IAAI,CAAC,0CAAG,KAAK,CAAC,EAAE;gBAC1B,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC;oBAC/B,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC;oBAClC,EAAE;iBACH,CAAC,CAAC;aACJ;QACH,CAAC,CAAC,CACH,CAAC;KACH;IAED,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG;IACnB,gBAAgB;CACjB,CAAC;AAEF,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,IAAY,EAAa,EAAE,CAC1D,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;KACb,GAAG,CAAC,YAAY,CAAC;KACjB,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAA,CAAC,aAAD,CAAC,uBAAD,CAAC,CAAE,IAAI,CAAA,IAAI,CAAA,CAAC,aAAD,CAAC,uBAAD,CAAC,CAAE,IAAI,MAAK,MAAM,IAAI,CAAC,CAAC,CAAA,CAAC,aAAD,CAAC,uBAAD,CAAC,CAAE,KAAK,CAAA,CAAC;KAC1D,MAAM,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;IACrB,MAAM,QAAQ,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IAClD,OAAO,QAAQ,CAAC,CAAC;QACf,QAAQ,KAAK,gBAAgB,CAAC,CAAC;YAC7B,oDAAoD;YACpD,gBAAgB,CAAC,KAAK,EAAE,GAAG,EAAE,QAAQ,CAAC,CAAC,CAAC;YACxC,QAAQ,CAAC,gBAAgB,CAAC,KAAK,EAAE,GAAG,EAAE,QAAQ,CAAC,EAAE,GAAG,CAAC;QACvD,CAAC,CAAC,QAAQ,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;AAC3B,CAAC,CAAC,CAAC;AAEP,MAAM,CAAC,MAAM,YAAY,GAAG,CAC1B,cAA2B,EAAE,kBAA+B,EAAE,KAAqB,EAAE,eAAgC,EACrH,EAAE,CAAC,IAAI,CACL,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,MAAM,EAAC,CAAC;IACb,KAAK,CAAC,CAAC;IACP;QACE,GAAG,CAAC,cAAc,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC;QACjD,GAAG,CAAC,kBAAkB,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC;KACtD,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAA,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAE,MAAM,CAAA,IAAI,eAAe,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CACxF,CAAC,IAAI,CACJ,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC,CAAE,CAAC,KAAK,CAAC,CAAC,EACxB,OAAO,EAAE,EACT,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CACxC,CAAC,SAAS,EAAE,CAAC;AAIhB,MAAM,CAAN,IAAY,SAMX;AAND,WAAY,SAAS;IACnB,mCAAsB,CAAA;IACtB,6BAAgB,CAAA;IAChB,8EAAiE,CAAA;IACjE,mEAAsD,CAAA;IACtD,yCAA4B,CAAA;AAC9B,CAAC,EANW,SAAS,KAAT,SAAS,QAMpB;AAED,MAAM,aAAa,GAAG,CAAC,IAA2C,EAAE,IAAmB,EAAE,EAAE;;IACzF,OAAA;QACE,SAAS,CAAC,OAAO;QACjB,SAAS,CAAC,KAAK;KAChB,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC,IAAI,CACnC,CAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,YAAY,MAAI,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,IAAI,CAAA,KAAI,MAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,cAAc,0CAAE,MAAM,CAAA,CACjE,CAAA;CAAA,CAAC;AAEJ,MAAM,SAAS,GAAG,CAAC,IAA2C,EAAE,IAAmB,EAAE,EAAE,CACrF,MAAM,CAAC,IAAI,CAAC;IACV,CAAC,CAAC,CACA,CAAC,IAAI,CAAC,UAAU;QACd,CAAC,CAAC,SAAS,CAAC,WAAW;QACvB,CAAC,CAAC,iBAAiB,CAAC,IAAI,CAAC;YACvB,CAAC,CAAC,CACA,WAAW,IAAI,IAAI;gBACjB,CAAC,CAAC,IAAI,CAAC,SAAS;oBACd,CAAC,CAAC,IAAI,CAAC,cAAc;wBACnB,CAAC,CAAC,SAAS,CAAC,OAAO;wBACnB,CAAC,CAAC,SAAS,CAAC,YAAY;oBAC1B,CAAC,CAAC,SAAS,CAAC,KAAK;gBACnB,CAAC,CAAC,SAAS,CAAC,YAAY,CAC3B;YACD,CAAC,CAAC,IAAI,CAAC,cAAc;gBACnB,CAAC,CAAC,SAAS,CAAC,aAAa;gBACzB,CAAC,CAAC,SAAS,CAAC,YAAY,CAC/B;IACD,CAAC,CAAC,CACA;QACE,OAAO,IAAI,CAAC,aAAa,KAAK,WAAW;QACzC,IAAI,CAAC,cAAc,CAAC,kBAAkB;KACvC,CAAC,KAAK,CAAC,OAAO,CAAC;QACd,CAAC,CAAC,SAAS,CAAC,aAAa;QACzB,CAAC,CAAC,SAAS,CAAC,YAAY,CAC3B,CAAC;AAmDN,MAAM,YAAY,GAAG,CAAC,MAAa,EAAE,MAAc,EAAE,EAAE;IACrD,MAAM,cAAc,GAAG,MAAM;SAC1B,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,aAAa,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QACjD,oGAAoG;SACnG,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC;IAC3B,OAAO,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;AACvF,CAAC,CAAC;AAEF,MAAM,iBAAiB,GAAG,CAAC,GAAiB,EAAE,EAAE,CAAC,CAAC,CAAC,uBAAuB,IAAI,GAAG,CAAC,IAAI,GAAG,CAAC,qBAAqB,CAAC;AAEhH,MAAM,YAAY,GAAG,CAAC,GAAiB,EAAE,EAAE,CAAC,CAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,UAAU,MAAK,kBAAkB,CAAC,UAAU,CAAC;AAE9F,MAAM,MAAM,GAAG,CAAC,GAAiB,EAAE,gBAAgB,GAAG,IAAI,EAAE,EAAE,CAC5D,CAAC,CAAC,GAAG,IAAI,CACP,WAAW,IAAI,GAAG;IAClB,aAAa,IAAI,GAAG;IACpB,CAAC,gBAAgB,IAAI,uBAAuB,IAAI,GAAG,CAAC,CACrD,CAAC;AAEJ,MAAM,cAAc,GAAG,CAAC,MAAmB,EAAE,GAAG,GAAG,OAAO,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IAC/E,GAAG,CAAC,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;IAClB,GAAG,CAAC,CAAC,CAAC,OAAO,IAAI,EAAE,CAAC;CACrB,CAAC,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;AAElB,MAAM,mBAAmB,GAErB;IACF,QAAQ,EAAE,CAAC,MAA4C,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE;;QAAC,OAAA,CAAC,CAAC,EAAE,KAAI,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,CAAA;YACxF,CAAC,CAAC,CAAA,MAAA,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,0CAAE,KAAK,KAAI,EAAE;YAC3E,CAAC,CAAC,EAAE,CAAA;KAAA;IACN,KAAK,EAAE,CAAC,MAAkB,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE;;QAAC,OAAA,CAAC,CAAC,EAAE,KAAI,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,MAAM,CAAA;YAC3D,CAAC,CAAC,aAAa,CAAC,MAAA,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,MAAM,EAAE,EAAE,EAAE,CAAC,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,0CAAE,KAAK,EAAE,EAAE,CAAC;YAC1G,CAAC,CAAC,EAAE,CAAA;KAAA;IACN,OAAO,EAAE,CAAC,UAAU,EAAE,GAAG,EAAE,EAAE;QAC3B,MAAM,KAAK,GAAG,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,MAAM,EAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC7D,OAAO,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC,QAAQ,CAAC,OAAO,KAAK,CAAC;YACxE,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC;gBACpB,CAAC,CAAC,EAAE;gBACJ,CAAC,CAAC,KAAK;YACP,CAAC,CAAC,IAAI,CAAC;IACX,CAAC;CACF,CAAC;AAEF,MAAM,cAAc,GAAG,CAAC,UAAuB,EAAE,GAAW,EAAE,EAAW,EAAE,EAAE,CAC3E,mBAAmB,CAAC,GAAG,IAAI,mBAAmB,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,UAAU,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;AAEzF,MAAM,WAAW,GAAG,CAAC,IAAmB,EAAE,GAAW,EAAE,IAAY,EAAE,EAAE,CACrE,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAChB,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC7B,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAc,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,EAA4B,CAAA,CAAC,CAAC,CAAC;IACvF,EAAE,GAAG,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAA2B,CAC9D,CAAC,CAAC,CAAC,SAAS,CAAC;AAEhB,MAAM,aAAa,GAAG,CAAC,KAAkB,EAAE,MAAgB,EAAE,EAAE,CAC7D,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CACnB,CAAE,IAAY,CAAC,UAAU,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAChE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,UAAU,EAAE,EAAE,EAAE,YAAY,EAAE,UAAU,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;AAEzG,MAAM,YAAY,GAAG,CACnB,OAAkB,EAAE,IAAmB,EAAE,QAAqB,EAAE,YAAyB,EAAE,MAAgB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,EAC9G,EAAE,CAC3B,MAAM,CAAC;IACL,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CACjC;QACE,WAAW,CAAC,IAAI,EAAE,GAAG,EAAE,OAAO,CAAC;QAC/B,WAAW,CAAC,IAAI,EAAE,GAAG,EAAE,UAAU,CAAC;KACnC;SACE,IAAI,EAAE;SACN,MAAM,CAAC,OAAO,CAAC;SACf,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,iCAAM,CAAC,KAAE,YAAY,EAAE,CAAC,GAAG,CAAC,IAAG,CAAC,CAC7C;IACD,GAAG,aAAa,CAAC,QAAQ,EAAE,MAAM,CAAC;IAClC,GAAG,aAAa,CAAC,YAAY,EAAE,MAAM,CAAC;CACvC,CAAC;KACC,GAAG,CAAC,CAAC,CAAC,EAAE;IACP,MAAM,aAAa,GAAG,cAAc,CAAC,QAAQ,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;IAC5D,MAAM,iBAAiB,GAAG,cAAc,CAAC,YAAY,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;IACpE,uCACK,CAAC,KACJ,YAAY,EAAE,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,mBAAmB,CAAC,MAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,CAAQ,CAAC,CAAC,EACnG,aAAa;QACb,iBAAiB,EACjB,cAAc,EAAE,CAAC,WAAW,CAAC,iBAAiB,CAAC,IAAI,iBAAiB,KAAK,aAAa,EACtF,UAAU,EAAE,IAAI,IAChB;AACJ,CAAC,CAAC;KACD,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC;KACtC,GAAG,CAAC,uBAAuB,CAAC,OAAO,CAAC,CAAC,CAAC;AAE3C,mGAAmG;AAEnG,MAAM,OAAO,GAAG,CACd,IAAmB,EAAE,QAAqB,EAAE,YAAyB,EAAE,MAAgB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,EAC1F,EAAE,CAC3B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC;KACd,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC;KAC9B,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACX,GAAG;IACH,YAAY,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,MAAM,IAAI,EAAE,CAAC;SACnC,GAAG,CAAC,mBAAmB,CAAC,MAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,EAAE,GAAG,EAAS,CAAC,CAAC;QAC7E,oFAAoF;SACnF,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IACzB,aAAa,EAAE,cAAc,CAAC,QAAQ,EAAE,GAAG,CAAC;IAC5C,iBAAiB,EAAE,cAAc,CAAC,YAAY,EAAE,GAAG,CAAC;IACpD,cAAc,EAAE,cAAc,CAAC,YAAY,EAAE,GAAG,CAAC;IACjD,UAAU,EAAE,IAAI;CACjB,CAAC,CAAC;KACF,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC;KACtC,GAAG,CAAC,uBAAuB,CAAC,IAAI,CAAC,CAAC,CAAC;AAExC,MAAM,mBAAmB,GAAG,CAAC,IAAkB,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,KAAK,kBAAkB,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC;AAErH,MAAM,UAAU,GAAG,CAAC,IAAkB,EAAE,EAAE,CACxC;IACE,CAAC,mBAAmB,CAAC,IAAI,CAAC;IAC1B,CAAC,IAAI,CAAC,KAAK;IACX,CAAC,IAAI,CAAC,KAAK;IACX,CAAC,IAAI,CAAC,QAAQ;CACf,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI;IAClB,WAAW,IAAI,IAAI;IACnB,uBAAuB,IAAI,IAAI;IAC/B,aAAa,IAAI,IAAI;CACtB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;AAElB,MAAM,gBAAgB,GAAG,CACvB,MAAiE,EAAE,MAAc,EAAE,QAAgB,EAAE,KAAa,EAC1G,EAAE;IACV,MAAM,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE;QACtC,MAAM,UAAU,GAAG,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACxF,OAAO,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC;YACrB,CAAC,CAAC,UAAU;gBACV,CAAC,CAAC,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC;gBAC/B,CAAC,CAAC,EAAE;YACN,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,KAAK,EAAE,QAAQ,KAAK,CAAC,CAAC,GAAG,EAAE,KAAK,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC;gBAC1E,CAAC,CAAC,GAAG,KAAK,EAAE;gBACZ,CAAC,CAAC,EAAE,CAAC;IACX,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;IACnB,OAAO,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;AAC1C,CAAC,CAAC;AAEF,MAAM,mBAAmB,GAAG,CAC1B,MAAgB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE,QAAgC,EAC9E,EAAE,CAAC,CAAC,QAAgB,EAAE,EAAE;IACxB,MAAM,IAAI,GAAG;QACX,OAAO,EAAE,QAAQ;QACjB,IAAI,EAAE,EAAE,KAAK,EAAE,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,EAAE,KAAI,MAAM,EAAE;QACvC,WAAW,EAAE,EAAE,KAAK,EAAE,QAAQ,EAAE;KAC1B,CAAC;IACT,OAAO;QACL,QAAQ;QACR,KAAK,EAAE,iBAAiB,CAAC,MAAM,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;YACjD,iBAAiB,CAAC,MAAM,EAAE,cAAc,CAAC,IAAI,EAAE,GAAG,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,GAAG,IAAI,QAAQ,EAAE,CAAC,CAAC;YAC/E,uBAAuB;YACvB,iBAAiB,CAAC,MAAM,EAAE,cAAc,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,WAAW,EAAE,IAAI,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,GAAG,EAAE,CAAC,CAAC;YACzF,sCAAsC;YACtC,iBAAiB,CAAC,MAAM,EAAE,cAAc,CAAC,IAAI,EAAE,GAAG,IAAI,CAAC,WAAW,EAAE,IAAI,QAAQ,EAAE,CAAC,CAAC;KACvF,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,mBAAmB,GAAG,CAAC,IAA2C,EAAE,IAAmB,EAAE,EAAE,CAAC,CAAC,KAAmB,EAAE,EAAE,CAAC,CAAC,gCACvH,KAAK,KACR,IAAI,EAAE,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAG,KAAK,CAAC,QAAQ,CAAC,EAC5B,MAAM,EAAE,SAAS,CAAC,IAAI,EAAE,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,EAC/C,QAAQ,EAAE,aAAa,CAAC,IAAI,EAAE,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,GACrC,CAAA,CAAC;AAEnB,MAAM,uBAAuB,GAAG,CAC9B,IAA+B,EAC/B,EAAE,CAAC,CAAoD,IAAO,EAAE,EAAE;IAClE,MAAM,SAAS,GAAI,IAA8B,CAAC,EAAE,IAAK,IAA8B,CAAC,GAAG,CAAC,CAAC;QAC1F,IAA8B,CAAC,EAAE,IAAK,IAA8B,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC;IACnF,MAAM,GAAG,GAAG,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC/C,OAAO,gCACF,IAAI,KACP,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAC1C,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,mBAAmB,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,mBAAmB,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC,KAAK,CAAC,CACzG,GACG,CAAC;AACT,CAAC,CAAC;AAEF;;;;;GAKG;AACH,MAAM,mBAAmB,GAAG,CAAC,MAA2B,EAAE,MAAc,EAAE,QAAgB,EAAE,MAAsB,EAAE,EAAE;IACpH,MAAM,eAAe,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAC3C,KAAK;QACL,KAAK,EAAE,gBAAgB,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,CAAC;KACzE,CAAC,CAAC,CAAC;IACJ,OAAO,eAAe;SACnB,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,EAAE;QACjC,MAAM,OAAO,GAAG,KAAK,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;QACpC,MAAM,UAAU,GAAG,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC;QAC/D,IAAI,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QAC1E,OAAO,IAAI,CAAC;IACd,CAAC,EAAE,EAAsB,CAAC;SACzB,MAAM,CAAC,OAAO,CAAC;SACf,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AACzC,CAAC,CAAC;AAEF,MAAM,WAAW,GAAG,CAAC,MAAyC,EAAE,EAAE,CAChE,MAAM,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;AAE1E,MAAM,eAAe,GAAG,CAAC,MAAmB,EAAE,QAAgB,EAAE,MAAc,EAAE,EAAE,WAChF,OAAA,aAAa,CAAC,MAAA,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,WAAC,OAAA,CAAA,MAAA,CAAC,CAAC,WAAW,0CAAG,KAAK,CAAC,MAAK,QAAQ,CAAA,EAAA,CAAC,0CAAE,KAAiB,EAAE,MAAM,CAAC,CAAA,EAAA,CAAC;AAElG,MAAM,mBAAmB,GAAG,CAAC,MAAmB,EAAE,MAAqC,EAAE,MAAc,EAAE,EAAE,CACzG,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC;IACnB,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,QAAQ,EAAE,eAAe,CAAC,MAAM,EAAE,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC;IAC5G,CAAC,CAAC,EAAE,CAAC;AAET,MAAM,CAAC,MAAM,eAAe,GAAG,CAC7B,QAAkB,EAAE,IAAe,EAAE,MAAgB,EAAE,MAA2B,EAClF,iBAA8B,EAAE,qBAAkC,EAClE,OAAgB,EAChB,EAAE;IACF,MAAM,cAAc,GAAG,CAAC,iBAAiB,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAE,KAAa,CAAC,OAAO,CAAC,CAAC;IAC1F,MAAM,kBAAkB,GAAG,CAAC,qBAAqB,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAE,KAAa,CAAC,OAAO,CAAC,CAAC;IAClG,MAAM,IAAI,GAAe,cAAc,CAAC,MAAM,CAAC,CAAC;QAC9C,cAAc,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,cAAc,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QACtD,kBAAkB,CAAC,MAAM,CAAC,CAAC;YACzB,kBAAkB,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,kBAAkB,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;YAC9D,SAAS,CAAC;IAEd,OAAO,CAAC,IAAiB,EAAiB,EAAE;QAC1C,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;QAC3B,MAAM,QAAQ,GAAG,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE,CAAkB,CAAC;QACxD,MAAM,QAAQ,GAAG,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,KAAK,CAAC,CAAC,IAAK,CAAC,KAAK,CAAC,CAAC,CAAC;QACvE,MAAM,YAAY,GAAG,kBAAkB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,KAAK,CAAC,CAAC,IAAK,CAAC,KAAK,CAAC,CAAC,CAAC;QAC/E,MAAM,OAAO,GAAG,CAAC,CAAC,QAAQ,CAAC,MAAM,IAAI,CAAC,CAAC,YAAY,CAAC,MAAM,IAAI,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;QAC/F,MAAM,gBAAgB,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;QACpD,MAAM,YAAY,GAAG,mBAAmB,CACtC,MAAM,EAAE,MAAM,EAAE,OAAQ,EACxB,MAAM,CAAC;YACL,GAAG,CAAC,QAAQ,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;YACnE,GAAG,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,OAAQ,EAAE,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,CAAC,KAAe,CAAC;SAC1F,CAAC,CAAC,GAAG,CAAC,mBAAmB,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC,CACtD,CAAC;QACF,MAAM,IAAI,GAAG,OAAO,CAAC,QAAQ,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,EAAE,gBAAgB,CAAC,CAAC;QACjF,MAAM,SAAS,GAAG,YAAY,CAAC,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,YAAY,EAAE,MAAM,EAAE,gBAAgB,CAAC,CAAC;QACjG,MAAM,UAAU,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC;aACxC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YACxD,6CAA6C;aAC5C,MAAM,CAAC,iBAAiB,CAAC;aACzB,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,KAAK,CAAC,CAAC;QAEvC,OAAO,uBAAuB,CAAC,QAAQ,CAAC,CAAC;YACvC,MAAM,EAAE,IAAI;YACZ,OAAO,EAAE,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC;YAChD,MAAM;YACN,IAAI;YACJ,IAAI;YACJ,YAAY;YACZ,QAAQ;YACR,aAAa,EAAE,YAAY,CAAC,QAAQ,EAAE,MAAM,CAAC;YAC7C,YAAY;YACZ,iBAAiB,EAAE,YAAY,CAAC,YAAY,EAAE,MAAM,CAAC;YACrD,UAAU,EAAE,CAAC,CAAC,QAAQ,CAAC,MAAM;YAC7B,cAAc,EAAE,cAAc,CAAC,YAAY,CAAC;YAC5C,OAAO;YACP,UAAU;YACV,IAAI,EAAE,QAAQ;YACd,IAAI;YACJ,SAAS;YACT,WAAW,EAAE,WAAW,CAAC,YAAY,CAAC;YACtC,uBAAuB,EAAE,mBAAmB,CAAC,QAAQ,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC;YAC/E,2BAA2B,EAAE,mBAAmB,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC;SACxF,CAAC,CAAC;IACL,CAAC,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,aAA8B,EAAE,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE;IACrF,CAAC;IACD,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC;QAC5B,CAAC,CAAC,YAAY,CAAC,MAAM;QACrB,GAAG,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,eAAC,OAAA,MAAA,MAAA,CAAC,CAAC,YAAY,0CAAE,MAAM,mCAAI,CAAC,CAAA,EAAA,CAAC;QACpD,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;KACtB,CAAC;CACH,CAAC,CAAC","sourcesContent":["/* eslint-disable complexity */\nimport { from } from 'rxjs';\nimport { distinct, toArray, map } from 'rxjs/operators';\nimport { fileToExt, SupportedExtensions } from '@hestia-earth/api';\nimport {\n  Emission, EmissionMethodTier, ITermJSONLD, Product, Input as HestiaInput,\n  NodeType, TermTermType, Property, SchemaType, isTypeNode\n} from '@hestia-earth/schema';\nimport { unique, isUndefined } from '@hestia-earth/utils';\nimport { propertyValue } from '@hestia-earth/utils/dist/term';\nconst get = require('lodash.get');\nconst set = require('lodash.set');\nconst orderBy = require('lodash.orderby');\n\nimport {\n  IOrchestratorConfig, IOrchestratorModelConfig, findConfigModels, findModels, IModel,\n  findMatchingModel, modelParams, modelKeyParams\n} from '../engine/engine.service';\n\nexport interface INodeMissingLookupLog {\n  filename: string;\n  termId: string;\n  column: string;\n  // attributes linked to the models\n  model?: string;\n  term?: string;\n  key?: string;\n}\n\nexport interface INodeTermLog {\n  runRequired?: boolean;\n  shouldRun?: boolean;\n  shouldRunOrchestrator?: boolean;\n  missingLookups?: INodeMissingLookupLog[];\n  requirements?: { [key: string]: any };\n  logs?: { [key: string]: any };\n  [key: string]: any;\n  // possible sub values\n  input?: string | string[];\n  property?: string | string[];\n}\n\nexport interface INodeTermLogs {\n  [modelKey: string]: any | INodeTermLog;\n  models: string[];\n  isKey: boolean;\n}\n\nexport interface INodeLogs {\n  [term: string]: INodeTermLogs;\n}\n\nconst termTypes = Object.values(TermTermType);\n\nconst blankNodeTypes = Object.values(SchemaType).filter(t => !isTypeNode(t));\n\nconst schemaTypesLowerCase = Object.values(SchemaType).map(v => v.toLowerCase());\n\nconst blankNodeTypesLowerCase = blankNodeTypes.map(v => v.toLowerCase());\n\nconst missingLookupPrefix = 'Missing lookup';\n\nconst parseFilename = (filepath: string) => {\n  const [filename] = filepath.split('.');\n  const ext = termTypes.includes(filename as any) ? SupportedExtensions.xlsx : SupportedExtensions.csv;\n  return fileToExt(filename, ext);\n};\n\nconst parseLookup = ({ column, termid, [missingLookupPrefix]: missingLookup }) => ({\n  filename: parseFilename(missingLookup), termId: termid, column\n});\n\nconst csvValue = (value: string) => (value || '').replace('[', '').replace(']', '');\n\nconst parseMessage = (message: string) => {\n  try {\n    const data = JSON.parse(message);\n    return data.message.split(',').reduce((prev, parts) => {\n      const [key, value] = parts.split('=');\n      const val = csvValue(value);\n      return {\n        ...prev,\n        ...(key && val ? { [key.trim()]: val } : {})\n      };\n    }, { logger: data.logger });\n  }\n  catch (err) {\n    // make sure it works even if one log is malformed\n    return {};\n  }\n};\n\nconst omitLogKeys = (log: any) =>\n  Object.fromEntries(Object.entries(log).filter(([key]) => !schemaTypesLowerCase.includes(key)));\n\nconst includeBlankNodes = (logs, log) =>\n  Object\n    .keys(log)\n    .filter(key => blankNodeTypesLowerCase.includes(key))\n    .reduce((prev, key) => ({\n      ...prev,\n      [key]: unique([\n        ...((typeof prev[key] === 'string' ? [prev[key]] : prev[key]) || []),\n        log[key]\n      ])\n    }), logs);\n\nconst groupLog = (group, { logger, term, model, key, should_run, run_required, property, ...log }: any) => {\n  const isOrchestrator = logger.includes('orchestrator');\n  const isKey = !isOrchestrator && !!key;\n  const parentLogKey = [`[\"${term}\"]`, !isOrchestrator && key || property].filter(Boolean).join('.');\n  const logModelKey = [parentLogKey, model].filter(Boolean).join('.');\n\n  set(group, `${parentLogKey}.models`, unique([\n    ...get(group, `${parentLogKey}.models`, []),\n    model\n  ]));\n  set(group, `${parentLogKey}.isKey`, isKey);\n\n  let data = get(group, logModelKey, {});\n\n  data = includeBlankNodes(data, log);\n\n  if (typeof should_run !== 'undefined') {\n    const shouldRun = should_run === 'True';\n\n    data = isOrchestrator ?\n      {\n        ...data,\n        shouldRunOrchestrator: shouldRun\n      } :\n      {\n        ...data,\n        ...omitLogKeys(log),\n        shouldRun\n      };\n  }\n  else if (typeof run_required !== 'undefined') {\n    const runRequired = run_required === 'True';\n\n    data =  {\n      ...data,\n      ...(runRequired ? {} : omitLogKeys(log)), // no need to save logs if we need to run the model\n      runRequired\n    };\n  }\n  else if ('requirements' in log) {\n    const { requirements, ...logData } = log;\n\n    data.requirements = {\n      ...(data.requirements || {}),\n      ...logData\n    };\n  }\n  else if (missingLookupPrefix in log) {\n    data.missingLookups = unique([\n      ...(data.missingLookups || []),\n      parseLookup(log)\n    ]);\n  }\n  else if (!isOrchestrator) {\n    data.logs = {\n      ...(data.logs || {}),\n      ...omitLogKeys(log)\n    };\n  }\n\n  set(group, logModelKey, data);\n  return group;\n};\n\nconst groupLogSubValue = (group, log, key: string) => {\n  const id = log[key];\n  const data = groupLog(group[id] || {}, log);\n  group[id] = data;\n\n  if (key === 'transformation') {\n    // add value to the same term/model on parent group\n    Object.entries(group[id]).map(([term, models]) =>\n      Object.keys(models).map(model => {\n        if (group?.[term]?.[model]) {\n          group[term][model][key] = unique([\n            ...(group[term][model][key] || []),\n            id\n          ]);\n        }\n      })\n    );\n  }\n\n  return group;\n};\n\nconst subValueKeys = [\n  'transformation'\n];\n\nexport const groupLogsByModel = (data: string): INodeLogs =>\n  data.split('\\n')\n    .map(parseMessage)\n    .filter(v => !!v?.term && v?.term !== 'None' && !!v?.model)\n    .reduce((group, log) => {\n      const subValue = subValueKeys.find(v => !!log[v]);\n      return subValue ?\n        subValue === 'transformation' ?\n          // for transformation, do not add to top-level model\n          groupLogSubValue(group, log, subValue) :\n          groupLog(groupLogSubValue(group, log, subValue), log)\n        : groupLog(group, log);\n    });\n\nexport const computeTerms = (\n  originalValues: blankNode[], recalculatedValues: blankNode[], terms?: ITermJSONLD[], filterTermTypes?: TermTermType[]\n) => from(\n    terms?.length ?\n      terms :\n      [\n        ...(originalValues || []).map(({ term }) => term),\n        ...(recalculatedValues || []).map(({ term }) => term)\n      ].filter(node => !filterTermTypes?.length || filterTermTypes.includes(node.termType))\n  ).pipe(\n    distinct(v => v!['@id']),\n    toArray(),\n    map(v => orderBy(v, ['name'], ['asc']))\n  ).toPromise();\n\nexport type blankNode = Emission | Product | HestiaInput | Property;\n\nexport enum LogStatus {\n  success = 'successful',\n  error = 'failed',\n  skipHierarchy = 'not run (model higher up hierarchy run instead)',\n  dataProvided = 'not run (user provided data retained)',\n  notRequired = 'not relevant'\n}\n\nconst hasLogDetails = (data: IBlankNodeLogSubValue | IBlankNodeLog, logs?: INodeTermLog) =>\n  [\n    LogStatus.success,\n    LogStatus.error\n  ].includes(logStatus(data, logs)) && (\n    logs?.requirements || logs?.logs || logs?.missingLookups?.length\n  );\n\nconst logStatus = (data: IBlankNodeLogSubValue | IBlankNodeLog, logs?: INodeTermLog) =>\n  hasLog(logs)\n    ? (\n      !data.isRequired\n        ? LogStatus.notRequired\n        : isRunOrchestrator(logs)\n          ? (\n            'shouldRun' in logs\n              ? logs.shouldRun\n                ? data.isRecalculated\n                  ? LogStatus.success\n                  : LogStatus.dataProvided\n                : LogStatus.error\n              : LogStatus.dataProvided\n          )\n          : data.isRecalculated\n            ? LogStatus.skipHierarchy\n            : LogStatus.dataProvided\n    )\n    : (\n      [\n        typeof data.originalValue === 'undefined', // no original value\n        data.isRecalculated // is recalculated\n      ].every(Boolean)\n        ? LogStatus.skipHierarchy\n        : LogStatus.dataProvided\n    );\n\nexport interface IConfigModel {\n  methodId: string;\n  logs?: INodeTermLog;\n  hasLogs?: boolean;\n  status?: LogStatus;\n  model?: IModel;\n}\n\nexport interface IBlankNodeLogSubValue {\n  key: string;\n  originalValue: number | string | boolean;\n  recalculatedValue: number | string | boolean;\n  isRecalculated: boolean;\n  isRequired?: boolean;\n  id?: any;\n  configModels?: IConfigModel[];\n  logs?: INodeTermLogs;\n}\n\nexport interface IBlankNodeLog {\n  isOpen: boolean;\n  canOpen: boolean;\n  term: ITermJSONLD;\n  termId: string;\n  type?: SchemaType;\n  configModels: (IConfigModel | IConfigModel[])[];\n  original: blankNode[];\n  originalValue: number;\n  // when multiple models are running in parallel\n  originalValueByMethodId?: {\n    [methodId: string]: number;\n  };\n  recalculated: blankNode[];\n  recalculatedValue: number;\n  // when multiple models are running in parallel\n  recalculatedValueByMethodId?: {\n    [methodId: string]: number;\n  };\n  isOriginal: boolean;\n  isRecalculated: boolean;\n  hasData: boolean;\n  isRequired: boolean;\n  logs?: INodeTermLogs;\n  keys: IBlankNodeLogSubValue[];\n  subValues: IBlankNodeLogSubValue[];\n  // contains multiple models all running in parallel\n  allParallel?: boolean;\n}\n\nconst reduceValues = (values: any[], termId: string) => {\n  const propertyValues = values\n    .map(({ value }) => propertyValue(value, termId))\n    // propertyValue may return null if the value is null or undefined, therefore remove them from total\n    .filter(v => v !== null);\n  return propertyValues.length ? propertyValues.reduce((p, v) => p + v, 0) : undefined;\n};\n\nconst isRunOrchestrator = (log: INodeTermLog) => !('shouldRunOrchestrator' in log) || log.shouldRunOrchestrator;\n\nconst isBackground = (log: INodeTermLog) => log?.methodTier === EmissionMethodTier.background;\n\nconst hasLog = (log: INodeTermLog, withOrchestrator = true) =>\n  !!log && (\n    'shouldRun' in log ||\n    'runRequired' in log ||\n    (withOrchestrator && 'shouldRunOrchestrator' in log)\n  );\n\nconst isRecalculated = (values: blankNode[], key = 'value') => values.some(v => ([\n  ...(v.added || []),\n  ...(v.updated || [])\n]).includes(key));\n\nconst blankNodeValueByKey: {\n  [key: string]: (values: blankNode[], key?: string, id?: string) => number | string | boolean;\n} = {\n  property: (values: (Emission | Product | HestiaInput)[], _k, id) => !!id && values?.length\n    ? (values[0].properties || []).find(p => p.term['@id'] === id)?.value || ''\n    : '',\n  input: (values: Emission[], _k, id) => !!id && values?.length\n    ? propertyValue(values.find(({ inputs }) => (inputs || []).some(input => input['@id'] === id))?.value, id)\n    : '',\n  default: (blankNodes, key) => {\n    const value = blankNodes?.length ? blankNodes[0][key] : null;\n    return ['string', 'number', 'boolean', 'undefined'].includes(typeof value)\n      ? isUndefined(value)\n      ? ''\n      : value\n      : null;\n  }\n};\n\nconst blankNodeValue = (blankNodes: blankNode[], key: string, id?: string) =>\n  blankNodeValueByKey[key in blankNodeValueByKey ? key : 'default'](blankNodes, key, id);\n\nconst logSubValue = (logs: INodeTermLogs, key: string, prop: string) =>\n  logs[key][prop] ? (\n    Array.isArray(logs[key][prop]) ?\n      (logs[key][prop] as string[]).map(id => ({ key: prop, id } as IBlankNodeLogSubValue)) :\n      { key: prop, id: logs[key][prop] } as IBlankNodeLogSubValue\n  ) : undefined;\n\nconst logProperties = (nodes: blankNode[], models: IModel[]) =>\n  nodes.flatMap(node =>\n    ((node as any).properties || []).map(({ term }) => term['@id'])\n  ).map(id => ({ key: 'property', id, configModels: findModels(models, id).map(({ model }) => model) }));\n\nconst logSubValues = (\n  allLogs: INodeLogs, logs: INodeTermLogs, original: blankNode[], recalculated: blankNode[], models: IModel[], { nodeType, type, termId }\n): IBlankNodeLogSubValue[] =>\n  unique([\n    ...Object.keys(logs).flatMap(key =>\n      [\n        logSubValue(logs, key, 'input'),\n        logSubValue(logs, key, 'property')\n      ]\n        .flat()\n        .filter(Boolean)\n        .map(v => ({ ...v, configModels: [key] }))\n    ),\n    ...logProperties(original, models),\n    ...logProperties(recalculated, models)\n  ])\n    .map(v => {\n      const originalValue = blankNodeValue(original, v.key, v.id);\n      const recalculatedValue = blankNodeValue(recalculated, v.key, v.id);\n      return {\n        ...v,\n        configModels: v.configModels.map(configModelWithDocs(models, { nodeType, type, termId }, v as any)),\n        originalValue,\n        recalculatedValue,\n        isRecalculated: !isUndefined(recalculatedValue) && recalculatedValue !== originalValue,\n        isRequired: true\n      };\n    })\n    .filter(v => v.configModels.length > 0)\n    .map(dataWithConfigModelLogs(allLogs));\n\n// const hasKey = (blankNodes: blankNode[], key: string) => (blankNodes || []).some(n => key in n);\n\nconst logKeys = (\n  logs: INodeTermLogs, original: blankNode[], recalculated: blankNode[], models: IModel[], { nodeType, type, termId }\n): IBlankNodeLogSubValue[] =>\n  Object.keys(logs)\n    .filter(key => logs[key].isKey)\n    .map(key => ({\n      key,\n      configModels: (logs[key].models || [])\n        .map(configModelWithDocs(models, { nodeType, type, termId }, { key } as any))\n        // only take those we found a matching model (avoid matching key on wrong node type)\n        .filter(v => !!v.model),\n      originalValue: blankNodeValue(original, key),\n      recalculatedValue: blankNodeValue(recalculated, key),\n      isRecalculated: isRecalculated(recalculated, key),\n      isRequired: true\n    }))\n    .filter(v => v.configModels.length > 0)\n    .map(dataWithConfigModelLogs(logs));\n\nconst isBackgroundNoInput = (logs: INodeTermLog) => logs.methodTier === EmissionMethodTier.background && !logs.input;\n\nconst isModelLog = (logs: INodeTermLog) =>\n  [\n    !isBackgroundNoInput(logs),\n    !logs.isKey,\n    !logs.input,\n    !logs.property\n  ].every(Boolean) && [\n    'shouldRun' in logs,\n    'shouldRunOrchestrator' in logs,\n    'runRequired' in logs\n  ].some(Boolean);\n\nconst modelConfigOrder = (\n  models: (IOrchestratorModelConfig | IOrchestratorModelConfig[])[], termId: string, modelKey: string, model: string\n): string => {\n  const indexes = models.map((m, index) => {\n    const arrayIndex = Array.isArray(m) ? modelConfigOrder(m, termId, modelKey, model) : '';\n    return Array.isArray(m)\n      ? arrayIndex\n        ? [index, arrayIndex].join('.')\n        : ''\n      : [termId === m.value, modelKey === m.key, model === m.model].every(Boolean)\n        ? `${index}`\n        : '';\n  }).filter(Boolean);\n  return indexes.length ? indexes[0] : '';\n};\n\nconst configModelWithDocs = (\n  models: IModel[], { nodeType, type, termId }, subValue?: IBlankNodeLogSubValue\n) => (methodId: string) => {\n  const node = {\n    '@type': nodeType,\n    term: { '@id': subValue?.id || termId },\n    methodModel: { '@id': methodId }\n  } as any;\n  return {\n    methodId,\n    model: findMatchingModel(models, modelParams(node)) ||\n      findMatchingModel(models, modelKeyParams(node, `${subValue?.key}.${methodId}`)) ||\n      // handle \"input.price\"\n      findMatchingModel(models, modelKeyParams(node, `${type.toLowerCase()}.${subValue?.key}`)) ||\n      // handle \"input.hestiaAggregatedData\"\n      findMatchingModel(models, modelKeyParams(node, `${type.toLowerCase()}.${methodId}`))\n  };\n};\n\nconst configModelWithLogs = (data: IBlankNodeLog | IBlankNodeLogSubValue, logs: INodeTermLogs) => (model: IConfigModel) => ({\n  ...model,\n  logs: logs?.[model.methodId],\n  status: logStatus(data, logs?.[model.methodId]),\n  showLogs: hasLogDetails(data, logs?.[model.methodId])\n} as IConfigModel);\n\nconst dataWithConfigModelLogs = (\n  logs: INodeLogs | INodeTermLogs\n) => <T extends (IBlankNodeLog | IBlankNodeLogSubValue)>(data: T) => {\n  const subLogKey = (data as IBlankNodeLogSubValue).id || (data as IBlankNodeLogSubValue).key ?\n    (data as IBlankNodeLogSubValue).id || (data as IBlankNodeLogSubValue).key : null;\n  const log = subLogKey ? logs[subLogKey] : logs;\n  return {\n    ...data,\n    configModels: data.configModels.map(model =>\n      Array.isArray(model) ? model.map(configModelWithLogs(data, log)) : configModelWithLogs(data, log)(model)\n    )\n  } as T;\n};\n\n/**\n * Group models running in parallel under the same array, as they should appear vertically.\n *\n * @param config The configuration.\n * @param models The list of models\n */\nconst groupParallelModels = (config: IOrchestratorConfig, termId: string, modelKey: string, models: IConfigModel[]) => {\n  const modelsWithOrder = models.map(model => ({\n    model,\n    order: modelConfigOrder(config.models, termId, modelKey, model.methodId)\n  }));\n  return modelsWithOrder\n    .reduce((prev, { model, order }) => {\n      const isArray = order.includes('.');\n      const arrayIndex = isArray ? order.split('.')[0] : prev.length;\n      prev[arrayIndex] = isArray ? [...(prev[arrayIndex] || []), model] : model;\n      return prev;\n    }, [] as IConfigModel[][])\n    .filter(Boolean)\n    .map(v => v.length === 1 ? v[0] : v);\n};\n\nconst allParallel = (models: (IConfigModel | IConfigModel[])[]) =>\n  models.length === 1 && Array.isArray(models[0]) && models[0].length > 1;\n\nconst valueByMethodId = (values: blankNode[], methodId: string, termId: string) =>\n  propertyValue(values.find(v => v.methodModel?.['@id'] === methodId)?.value as number[], termId);\n\nconst groupParallelValues = (values: blankNode[], models: IConfigModel | IConfigModel[], termId: string) =>\n  Array.isArray(models)\n    ? Object.fromEntries(models.map(model => [model.methodId, valueByMethodId(values, model.methodId, termId)]))\n    : {};\n\nexport const groupLogsByTerm = (\n  nodeType: NodeType, logs: INodeLogs, models: IModel[], config: IOrchestratorConfig,\n  allOriginalValues: blankNode[], allRecalculatedValues: blankNode[],\n  nodeKey?: string\n) => {\n  const originalValues = (allOriginalValues || []).filter(value => !(value as any).deleted);\n  const recalculatedValues = (allRecalculatedValues || []).filter(value => !(value as any).deleted);\n  const type: SchemaType = originalValues.length ?\n    originalValues[0]['@type'] || originalValues[0].type :\n    recalculatedValues.length ?\n      recalculatedValues[0]['@type'] || recalculatedValues[0].type :\n      undefined;\n\n  return (term: ITermJSONLD): IBlankNodeLog => {\n    const termId = term['@id'];\n    const termLogs = get(logs, termId, {}) as INodeTermLogs;\n    const original = originalValues.filter(v => termId === v.term!['@id']);\n    const recalculated = recalculatedValues.filter(v => termId === v.term!['@id']);\n    const hasData = !!original.length || !!recalculated.length || Object.keys(termLogs).length > 0;\n    const configModelsData = { nodeType, type, termId };\n    const configModels = groupParallelModels(\n      config, termId, nodeKey!,\n      unique([\n        ...(termLogs.models || []).filter(key => isModelLog(termLogs[key])),\n        ...findConfigModels(config, termId, nodeKey!, models).map(({ model }) => model as string)\n      ]).map(configModelWithDocs(models, configModelsData))\n    );\n    const keys = logKeys(termLogs, original, recalculated, models, configModelsData);\n    const subValues = logSubValues(logs, termLogs, original, recalculated, models, configModelsData);\n    const isRequired = !Object.values(termLogs)\n      .filter(v => typeof v === 'object' && !Array.isArray(v))\n      // ignore models that were never going to run\n      .filter(isRunOrchestrator)\n      .every(v => v.runRequired === false);\n\n    return dataWithConfigModelLogs(termLogs)({\n      isOpen: true,\n      canOpen: keys.length > 0 || subValues.length > 0,\n      termId,\n      term,\n      type,\n      configModels,\n      original,\n      originalValue: reduceValues(original, termId),\n      recalculated,\n      recalculatedValue: reduceValues(recalculated, termId),\n      isOriginal: !!original.length,\n      isRecalculated: isRecalculated(recalculated),\n      hasData,\n      isRequired,\n      logs: termLogs,\n      keys,\n      subValues,\n      allParallel: allParallel(configModels),\n      originalValueByMethodId: groupParallelValues(original, configModels[0], termId),\n      recalculatedValueByMethodId: groupParallelValues(recalculated, configModels[0], termId)\n    });\n  };\n};\n\nexport const modelCount = (blankNodeLogs: IBlankNodeLog[]) => Math.max.apply(Math.max, [\n  0,\n  ...blankNodeLogs.flatMap(v => [\n    v.configModels.length,\n    ...v.subValues.map(s => s.configModels?.length ?? 0),\n    v.keys.length ? 1 : 0\n  ])\n]);\n"]}
|