@hestia-earth/ui-components 0.2.12 → 0.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/hestia-earth-ui-components.umd.js +474 -473
- package/bundles/hestia-earth-ui-components.umd.js.map +1 -1
- package/common/clipboard/clipboard.component.d.ts +1 -0
- package/cycles/cycles-activity/cycles-activity.component.d.ts +1 -3
- package/cycles/cycles-activity-logs/cycles-activity-logs.component.d.ts +42 -10
- package/cycles/cycles-completeness/cycles-completeness.component.d.ts +1 -3
- package/cycles/cycles-emissions/cycles-emissions.component.d.ts +1 -3
- package/cycles/cycles-emissions-chart/cycles-emissions-chart.component.d.ts +1 -2
- package/cycles/cycles-emissions-logs/cycles-emissions-logs.component.d.ts +42 -6
- package/cycles/cycles-practices/cycles-practices.component.d.ts +1 -3
- package/cycles/cycles-practices-logs/cycles-practices-logs.component.d.ts +42 -10
- package/cycles/cycles-result/cycles-result.component.d.ts +1 -3
- package/cycles/cycles.model.d.ts +3 -4
- package/esm2015/common/clipboard/clipboard.component.js +5 -3
- package/esm2015/cycles/cycles-activity/cycles-activity.component.js +2 -8
- package/esm2015/cycles/cycles-activity-logs/cycles-activity-logs.component.js +11 -21
- package/esm2015/cycles/cycles-completeness/cycles-completeness.component.js +2 -8
- package/esm2015/cycles/cycles-emissions/cycles-emissions.component.js +2 -8
- package/esm2015/cycles/cycles-emissions-chart/cycles-emissions-chart.component.js +4 -9
- package/esm2015/cycles/cycles-emissions-logs/cycles-emissions-logs.component.js +12 -14
- package/esm2015/cycles/cycles-practices/cycles-practices.component.js +2 -8
- package/esm2015/cycles/cycles-practices-logs/cycles-practices-logs.component.js +10 -21
- package/esm2015/cycles/cycles-result/cycles-result.component.js +4 -12
- package/esm2015/cycles/cycles.model.js +4 -5
- package/esm2015/files/files-form/files-form.component.js +1 -1
- package/esm2015/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.js +4 -9
- package/esm2015/impact-assessments/impact-assessments-products/impact-assessments-products.component.js +2 -8
- package/esm2015/impact-assessments/impact-assessments-products-logs/impact-assessments-products-logs.component.js +8 -12
- package/esm2015/node/index.js +2 -1
- package/esm2015/node/node-link/node-link.component.js +2 -2
- package/esm2015/node/node-logs-models/node-logs-models.component.js +56 -326
- package/esm2015/node/node-logs-models/node-logs-models.model.js +370 -0
- package/esm2015/node/node-missing-lookup-factors/node-missing-lookup-factors.component.js +1 -1
- package/esm2015/node/node-value-details/node-value-details.component.js +3 -3
- package/esm2015/node/node.service.js +1 -1
- package/esm2015/sites/sites-maps/sites-maps.component.js +3 -9
- package/esm2015/sites/sites-measurements/sites-measurements.component.js +2 -8
- package/esm2015/sites/sites-measurements-logs/sites-measurements-logs.component.js +8 -12
- package/fesm2015/hestia-earth-ui-components.js +339 -328
- package/fesm2015/hestia-earth-ui-components.js.map +1 -1
- package/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.d.ts +1 -2
- package/impact-assessments/impact-assessments-products/impact-assessments-products.component.d.ts +1 -3
- package/impact-assessments/impact-assessments-products-logs/impact-assessments-products-logs.component.d.ts +37 -6
- package/node/index.d.ts +1 -0
- package/node/node-logs-models/node-logs-models.component.d.ts +24 -88
- package/node/node-logs-models/node-logs-models.model.d.ts +88 -0
- package/node/node-missing-lookup-factors/node-missing-lookup-factors.component.d.ts +2 -1
- package/node/node.service.d.ts +1 -31
- package/package.json +2 -2
- package/sites/sites-maps/sites-maps.component.d.ts +1 -3
- package/sites/sites-measurements/sites-measurements.component.d.ts +1 -3
- package/sites/sites-measurements-logs/sites-measurements-logs.component.d.ts +39 -6
|
@@ -0,0 +1,370 @@
|
|
|
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-models.model.js","sourceRoot":"","sources":["../../../../src/node/node-logs-models/node-logs-models.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,6BAA6B,CAAC;AAmCrC,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"]}
|
|
@@ -32,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
32
32
|
}], ctorParameters: function () { return [{ type: i1.HeNodeService }]; }, propDecorators: { node: [{
|
|
33
33
|
type: Input
|
|
34
34
|
}] } });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS1taXNzaW5nLWxvb2t1cC1mYWN0b3JzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9ub2RlL25vZGUtbWlzc2luZy1sb29rdXAtZmFjdG9ycy9ub2RlLW1pc3NpbmctbG9va3VwLWZhY3RvcnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vc3JjL25vZGUvbm9kZS1taXNzaW5nLWxvb2t1cC1mYWN0b3JzL25vZGUtbWlzc2luZy1sb29rdXAtZmFjdG9ycy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQVUsTUFBTSxlQUFlLENBQUM7QUFDbEYsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLG1CQUFtQixDQUFDOzs7OztBQVk5QyxNQUFNLE9BQU8saUNBQWlDO0lBTzVDLFlBQ1MsV0FBMEI7UUFBMUIsZ0JBQVcsR0FBWCxXQUFXLENBQWU7UUFKNUIsWUFBTyxHQUFHLElBQUksQ0FBQztRQUNmLFNBQUksR0FBNEIsRUFBRSxDQUFDO0lBSXRDLENBQUM7SUFFQyxRQUFROztZQUNaLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDO1lBQ3BCLElBQUksQ0FBQyxJQUFJLEdBQUcsTUFBTSxJQUFJLENBQUMsV0FBVyxDQUFDLG9CQUFvQixpQ0FDbEQsSUFBSSxDQUFDLElBQUksS0FDWixTQUFTLEVBQUUsU0FBUyxDQUFDLFlBQVksSUFDakMsQ0FBQztZQUNILElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFDO1FBQ3ZCLENBQUM7S0FBQTs7K0hBbEJVLGlDQUFpQzttSEFBakMsaUNBQWlDLGdHQ2I5Qyw4akRBcURBOzRGRHhDYSxpQ0FBaUM7a0JBTjdDLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGdDQUFnQztvQkFDMUMsV0FBVyxFQUFFLDhDQUE4QztvQkFDM0QsU0FBUyxFQUFFLENBQUMsOENBQThDLENBQUM7b0JBQzNELGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNoRDtvR0FHUSxJQUFJO3NCQURWLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBEYXRhU3RhdGUgfSBmcm9tICdAaGVzdGlhLWVhcnRoL2FwaSc7XG5pbXBvcnQgeyBKU09OTEQsIE5vZGVUeXBlIH0gZnJvbSAnQGhlc3RpYS1lYXJ0aC9zY2hlbWEnO1xuXG5pbXBvcnQgeyBJTm9kZU1pc3NpbmdMb29rdXBMb2cgfSBmcm9tICcuLi9ub2RlLWxvZ3MtbW9kZWxzL25vZGUtbG9ncy1tb2RlbHMubW9kZWwnO1xuaW1wb3J0IHsgSGVOb2RlU2VydmljZSB9IGZyb20gJy4uL25vZGUuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2hlLW5vZGUtbWlzc2luZy1sb29rdXAtZmFjdG9ycycsXG4gIHRlbXBsYXRlVXJsOiAnLi9ub2RlLW1pc3NpbmctbG9va3VwLWZhY3RvcnMuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9ub2RlLW1pc3NpbmctbG9va3VwLWZhY3RvcnMuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgTm9kZU1pc3NpbmdMb29rdXBGYWN0b3JzQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KClcbiAgcHVibGljIG5vZGU/OiBKU09OTEQ8Tm9kZVR5cGU+O1xuXG4gIHB1YmxpYyBsb2FkaW5nID0gdHJ1ZTtcbiAgcHVibGljIGxvZ3M6IElOb2RlTWlzc2luZ0xvb2t1cExvZ1tdID0gW107XG5cbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIG5vZGVTZXJ2aWNlOiBIZU5vZGVTZXJ2aWNlXG4gICkgeyB9XG5cbiAgYXN5bmMgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5sb2FkaW5nID0gdHJ1ZTtcbiAgICB0aGlzLmxvZ3MgPSBhd2FpdCB0aGlzLm5vZGVTZXJ2aWNlLmdldE1pc3NpbmdMb29rdXBzTG9nKHtcbiAgICAgIC4uLnRoaXMubm9kZSxcbiAgICAgIGRhdGFTdGF0ZTogRGF0YVN0YXRlLnJlY2FsY3VsYXRlZFxuICAgIH0pO1xuICAgIHRoaXMubG9hZGluZyA9IGZhbHNlO1xuICB9XG59XG4iLCI8ZGl2ICpuZ0lmPVwiIWxvYWRpbmc7IGVsc2UgbG9hZGVyXCIgY2xhc3M9XCJ0YWJsZS1jb250YWluZXIgZGF0YS10YWJsZS1jb250YWluZXJcIj5cbiAgPHRhYmxlIGNsYXNzPVwidGFibGUgaXMtZnVsbHdpZHRoIGlzLWhvdmVyYWJsZSBtYi0wXCI+XG4gICAgPHRoZWFkIGNsYXNzPVwiaGFzLWJhY2tncm91bmQtYmxhY2tcIj5cbiAgICAgIDx0cj5cbiAgICAgICAgPHRoPlxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwiaGFzLXRleHQtd2hpdGVcIj5GaWxlbmFtZTwvc3Bhbj5cbiAgICAgICAgPC90aD5cbiAgICAgICAgPHRoPlxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwiaGFzLXRleHQtd2hpdGVcIj5Db2x1bW4gVGl0bGU8L3NwYW4+XG4gICAgICAgIDwvdGg+XG4gICAgICAgIDx0aD5cbiAgICAgICAgICA8c3BhbiBjbGFzcz1cImhhcy10ZXh0LXdoaXRlXCI+Um93ICh0ZXJtLmlkKTwvc3Bhbj5cbiAgICAgICAgPC90aD5cbiAgICAgICAgPHRoPlxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwiaGFzLXRleHQtd2hpdGVcIj5Nb2RlbDwvc3Bhbj5cbiAgICAgICAgPC90aD5cbiAgICAgIDwvdHI+XG4gICAgPC90aGVhZD5cbiAgICA8dGJvZHk+XG4gICAgICA8dHIgKm5nSWY9XCIhbG9ncy5sZW5ndGhcIj5cbiAgICAgICAgPHRkIGNvbHNwYW49XCIzXCI+XG4gICAgICAgICAgPHNwYW4+Tm8gbWlzc2luZyBsb29rdXAgZmFjdG9ycy48L3NwYW4+XG4gICAgICAgIDwvdGQ+XG4gICAgICA8L3RyPlxuICAgICAgPHRyICpuZ0Zvcj1cImxldCBsb2cgb2YgbG9nc1wiPlxuICAgICAgICA8dGQ+e3tsb2cuZmlsZW5hbWV9fTwvdGQ+XG4gICAgICAgIDx0ZD5cbiAgICAgICAgICA8c3BhbiAqbmdJZj1cImxvZy5jb2x1bW47IGVsc2UgbmFcIj57e2xvZy5jb2x1bW59fTwvc3Bhbj5cbiAgICAgICAgPC90ZD5cbiAgICAgICAgPHRkPlxuICAgICAgICAgIDxzcGFuICpuZ0lmPVwibG9nLnRlcm1JZDsgZWxzZSBuYVwiPnt7bG9nLnRlcm1JZH19PC9zcGFuPlxuICAgICAgICA8L3RkPlxuICAgICAgICA8dGQ+XG4gICAgICAgICAgPG5nLWNvbnRhaW5lciAqbmdJZj1cImxvZy5tb2RlbDsgZWxzZSBuYVwiPlxuICAgICAgICAgICAgPHNwYW4+e3tsb2cubW9kZWx9fTwvc3Bhbj5cbiAgICAgICAgICAgIDxzcGFuIGNsYXNzPVwicGwtMVwiICpuZ0lmPVwibG9nLmtleVwiPi8ge3tsb2cua2V5fX08L3NwYW4+XG4gICAgICAgICAgICA8c3BhbiBjbGFzcz1cInBsLTFcIiAqbmdJZj1cImxvZy50ZXJtICYmIGxvZy50ZXJtICE9PSBsb2cudGVybUlkXCI+LyB7e2xvZy50ZXJtfX08L3NwYW4+XG4gICAgICAgICAgPC9uZy1jb250YWluZXI+XG4gICAgICAgIDwvdGQ+XG4gICAgICA8L3RyPlxuICAgIDwvdGJvZHk+XG4gIDwvdGFibGU+XG48L2Rpdj5cblxuPG5nLXRlbXBsYXRlICNsb2FkZXI+XG4gIDxkaXYgY2xhc3M9XCJoYXMtdGV4dC1jZW50ZXIgcHktM1wiPlxuICAgIDxmYS1pY29uIGljb249XCJzcGlubmVyXCIgW3B1bHNlXT1cInRydWVcIiBzaXplPVwibGdcIj48L2ZhLWljb24+XG4gIDwvZGl2PlxuPC9uZy10ZW1wbGF0ZT5cblxuPG5nLXRlbXBsYXRlICNuYT5cbiAgPHNwYW4+LTwvc3Bhbj5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
|
|
@@ -9,10 +9,10 @@ const additionalKeys = [
|
|
|
9
9
|
'methodModelDescription', 'description',
|
|
10
10
|
'primary', 'emissionDuration', 'observations', 'statsDefinition',
|
|
11
11
|
'term', 'source', 'variety', 'reliability', 'price', 'currency', 'cost', 'revenue', 'economicValueShare',
|
|
12
|
-
'impactAssessment', 'properties'
|
|
12
|
+
'operation', 'impactAssessment', 'properties'
|
|
13
13
|
];
|
|
14
14
|
const tableKeys = [
|
|
15
|
-
'inputs', 'transformation', 'value', 'dates', 'methodModel', 'methodTier', 'statsDefinition'
|
|
15
|
+
'inputs', 'transformation', 'operation', 'value', 'dates', 'methodModel', 'methodTier', 'statsDefinition'
|
|
16
16
|
];
|
|
17
17
|
export class NodeValueDetailsComponent {
|
|
18
18
|
constructor() {
|
|
@@ -46,4 +46,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
46
46
|
}], dataKey: [{
|
|
47
47
|
type: Input
|
|
48
48
|
}] } });
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9kZS12YWx1ZS1kZXRhaWxzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9ub2RlL25vZGUtdmFsdWUtZGV0YWlscy9ub2RlLXZhbHVlLWRldGFpbHMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vc3JjL25vZGUvbm9kZS12YWx1ZS1kZXRhaWxzL25vZGUtdmFsdWUtZGV0YWlscy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBVSxNQUFNLGVBQWUsQ0FBQztBQUdsRixPQUFPLEVBQUUsaUJBQWlCLEVBQWdCLE1BQU0seUJBQXlCLENBQUM7QUFDMUUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLG9CQUFvQixDQUFDOzs7OztBQUU3QyxNQUFNLGNBQWMsR0FBRztJQUNyQix3QkFBd0IsRUFBRSxhQUFhO0lBQ3ZDLFNBQVMsRUFBRSxrQkFBa0IsRUFBRSxjQUFjLEVBQUUsaUJBQWlCO0lBQ2hFLE1BQU0sRUFBRSxRQUFRLEVBQUUsU0FBUyxFQUFFLGFBQWEsRUFBRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsb0JBQW9CO0lBQ3hHLFdBQVcsRUFBRSxrQkFBa0IsRUFBRSxZQUFZO0NBQzlDLENBQUM7QUFDRixNQUFNLFNBQVMsR0FBRztJQUNoQixRQUFRLEVBQUUsZ0JBQWdCLEVBQUUsV0FBVyxFQUFFLE9BQU8sRUFBRSxPQUFPLEVBQUUsYUFBYSxFQUFFLFlBQVksRUFBRSxpQkFBaUI7Q0FDMUcsQ0FBQztBQVFGLE1BQU0sT0FBTyx5QkFBeUI7SUFOdEM7UUFjUyxZQUFPLEdBQUcsT0FBTyxFQUFFLENBQUM7UUFDcEIsU0FBSSxHQUFHLENBQUMsT0FBTyxFQUFFLEdBQUcsaUJBQWlCLENBQUMsQ0FBQztRQUN2QyxtQkFBYyxHQUFHLGNBQWMsQ0FBQztRQUNoQyxjQUFTLEdBQUcsU0FBUyxDQUFDO0tBUzlCO0lBUEMsSUFBVyxJQUFJOztRQUNiLE9BQU8sTUFBQSxJQUFJLENBQUMsSUFBSSwwQ0FBRSxLQUFLLENBQUMsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxRQUFRO1FBQ04sSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLFdBQUMsT0FBQSxDQUFDLENBQUEsTUFBQSxJQUFJLENBQUMsSUFBSSwwQ0FBRSxLQUFLLEtBQUksRUFBRSxDQUFDLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsR0FBRyxJQUFJLElBQUksQ0FBQyxDQUFBLEVBQUEsQ0FBQyxDQUFDO0lBQy9GLENBQUM7O3VIQW5CVSx5QkFBeUI7MkdBQXpCLHlCQUF5QixpSUN0QnRDLG15Q0ErQkE7NEZEVGEseUJBQXlCO2tCQU5yQyxTQUFTO21CQUFDO29CQUNULFFBQVEsRUFBRSx1QkFBdUI7b0JBQ2pDLFdBQVcsRUFBRSxxQ0FBcUM7b0JBQ2xELFNBQVMsRUFBRSxDQUFDLHFDQUFxQyxDQUFDO29CQUNsRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDaEQ7OEJBR1EsSUFBSTtzQkFEVixLQUFLO2dCQUdDLFFBQVE7c0JBRGQsS0FBSztnQkFHQyxPQUFPO3NCQURiLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOb2RlVHlwZSB9IGZyb20gJ0BoZXN0aWEtZWFydGgvc2NoZW1hJztcblxuaW1wb3J0IHsgZ3JvdXBwZWRWYWx1ZUtleXMsIElHcm91cGVkTm9kZSB9IGZyb20gJy4uLy4uL2NvbW1vbi9ub2RlLXV0aWxzJztcbmltcG9ydCB7IGJhc2VVcmwgfSBmcm9tICcuLi8uLi9jb21tb24vdXRpbHMnO1xuXG5jb25zdCBhZGRpdGlvbmFsS2V5cyA9IFtcbiAgJ21ldGhvZE1vZGVsRGVzY3JpcHRpb24nLCAnZGVzY3JpcHRpb24nLFxuICAncHJpbWFyeScsICdlbWlzc2lvbkR1cmF0aW9uJywgJ29ic2VydmF0aW9ucycsICdzdGF0c0RlZmluaXRpb24nLFxuICAndGVybScsICdzb3VyY2UnLCAndmFyaWV0eScsICdyZWxpYWJpbGl0eScsICdwcmljZScsICdjdXJyZW5jeScsICdjb3N0JywgJ3JldmVudWUnLCAnZWNvbm9taWNWYWx1ZVNoYXJlJyxcbiAgJ29wZXJhdGlvbicsICdpbXBhY3RBc3Nlc3NtZW50JywgJ3Byb3BlcnRpZXMnXG5dO1xuY29uc3QgdGFibGVLZXlzID0gW1xuICAnaW5wdXRzJywgJ3RyYW5zZm9ybWF0aW9uJywgJ29wZXJhdGlvbicsICd2YWx1ZScsICdkYXRlcycsICdtZXRob2RNb2RlbCcsICdtZXRob2RUaWVyJywgJ3N0YXRzRGVmaW5pdGlvbidcbl07XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2hlLW5vZGUtdmFsdWUtZGV0YWlscycsXG4gIHRlbXBsYXRlVXJsOiAnLi9ub2RlLXZhbHVlLWRldGFpbHMuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9ub2RlLXZhbHVlLWRldGFpbHMuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcbn0pXG5leHBvcnQgY2xhc3MgTm9kZVZhbHVlRGV0YWlsc0NvbXBvbmVudDxUPiBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBkYXRhPzogSUdyb3VwZWROb2RlPFQ+O1xuICBASW5wdXQoKVxuICBwdWJsaWMgbm9kZVR5cGU/OiBOb2RlVHlwZTtcbiAgQElucHV0KClcbiAgcHVibGljIGRhdGFLZXk/OiBzdHJpbmc7XG5cbiAgcHVibGljIGJhc2VVcmwgPSBiYXNlVXJsKCk7XG4gIHB1YmxpYyBrZXlzID0gWyd2YWx1ZScsIC4uLmdyb3VwcGVkVmFsdWVLZXlzXTtcbiAgcHVibGljIGFkZGl0aW9uYWxLZXlzID0gYWRkaXRpb25hbEtleXM7XG4gIHB1YmxpYyB0YWJsZUtleXMgPSB0YWJsZUtleXM7XG5cbiAgcHVibGljIGdldCB0eXBlKCkge1xuICAgIHJldHVybiB0aGlzLmRhdGE/Lm5vZGVzWzBdWydAdHlwZSddO1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy50YWJsZUtleXMgPSB0YWJsZUtleXMuZmlsdGVyKGtleSA9PiAodGhpcy5kYXRhPy5ub2RlcyB8fCBbXSkuc29tZShub2RlID0+IGtleSBpbiBub2RlKSk7XG4gIH1cbn1cbiIsIjxuZy1jb250YWluZXIgKmJpbmRPbmNlPVwiZGF0YVwiPlxuICA8bmctY29udGFpbmVyICpuZ0lmPVwiZGF0YT8ubm9kZXM/Lmxlbmd0aCA9PT0gMTsgZWxzZSBzaG93VGFibGVcIj5cbiAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBrZXkgb2Yga2V5c1wiPlxuICAgICAgPGhlLWxpbmsta2V5LXZhbHVlIFtub2RlXT1cImRhdGEhLm5vZGVzWzBdXCIgW25vZGVUeXBlXT1cIm5vZGVUeXBlXCIgW2RhdGFLZXldPVwiZGF0YUtleVwiIFtrZXldPVwia2V5XCI+PC9oZS1saW5rLWtleS12YWx1ZT5cbiAgICA8L25nLWNvbnRhaW5lcj5cbiAgICA8bmctY29udGFpbmVyICpuZ0Zvcj1cImxldCBrZXkgb2YgYWRkaXRpb25hbEtleXNcIj5cbiAgICAgIDxoZS1saW5rLWtleS12YWx1ZSBbbm9kZV09XCJkYXRhIS5ub2Rlc1swXVwiIFtub2RlVHlwZV09XCJub2RlVHlwZVwiIFtkYXRhS2V5XT1cImRhdGFLZXlcIiBba2V5XT1cImtleVwiPjwvaGUtbGluay1rZXktdmFsdWU+XG4gICAgPC9uZy1jb250YWluZXI+XG4gIDwvbmctY29udGFpbmVyPlxuPC9uZy1jb250YWluZXI+XG5cbjxuZy10ZW1wbGF0ZSAjc2hvd1RhYmxlPlxuICA8aGUtbGluay1rZXktdmFsdWUgW25vZGVdPVwiZGF0YSEubm9kZXNbMF1cIiBbbm9kZVR5cGVdPVwibm9kZVR5cGVcIiBbZGF0YUtleV09XCJkYXRhS2V5XCIga2V5PVwidGVybVwiPjwvaGUtbGluay1rZXktdmFsdWU+XG5cbiAgPGRpdiBjbGFzcz1cInRhYmxlLWNvbnRhaW5lciBtdC0yXCI+XG4gICAgPHRhYmxlIGNsYXNzPVwidGFibGUgaXMtbmFycm93XCI+XG4gICAgICA8dGhlYWQ+XG4gICAgICAgIDx0aCAqbmdGb3I9XCJsZXQga2V5IG9mIHRhYmxlS2V5c1wiPlxuICAgICAgICAgIDxhIFtocmVmXT1cImJhc2VVcmwgKyAnL3NjaGVtYS8nICsgdHlwZSArICcjJyArIGtleVwiIHRhcmdldD1cIl9ibGFua1wiPjxiPnt7a2V5fX08L2I+PC9hPlxuICAgICAgICA8L3RoPlxuICAgICAgPC90aGVhZD5cbiAgICAgIDx0Ym9keT5cbiAgICAgICAgPHRyICpuZ0Zvcj1cImxldCBub2RlIG9mIGRhdGEhLm5vZGVzXCI+XG4gICAgICAgICAgPHRkICpuZ0Zvcj1cImxldCBrZXkgb2YgdGFibGVLZXlzXCI+XG4gICAgICAgICAgICA8aGUtbGluay1rZXktdmFsdWUgW25vZGVdPVwibm9kZVwiIFtub2RlVHlwZV09XCJub2RlVHlwZVwiIFtkYXRhS2V5XT1cImRhdGFLZXlcIiBba2V5XT1cImtleVwiPjwvaGUtbGluay1rZXktdmFsdWU+XG4gICAgICAgICAgPC90ZD5cbiAgICAgICAgPC90cj5cbiAgICAgIDwvdGJvZHk+XG4gICAgPC90YWJsZT5cbiAgPC9kaXY+XG48L25nLXRlbXBsYXRlPlxuIl19
|