@hestia-earth/ui-components 0.23.0 → 0.23.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.
Files changed (23) hide show
  1. package/common/utils.d.ts +1 -0
  2. package/engine/engine-models-version-link/engine-models-version-link.component.d.ts +2 -1
  3. package/esm2022/common/utils.mjs +8 -1
  4. package/esm2022/cycles/cycles-activity/cycles-activity.component.mjs +4 -4
  5. package/esm2022/cycles/cycles-completeness/cycles-completeness.component.mjs +4 -4
  6. package/esm2022/cycles/cycles-emissions/cycles-emissions.component.mjs +4 -4
  7. package/esm2022/cycles/cycles-practices/cycles-practices.component.mjs +4 -4
  8. package/esm2022/engine/engine-models-version-link/engine-models-version-link.component.mjs +6 -3
  9. package/esm2022/engine/engine-orchestrator-edit/engine-orchestrator-edit.component.mjs +2 -2
  10. package/esm2022/files/files-error.model.mjs +11 -10
  11. package/esm2022/files/files-form/files-form.component.mjs +3 -12
  12. package/esm2022/files/files-upload-errors/files-upload-errors.component.mjs +6 -10
  13. package/esm2022/impact-assessments/impact-assessments-products/impact-assessments-products.component.mjs +5 -3
  14. package/esm2022/node/node-csv-select-headers/node-csv-select-headers.component.mjs +2 -2
  15. package/esm2022/node/node-logs-models/node-logs-models.component.mjs +6 -5
  16. package/esm2022/select/select.component.mjs +2 -2
  17. package/esm2022/sites/sites-measurements/sites-measurements.component.mjs +4 -4
  18. package/fesm2022/hestia-earth-ui-components.mjs +58 -57
  19. package/fesm2022/hestia-earth-ui-components.mjs.map +1 -1
  20. package/files/files-form/files-form.component.d.ts +1 -1
  21. package/files/files-upload-errors/files-upload-errors.component.d.ts +3 -6
  22. package/node/node-logs-models/node-logs-models.component.d.ts +1 -0
  23. package/package.json +4 -4
@@ -7,7 +7,7 @@ import { propertyValue } from '@hestia-earth/utils/dist/term';
7
7
  import { loadResourceKey } from '@hestia-earth/glossary';
8
8
  import { LogStatus, groupLogsByModel, groupLogsByTerm, modelCount, computeTerms, logValueArray, groupdLogsByKey, computeKeys } from './node-logs-models.model';
9
9
  import { matchExactQuery, matchId, matchTermType, matchType } from '../../search/search.model';
10
- import { baseUrl, isExternal } from '../../common/utils';
10
+ import { baseUrl, isExternal, typeaheadFocus } from '../../common/utils';
11
11
  import { termTypeLabel } from '../../terms/terms.model';
12
12
  import * as i0 from "@angular/core";
13
13
  import * as i1 from "../node.service";
@@ -85,7 +85,7 @@ const matchTermTypeFromKey = {
85
85
  impacts: indicatorTermTermType.term,
86
86
  endpoints: indicatorTermTermType.term
87
87
  };
88
- const termSearch = (term) => term.replace(/[,\s]/g, '').toLowerCase();
88
+ const termSearch = (term = '') => term.replace(/[,\s]/g, '').toLowerCase();
89
89
  export class NodeLogsModelsComponent {
90
90
  constructor(nodeService, searchService, engineService) {
91
91
  this.nodeService = nodeService;
@@ -117,6 +117,7 @@ export class NodeLogsModelsComponent {
117
117
  this.showLegend = true;
118
118
  this.allTerms = [];
119
119
  this.suggestTerm = (text$) => text$.pipe(distinctUntilChanged(), switchMap(v => this.suggestByTerm(v)));
120
+ this.typeaheadFocus = typeaheadFocus;
120
121
  }
121
122
  async ngOnInit() {
122
123
  this.logsUrl = this.nodeService.nodeLogsUrl(this.node);
@@ -238,11 +239,11 @@ export class NodeLogsModelsComponent {
238
239
  return this.node?.functionalUnit;
239
240
  }
240
241
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.8", ngImport: i0, type: NodeLogsModelsComponent, deps: [{ token: i1.HeNodeService }, { token: i2.HeSearchService }, { token: i3.HeEngineService }], target: i0.ɵɵFactoryTarget.Component }); }
241
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.8", type: NodeLogsModelsComponent, selector: "he-node-logs-models", inputs: { node: "node", nodeKey: "nodeKey", originalValues: "originalValues", recalculatedValues: "recalculatedValues", terms: "terms", filterTermTypes: "filterTermTypes", filterTermTypesLabel: "filterTermTypesLabel", logsKey: "logsKey" }, ngImport: i0, template: "<div class=\"px-3 pb-3\">\n <div class=\"has-text-right mb-2\" *ngIf=\"!isExternal\">\n <a class=\"is-size-7\" *ngIf=\"logsUrl\" [href]=\"logsUrl\" target=\"_blank\">\n <fa-icon icon=\"external-link-alt\"></fa-icon>\n <span class=\"pl-2\">Open Full Logs</span>\n </a>\n </div>\n\n <he-data-table class=\"mb-1 is-small\" [small]=\"true\" maxHeight=\"320\">\n <table class=\"table is-fullwidth is-narrow is-striped\">\n <thead>\n <tr>\n <th class=\"width-auto has-border-right\">\n <div class=\"field\" *ngIf=\"allTerms?.length\">\n <div class=\"control is-expanded has-icons-right\">\n <input\n class=\"input search-input is-small\"\n [(ngModel)]=\"term\"\n name=\"term\"\n placeholder=\"Filter by name\"\n [ngbTypeahead]=\"suggestTerm\"\n [focusFirst]=\"false\"\n (selectItem)=\"filterResults()\" />\n <a class=\"icon is-small is-right\" [class.is-hidden]=\"!term\" (click)=\"term = ''; filterResults()\">\n <fa-icon icon=\"times\"></fa-icon>\n </a>\n </div>\n </div>\n </th>\n <th *ngIf=\"isBlankNodes\">\n <span class=\"is-pr-1\">Units</span>\n <span>(per&nbsp;</span>\n <span [ngSwitch]=\"functionalUnit\">\n <ng-container *ngSwitchCase=\"CycleFunctionalUnit['1 ha']\">hectare</ng-container>\n <ng-container *ngSwitchDefault>kg product</ng-container>\n </span>\n <span>)</span>\n </th>\n <th>Original</th>\n <th>Recalculated</th>\n <th *ngIf=\"isBlankNodes\">Difference</th>\n <th *ngFor=\"let c of methodModelsCount | times; let i = index\">({{ i + 1 }})</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngIf=\"loading\">\n <td class=\"has-text-centered\" colspan=\"6\">\n <div class=\"has-text-center py-3\">\n <fa-icon icon=\"spinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n </div>\n </td>\n </tr>\n <tr *ngIf=\"!loading && blankNodes.length === 0\">\n <td class=\"has-text-centered\" colspan=\"6\">\n <span>No data</span>\n </td>\n </tr>\n <ng-container *ngFor=\"let blankNode of blankNodes; trackBy: trackByBlankNode\">\n <tr [class.has-sub-rows]=\"blankNode.canOpen\" [class.is-open]=\"blankNode.isOpen\">\n <td class=\"width-auto has-border-right is-nowrap\" [attr.title]=\"blankNode.term?.name || blankNode.key\">\n <a\n class=\"is-inline-block is-align-top pr-2 open-node\"\n (click)=\"blankNode.isOpen = !blankNode.isOpen\"\n *ngIf=\"blankNode.canOpen\">\n <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!blankNode.isOpen\"></fa-icon>\n <fa-icon icon=\"angle-right\" [class.is-hidden]=\"blankNode.isOpen\"></fa-icon>\n </a>\n <he-node-link class=\"is-inline-block is-pre-wrap\" *ngIf=\"blankNode.term\" [node]=\"blankNode.term\">\n <span [innerHtml]=\"blankNode.term.name | compound\"></span>\n </he-node-link>\n <span *ngIf=\"blankNode.key\">{{ blankNode.key }}</span>\n </td>\n <td *ngIf=\"isBlankNodes\">\n <span class=\"is-nowrap\" [innerHtml]=\"blankNode.term?.units | compound\"></span>\n </td>\n <td>\n <ng-template #defaultOriginalValue>\n <span>{{ blankNode.originalValue | precision: 3 | default: '-' }}</span>\n </ng-template>\n <ng-container *ngIf=\"blankNode.allParallel; else defaultOriginalValue\">\n <div *ngFor=\"let model of blankNode.configModels[0]\">\n {{ blankNode.originalValueByMethodId[model.methodId] | precision: 3 | default: '-' }}\n </div>\n </ng-container>\n </td>\n <td>\n <ng-container *ngIf=\"!blankNode.isOriginal || blankNode.isRecalculated; else notRecalculated\">\n <ng-template #defaultRecalculatedValue>\n <span>{{ blankNode.recalculatedValue | precision: 3 | default: '-' }}</span>\n </ng-template>\n <ng-container *ngIf=\"blankNode.allParallel; else defaultRecalculatedValue\">\n <div *ngFor=\"let model of blankNode.configModels[0]\">\n {{ blankNode.recalculatedValueByMethodId[model.methodId] | precision: 3 | default: '-' }}\n </div>\n </ng-container>\n </ng-container>\n </td>\n <td *ngIf=\"isBlankNodes\" class=\"is-nowrap\">\n <ng-template #defaultDeltaValue>\n <he-blank-node-value-delta\n *ngIf=\"blankNode.original.length && blankNode.isRecalculated; else noValue\"\n [value]=\"blankNode.recalculatedValue\"\n [originalValue]=\"blankNode.originalValue\"></he-blank-node-value-delta>\n </ng-template>\n <ng-container *ngIf=\"blankNode.allParallel; else defaultDeltaValue\">\n <div *ngFor=\"let model of blankNode.configModels[0]\">\n <he-blank-node-value-delta\n *ngIf=\"\n blankNode.originalValueByMethodId[model.methodId] !== null &&\n blankNode.recalculatedValueByMethodId[model.methodId] !== null;\n else noValue\n \"\n [value]=\"blankNode.recalculatedValueByMethodId[model.methodId]\"\n [originalValue]=\"blankNode.originalValueByMethodId[model.methodId]\"></he-blank-node-value-delta>\n </div>\n </ng-container>\n </td>\n <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: blankNode }\"></ng-container>\n </tr>\n\n <tr\n *ngFor=\"let subValue of blankNode.keys\"\n [class.is-hidden]=\"!blankNode.isOpen\"\n [class.has-sub-rows]=\"blankNode.subValues?.length\"\n [class.is-sub-row]=\"blankNode.canOpen\">\n <td class=\"width-auto has-border-right is-nowrap\">\n <span class=\"is-inline-block is-align-top pl-3 pr-1 field-node\">Field:</span>\n\n <a\n class=\"is-inline-block is-pre-wrap\"\n *ngIf=\"blankNode.type\"\n [href]=\"baseUrl + '/schema/' + blankNode.type + '#' + subValue.key\"\n target=\"_blank\"\n [title]=\"subValue.key\">\n <span>{{ subValue.key }}</span>\n </a>\n <span class=\"is-inline-block is-align-top\" *ngIf=\"!blankNode.type\">{{ subValue.key }}</span>\n </td>\n <td *ngIf=\"isBlankNodes\"></td>\n <td>\n <span *ngIf=\"subValue.originalValue !== null; else noValue\">\n {{ subValue.originalValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td>\n <span *ngIf=\"subValue.isRecalculated || subValue.key === 'impactAssessment'; else notRecalculated\">\n {{ subValue.recalculatedValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td *ngIf=\"isBlankNodes\">-</td>\n <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: subValue }\"></ng-container>\n </tr>\n\n <tr\n *ngFor=\"let subValue of blankNode.subValues\"\n [class.is-hidden]=\"!blankNode.isOpen\"\n [class.is-sub-row]=\"blankNode.canOpen\">\n <td class=\"width-auto has-border-right\">\n <span class=\"is-inline-block is-align-top pl-3\">{{ subValue.key | keyToLabel }}</span>\n\n <ng-container *ngIf=\"subValue.id\">\n <span class=\"is-inline-block\" class=\"is-inline-block is-align-top pr-1\">:</span>\n\n <ng-container [ngSwitch]=\"subValue.key\">\n <span class=\"is-inline-block\" *ngSwitchCase=\"'backgroundData'\">{{ subValue.id | keyToLabel }}</span>\n <he-node-link\n *ngSwitchDefault\n class=\"is-block pl-4\"\n [node]=\"termById(subValue.id)\"\n [attr.title]=\"termById(subValue.id).name\">\n <span [innerHtml]=\"termById(subValue.id).name | compound\"></span>\n </he-node-link>\n </ng-container>\n </ng-container>\n </td>\n <td *ngIf=\"isBlankNodes\">\n <span class=\"is-nowrap\" *ngIf=\"subValue.showUnits\" [innerHtml]=\"blankNode.term?.units | compound\"></span>\n </td>\n <td>\n <span *ngIf=\"subValue.originalValue !== null; else noValue\">\n {{ subValue.originalValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td>\n <span *ngIf=\"subValue.isRecalculated; else notRecalculated\">\n {{ subValue.recalculatedValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td *ngIf=\"isBlankNodes\">-</td>\n <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: subValue }\"></ng-container>\n </tr>\n </ng-container>\n </tbody>\n </table>\n </he-data-table>\n\n <div class=\"is-size-7 is-italic\">\n <div class=\"columns is-variable is-1 my-0\">\n <div class=\"column is-narrow\">\n <p>\n <a class=\"is-inline-block pr-2\" (click)=\"showLegend = !showLegend\">\n <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!showLegend\"></fa-icon>\n <fa-icon icon=\"angle-right\" [class.is-hidden]=\"showLegend\"></fa-icon>\n </a>\n <span class=\"is-inline-block\">Legend:</span>\n </p>\n <ul class=\"content pl-2\" [class.is-hidden]=\"!showLegend\">\n <ng-container *ngFor=\"let status of LogStatus | keys\">\n <li *ngIf=\"logIcon[status.value]\" class=\"has-text-{{ logColor[status.value] }}\">\n <fa-icon [icon]=\"logIcon[status.value]\"></fa-icon>\n <span class=\"pl-1\">{{ status.value }}</span>\n </li>\n </ng-container>\n </ul>\n </div>\n <div class=\"column has-text-right\" *ngIf=\"filteredType\">\n <label class=\"is-inline-block checkbox\">\n <input\n type=\"checkbox\"\n class=\"selector\"\n [(ngModel)]=\"onlyRequired\"\n (change)=\"filterResults()\"\n [disabled]=\"!!term\" />\n <span class=\"ml-2\">\n Show only {{ filteredType | pluralize }} included in the default Hestia system boundary\n </span>\n </label>\n </div>\n </div>\n </div>\n</div>\n\n<ng-template #blankNodeModels let-data=\"data\">\n <ng-template #notInSystemBoundary>\n <td [attr.colspan]=\"methodModelsCount\">\n <span>Not in Hestia system boundary</span>\n </td>\n </ng-template>\n\n <ng-container *ngIf=\"isSystemBoundary(data); else noValue\">\n <td class=\"blank-node-index-{{ i }}\" *ngFor=\"let c of methodModelsCount | times; let i = index\">\n <ng-container *ngIf=\"getModelsAt(data, i); let models; else: noValue\">\n <ng-template #modelSerie>\n <ng-container *ngTemplateOutlet=\"blankNodeModel; context: { model: models, data }\"></ng-container>\n </ng-template>\n <div *ngIf=\"models | isArray; else modelSerie\">\n <p *ngFor=\"let model of models\">\n <ng-container *ngTemplateOutlet=\"blankNodeModel; context: { model, data }\"></ng-container>\n </p>\n </div>\n </ng-container>\n </td>\n </ng-container>\n</ng-template>\n\n<ng-template #blankNodeModel let-model=\"model\" let-data=\"data\">\n <span\n class=\"is-nowrap\"\n [class.trigger-popover]=\"model.showLogs\"\n [ngbPopover]=\"logDetails\"\n [autoClose]=\"'outside'\"\n popoverClass=\"is-narrow\"\n triggers=\"manual\"\n #p=\"ngbPopover\"\n placement=\"left\"\n container=\"body\"\n (click)=\"p.isOpen() ? p.close() : model.showLogs ? p.open({ logs: model.logs }) : null\">\n <span class=\"is-capitalized\">{{ methodName(model) }}</span>\n <span class=\"pl-1\" *ngIf=\"model.logs?.methodTier || model.model?.methodTier\">\n [{{ model.logs?.methodTier || model.model?.methodTier }}]\n </span>\n\n <span\n class=\"pl-1 has-text-{{ logColor[model.status] }} trigger-popover\"\n [ngbPopover]=\"logStatusDetails\"\n [autoClose]=\"'outside'\"\n popoverClass=\"is-narrow\"\n triggers=\"manual\"\n #p1=\"ngbPopover\"\n placement=\"left\"\n container=\"body\"\n (click)=\"$event.stopPropagation(); p1.isOpen() ? p1.close() : p1.open({ model, data })\">\n <fa-icon [icon]=\"logIcon[model.status]\"></fa-icon>\n </span>\n\n <span class=\"pl-1\" *ngIf=\"model.model\">\n (\n <ng-container *ngTemplateOutlet=\"docsLink; context: { $implicit: model.model }\"></ng-container>\n )\n </span>\n </span>\n</ng-template>\n\n<ng-template #noValue>-</ng-template>\n\n<ng-template #notRecalculated>not recalculated</ng-template>\n\n<ng-template #logDetails let-logs=\"logs\">\n <div class=\"table-container\" *bindOnce=\"logs\">\n <table class=\"table is-dark is-fullwidth\">\n <tbody>\n <ng-container *ngIf=\"logs?.requirements\">\n <ng-container *ngFor=\"let key of requirementKeys(logs.requirements)\">\n <ng-container *ngTemplateOutlet=\"logLine; context: { key, value: logs.requirements[key] }\"></ng-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"logs?.logs\">\n <ng-container *ngFor=\"let key of logs.logs | keys\">\n <ng-container *ngTemplateOutlet=\"logLine; context: key\"></ng-container>\n </ng-container>\n </ng-container>\n </tbody>\n </table>\n </div>\n\n <ng-container *bindOnce=\"logs\">\n <div class=\"it-mt-2\" *ngIf=\"logs?.missingLookups?.length\">\n <p>Optional data missing:</p>\n\n <div class=\"table-container data-table-container\">\n <table class=\"table is-dark is-fullwidth is-striped\">\n <thead>\n <tr>\n <th class=\"has-text-white\">\n <span>Filename</span>\n </th>\n <th class=\"has-text-white\">\n <span>Column Title</span>\n </th>\n <th class=\"has-text-white\">\n <span>Row (term.id)</span>\n </th>\n </tr>\n </thead>\n <tbody class=\"has-text-white\">\n <tr *ngFor=\"let data of logs.missingLookups\">\n <td>{{ data.filename }}</td>\n <td>{{ data.column }}</td>\n <td>{{ data.termId }}</td>\n </tr>\n </tbody>\n </table>\n </div>\n </div>\n </ng-container>\n</ng-template>\n\n<ng-template #logLineValue let-key=\"key\" let-value=\"value\">\n <ng-template #defaultValue>\n <span class=\"is-inline-block is-align-middle\">{{ value }}</span>\n </ng-template>\n <ng-container *ngIf=\"requirementLinkedNode(key, value); let linkedNode; else: defaultValue\">\n <he-node-link\n class=\"is-inline-block is-align-middle\"\n linkClass=\"is-dark\"\n [node]=\"linkedNode\"\n [showExternalLink]=\"true\"></he-node-link>\n </ng-container>\n</ng-template>\n\n<ng-template #logLine let-key=\"key\" let-value=\"value\">\n <tr>\n <td class=\"has-border-right copy-log\">\n <span class=\"is-inline-block is-align-middle\" [ngSwitch]=\"key\">\n <ng-container *ngSwitchDefault>{{ key | keyToLabel }}</ng-container>\n\n <ng-container *ngSwitchCase=\"'node_type_allowed'\">\n Is the current\n <code>Node</code>\n allowed to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'siteType_allowed'\">\n Is the current\n <code>siteType</code>\n allowed to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'primary_product_id_allowed'\">\n Is the current primary product\n <code>@id</code>\n allowed to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'primary_product_termType_allowed'\">\n Is the current primary product\n <code>termType</code>\n allowed to run this model\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'geospatial_data'\">Has geospatial data necessary to run this model</ng-container>\n <ng-container *ngSwitchCase=\"'contains_geospatial_data'\">\n Has geospatial data necessary to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'current_size'\">Current polygon area</ng-container>\n <ng-container *ngSwitchCase=\"'max_area_size'\">Maximum polygon area to run this model</ng-container>\n <ng-container *ngSwitchCase=\"'below_max_area_size'\">Polygon below the maximum area</ng-container>\n <ng-container *ngSwitchCase=\"'region_factor'\">Factor from region lookup</ng-container>\n\n <ng-container *ngSwitchCase=\"'pesticides_complete'\">\n Pesticide data are\n <code>complete</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'has_pesticides_inputs'\">\n Cycle contains\n <code>pesticideAI</code>\n Inputs\n </ng-container>\n <ng-container *ngSwitchCase=\"'all_pesticideAI_have_lookup_value'\">\n All\n <code>pesticideAI</code>\n Inputs have a lookup value\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'has_crop_residue_burnt'\">\n <code>aboveGroundCropResidueBurnt</code>\n is present as Product\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'liquid_slurry_sludge_P'\">Liquid, Slurry, and Sludge P</ng-container>\n\n <ng-container *ngSwitchCase=\"'term_type_cropResidue_complete'\">\n Data completeness for \"cropResidue\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_excreta_complete'\">\n Data completeness for \"excreta\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_fertiliser_complete'\">\n Data completeness for \"fertiliser\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_material_complete'\">\n Data completeness for \"material\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_other_complete'\">\n Data completeness for \"other\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_pesticidesAntibiotics_complete'\">\n Data completeness for \"pesticidesAntibiotics\" must be\n <code>true</code>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'term_type_cropResidue_incomplete'\">\n Data completeness for \"cropResidue\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_excreta_incomplete'\">\n Data completeness for \"excreta\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_fertiliser_incomplete'\">\n Data completeness for \"fertiliser\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_material_incomplete'\">\n Data completeness for \"material\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_other_incomplete'\">\n Data completeness for \"other\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_pesticidesAntibiotics_incomplete'\">\n Data completeness for \"pesticidesAntibiotics\" must be\n <code>false</code>\n </ng-container>\n </span>\n <he-clipboard\n class=\"is-inline-block is-align-middle\"\n clipboardClass=\"is-size-7 is-p-1\"\n [icon]=\"['far', 'clone']\"\n [value]=\"key\"\n [hideText]=\"true\"></he-clipboard>\n </td>\n <td>\n <ng-template #singleValue>\n <ng-container *ngTemplateOutlet=\"logLineValue; context: { key, value }\"></ng-container>\n </ng-template>\n <div *ngIf=\"logValueArray(value); let valueArray; else: singleValue\">\n <table class=\"table is-dark is-bordered is-striped\">\n <thead *ngIf=\"valueArray[0] | isObject\">\n <tr>\n <th class=\"has-text-white\" *ngFor=\"let v of valueArray[0] | keys\">{{ v.key }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let v of valueArray\">\n <ng-template #singleArrayValue>\n <td>{{ v }}</td>\n </ng-template>\n <ng-container *ngIf=\"v | isObject; else singleArrayValue\">\n <td *ngFor=\"let vv of v | keys\">{{ vv.value }}</td>\n </ng-container>\n </tr>\n </tbody>\n </table>\n </div>\n </td>\n </tr>\n</ng-template>\n\n<ng-template #logStatusDetails let-model=\"model\" let-data=\"data\">\n <ng-container *bindOnce=\"model\">\n <div class=\"is-mb-2\">\n <span>Status:</span>\n <span class=\"is-pl-1\">{{ model.status }}</span>\n </div>\n\n <ng-container *ngIf=\"model.status === LogStatus.notRequired && model.logs?.is_not_relevant === 'True'\">\n <ul class=\"is-pl-3 is-list-style-disc\">\n <li *ngIf=\"model.logs.logs?.siteType_allowed === 'False'\">\n The\n <code>siteType</code>\n is not relevant.\n </li>\n <li *ngIf=\"model.logs.logs?.product_id_allowed === 'False'\">\n The primary product\n <code>@id</code>\n is not relevant.\n </li>\n <li *ngIf=\"model.logs.logs?.product_termType_allowed === 'False'\">\n The primary product\n <code>termType</code>\n is not relevant.\n </li>\n </ul>\n </ng-container>\n\n <ng-container\n *ngIf=\"model.logs && model.status !== LogStatus.notRequired && model.status !== LogStatus.skipHierarchy\">\n <ul class=\"is-pl-3 is-list-style-disc\">\n <ng-template #showRunOrchestrator>\n <li class=\"is-run-orchestrator\">\n <p *ngIf=\"model.logs?.shouldRun\">All the requirements were met to run the model.</p>\n <ng-container *ngIf=\"!model.logs?.shouldRun\">\n <p>Some of the requirements were not met to run the model.</p>\n <p>You can click on the model name on the left to view the debugging logs.</p>\n </ng-container>\n <ng-container *ngIf=\"model.logs?.logs?.error\">\n <p>The model failed to run for the following reason:</p>\n <p>\n <code>{{ model.logs.logs.error }}</code>\n </p>\n </ng-container>\n </li>\n </ng-template>\n\n <li\n class=\"is-no-run-orchestrator\"\n *ngIf=\"model.logs?.shouldRunOrchestrator === false; else showRunOrchestrator\">\n <ng-container *ngIf=\"!model.logs.runRequired\">\n <span class=\"is-run-node-type-not-allowed\" *ngIf=\"model.logs.logs?.node_type_allowed === 'False'\">\n This model should not run for {{ nodeType | pluralize: 0 }}\n </span>\n </ng-container>\n\n <ng-template #runNoConfig>\n <span class=\"is-run-not-empty\" *ngIf=\"model.logs.logs?.is_empty === 'False'\">\n The {{ data.type || 'blank node' }} with Term\n <code>{{ data.termId }}</code>\n is already present or already added by another model.\n </span>\n </ng-template>\n\n <ng-container *ngIf=\"model.config; else runNoConfig\">\n <p class=\"is-run-strategy-{{ model.config.runStrategy }}\" [ngSwitch]=\"model.config.runStrategy\">\n <span *ngSwitchCase=\"'always'\"></span>\n <span *ngSwitchCase=\"'add_key_if_missing'\">We only gap-fill this key if not present</span>\n <span *ngSwitchCase=\"'add_blank_node_if_missing'\">We only gap-fill this Blank Node if not present.</span>\n </p>\n\n <p class=\"is-mt-1\">\n <span\n class=\"is-run-with-measured\"\n *ngIf=\"\n model.config.runArgs?.runNonMeasured && hasMethodTier(data.original, EmissionMethodTier.measured)\n \">\n The\n <code>{{ model.config.value }}</code>\n was reported as measured.\n </span>\n </p>\n </ng-container>\n </li>\n\n <li *ngIf=\"model.logs?.replaceLowerTier !== undefined\">\n <span>\n The recalculated\n <b>methodTier</b>\n was\n </span>\n <span class=\"is-pl-1 is-underlined\" *ngIf=\"!model.logs.replaceLowerTier\">lower than</span>\n <span class=\"is-pl-1 is-underlined\" *ngIf=\"model.logs.replaceLowerTier\">higher than or equal to</span>\n <span class=\"is-pl-1\">\n the original\n <b>methodTier</b>\n .\n </span>\n </li>\n\n <li class=\"is-merge-replaceLowerTier\" *ngIf=\"model.logs.replaceLowerTier\">\n <span>The recalculated</span>\n <b class=\"is-pl-1\">{{ model.config?.mergeArgs?.replaceThreshold?.[0] || 'value' }}</b>\n <span class=\"is-pl-1\">was</span>\n <span class=\"is-pl-1\">\n <ng-container *ngIf=\"model.config?.mergeArgs\">\n <span class=\"is-underlined\" *ngIf=\"!model.logs.replaceThreshold\">less than</span>\n <span class=\"is-underlined\" *ngIf=\"model.logs.replaceThreshold\">more than or equal to</span>\n <b class=\"is-pl-1\">{{ model.config.mergeArgs.replaceThreshold[1] * 100 }}%</b>\n </ng-container>\n <ng-container *ngIf=\"!model.config?.mergeArgs\">\n <span class=\"is-underlined\" *ngIf=\"!model.logs.replaceThreshold\">not sufficiently</span>\n <span class=\"is-underlined\" *ngIf=\"model.logs.replaceThreshold\">sufficiently</span>\n </ng-container>\n </span>\n <span class=\"is-pl-1\">different from the original</span>\n <b class=\"is-pl-1\">{{ model.config?.mergeArgs?.replaceThreshold?.[0] || 'value' }}.</b>\n </li>\n </ul>\n </ng-container>\n </ng-container>\n</ng-template>\n\n<ng-template #docsLink let-model>\n <a [href]=\"model.apiDocsPath || model.docPath || model.path\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\n <span>Docs</span>\n <fa-icon class=\"ml-1\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n </a>\n</ng-template>\n", styles: [":host{display:block}::ng-deep .table{background-color:transparent}::ng-deep .table td he-node-link{width:190px}@media screen and (max-width: 768px){::ng-deep .table td he-node-link{width:150px}}::ng-deep .table td .open-node+he-node-link{width:170px}@media screen and (max-width: 768px){::ng-deep .table td .open-node+he-node-link{width:130px}}::ng-deep .table td.has-border-right{box-shadow:1px 0 #6c8093}::ng-deep .table .has-sub-rows.is-open>td:first-child:before,::ng-deep .table .is-sub-row>td:first-child:before{display:block;position:absolute;content:\" \";background-color:#6c809333;height:100%;width:1px;top:0;left:12px}::ng-deep .table .has-sub-rows.is-open>td:first-child:before{top:25px}::ng-deep .table .popover-body .table-container{max-height:260px;overflow-y:auto}::ng-deep .copy-log he-clipboard{visibility:hidden}::ng-deep .copy-log:hover he-clipboard{visibility:visible}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i4.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i6.NgbTypeahead, selector: "input[ngbTypeahead]", inputs: ["autocomplete", "container", "editable", "focusFirst", "inputFormatter", "ngbTypeahead", "resultFormatter", "resultTemplate", "selectOnExact", "showHint", "placement", "popperOptions", "popupClass"], outputs: ["selectItem"], exportAs: ["ngbTypeahead"] }, { kind: "directive", type: i6.NgbPopover, selector: "[ngbPopover]", inputs: ["animation", "autoClose", "ngbPopover", "popoverTitle", "placement", "popperOptions", "triggers", "positionTarget", "container", "disablePopover", "popoverClass", "popoverContext", "openDelay", "closeDelay"], outputs: ["shown", "hidden"], exportAs: ["ngbPopover"] }, { kind: "component", type: i7.FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "classes", "transform", "a11yRole"] }, { kind: "directive", type: i8.BindOnceDirective, selector: "[bindOnce]", inputs: ["bindOnce"] }, { kind: "component", type: i9.BlankNodeValueDeltaComponent, selector: "he-blank-node-value-delta", inputs: ["value", "originalValue", "displayType"] }, { kind: "component", type: i10.ClipboardComponent, selector: "he-clipboard", inputs: ["value", "disabled", "hideText", "icon", "size", "rotate", "clipboardClass"] }, { kind: "component", type: i11.DataTableComponent, selector: "he-data-table", inputs: ["minHeight", "maxHeight", "small"] }, { kind: "component", type: i12.NodeLinkComponent, selector: "he-node-link", inputs: ["node", "showExternalLink", "linkClass"] }, { kind: "pipe", type: i13.CompoundPipe, name: "compound" }, { kind: "pipe", type: i14.DefaultPipe, name: "default" }, { kind: "pipe", type: i15.KeysPipe, name: "keys" }, { kind: "pipe", type: i16.PluralizePipe, name: "pluralize" }, { kind: "pipe", type: i17.KeyToLabelPipe, name: "keyToLabel" }, { kind: "pipe", type: i18.PrecisionPipe, name: "precision" }, { kind: "pipe", type: i19.TimesPipe, name: "times" }, { kind: "pipe", type: i20.IsArrayPipe, name: "isArray" }, { kind: "pipe", type: i21.IsObjectPipe, name: "isObject" }] }); }
242
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.8", type: NodeLogsModelsComponent, selector: "he-node-logs-models", inputs: { node: "node", nodeKey: "nodeKey", originalValues: "originalValues", recalculatedValues: "recalculatedValues", terms: "terms", filterTermTypes: "filterTermTypes", filterTermTypesLabel: "filterTermTypesLabel", logsKey: "logsKey" }, ngImport: i0, template: "<div class=\"px-3 pb-3\">\n <div class=\"has-text-right mb-2\" *ngIf=\"!isExternal\">\n <a class=\"is-size-7\" *ngIf=\"logsUrl\" [href]=\"logsUrl\" target=\"_blank\">\n <fa-icon icon=\"external-link-alt\"></fa-icon>\n <span class=\"pl-2\">Open Full Logs</span>\n </a>\n </div>\n\n <he-data-table class=\"mb-1 is-small\" [small]=\"true\" maxHeight=\"320\">\n <table class=\"table is-fullwidth is-narrow is-striped\">\n <thead>\n <tr>\n <th class=\"width-auto has-border-right\">\n <div class=\"field\" *ngIf=\"allTerms?.length\">\n <div class=\"control is-expanded has-icons-right\">\n <input\n class=\"input search-input is-small\"\n [(ngModel)]=\"term\"\n name=\"term\"\n placeholder=\"Select entry by name\"\n [ngbTypeahead]=\"suggestTerm\"\n [focusFirst]=\"true\"\n (focus)=\"typeaheadFocus($event)\"\n (selectItem)=\"filterResults()\" />\n <a class=\"icon is-small is-right\" [class.is-hidden]=\"!term\" (click)=\"term = ''; filterResults()\">\n <fa-icon icon=\"times\"></fa-icon>\n </a>\n </div>\n </div>\n </th>\n <th *ngIf=\"isBlankNodes\">\n <span class=\"is-pr-1\">Units</span>\n <span>(per&nbsp;</span>\n <span [ngSwitch]=\"functionalUnit\">\n <ng-container *ngSwitchCase=\"CycleFunctionalUnit['1 ha']\">hectare</ng-container>\n <ng-container *ngSwitchDefault>kg product</ng-container>\n </span>\n <span>)</span>\n </th>\n <th>Original</th>\n <th>Recalculated</th>\n <th *ngIf=\"isBlankNodes\">Difference</th>\n <th *ngFor=\"let c of methodModelsCount | times; let i = index\">({{ i + 1 }})</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngIf=\"loading\">\n <td class=\"has-text-centered\" colspan=\"6\">\n <div class=\"has-text-center py-3\">\n <fa-icon icon=\"spinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n </div>\n </td>\n </tr>\n <tr *ngIf=\"!loading && blankNodes.length === 0\">\n <td class=\"has-text-centered\" colspan=\"6\">\n <span>No data</span>\n </td>\n </tr>\n <ng-container *ngFor=\"let blankNode of blankNodes; trackBy: trackByBlankNode\">\n <tr [class.has-sub-rows]=\"blankNode.canOpen\" [class.is-open]=\"blankNode.isOpen\">\n <td class=\"width-auto has-border-right is-nowrap\" [attr.title]=\"blankNode.term?.name || blankNode.key\">\n <a\n class=\"is-inline-block is-align-top pr-2 open-node\"\n (click)=\"blankNode.isOpen = !blankNode.isOpen\"\n *ngIf=\"blankNode.canOpen\">\n <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!blankNode.isOpen\"></fa-icon>\n <fa-icon icon=\"angle-right\" [class.is-hidden]=\"blankNode.isOpen\"></fa-icon>\n </a>\n <he-node-link class=\"is-inline-block is-pre-wrap\" *ngIf=\"blankNode.term\" [node]=\"blankNode.term\">\n <span [innerHtml]=\"blankNode.term.name | compound\"></span>\n </he-node-link>\n <span *ngIf=\"blankNode.key\">{{ blankNode.key }}</span>\n </td>\n <td *ngIf=\"isBlankNodes\">\n <span class=\"is-nowrap\" [innerHtml]=\"blankNode.term?.units | compound\"></span>\n </td>\n <td>\n <ng-template #defaultOriginalValue>\n <span>{{ blankNode.originalValue | precision: 3 | default: '-' }}</span>\n </ng-template>\n <ng-container *ngIf=\"blankNode.allParallel; else defaultOriginalValue\">\n <div *ngFor=\"let model of blankNode.configModels[0]\">\n {{ blankNode.originalValueByMethodId[model.methodId] | precision: 3 | default: '-' }}\n </div>\n </ng-container>\n </td>\n <td>\n <ng-container *ngIf=\"!blankNode.isOriginal || blankNode.isRecalculated; else notRecalculated\">\n <ng-template #defaultRecalculatedValue>\n <span>{{ blankNode.recalculatedValue | precision: 3 | default: '-' }}</span>\n </ng-template>\n <ng-container *ngIf=\"blankNode.allParallel; else defaultRecalculatedValue\">\n <div *ngFor=\"let model of blankNode.configModels[0]\">\n {{ blankNode.recalculatedValueByMethodId[model.methodId] | precision: 3 | default: '-' }}\n </div>\n </ng-container>\n </ng-container>\n </td>\n <td *ngIf=\"isBlankNodes\" class=\"is-nowrap\">\n <ng-template #defaultDeltaValue>\n <he-blank-node-value-delta\n *ngIf=\"blankNode.original.length && blankNode.isRecalculated; else noValue\"\n [value]=\"blankNode.recalculatedValue\"\n [originalValue]=\"blankNode.originalValue\"></he-blank-node-value-delta>\n </ng-template>\n <ng-container *ngIf=\"blankNode.allParallel; else defaultDeltaValue\">\n <div *ngFor=\"let model of blankNode.configModels[0]\">\n <he-blank-node-value-delta\n *ngIf=\"\n blankNode.originalValueByMethodId[model.methodId] !== null &&\n blankNode.recalculatedValueByMethodId[model.methodId] !== null;\n else noValue\n \"\n [value]=\"blankNode.recalculatedValueByMethodId[model.methodId]\"\n [originalValue]=\"blankNode.originalValueByMethodId[model.methodId]\"></he-blank-node-value-delta>\n </div>\n </ng-container>\n </td>\n <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: blankNode }\"></ng-container>\n </tr>\n\n <tr\n *ngFor=\"let subValue of blankNode.keys\"\n [class.is-hidden]=\"!blankNode.isOpen\"\n [class.has-sub-rows]=\"blankNode.subValues?.length\"\n [class.is-sub-row]=\"blankNode.canOpen\">\n <td class=\"width-auto has-border-right is-nowrap\">\n <span class=\"is-inline-block is-align-top pl-3 pr-1 field-node\">Field:</span>\n\n <a\n class=\"is-inline-block is-pre-wrap\"\n *ngIf=\"blankNode.type\"\n [href]=\"baseUrl + '/schema/' + blankNode.type + '#' + subValue.key\"\n target=\"_blank\"\n [title]=\"subValue.key\">\n <span>{{ subValue.key }}</span>\n </a>\n <span class=\"is-inline-block is-align-top\" *ngIf=\"!blankNode.type\">{{ subValue.key }}</span>\n </td>\n <td *ngIf=\"isBlankNodes\"></td>\n <td>\n <span *ngIf=\"subValue.originalValue !== null; else noValue\">\n {{ subValue.originalValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td>\n <span *ngIf=\"subValue.isRecalculated || subValue.key === 'impactAssessment'; else notRecalculated\">\n {{ subValue.recalculatedValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td *ngIf=\"isBlankNodes\">-</td>\n <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: subValue }\"></ng-container>\n </tr>\n\n <tr\n *ngFor=\"let subValue of blankNode.subValues\"\n [class.is-hidden]=\"!blankNode.isOpen\"\n [class.is-sub-row]=\"blankNode.canOpen\">\n <td class=\"width-auto has-border-right\">\n <span class=\"is-inline-block is-align-top pl-3\">{{ subValue.key | keyToLabel }}</span>\n\n <ng-container *ngIf=\"subValue.id\">\n <span class=\"is-inline-block\" class=\"is-inline-block is-align-top pr-1\">:</span>\n\n <ng-container [ngSwitch]=\"subValue.key\">\n <span class=\"is-inline-block\" *ngSwitchCase=\"'backgroundData'\">{{ subValue.id | keyToLabel }}</span>\n <he-node-link\n *ngSwitchDefault\n class=\"is-block pl-4\"\n [node]=\"termById(subValue.id)\"\n [attr.title]=\"termById(subValue.id).name\">\n <span [innerHtml]=\"termById(subValue.id).name | compound\"></span>\n </he-node-link>\n </ng-container>\n </ng-container>\n </td>\n <td *ngIf=\"isBlankNodes\">\n <span class=\"is-nowrap\" *ngIf=\"subValue.showUnits\" [innerHtml]=\"blankNode.term?.units | compound\"></span>\n </td>\n <td>\n <span *ngIf=\"subValue.originalValue !== null; else noValue\">\n {{ subValue.originalValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td>\n <span *ngIf=\"subValue.isRecalculated; else notRecalculated\">\n {{ subValue.recalculatedValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td *ngIf=\"isBlankNodes\">-</td>\n <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: subValue }\"></ng-container>\n </tr>\n </ng-container>\n </tbody>\n </table>\n </he-data-table>\n\n <div class=\"is-size-7 is-italic\">\n <div class=\"columns is-variable is-1 my-0\">\n <div class=\"column is-narrow\">\n <p>\n <a class=\"is-inline-block pr-2\" (click)=\"showLegend = !showLegend\">\n <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!showLegend\"></fa-icon>\n <fa-icon icon=\"angle-right\" [class.is-hidden]=\"showLegend\"></fa-icon>\n </a>\n <span class=\"is-inline-block\">Legend:</span>\n </p>\n <ul class=\"content pl-2\" [class.is-hidden]=\"!showLegend\">\n <ng-container *ngFor=\"let status of LogStatus | keys\">\n <li *ngIf=\"logIcon[status.value]\" class=\"has-text-{{ logColor[status.value] }}\">\n <fa-icon [icon]=\"logIcon[status.value]\"></fa-icon>\n <span class=\"pl-1\">{{ status.value }}</span>\n </li>\n </ng-container>\n </ul>\n </div>\n <div class=\"column has-text-right\" *ngIf=\"filteredType\">\n <label class=\"is-inline-block checkbox\">\n <input\n type=\"checkbox\"\n class=\"selector\"\n [(ngModel)]=\"onlyRequired\"\n (change)=\"filterResults()\"\n [disabled]=\"!!term\" />\n <span class=\"ml-2\">\n Show only {{ filteredType | pluralize }} included in the default Hestia system boundary\n </span>\n </label>\n </div>\n </div>\n </div>\n</div>\n\n<ng-template #blankNodeModels let-data=\"data\">\n <ng-template #notInSystemBoundary>\n <td [attr.colspan]=\"methodModelsCount\">\n <span>Not in Hestia system boundary</span>\n </td>\n </ng-template>\n\n <ng-container *ngIf=\"isSystemBoundary(data); else noValue\">\n <td class=\"blank-node-index-{{ i }}\" *ngFor=\"let c of methodModelsCount | times; let i = index\">\n <ng-container *ngIf=\"getModelsAt(data, i); let models; else: noValue\">\n <ng-template #modelSerie>\n <ng-container *ngTemplateOutlet=\"blankNodeModel; context: { model: models, data }\"></ng-container>\n </ng-template>\n <div *ngIf=\"models | isArray; else modelSerie\">\n <p *ngFor=\"let model of models\">\n <ng-container *ngTemplateOutlet=\"blankNodeModel; context: { model, data }\"></ng-container>\n </p>\n </div>\n </ng-container>\n </td>\n </ng-container>\n</ng-template>\n\n<ng-template #blankNodeModel let-model=\"model\" let-data=\"data\">\n <span\n class=\"is-nowrap\"\n [class.trigger-popover]=\"model.showLogs\"\n [ngbPopover]=\"logDetails\"\n [autoClose]=\"'outside'\"\n popoverClass=\"is-narrow\"\n triggers=\"manual\"\n #p=\"ngbPopover\"\n placement=\"left\"\n container=\"body\"\n (click)=\"p.isOpen() ? p.close() : model.showLogs ? p.open({ logs: model.logs }) : null\">\n <span class=\"is-capitalized\">{{ methodName(model) }}</span>\n <span class=\"pl-1\" *ngIf=\"model.logs?.methodTier || model.model?.methodTier\">\n [{{ model.logs?.methodTier || model.model?.methodTier }}]\n </span>\n\n <span\n class=\"pl-1 has-text-{{ logColor[model.status] }} trigger-popover\"\n [ngbPopover]=\"logStatusDetails\"\n [autoClose]=\"'outside'\"\n popoverClass=\"is-narrow\"\n triggers=\"manual\"\n #p1=\"ngbPopover\"\n placement=\"left\"\n container=\"body\"\n (click)=\"$event.stopPropagation(); p1.isOpen() ? p1.close() : p1.open({ model, data })\">\n <fa-icon [icon]=\"logIcon[model.status]\"></fa-icon>\n </span>\n\n <span class=\"pl-1\" *ngIf=\"model.model\">\n (\n <ng-container *ngTemplateOutlet=\"docsLink; context: { $implicit: model.model }\"></ng-container>\n )\n </span>\n </span>\n</ng-template>\n\n<ng-template #noValue>-</ng-template>\n\n<ng-template #notRecalculated>not recalculated</ng-template>\n\n<ng-template #logDetails let-logs=\"logs\">\n <div class=\"table-container\" *bindOnce=\"logs\">\n <table class=\"table is-dark is-fullwidth\">\n <tbody>\n <ng-container *ngIf=\"logs?.requirements\">\n <ng-container *ngFor=\"let key of requirementKeys(logs.requirements)\">\n <ng-container *ngTemplateOutlet=\"logLine; context: { key, value: logs.requirements[key] }\"></ng-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"logs?.logs\">\n <ng-container *ngFor=\"let key of logs.logs | keys\">\n <ng-container *ngTemplateOutlet=\"logLine; context: key\"></ng-container>\n </ng-container>\n </ng-container>\n </tbody>\n </table>\n </div>\n\n <ng-container *bindOnce=\"logs\">\n <div class=\"it-mt-2\" *ngIf=\"logs?.missingLookups?.length\">\n <p>Optional data missing:</p>\n\n <div class=\"table-container data-table-container\">\n <table class=\"table is-dark is-fullwidth is-striped\">\n <thead>\n <tr>\n <th class=\"has-text-white\">\n <span>Filename</span>\n </th>\n <th class=\"has-text-white\">\n <span>Column Title</span>\n </th>\n <th class=\"has-text-white\">\n <span>Row (term.id)</span>\n </th>\n </tr>\n </thead>\n <tbody class=\"has-text-white\">\n <tr *ngFor=\"let data of logs.missingLookups\">\n <td>{{ data.filename }}</td>\n <td>{{ data.column }}</td>\n <td>{{ data.termId }}</td>\n </tr>\n </tbody>\n </table>\n </div>\n </div>\n </ng-container>\n</ng-template>\n\n<ng-template #logLineValue let-key=\"key\" let-value=\"value\">\n <ng-template #defaultValue>\n <span class=\"is-inline-block is-align-middle\">{{ value }}</span>\n </ng-template>\n <ng-container *ngIf=\"requirementLinkedNode(key, value); let linkedNode; else: defaultValue\">\n <he-node-link\n class=\"is-inline-block is-align-middle\"\n linkClass=\"is-dark\"\n [node]=\"linkedNode\"\n [showExternalLink]=\"true\"></he-node-link>\n </ng-container>\n</ng-template>\n\n<ng-template #logLine let-key=\"key\" let-value=\"value\">\n <tr>\n <td class=\"has-border-right copy-log\">\n <span class=\"is-inline-block is-align-middle\" [ngSwitch]=\"key\">\n <ng-container *ngSwitchDefault>{{ key | keyToLabel }}</ng-container>\n\n <ng-container *ngSwitchCase=\"'node_type_allowed'\">\n Is the current\n <code>Node</code>\n allowed to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'siteType_allowed'\">\n Is the current\n <code>siteType</code>\n allowed to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'primary_product_id_allowed'\">\n Is the current primary product\n <code>@id</code>\n allowed to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'primary_product_termType_allowed'\">\n Is the current primary product\n <code>termType</code>\n allowed to run this model\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'geospatial_data'\">Has geospatial data necessary to run this model</ng-container>\n <ng-container *ngSwitchCase=\"'contains_geospatial_data'\">\n Has geospatial data necessary to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'current_size'\">Current polygon area</ng-container>\n <ng-container *ngSwitchCase=\"'max_area_size'\">Maximum polygon area to run this model</ng-container>\n <ng-container *ngSwitchCase=\"'below_max_area_size'\">Polygon below the maximum area</ng-container>\n <ng-container *ngSwitchCase=\"'region_factor'\">Factor from region lookup</ng-container>\n\n <ng-container *ngSwitchCase=\"'pesticides_complete'\">\n Pesticide data are\n <code>complete</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'has_pesticides_inputs'\">\n Cycle contains\n <code>pesticideAI</code>\n Inputs\n </ng-container>\n <ng-container *ngSwitchCase=\"'all_pesticideAI_have_lookup_value'\">\n All\n <code>pesticideAI</code>\n Inputs have a lookup value\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'has_crop_residue_burnt'\">\n <code>aboveGroundCropResidueBurnt</code>\n is present as Product\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'liquid_slurry_sludge_P'\">Liquid, Slurry, and Sludge P</ng-container>\n\n <ng-container *ngSwitchCase=\"'term_type_cropResidue_complete'\">\n Data completeness for \"cropResidue\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_excreta_complete'\">\n Data completeness for \"excreta\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_fertiliser_complete'\">\n Data completeness for \"fertiliser\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_material_complete'\">\n Data completeness for \"material\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_other_complete'\">\n Data completeness for \"other\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_pesticidesAntibiotics_complete'\">\n Data completeness for \"pesticidesAntibiotics\" must be\n <code>true</code>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'term_type_cropResidue_incomplete'\">\n Data completeness for \"cropResidue\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_excreta_incomplete'\">\n Data completeness for \"excreta\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_fertiliser_incomplete'\">\n Data completeness for \"fertiliser\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_material_incomplete'\">\n Data completeness for \"material\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_other_incomplete'\">\n Data completeness for \"other\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_pesticidesAntibiotics_incomplete'\">\n Data completeness for \"pesticidesAntibiotics\" must be\n <code>false</code>\n </ng-container>\n </span>\n <he-clipboard\n class=\"is-inline-block is-align-middle\"\n clipboardClass=\"is-size-7 is-p-1\"\n [icon]=\"['far', 'clone']\"\n [value]=\"key\"\n [hideText]=\"true\"></he-clipboard>\n </td>\n <td>\n <ng-template #singleValue>\n <ng-container *ngTemplateOutlet=\"logLineValue; context: { key, value }\"></ng-container>\n </ng-template>\n <div *ngIf=\"logValueArray(value); let valueArray; else: singleValue\">\n <table class=\"table is-dark is-bordered is-striped\">\n <thead *ngIf=\"valueArray[0] | isObject\">\n <tr>\n <th class=\"has-text-white\" *ngFor=\"let v of valueArray[0] | keys\">{{ v.key }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let v of valueArray\">\n <ng-template #singleArrayValue>\n <td>{{ v }}</td>\n </ng-template>\n <ng-container *ngIf=\"v | isObject; else singleArrayValue\">\n <td *ngFor=\"let vv of v | keys\">{{ vv.value }}</td>\n </ng-container>\n </tr>\n </tbody>\n </table>\n </div>\n </td>\n </tr>\n</ng-template>\n\n<ng-template #logStatusDetails let-model=\"model\" let-data=\"data\">\n <ng-container *bindOnce=\"model\">\n <div class=\"is-mb-2\">\n <span>Status:</span>\n <span class=\"is-pl-1\">{{ model.status }}</span>\n </div>\n\n <ng-container *ngIf=\"model.status === LogStatus.notRequired && model.logs?.is_not_relevant === 'True'\">\n <ul class=\"is-pl-3 is-list-style-disc\">\n <li *ngIf=\"model.logs.logs?.siteType_allowed === 'False'\">\n The\n <code>siteType</code>\n is not relevant.\n </li>\n <li *ngIf=\"model.logs.logs?.product_id_allowed === 'False'\">\n The primary product\n <code>@id</code>\n is not relevant.\n </li>\n <li *ngIf=\"model.logs.logs?.product_termType_allowed === 'False'\">\n The primary product\n <code>termType</code>\n is not relevant.\n </li>\n </ul>\n </ng-container>\n\n <ng-container\n *ngIf=\"model.logs && model.status !== LogStatus.notRequired && model.status !== LogStatus.skipHierarchy\">\n <ul class=\"is-pl-3 is-list-style-disc\">\n <ng-template #showRunOrchestrator>\n <li class=\"is-run-orchestrator\">\n <p *ngIf=\"model.logs?.shouldRun\">All the requirements were met to run the model.</p>\n <ng-container *ngIf=\"!model.logs?.shouldRun\">\n <p>Some of the requirements were not met to run the model.</p>\n <p>You can click on the model name on the left to view the debugging logs.</p>\n </ng-container>\n <ng-container *ngIf=\"model.logs?.logs?.error\">\n <p>The model failed to run for the following reason:</p>\n <p>\n <code>{{ model.logs.logs.error }}</code>\n </p>\n </ng-container>\n </li>\n </ng-template>\n\n <li\n class=\"is-no-run-orchestrator\"\n *ngIf=\"model.logs?.shouldRunOrchestrator === false; else showRunOrchestrator\">\n <ng-container *ngIf=\"!model.logs.runRequired\">\n <span class=\"is-run-node-type-not-allowed\" *ngIf=\"model.logs.logs?.node_type_allowed === 'False'\">\n This model should not run for {{ nodeType | pluralize: 0 }}\n </span>\n </ng-container>\n\n <ng-template #runNoConfig>\n <span class=\"is-run-not-empty\" *ngIf=\"model.logs.logs?.is_empty === 'False'\">\n The {{ data.type || 'blank node' }} with Term\n <code>{{ data.termId }}</code>\n is already present or already added by another model.\n </span>\n </ng-template>\n\n <ng-container *ngIf=\"model.config; else runNoConfig\">\n <p class=\"is-run-strategy-{{ model.config.runStrategy }}\" [ngSwitch]=\"model.config.runStrategy\">\n <span *ngSwitchCase=\"'always'\"></span>\n <span *ngSwitchCase=\"'add_key_if_missing'\">We only gap-fill this key if not present</span>\n <span *ngSwitchCase=\"'add_blank_node_if_missing'\">We only gap-fill this Blank Node if not present.</span>\n </p>\n\n <p class=\"is-mt-1\">\n <span\n class=\"is-run-with-measured\"\n *ngIf=\"\n model.config.runArgs?.runNonMeasured && hasMethodTier(data.original, EmissionMethodTier.measured)\n \">\n The\n <code>{{ model.config.value }}</code>\n was reported as measured.\n </span>\n </p>\n </ng-container>\n </li>\n\n <li *ngIf=\"model.logs?.replaceLowerTier !== undefined\">\n <span>\n The recalculated\n <b>methodTier</b>\n was\n </span>\n <span class=\"is-pl-1 is-underlined\" *ngIf=\"!model.logs.replaceLowerTier\">lower than</span>\n <span class=\"is-pl-1 is-underlined\" *ngIf=\"model.logs.replaceLowerTier\">higher than or equal to</span>\n <span class=\"is-pl-1\">\n the original\n <b>methodTier</b>\n .\n </span>\n </li>\n\n <li class=\"is-merge-replaceLowerTier\" *ngIf=\"model.logs.replaceLowerTier\">\n <span>The recalculated</span>\n <b class=\"is-pl-1\">{{ model.config?.mergeArgs?.replaceThreshold?.[0] || 'value' }}</b>\n <span class=\"is-pl-1\">was</span>\n <span class=\"is-pl-1\">\n <ng-container *ngIf=\"model.config?.mergeArgs\">\n <span class=\"is-underlined\" *ngIf=\"!model.logs.replaceThreshold\">less than</span>\n <span class=\"is-underlined\" *ngIf=\"model.logs.replaceThreshold\">more than or equal to</span>\n <b class=\"is-pl-1\">{{ model.config.mergeArgs.replaceThreshold[1] * 100 }}%</b>\n </ng-container>\n <ng-container *ngIf=\"!model.config?.mergeArgs\">\n <span class=\"is-underlined\" *ngIf=\"!model.logs.replaceThreshold\">not sufficiently</span>\n <span class=\"is-underlined\" *ngIf=\"model.logs.replaceThreshold\">sufficiently</span>\n </ng-container>\n </span>\n <span class=\"is-pl-1\">different from the original</span>\n <b class=\"is-pl-1\">{{ model.config?.mergeArgs?.replaceThreshold?.[0] || 'value' }}.</b>\n </li>\n </ul>\n </ng-container>\n </ng-container>\n</ng-template>\n\n<ng-template #docsLink let-model>\n <a [href]=\"model.apiDocsPath || model.docPath || model.path\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\n <span>Docs</span>\n <fa-icon class=\"ml-1\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n </a>\n</ng-template>\n", styles: [":host{display:block}::ng-deep .table{background-color:transparent}::ng-deep .table td he-node-link{width:190px}@media screen and (max-width: 768px){::ng-deep .table td he-node-link{width:150px}}::ng-deep .table td .open-node+he-node-link{width:170px}@media screen and (max-width: 768px){::ng-deep .table td .open-node+he-node-link{width:130px}}::ng-deep .table td.has-border-right{box-shadow:1px 0 #6c8093}::ng-deep .table .has-sub-rows.is-open>td:first-child:before,::ng-deep .table .is-sub-row>td:first-child:before{display:block;position:absolute;content:\" \";background-color:#6c809333;height:100%;width:1px;top:0;left:12px}::ng-deep .table .has-sub-rows.is-open>td:first-child:before{top:25px}::ng-deep .table .popover-body .table-container{max-height:260px;overflow-y:auto}::ng-deep .copy-log he-clipboard{visibility:hidden}::ng-deep .copy-log:hover he-clipboard{visibility:visible}\n"], dependencies: [{ kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i4.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i5.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i6.NgbTypeahead, selector: "input[ngbTypeahead]", inputs: ["autocomplete", "container", "editable", "focusFirst", "inputFormatter", "ngbTypeahead", "resultFormatter", "resultTemplate", "selectOnExact", "showHint", "placement", "popperOptions", "popupClass"], outputs: ["selectItem"], exportAs: ["ngbTypeahead"] }, { kind: "directive", type: i6.NgbPopover, selector: "[ngbPopover]", inputs: ["animation", "autoClose", "ngbPopover", "popoverTitle", "placement", "popperOptions", "triggers", "positionTarget", "container", "disablePopover", "popoverClass", "popoverContext", "openDelay", "closeDelay"], outputs: ["shown", "hidden"], exportAs: ["ngbPopover"] }, { kind: "component", type: i7.FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "classes", "transform", "a11yRole"] }, { kind: "directive", type: i8.BindOnceDirective, selector: "[bindOnce]", inputs: ["bindOnce"] }, { kind: "component", type: i9.BlankNodeValueDeltaComponent, selector: "he-blank-node-value-delta", inputs: ["value", "originalValue", "displayType"] }, { kind: "component", type: i10.ClipboardComponent, selector: "he-clipboard", inputs: ["value", "disabled", "hideText", "icon", "size", "rotate", "clipboardClass"] }, { kind: "component", type: i11.DataTableComponent, selector: "he-data-table", inputs: ["minHeight", "maxHeight", "small"] }, { kind: "component", type: i12.NodeLinkComponent, selector: "he-node-link", inputs: ["node", "showExternalLink", "linkClass"] }, { kind: "pipe", type: i13.CompoundPipe, name: "compound" }, { kind: "pipe", type: i14.DefaultPipe, name: "default" }, { kind: "pipe", type: i15.KeysPipe, name: "keys" }, { kind: "pipe", type: i16.PluralizePipe, name: "pluralize" }, { kind: "pipe", type: i17.KeyToLabelPipe, name: "keyToLabel" }, { kind: "pipe", type: i18.PrecisionPipe, name: "precision" }, { kind: "pipe", type: i19.TimesPipe, name: "times" }, { kind: "pipe", type: i20.IsArrayPipe, name: "isArray" }, { kind: "pipe", type: i21.IsObjectPipe, name: "isObject" }] }); }
242
243
  }
243
244
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.8", ngImport: i0, type: NodeLogsModelsComponent, decorators: [{
244
245
  type: Component,
245
- args: [{ selector: 'he-node-logs-models', template: "<div class=\"px-3 pb-3\">\n <div class=\"has-text-right mb-2\" *ngIf=\"!isExternal\">\n <a class=\"is-size-7\" *ngIf=\"logsUrl\" [href]=\"logsUrl\" target=\"_blank\">\n <fa-icon icon=\"external-link-alt\"></fa-icon>\n <span class=\"pl-2\">Open Full Logs</span>\n </a>\n </div>\n\n <he-data-table class=\"mb-1 is-small\" [small]=\"true\" maxHeight=\"320\">\n <table class=\"table is-fullwidth is-narrow is-striped\">\n <thead>\n <tr>\n <th class=\"width-auto has-border-right\">\n <div class=\"field\" *ngIf=\"allTerms?.length\">\n <div class=\"control is-expanded has-icons-right\">\n <input\n class=\"input search-input is-small\"\n [(ngModel)]=\"term\"\n name=\"term\"\n placeholder=\"Filter by name\"\n [ngbTypeahead]=\"suggestTerm\"\n [focusFirst]=\"false\"\n (selectItem)=\"filterResults()\" />\n <a class=\"icon is-small is-right\" [class.is-hidden]=\"!term\" (click)=\"term = ''; filterResults()\">\n <fa-icon icon=\"times\"></fa-icon>\n </a>\n </div>\n </div>\n </th>\n <th *ngIf=\"isBlankNodes\">\n <span class=\"is-pr-1\">Units</span>\n <span>(per&nbsp;</span>\n <span [ngSwitch]=\"functionalUnit\">\n <ng-container *ngSwitchCase=\"CycleFunctionalUnit['1 ha']\">hectare</ng-container>\n <ng-container *ngSwitchDefault>kg product</ng-container>\n </span>\n <span>)</span>\n </th>\n <th>Original</th>\n <th>Recalculated</th>\n <th *ngIf=\"isBlankNodes\">Difference</th>\n <th *ngFor=\"let c of methodModelsCount | times; let i = index\">({{ i + 1 }})</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngIf=\"loading\">\n <td class=\"has-text-centered\" colspan=\"6\">\n <div class=\"has-text-center py-3\">\n <fa-icon icon=\"spinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n </div>\n </td>\n </tr>\n <tr *ngIf=\"!loading && blankNodes.length === 0\">\n <td class=\"has-text-centered\" colspan=\"6\">\n <span>No data</span>\n </td>\n </tr>\n <ng-container *ngFor=\"let blankNode of blankNodes; trackBy: trackByBlankNode\">\n <tr [class.has-sub-rows]=\"blankNode.canOpen\" [class.is-open]=\"blankNode.isOpen\">\n <td class=\"width-auto has-border-right is-nowrap\" [attr.title]=\"blankNode.term?.name || blankNode.key\">\n <a\n class=\"is-inline-block is-align-top pr-2 open-node\"\n (click)=\"blankNode.isOpen = !blankNode.isOpen\"\n *ngIf=\"blankNode.canOpen\">\n <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!blankNode.isOpen\"></fa-icon>\n <fa-icon icon=\"angle-right\" [class.is-hidden]=\"blankNode.isOpen\"></fa-icon>\n </a>\n <he-node-link class=\"is-inline-block is-pre-wrap\" *ngIf=\"blankNode.term\" [node]=\"blankNode.term\">\n <span [innerHtml]=\"blankNode.term.name | compound\"></span>\n </he-node-link>\n <span *ngIf=\"blankNode.key\">{{ blankNode.key }}</span>\n </td>\n <td *ngIf=\"isBlankNodes\">\n <span class=\"is-nowrap\" [innerHtml]=\"blankNode.term?.units | compound\"></span>\n </td>\n <td>\n <ng-template #defaultOriginalValue>\n <span>{{ blankNode.originalValue | precision: 3 | default: '-' }}</span>\n </ng-template>\n <ng-container *ngIf=\"blankNode.allParallel; else defaultOriginalValue\">\n <div *ngFor=\"let model of blankNode.configModels[0]\">\n {{ blankNode.originalValueByMethodId[model.methodId] | precision: 3 | default: '-' }}\n </div>\n </ng-container>\n </td>\n <td>\n <ng-container *ngIf=\"!blankNode.isOriginal || blankNode.isRecalculated; else notRecalculated\">\n <ng-template #defaultRecalculatedValue>\n <span>{{ blankNode.recalculatedValue | precision: 3 | default: '-' }}</span>\n </ng-template>\n <ng-container *ngIf=\"blankNode.allParallel; else defaultRecalculatedValue\">\n <div *ngFor=\"let model of blankNode.configModels[0]\">\n {{ blankNode.recalculatedValueByMethodId[model.methodId] | precision: 3 | default: '-' }}\n </div>\n </ng-container>\n </ng-container>\n </td>\n <td *ngIf=\"isBlankNodes\" class=\"is-nowrap\">\n <ng-template #defaultDeltaValue>\n <he-blank-node-value-delta\n *ngIf=\"blankNode.original.length && blankNode.isRecalculated; else noValue\"\n [value]=\"blankNode.recalculatedValue\"\n [originalValue]=\"blankNode.originalValue\"></he-blank-node-value-delta>\n </ng-template>\n <ng-container *ngIf=\"blankNode.allParallel; else defaultDeltaValue\">\n <div *ngFor=\"let model of blankNode.configModels[0]\">\n <he-blank-node-value-delta\n *ngIf=\"\n blankNode.originalValueByMethodId[model.methodId] !== null &&\n blankNode.recalculatedValueByMethodId[model.methodId] !== null;\n else noValue\n \"\n [value]=\"blankNode.recalculatedValueByMethodId[model.methodId]\"\n [originalValue]=\"blankNode.originalValueByMethodId[model.methodId]\"></he-blank-node-value-delta>\n </div>\n </ng-container>\n </td>\n <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: blankNode }\"></ng-container>\n </tr>\n\n <tr\n *ngFor=\"let subValue of blankNode.keys\"\n [class.is-hidden]=\"!blankNode.isOpen\"\n [class.has-sub-rows]=\"blankNode.subValues?.length\"\n [class.is-sub-row]=\"blankNode.canOpen\">\n <td class=\"width-auto has-border-right is-nowrap\">\n <span class=\"is-inline-block is-align-top pl-3 pr-1 field-node\">Field:</span>\n\n <a\n class=\"is-inline-block is-pre-wrap\"\n *ngIf=\"blankNode.type\"\n [href]=\"baseUrl + '/schema/' + blankNode.type + '#' + subValue.key\"\n target=\"_blank\"\n [title]=\"subValue.key\">\n <span>{{ subValue.key }}</span>\n </a>\n <span class=\"is-inline-block is-align-top\" *ngIf=\"!blankNode.type\">{{ subValue.key }}</span>\n </td>\n <td *ngIf=\"isBlankNodes\"></td>\n <td>\n <span *ngIf=\"subValue.originalValue !== null; else noValue\">\n {{ subValue.originalValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td>\n <span *ngIf=\"subValue.isRecalculated || subValue.key === 'impactAssessment'; else notRecalculated\">\n {{ subValue.recalculatedValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td *ngIf=\"isBlankNodes\">-</td>\n <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: subValue }\"></ng-container>\n </tr>\n\n <tr\n *ngFor=\"let subValue of blankNode.subValues\"\n [class.is-hidden]=\"!blankNode.isOpen\"\n [class.is-sub-row]=\"blankNode.canOpen\">\n <td class=\"width-auto has-border-right\">\n <span class=\"is-inline-block is-align-top pl-3\">{{ subValue.key | keyToLabel }}</span>\n\n <ng-container *ngIf=\"subValue.id\">\n <span class=\"is-inline-block\" class=\"is-inline-block is-align-top pr-1\">:</span>\n\n <ng-container [ngSwitch]=\"subValue.key\">\n <span class=\"is-inline-block\" *ngSwitchCase=\"'backgroundData'\">{{ subValue.id | keyToLabel }}</span>\n <he-node-link\n *ngSwitchDefault\n class=\"is-block pl-4\"\n [node]=\"termById(subValue.id)\"\n [attr.title]=\"termById(subValue.id).name\">\n <span [innerHtml]=\"termById(subValue.id).name | compound\"></span>\n </he-node-link>\n </ng-container>\n </ng-container>\n </td>\n <td *ngIf=\"isBlankNodes\">\n <span class=\"is-nowrap\" *ngIf=\"subValue.showUnits\" [innerHtml]=\"blankNode.term?.units | compound\"></span>\n </td>\n <td>\n <span *ngIf=\"subValue.originalValue !== null; else noValue\">\n {{ subValue.originalValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td>\n <span *ngIf=\"subValue.isRecalculated; else notRecalculated\">\n {{ subValue.recalculatedValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td *ngIf=\"isBlankNodes\">-</td>\n <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: subValue }\"></ng-container>\n </tr>\n </ng-container>\n </tbody>\n </table>\n </he-data-table>\n\n <div class=\"is-size-7 is-italic\">\n <div class=\"columns is-variable is-1 my-0\">\n <div class=\"column is-narrow\">\n <p>\n <a class=\"is-inline-block pr-2\" (click)=\"showLegend = !showLegend\">\n <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!showLegend\"></fa-icon>\n <fa-icon icon=\"angle-right\" [class.is-hidden]=\"showLegend\"></fa-icon>\n </a>\n <span class=\"is-inline-block\">Legend:</span>\n </p>\n <ul class=\"content pl-2\" [class.is-hidden]=\"!showLegend\">\n <ng-container *ngFor=\"let status of LogStatus | keys\">\n <li *ngIf=\"logIcon[status.value]\" class=\"has-text-{{ logColor[status.value] }}\">\n <fa-icon [icon]=\"logIcon[status.value]\"></fa-icon>\n <span class=\"pl-1\">{{ status.value }}</span>\n </li>\n </ng-container>\n </ul>\n </div>\n <div class=\"column has-text-right\" *ngIf=\"filteredType\">\n <label class=\"is-inline-block checkbox\">\n <input\n type=\"checkbox\"\n class=\"selector\"\n [(ngModel)]=\"onlyRequired\"\n (change)=\"filterResults()\"\n [disabled]=\"!!term\" />\n <span class=\"ml-2\">\n Show only {{ filteredType | pluralize }} included in the default Hestia system boundary\n </span>\n </label>\n </div>\n </div>\n </div>\n</div>\n\n<ng-template #blankNodeModels let-data=\"data\">\n <ng-template #notInSystemBoundary>\n <td [attr.colspan]=\"methodModelsCount\">\n <span>Not in Hestia system boundary</span>\n </td>\n </ng-template>\n\n <ng-container *ngIf=\"isSystemBoundary(data); else noValue\">\n <td class=\"blank-node-index-{{ i }}\" *ngFor=\"let c of methodModelsCount | times; let i = index\">\n <ng-container *ngIf=\"getModelsAt(data, i); let models; else: noValue\">\n <ng-template #modelSerie>\n <ng-container *ngTemplateOutlet=\"blankNodeModel; context: { model: models, data }\"></ng-container>\n </ng-template>\n <div *ngIf=\"models | isArray; else modelSerie\">\n <p *ngFor=\"let model of models\">\n <ng-container *ngTemplateOutlet=\"blankNodeModel; context: { model, data }\"></ng-container>\n </p>\n </div>\n </ng-container>\n </td>\n </ng-container>\n</ng-template>\n\n<ng-template #blankNodeModel let-model=\"model\" let-data=\"data\">\n <span\n class=\"is-nowrap\"\n [class.trigger-popover]=\"model.showLogs\"\n [ngbPopover]=\"logDetails\"\n [autoClose]=\"'outside'\"\n popoverClass=\"is-narrow\"\n triggers=\"manual\"\n #p=\"ngbPopover\"\n placement=\"left\"\n container=\"body\"\n (click)=\"p.isOpen() ? p.close() : model.showLogs ? p.open({ logs: model.logs }) : null\">\n <span class=\"is-capitalized\">{{ methodName(model) }}</span>\n <span class=\"pl-1\" *ngIf=\"model.logs?.methodTier || model.model?.methodTier\">\n [{{ model.logs?.methodTier || model.model?.methodTier }}]\n </span>\n\n <span\n class=\"pl-1 has-text-{{ logColor[model.status] }} trigger-popover\"\n [ngbPopover]=\"logStatusDetails\"\n [autoClose]=\"'outside'\"\n popoverClass=\"is-narrow\"\n triggers=\"manual\"\n #p1=\"ngbPopover\"\n placement=\"left\"\n container=\"body\"\n (click)=\"$event.stopPropagation(); p1.isOpen() ? p1.close() : p1.open({ model, data })\">\n <fa-icon [icon]=\"logIcon[model.status]\"></fa-icon>\n </span>\n\n <span class=\"pl-1\" *ngIf=\"model.model\">\n (\n <ng-container *ngTemplateOutlet=\"docsLink; context: { $implicit: model.model }\"></ng-container>\n )\n </span>\n </span>\n</ng-template>\n\n<ng-template #noValue>-</ng-template>\n\n<ng-template #notRecalculated>not recalculated</ng-template>\n\n<ng-template #logDetails let-logs=\"logs\">\n <div class=\"table-container\" *bindOnce=\"logs\">\n <table class=\"table is-dark is-fullwidth\">\n <tbody>\n <ng-container *ngIf=\"logs?.requirements\">\n <ng-container *ngFor=\"let key of requirementKeys(logs.requirements)\">\n <ng-container *ngTemplateOutlet=\"logLine; context: { key, value: logs.requirements[key] }\"></ng-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"logs?.logs\">\n <ng-container *ngFor=\"let key of logs.logs | keys\">\n <ng-container *ngTemplateOutlet=\"logLine; context: key\"></ng-container>\n </ng-container>\n </ng-container>\n </tbody>\n </table>\n </div>\n\n <ng-container *bindOnce=\"logs\">\n <div class=\"it-mt-2\" *ngIf=\"logs?.missingLookups?.length\">\n <p>Optional data missing:</p>\n\n <div class=\"table-container data-table-container\">\n <table class=\"table is-dark is-fullwidth is-striped\">\n <thead>\n <tr>\n <th class=\"has-text-white\">\n <span>Filename</span>\n </th>\n <th class=\"has-text-white\">\n <span>Column Title</span>\n </th>\n <th class=\"has-text-white\">\n <span>Row (term.id)</span>\n </th>\n </tr>\n </thead>\n <tbody class=\"has-text-white\">\n <tr *ngFor=\"let data of logs.missingLookups\">\n <td>{{ data.filename }}</td>\n <td>{{ data.column }}</td>\n <td>{{ data.termId }}</td>\n </tr>\n </tbody>\n </table>\n </div>\n </div>\n </ng-container>\n</ng-template>\n\n<ng-template #logLineValue let-key=\"key\" let-value=\"value\">\n <ng-template #defaultValue>\n <span class=\"is-inline-block is-align-middle\">{{ value }}</span>\n </ng-template>\n <ng-container *ngIf=\"requirementLinkedNode(key, value); let linkedNode; else: defaultValue\">\n <he-node-link\n class=\"is-inline-block is-align-middle\"\n linkClass=\"is-dark\"\n [node]=\"linkedNode\"\n [showExternalLink]=\"true\"></he-node-link>\n </ng-container>\n</ng-template>\n\n<ng-template #logLine let-key=\"key\" let-value=\"value\">\n <tr>\n <td class=\"has-border-right copy-log\">\n <span class=\"is-inline-block is-align-middle\" [ngSwitch]=\"key\">\n <ng-container *ngSwitchDefault>{{ key | keyToLabel }}</ng-container>\n\n <ng-container *ngSwitchCase=\"'node_type_allowed'\">\n Is the current\n <code>Node</code>\n allowed to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'siteType_allowed'\">\n Is the current\n <code>siteType</code>\n allowed to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'primary_product_id_allowed'\">\n Is the current primary product\n <code>@id</code>\n allowed to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'primary_product_termType_allowed'\">\n Is the current primary product\n <code>termType</code>\n allowed to run this model\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'geospatial_data'\">Has geospatial data necessary to run this model</ng-container>\n <ng-container *ngSwitchCase=\"'contains_geospatial_data'\">\n Has geospatial data necessary to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'current_size'\">Current polygon area</ng-container>\n <ng-container *ngSwitchCase=\"'max_area_size'\">Maximum polygon area to run this model</ng-container>\n <ng-container *ngSwitchCase=\"'below_max_area_size'\">Polygon below the maximum area</ng-container>\n <ng-container *ngSwitchCase=\"'region_factor'\">Factor from region lookup</ng-container>\n\n <ng-container *ngSwitchCase=\"'pesticides_complete'\">\n Pesticide data are\n <code>complete</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'has_pesticides_inputs'\">\n Cycle contains\n <code>pesticideAI</code>\n Inputs\n </ng-container>\n <ng-container *ngSwitchCase=\"'all_pesticideAI_have_lookup_value'\">\n All\n <code>pesticideAI</code>\n Inputs have a lookup value\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'has_crop_residue_burnt'\">\n <code>aboveGroundCropResidueBurnt</code>\n is present as Product\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'liquid_slurry_sludge_P'\">Liquid, Slurry, and Sludge P</ng-container>\n\n <ng-container *ngSwitchCase=\"'term_type_cropResidue_complete'\">\n Data completeness for \"cropResidue\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_excreta_complete'\">\n Data completeness for \"excreta\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_fertiliser_complete'\">\n Data completeness for \"fertiliser\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_material_complete'\">\n Data completeness for \"material\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_other_complete'\">\n Data completeness for \"other\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_pesticidesAntibiotics_complete'\">\n Data completeness for \"pesticidesAntibiotics\" must be\n <code>true</code>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'term_type_cropResidue_incomplete'\">\n Data completeness for \"cropResidue\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_excreta_incomplete'\">\n Data completeness for \"excreta\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_fertiliser_incomplete'\">\n Data completeness for \"fertiliser\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_material_incomplete'\">\n Data completeness for \"material\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_other_incomplete'\">\n Data completeness for \"other\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_pesticidesAntibiotics_incomplete'\">\n Data completeness for \"pesticidesAntibiotics\" must be\n <code>false</code>\n </ng-container>\n </span>\n <he-clipboard\n class=\"is-inline-block is-align-middle\"\n clipboardClass=\"is-size-7 is-p-1\"\n [icon]=\"['far', 'clone']\"\n [value]=\"key\"\n [hideText]=\"true\"></he-clipboard>\n </td>\n <td>\n <ng-template #singleValue>\n <ng-container *ngTemplateOutlet=\"logLineValue; context: { key, value }\"></ng-container>\n </ng-template>\n <div *ngIf=\"logValueArray(value); let valueArray; else: singleValue\">\n <table class=\"table is-dark is-bordered is-striped\">\n <thead *ngIf=\"valueArray[0] | isObject\">\n <tr>\n <th class=\"has-text-white\" *ngFor=\"let v of valueArray[0] | keys\">{{ v.key }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let v of valueArray\">\n <ng-template #singleArrayValue>\n <td>{{ v }}</td>\n </ng-template>\n <ng-container *ngIf=\"v | isObject; else singleArrayValue\">\n <td *ngFor=\"let vv of v | keys\">{{ vv.value }}</td>\n </ng-container>\n </tr>\n </tbody>\n </table>\n </div>\n </td>\n </tr>\n</ng-template>\n\n<ng-template #logStatusDetails let-model=\"model\" let-data=\"data\">\n <ng-container *bindOnce=\"model\">\n <div class=\"is-mb-2\">\n <span>Status:</span>\n <span class=\"is-pl-1\">{{ model.status }}</span>\n </div>\n\n <ng-container *ngIf=\"model.status === LogStatus.notRequired && model.logs?.is_not_relevant === 'True'\">\n <ul class=\"is-pl-3 is-list-style-disc\">\n <li *ngIf=\"model.logs.logs?.siteType_allowed === 'False'\">\n The\n <code>siteType</code>\n is not relevant.\n </li>\n <li *ngIf=\"model.logs.logs?.product_id_allowed === 'False'\">\n The primary product\n <code>@id</code>\n is not relevant.\n </li>\n <li *ngIf=\"model.logs.logs?.product_termType_allowed === 'False'\">\n The primary product\n <code>termType</code>\n is not relevant.\n </li>\n </ul>\n </ng-container>\n\n <ng-container\n *ngIf=\"model.logs && model.status !== LogStatus.notRequired && model.status !== LogStatus.skipHierarchy\">\n <ul class=\"is-pl-3 is-list-style-disc\">\n <ng-template #showRunOrchestrator>\n <li class=\"is-run-orchestrator\">\n <p *ngIf=\"model.logs?.shouldRun\">All the requirements were met to run the model.</p>\n <ng-container *ngIf=\"!model.logs?.shouldRun\">\n <p>Some of the requirements were not met to run the model.</p>\n <p>You can click on the model name on the left to view the debugging logs.</p>\n </ng-container>\n <ng-container *ngIf=\"model.logs?.logs?.error\">\n <p>The model failed to run for the following reason:</p>\n <p>\n <code>{{ model.logs.logs.error }}</code>\n </p>\n </ng-container>\n </li>\n </ng-template>\n\n <li\n class=\"is-no-run-orchestrator\"\n *ngIf=\"model.logs?.shouldRunOrchestrator === false; else showRunOrchestrator\">\n <ng-container *ngIf=\"!model.logs.runRequired\">\n <span class=\"is-run-node-type-not-allowed\" *ngIf=\"model.logs.logs?.node_type_allowed === 'False'\">\n This model should not run for {{ nodeType | pluralize: 0 }}\n </span>\n </ng-container>\n\n <ng-template #runNoConfig>\n <span class=\"is-run-not-empty\" *ngIf=\"model.logs.logs?.is_empty === 'False'\">\n The {{ data.type || 'blank node' }} with Term\n <code>{{ data.termId }}</code>\n is already present or already added by another model.\n </span>\n </ng-template>\n\n <ng-container *ngIf=\"model.config; else runNoConfig\">\n <p class=\"is-run-strategy-{{ model.config.runStrategy }}\" [ngSwitch]=\"model.config.runStrategy\">\n <span *ngSwitchCase=\"'always'\"></span>\n <span *ngSwitchCase=\"'add_key_if_missing'\">We only gap-fill this key if not present</span>\n <span *ngSwitchCase=\"'add_blank_node_if_missing'\">We only gap-fill this Blank Node if not present.</span>\n </p>\n\n <p class=\"is-mt-1\">\n <span\n class=\"is-run-with-measured\"\n *ngIf=\"\n model.config.runArgs?.runNonMeasured && hasMethodTier(data.original, EmissionMethodTier.measured)\n \">\n The\n <code>{{ model.config.value }}</code>\n was reported as measured.\n </span>\n </p>\n </ng-container>\n </li>\n\n <li *ngIf=\"model.logs?.replaceLowerTier !== undefined\">\n <span>\n The recalculated\n <b>methodTier</b>\n was\n </span>\n <span class=\"is-pl-1 is-underlined\" *ngIf=\"!model.logs.replaceLowerTier\">lower than</span>\n <span class=\"is-pl-1 is-underlined\" *ngIf=\"model.logs.replaceLowerTier\">higher than or equal to</span>\n <span class=\"is-pl-1\">\n the original\n <b>methodTier</b>\n .\n </span>\n </li>\n\n <li class=\"is-merge-replaceLowerTier\" *ngIf=\"model.logs.replaceLowerTier\">\n <span>The recalculated</span>\n <b class=\"is-pl-1\">{{ model.config?.mergeArgs?.replaceThreshold?.[0] || 'value' }}</b>\n <span class=\"is-pl-1\">was</span>\n <span class=\"is-pl-1\">\n <ng-container *ngIf=\"model.config?.mergeArgs\">\n <span class=\"is-underlined\" *ngIf=\"!model.logs.replaceThreshold\">less than</span>\n <span class=\"is-underlined\" *ngIf=\"model.logs.replaceThreshold\">more than or equal to</span>\n <b class=\"is-pl-1\">{{ model.config.mergeArgs.replaceThreshold[1] * 100 }}%</b>\n </ng-container>\n <ng-container *ngIf=\"!model.config?.mergeArgs\">\n <span class=\"is-underlined\" *ngIf=\"!model.logs.replaceThreshold\">not sufficiently</span>\n <span class=\"is-underlined\" *ngIf=\"model.logs.replaceThreshold\">sufficiently</span>\n </ng-container>\n </span>\n <span class=\"is-pl-1\">different from the original</span>\n <b class=\"is-pl-1\">{{ model.config?.mergeArgs?.replaceThreshold?.[0] || 'value' }}.</b>\n </li>\n </ul>\n </ng-container>\n </ng-container>\n</ng-template>\n\n<ng-template #docsLink let-model>\n <a [href]=\"model.apiDocsPath || model.docPath || model.path\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\n <span>Docs</span>\n <fa-icon class=\"ml-1\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n </a>\n</ng-template>\n", styles: [":host{display:block}::ng-deep .table{background-color:transparent}::ng-deep .table td he-node-link{width:190px}@media screen and (max-width: 768px){::ng-deep .table td he-node-link{width:150px}}::ng-deep .table td .open-node+he-node-link{width:170px}@media screen and (max-width: 768px){::ng-deep .table td .open-node+he-node-link{width:130px}}::ng-deep .table td.has-border-right{box-shadow:1px 0 #6c8093}::ng-deep .table .has-sub-rows.is-open>td:first-child:before,::ng-deep .table .is-sub-row>td:first-child:before{display:block;position:absolute;content:\" \";background-color:#6c809333;height:100%;width:1px;top:0;left:12px}::ng-deep .table .has-sub-rows.is-open>td:first-child:before{top:25px}::ng-deep .table .popover-body .table-container{max-height:260px;overflow-y:auto}::ng-deep .copy-log he-clipboard{visibility:hidden}::ng-deep .copy-log:hover he-clipboard{visibility:visible}\n"] }]
246
+ args: [{ selector: 'he-node-logs-models', template: "<div class=\"px-3 pb-3\">\n <div class=\"has-text-right mb-2\" *ngIf=\"!isExternal\">\n <a class=\"is-size-7\" *ngIf=\"logsUrl\" [href]=\"logsUrl\" target=\"_blank\">\n <fa-icon icon=\"external-link-alt\"></fa-icon>\n <span class=\"pl-2\">Open Full Logs</span>\n </a>\n </div>\n\n <he-data-table class=\"mb-1 is-small\" [small]=\"true\" maxHeight=\"320\">\n <table class=\"table is-fullwidth is-narrow is-striped\">\n <thead>\n <tr>\n <th class=\"width-auto has-border-right\">\n <div class=\"field\" *ngIf=\"allTerms?.length\">\n <div class=\"control is-expanded has-icons-right\">\n <input\n class=\"input search-input is-small\"\n [(ngModel)]=\"term\"\n name=\"term\"\n placeholder=\"Select entry by name\"\n [ngbTypeahead]=\"suggestTerm\"\n [focusFirst]=\"true\"\n (focus)=\"typeaheadFocus($event)\"\n (selectItem)=\"filterResults()\" />\n <a class=\"icon is-small is-right\" [class.is-hidden]=\"!term\" (click)=\"term = ''; filterResults()\">\n <fa-icon icon=\"times\"></fa-icon>\n </a>\n </div>\n </div>\n </th>\n <th *ngIf=\"isBlankNodes\">\n <span class=\"is-pr-1\">Units</span>\n <span>(per&nbsp;</span>\n <span [ngSwitch]=\"functionalUnit\">\n <ng-container *ngSwitchCase=\"CycleFunctionalUnit['1 ha']\">hectare</ng-container>\n <ng-container *ngSwitchDefault>kg product</ng-container>\n </span>\n <span>)</span>\n </th>\n <th>Original</th>\n <th>Recalculated</th>\n <th *ngIf=\"isBlankNodes\">Difference</th>\n <th *ngFor=\"let c of methodModelsCount | times; let i = index\">({{ i + 1 }})</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngIf=\"loading\">\n <td class=\"has-text-centered\" colspan=\"6\">\n <div class=\"has-text-center py-3\">\n <fa-icon icon=\"spinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n </div>\n </td>\n </tr>\n <tr *ngIf=\"!loading && blankNodes.length === 0\">\n <td class=\"has-text-centered\" colspan=\"6\">\n <span>No data</span>\n </td>\n </tr>\n <ng-container *ngFor=\"let blankNode of blankNodes; trackBy: trackByBlankNode\">\n <tr [class.has-sub-rows]=\"blankNode.canOpen\" [class.is-open]=\"blankNode.isOpen\">\n <td class=\"width-auto has-border-right is-nowrap\" [attr.title]=\"blankNode.term?.name || blankNode.key\">\n <a\n class=\"is-inline-block is-align-top pr-2 open-node\"\n (click)=\"blankNode.isOpen = !blankNode.isOpen\"\n *ngIf=\"blankNode.canOpen\">\n <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!blankNode.isOpen\"></fa-icon>\n <fa-icon icon=\"angle-right\" [class.is-hidden]=\"blankNode.isOpen\"></fa-icon>\n </a>\n <he-node-link class=\"is-inline-block is-pre-wrap\" *ngIf=\"blankNode.term\" [node]=\"blankNode.term\">\n <span [innerHtml]=\"blankNode.term.name | compound\"></span>\n </he-node-link>\n <span *ngIf=\"blankNode.key\">{{ blankNode.key }}</span>\n </td>\n <td *ngIf=\"isBlankNodes\">\n <span class=\"is-nowrap\" [innerHtml]=\"blankNode.term?.units | compound\"></span>\n </td>\n <td>\n <ng-template #defaultOriginalValue>\n <span>{{ blankNode.originalValue | precision: 3 | default: '-' }}</span>\n </ng-template>\n <ng-container *ngIf=\"blankNode.allParallel; else defaultOriginalValue\">\n <div *ngFor=\"let model of blankNode.configModels[0]\">\n {{ blankNode.originalValueByMethodId[model.methodId] | precision: 3 | default: '-' }}\n </div>\n </ng-container>\n </td>\n <td>\n <ng-container *ngIf=\"!blankNode.isOriginal || blankNode.isRecalculated; else notRecalculated\">\n <ng-template #defaultRecalculatedValue>\n <span>{{ blankNode.recalculatedValue | precision: 3 | default: '-' }}</span>\n </ng-template>\n <ng-container *ngIf=\"blankNode.allParallel; else defaultRecalculatedValue\">\n <div *ngFor=\"let model of blankNode.configModels[0]\">\n {{ blankNode.recalculatedValueByMethodId[model.methodId] | precision: 3 | default: '-' }}\n </div>\n </ng-container>\n </ng-container>\n </td>\n <td *ngIf=\"isBlankNodes\" class=\"is-nowrap\">\n <ng-template #defaultDeltaValue>\n <he-blank-node-value-delta\n *ngIf=\"blankNode.original.length && blankNode.isRecalculated; else noValue\"\n [value]=\"blankNode.recalculatedValue\"\n [originalValue]=\"blankNode.originalValue\"></he-blank-node-value-delta>\n </ng-template>\n <ng-container *ngIf=\"blankNode.allParallel; else defaultDeltaValue\">\n <div *ngFor=\"let model of blankNode.configModels[0]\">\n <he-blank-node-value-delta\n *ngIf=\"\n blankNode.originalValueByMethodId[model.methodId] !== null &&\n blankNode.recalculatedValueByMethodId[model.methodId] !== null;\n else noValue\n \"\n [value]=\"blankNode.recalculatedValueByMethodId[model.methodId]\"\n [originalValue]=\"blankNode.originalValueByMethodId[model.methodId]\"></he-blank-node-value-delta>\n </div>\n </ng-container>\n </td>\n <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: blankNode }\"></ng-container>\n </tr>\n\n <tr\n *ngFor=\"let subValue of blankNode.keys\"\n [class.is-hidden]=\"!blankNode.isOpen\"\n [class.has-sub-rows]=\"blankNode.subValues?.length\"\n [class.is-sub-row]=\"blankNode.canOpen\">\n <td class=\"width-auto has-border-right is-nowrap\">\n <span class=\"is-inline-block is-align-top pl-3 pr-1 field-node\">Field:</span>\n\n <a\n class=\"is-inline-block is-pre-wrap\"\n *ngIf=\"blankNode.type\"\n [href]=\"baseUrl + '/schema/' + blankNode.type + '#' + subValue.key\"\n target=\"_blank\"\n [title]=\"subValue.key\">\n <span>{{ subValue.key }}</span>\n </a>\n <span class=\"is-inline-block is-align-top\" *ngIf=\"!blankNode.type\">{{ subValue.key }}</span>\n </td>\n <td *ngIf=\"isBlankNodes\"></td>\n <td>\n <span *ngIf=\"subValue.originalValue !== null; else noValue\">\n {{ subValue.originalValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td>\n <span *ngIf=\"subValue.isRecalculated || subValue.key === 'impactAssessment'; else notRecalculated\">\n {{ subValue.recalculatedValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td *ngIf=\"isBlankNodes\">-</td>\n <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: subValue }\"></ng-container>\n </tr>\n\n <tr\n *ngFor=\"let subValue of blankNode.subValues\"\n [class.is-hidden]=\"!blankNode.isOpen\"\n [class.is-sub-row]=\"blankNode.canOpen\">\n <td class=\"width-auto has-border-right\">\n <span class=\"is-inline-block is-align-top pl-3\">{{ subValue.key | keyToLabel }}</span>\n\n <ng-container *ngIf=\"subValue.id\">\n <span class=\"is-inline-block\" class=\"is-inline-block is-align-top pr-1\">:</span>\n\n <ng-container [ngSwitch]=\"subValue.key\">\n <span class=\"is-inline-block\" *ngSwitchCase=\"'backgroundData'\">{{ subValue.id | keyToLabel }}</span>\n <he-node-link\n *ngSwitchDefault\n class=\"is-block pl-4\"\n [node]=\"termById(subValue.id)\"\n [attr.title]=\"termById(subValue.id).name\">\n <span [innerHtml]=\"termById(subValue.id).name | compound\"></span>\n </he-node-link>\n </ng-container>\n </ng-container>\n </td>\n <td *ngIf=\"isBlankNodes\">\n <span class=\"is-nowrap\" *ngIf=\"subValue.showUnits\" [innerHtml]=\"blankNode.term?.units | compound\"></span>\n </td>\n <td>\n <span *ngIf=\"subValue.originalValue !== null; else noValue\">\n {{ subValue.originalValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td>\n <span *ngIf=\"subValue.isRecalculated; else notRecalculated\">\n {{ subValue.recalculatedValue | precision: 3 | default: '-' }}\n </span>\n </td>\n <td *ngIf=\"isBlankNodes\">-</td>\n <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: subValue }\"></ng-container>\n </tr>\n </ng-container>\n </tbody>\n </table>\n </he-data-table>\n\n <div class=\"is-size-7 is-italic\">\n <div class=\"columns is-variable is-1 my-0\">\n <div class=\"column is-narrow\">\n <p>\n <a class=\"is-inline-block pr-2\" (click)=\"showLegend = !showLegend\">\n <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!showLegend\"></fa-icon>\n <fa-icon icon=\"angle-right\" [class.is-hidden]=\"showLegend\"></fa-icon>\n </a>\n <span class=\"is-inline-block\">Legend:</span>\n </p>\n <ul class=\"content pl-2\" [class.is-hidden]=\"!showLegend\">\n <ng-container *ngFor=\"let status of LogStatus | keys\">\n <li *ngIf=\"logIcon[status.value]\" class=\"has-text-{{ logColor[status.value] }}\">\n <fa-icon [icon]=\"logIcon[status.value]\"></fa-icon>\n <span class=\"pl-1\">{{ status.value }}</span>\n </li>\n </ng-container>\n </ul>\n </div>\n <div class=\"column has-text-right\" *ngIf=\"filteredType\">\n <label class=\"is-inline-block checkbox\">\n <input\n type=\"checkbox\"\n class=\"selector\"\n [(ngModel)]=\"onlyRequired\"\n (change)=\"filterResults()\"\n [disabled]=\"!!term\" />\n <span class=\"ml-2\">\n Show only {{ filteredType | pluralize }} included in the default Hestia system boundary\n </span>\n </label>\n </div>\n </div>\n </div>\n</div>\n\n<ng-template #blankNodeModels let-data=\"data\">\n <ng-template #notInSystemBoundary>\n <td [attr.colspan]=\"methodModelsCount\">\n <span>Not in Hestia system boundary</span>\n </td>\n </ng-template>\n\n <ng-container *ngIf=\"isSystemBoundary(data); else noValue\">\n <td class=\"blank-node-index-{{ i }}\" *ngFor=\"let c of methodModelsCount | times; let i = index\">\n <ng-container *ngIf=\"getModelsAt(data, i); let models; else: noValue\">\n <ng-template #modelSerie>\n <ng-container *ngTemplateOutlet=\"blankNodeModel; context: { model: models, data }\"></ng-container>\n </ng-template>\n <div *ngIf=\"models | isArray; else modelSerie\">\n <p *ngFor=\"let model of models\">\n <ng-container *ngTemplateOutlet=\"blankNodeModel; context: { model, data }\"></ng-container>\n </p>\n </div>\n </ng-container>\n </td>\n </ng-container>\n</ng-template>\n\n<ng-template #blankNodeModel let-model=\"model\" let-data=\"data\">\n <span\n class=\"is-nowrap\"\n [class.trigger-popover]=\"model.showLogs\"\n [ngbPopover]=\"logDetails\"\n [autoClose]=\"'outside'\"\n popoverClass=\"is-narrow\"\n triggers=\"manual\"\n #p=\"ngbPopover\"\n placement=\"left\"\n container=\"body\"\n (click)=\"p.isOpen() ? p.close() : model.showLogs ? p.open({ logs: model.logs }) : null\">\n <span class=\"is-capitalized\">{{ methodName(model) }}</span>\n <span class=\"pl-1\" *ngIf=\"model.logs?.methodTier || model.model?.methodTier\">\n [{{ model.logs?.methodTier || model.model?.methodTier }}]\n </span>\n\n <span\n class=\"pl-1 has-text-{{ logColor[model.status] }} trigger-popover\"\n [ngbPopover]=\"logStatusDetails\"\n [autoClose]=\"'outside'\"\n popoverClass=\"is-narrow\"\n triggers=\"manual\"\n #p1=\"ngbPopover\"\n placement=\"left\"\n container=\"body\"\n (click)=\"$event.stopPropagation(); p1.isOpen() ? p1.close() : p1.open({ model, data })\">\n <fa-icon [icon]=\"logIcon[model.status]\"></fa-icon>\n </span>\n\n <span class=\"pl-1\" *ngIf=\"model.model\">\n (\n <ng-container *ngTemplateOutlet=\"docsLink; context: { $implicit: model.model }\"></ng-container>\n )\n </span>\n </span>\n</ng-template>\n\n<ng-template #noValue>-</ng-template>\n\n<ng-template #notRecalculated>not recalculated</ng-template>\n\n<ng-template #logDetails let-logs=\"logs\">\n <div class=\"table-container\" *bindOnce=\"logs\">\n <table class=\"table is-dark is-fullwidth\">\n <tbody>\n <ng-container *ngIf=\"logs?.requirements\">\n <ng-container *ngFor=\"let key of requirementKeys(logs.requirements)\">\n <ng-container *ngTemplateOutlet=\"logLine; context: { key, value: logs.requirements[key] }\"></ng-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"logs?.logs\">\n <ng-container *ngFor=\"let key of logs.logs | keys\">\n <ng-container *ngTemplateOutlet=\"logLine; context: key\"></ng-container>\n </ng-container>\n </ng-container>\n </tbody>\n </table>\n </div>\n\n <ng-container *bindOnce=\"logs\">\n <div class=\"it-mt-2\" *ngIf=\"logs?.missingLookups?.length\">\n <p>Optional data missing:</p>\n\n <div class=\"table-container data-table-container\">\n <table class=\"table is-dark is-fullwidth is-striped\">\n <thead>\n <tr>\n <th class=\"has-text-white\">\n <span>Filename</span>\n </th>\n <th class=\"has-text-white\">\n <span>Column Title</span>\n </th>\n <th class=\"has-text-white\">\n <span>Row (term.id)</span>\n </th>\n </tr>\n </thead>\n <tbody class=\"has-text-white\">\n <tr *ngFor=\"let data of logs.missingLookups\">\n <td>{{ data.filename }}</td>\n <td>{{ data.column }}</td>\n <td>{{ data.termId }}</td>\n </tr>\n </tbody>\n </table>\n </div>\n </div>\n </ng-container>\n</ng-template>\n\n<ng-template #logLineValue let-key=\"key\" let-value=\"value\">\n <ng-template #defaultValue>\n <span class=\"is-inline-block is-align-middle\">{{ value }}</span>\n </ng-template>\n <ng-container *ngIf=\"requirementLinkedNode(key, value); let linkedNode; else: defaultValue\">\n <he-node-link\n class=\"is-inline-block is-align-middle\"\n linkClass=\"is-dark\"\n [node]=\"linkedNode\"\n [showExternalLink]=\"true\"></he-node-link>\n </ng-container>\n</ng-template>\n\n<ng-template #logLine let-key=\"key\" let-value=\"value\">\n <tr>\n <td class=\"has-border-right copy-log\">\n <span class=\"is-inline-block is-align-middle\" [ngSwitch]=\"key\">\n <ng-container *ngSwitchDefault>{{ key | keyToLabel }}</ng-container>\n\n <ng-container *ngSwitchCase=\"'node_type_allowed'\">\n Is the current\n <code>Node</code>\n allowed to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'siteType_allowed'\">\n Is the current\n <code>siteType</code>\n allowed to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'primary_product_id_allowed'\">\n Is the current primary product\n <code>@id</code>\n allowed to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'primary_product_termType_allowed'\">\n Is the current primary product\n <code>termType</code>\n allowed to run this model\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'geospatial_data'\">Has geospatial data necessary to run this model</ng-container>\n <ng-container *ngSwitchCase=\"'contains_geospatial_data'\">\n Has geospatial data necessary to run this model\n </ng-container>\n <ng-container *ngSwitchCase=\"'current_size'\">Current polygon area</ng-container>\n <ng-container *ngSwitchCase=\"'max_area_size'\">Maximum polygon area to run this model</ng-container>\n <ng-container *ngSwitchCase=\"'below_max_area_size'\">Polygon below the maximum area</ng-container>\n <ng-container *ngSwitchCase=\"'region_factor'\">Factor from region lookup</ng-container>\n\n <ng-container *ngSwitchCase=\"'pesticides_complete'\">\n Pesticide data are\n <code>complete</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'has_pesticides_inputs'\">\n Cycle contains\n <code>pesticideAI</code>\n Inputs\n </ng-container>\n <ng-container *ngSwitchCase=\"'all_pesticideAI_have_lookup_value'\">\n All\n <code>pesticideAI</code>\n Inputs have a lookup value\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'has_crop_residue_burnt'\">\n <code>aboveGroundCropResidueBurnt</code>\n is present as Product\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'liquid_slurry_sludge_P'\">Liquid, Slurry, and Sludge P</ng-container>\n\n <ng-container *ngSwitchCase=\"'term_type_cropResidue_complete'\">\n Data completeness for \"cropResidue\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_excreta_complete'\">\n Data completeness for \"excreta\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_fertiliser_complete'\">\n Data completeness for \"fertiliser\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_material_complete'\">\n Data completeness for \"material\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_other_complete'\">\n Data completeness for \"other\" must be\n <code>true</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_pesticidesAntibiotics_complete'\">\n Data completeness for \"pesticidesAntibiotics\" must be\n <code>true</code>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'term_type_cropResidue_incomplete'\">\n Data completeness for \"cropResidue\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_excreta_incomplete'\">\n Data completeness for \"excreta\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_fertiliser_incomplete'\">\n Data completeness for \"fertiliser\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_material_incomplete'\">\n Data completeness for \"material\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_other_incomplete'\">\n Data completeness for \"other\" must be\n <code>false</code>\n </ng-container>\n <ng-container *ngSwitchCase=\"'term_type_pesticidesAntibiotics_incomplete'\">\n Data completeness for \"pesticidesAntibiotics\" must be\n <code>false</code>\n </ng-container>\n </span>\n <he-clipboard\n class=\"is-inline-block is-align-middle\"\n clipboardClass=\"is-size-7 is-p-1\"\n [icon]=\"['far', 'clone']\"\n [value]=\"key\"\n [hideText]=\"true\"></he-clipboard>\n </td>\n <td>\n <ng-template #singleValue>\n <ng-container *ngTemplateOutlet=\"logLineValue; context: { key, value }\"></ng-container>\n </ng-template>\n <div *ngIf=\"logValueArray(value); let valueArray; else: singleValue\">\n <table class=\"table is-dark is-bordered is-striped\">\n <thead *ngIf=\"valueArray[0] | isObject\">\n <tr>\n <th class=\"has-text-white\" *ngFor=\"let v of valueArray[0] | keys\">{{ v.key }}</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let v of valueArray\">\n <ng-template #singleArrayValue>\n <td>{{ v }}</td>\n </ng-template>\n <ng-container *ngIf=\"v | isObject; else singleArrayValue\">\n <td *ngFor=\"let vv of v | keys\">{{ vv.value }}</td>\n </ng-container>\n </tr>\n </tbody>\n </table>\n </div>\n </td>\n </tr>\n</ng-template>\n\n<ng-template #logStatusDetails let-model=\"model\" let-data=\"data\">\n <ng-container *bindOnce=\"model\">\n <div class=\"is-mb-2\">\n <span>Status:</span>\n <span class=\"is-pl-1\">{{ model.status }}</span>\n </div>\n\n <ng-container *ngIf=\"model.status === LogStatus.notRequired && model.logs?.is_not_relevant === 'True'\">\n <ul class=\"is-pl-3 is-list-style-disc\">\n <li *ngIf=\"model.logs.logs?.siteType_allowed === 'False'\">\n The\n <code>siteType</code>\n is not relevant.\n </li>\n <li *ngIf=\"model.logs.logs?.product_id_allowed === 'False'\">\n The primary product\n <code>@id</code>\n is not relevant.\n </li>\n <li *ngIf=\"model.logs.logs?.product_termType_allowed === 'False'\">\n The primary product\n <code>termType</code>\n is not relevant.\n </li>\n </ul>\n </ng-container>\n\n <ng-container\n *ngIf=\"model.logs && model.status !== LogStatus.notRequired && model.status !== LogStatus.skipHierarchy\">\n <ul class=\"is-pl-3 is-list-style-disc\">\n <ng-template #showRunOrchestrator>\n <li class=\"is-run-orchestrator\">\n <p *ngIf=\"model.logs?.shouldRun\">All the requirements were met to run the model.</p>\n <ng-container *ngIf=\"!model.logs?.shouldRun\">\n <p>Some of the requirements were not met to run the model.</p>\n <p>You can click on the model name on the left to view the debugging logs.</p>\n </ng-container>\n <ng-container *ngIf=\"model.logs?.logs?.error\">\n <p>The model failed to run for the following reason:</p>\n <p>\n <code>{{ model.logs.logs.error }}</code>\n </p>\n </ng-container>\n </li>\n </ng-template>\n\n <li\n class=\"is-no-run-orchestrator\"\n *ngIf=\"model.logs?.shouldRunOrchestrator === false; else showRunOrchestrator\">\n <ng-container *ngIf=\"!model.logs.runRequired\">\n <span class=\"is-run-node-type-not-allowed\" *ngIf=\"model.logs.logs?.node_type_allowed === 'False'\">\n This model should not run for {{ nodeType | pluralize: 0 }}\n </span>\n </ng-container>\n\n <ng-template #runNoConfig>\n <span class=\"is-run-not-empty\" *ngIf=\"model.logs.logs?.is_empty === 'False'\">\n The {{ data.type || 'blank node' }} with Term\n <code>{{ data.termId }}</code>\n is already present or already added by another model.\n </span>\n </ng-template>\n\n <ng-container *ngIf=\"model.config; else runNoConfig\">\n <p class=\"is-run-strategy-{{ model.config.runStrategy }}\" [ngSwitch]=\"model.config.runStrategy\">\n <span *ngSwitchCase=\"'always'\"></span>\n <span *ngSwitchCase=\"'add_key_if_missing'\">We only gap-fill this key if not present</span>\n <span *ngSwitchCase=\"'add_blank_node_if_missing'\">We only gap-fill this Blank Node if not present.</span>\n </p>\n\n <p class=\"is-mt-1\">\n <span\n class=\"is-run-with-measured\"\n *ngIf=\"\n model.config.runArgs?.runNonMeasured && hasMethodTier(data.original, EmissionMethodTier.measured)\n \">\n The\n <code>{{ model.config.value }}</code>\n was reported as measured.\n </span>\n </p>\n </ng-container>\n </li>\n\n <li *ngIf=\"model.logs?.replaceLowerTier !== undefined\">\n <span>\n The recalculated\n <b>methodTier</b>\n was\n </span>\n <span class=\"is-pl-1 is-underlined\" *ngIf=\"!model.logs.replaceLowerTier\">lower than</span>\n <span class=\"is-pl-1 is-underlined\" *ngIf=\"model.logs.replaceLowerTier\">higher than or equal to</span>\n <span class=\"is-pl-1\">\n the original\n <b>methodTier</b>\n .\n </span>\n </li>\n\n <li class=\"is-merge-replaceLowerTier\" *ngIf=\"model.logs.replaceLowerTier\">\n <span>The recalculated</span>\n <b class=\"is-pl-1\">{{ model.config?.mergeArgs?.replaceThreshold?.[0] || 'value' }}</b>\n <span class=\"is-pl-1\">was</span>\n <span class=\"is-pl-1\">\n <ng-container *ngIf=\"model.config?.mergeArgs\">\n <span class=\"is-underlined\" *ngIf=\"!model.logs.replaceThreshold\">less than</span>\n <span class=\"is-underlined\" *ngIf=\"model.logs.replaceThreshold\">more than or equal to</span>\n <b class=\"is-pl-1\">{{ model.config.mergeArgs.replaceThreshold[1] * 100 }}%</b>\n </ng-container>\n <ng-container *ngIf=\"!model.config?.mergeArgs\">\n <span class=\"is-underlined\" *ngIf=\"!model.logs.replaceThreshold\">not sufficiently</span>\n <span class=\"is-underlined\" *ngIf=\"model.logs.replaceThreshold\">sufficiently</span>\n </ng-container>\n </span>\n <span class=\"is-pl-1\">different from the original</span>\n <b class=\"is-pl-1\">{{ model.config?.mergeArgs?.replaceThreshold?.[0] || 'value' }}.</b>\n </li>\n </ul>\n </ng-container>\n </ng-container>\n</ng-template>\n\n<ng-template #docsLink let-model>\n <a [href]=\"model.apiDocsPath || model.docPath || model.path\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\n <span>Docs</span>\n <fa-icon class=\"ml-1\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n </a>\n</ng-template>\n", styles: [":host{display:block}::ng-deep .table{background-color:transparent}::ng-deep .table td he-node-link{width:190px}@media screen and (max-width: 768px){::ng-deep .table td he-node-link{width:150px}}::ng-deep .table td .open-node+he-node-link{width:170px}@media screen and (max-width: 768px){::ng-deep .table td .open-node+he-node-link{width:130px}}::ng-deep .table td.has-border-right{box-shadow:1px 0 #6c8093}::ng-deep .table .has-sub-rows.is-open>td:first-child:before,::ng-deep .table .is-sub-row>td:first-child:before{display:block;position:absolute;content:\" \";background-color:#6c809333;height:100%;width:1px;top:0;left:12px}::ng-deep .table .has-sub-rows.is-open>td:first-child:before{top:25px}::ng-deep .table .popover-body .table-container{max-height:260px;overflow-y:auto}::ng-deep .copy-log he-clipboard{visibility:hidden}::ng-deep .copy-log:hover he-clipboard{visibility:visible}\n"] }]
246
247
  }], ctorParameters: function () { return [{ type: i1.HeNodeService }, { type: i2.HeSearchService }, { type: i3.HeEngineService }]; }, propDecorators: { node: [{
247
248
  type: Input
248
249
  }], nodeKey: [{
@@ -260,4 +261,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.8", ngImpor
260
261
  }], logsKey: [{
261
262
  type: Input
262
263
  }] } });
263
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-logs-models.component.js","sourceRoot":"","sources":["../../../../src/node/node-logs-models/node-logs-models.component.ts","../../../../src/node/node-logs-models/node-logs-models.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { Observable, from, of } from 'rxjs';\nimport {\n  distinct,\n  filter,\n  reduce,\n  toArray,\n  map,\n  distinctUntilChanged,\n  switchMap,\n  mergeMap,\n  mergeAll\n} from 'rxjs/operators';\nimport {\n  CycleFunctionalUnit,\n  EmissionMethodTier,\n  ITermJSONLD,\n  JSONLD,\n  NodeType,\n  Term,\n  TermTermType,\n  emissionTermTermType,\n  indicatorTermTermType,\n  inputTermTermType,\n  measurementTermTermType,\n  practiceTermTermType,\n  productTermTermType\n} from '@hestia-earth/schema';\nimport { keyToLabel } from '@hestia-earth/utils';\nimport { propertyValue } from '@hestia-earth/utils/dist/term';\nimport { loadResourceKey } from '@hestia-earth/glossary';\n\nimport {\n  IBlankNodeLogSubValue,\n  IBlankNodeLog,\n  LogStatus,\n  IConfigModel,\n  blankNode,\n  groupLogsByModel,\n  groupLogsByTerm,\n  modelCount,\n  computeTerms,\n  logValueArray,\n  INodeTermLogs,\n  INodeLogs,\n  nonBlankNode,\n  groupdLogsByKey,\n  INonBlankNodeLog,\n  ILog,\n  computeKeys\n} from './node-logs-models.model';\nimport { IJSONNode, HeNodeService } from '../node.service';\nimport { HeEngineService, IModel, IOrchestratorConfig } from '../../engine/engine.service';\nimport { matchExactQuery, matchId, matchTermType, matchType } from '../../search/search.model';\nimport { HeSearchService } from '../../search/search.service';\nimport { baseUrl, isExternal } from '../../common/utils';\nimport { termTypeLabel } from '../../terms/terms.model';\n\ntype nodeKey =\n  | 'inputs'\n  | 'products'\n  | 'completeness'\n  | 'practices'\n  | 'emissions'\n  | 'emissionsResourceUse'\n  | 'impacts'\n  | 'endpoints';\n\nconst nodeTypesLowerCase = Object.values(NodeType).map(v => v.toLowerCase());\n\nconst logIcon: {\n  [status in LogStatus]?: string | string[];\n} = {\n  [LogStatus.success]: 'check',\n  [LogStatus.error]: 'times',\n  [LogStatus.skipHierarchy]: ['far', 'circle'],\n  [LogStatus.dataProvided]: 'circle',\n  [LogStatus.notRequired]: 'dot-circle'\n};\n\nconst logColor: {\n  [status in LogStatus]?: string;\n} = {\n  [LogStatus.success]: 'success',\n  [LogStatus.error]: 'danger',\n  [LogStatus.skipHierarchy]: 'dark',\n  [LogStatus.dataProvided]: 'dark',\n  [LogStatus.notRequired]: 'grey'\n};\n\nconst methodIdLabel = (methodId: string, _model?: IModel) =>\n  (methodId\n    ? {\n        'cycle/transformation': 'Data From Transformation',\n        impact_assessment: 'Data From Cycle'\n      }[methodId]\n    : '') || (methodId.includes('/') ? methodId.split('/')[0] : keyToLabel(methodId));\n\nconst getModelsAt = (log: IBlankNodeLogSubValue | IBlankNodeLog, index: number) =>\n  ('modelsInSubValues' in log ? !log.modelsInSubValues || !log.isOpen : true) && log.configModels[index];\n\nconst requirementKeys = (requirements: { [key: string]: any }) =>\n  Object.keys(requirements).filter(k => !nodeTypesLowerCase.includes(k));\n\nconst requirementColor = (value: any) => (!value || ['None', 'False', '0', '0.0'].includes(value) ? 'danger' : 'white');\n\nconst requirementLinkedNodeByKey: {\n  [key: string]: (value: string) => Partial<JSONLD<NodeType>>;\n} = {\n  related_cycles: v => ({ '@type': NodeType.Cycle, '@id': v }),\n  cycle_id: v => ({ '@type': NodeType.Cycle, '@id': v }),\n  impact_assessment_id: v => ({ '@type': NodeType.ImpactAssessment, '@id': v }),\n  site_id: v => ({ '@type': NodeType.Site, '@id': v }),\n  source_id: v => ({ '@type': NodeType.Source, '@id': v })\n};\n\nconst requirementLinkedNode = (key: string, value: any) =>\n  key in requirementLinkedNodeByKey && requirementLinkedNodeByKey[key](value);\n\nconst isSystemBoundary =\n  (termId?: string) =>\n  ({ isRecalculated, isRequired }: Pick<ILog | IBlankNodeLogSubValue, 'isRecalculated' | 'isRequired'>) => {\n    // only exists for some terms\n    const inSystemBoundary = loadResourceKey('inHestiaDefaultSystemBoundary.json', termId);\n    return !inSystemBoundary ? [isRecalculated, isRequired].some(Boolean) : `${inSystemBoundary}` === 'true';\n  };\n\nconst isGenericTerm = (termId: string) => [termId.startsWith('excreta')].every(Boolean);\n\nconst extraTermIdsFromConfig = (config: IOrchestratorConfig, key: nodeKey) =>\n  config.models\n    .flat()\n    .filter(m => m.key === key)\n    .map(m => m.value)\n    .filter(Boolean)\n    .filter(v => !isGenericTerm(v));\n\nconst matchTermTypeFromKey: {\n  [key: string]: TermTermType[];\n} = {\n  products: productTermTermType.term,\n  inputs: inputTermTermType.term,\n  measurements: measurementTermTermType.term,\n  practices: practiceTermTermType.term,\n  emissions: emissionTermTermType.term,\n  emissionsResourceUse: indicatorTermTermType.term,\n  impacts: indicatorTermTermType.term,\n  endpoints: indicatorTermTermType.term\n};\n\nconst termSearch = (term: string) => term.replace(/[,\\s]/g, '').toLowerCase();\n\n@Component({\n  selector: 'he-node-logs-models',\n  templateUrl: './node-logs-models.component.html',\n  styleUrls: ['./node-logs-models.component.scss']\n})\nexport class NodeLogsModelsComponent implements OnInit {\n  private logs: string;\n  private allBlankNodes: (IBlankNodeLog | INonBlankNodeLog)[] = [];\n  private methodsById?: {\n    [id: string]: ITermJSONLD;\n  };\n  private termsById: {\n    [id: string]: ITermJSONLD;\n  } = {};\n\n  @Input()\n  private node?: IJSONNode;\n  @Input()\n  private nodeKey?: nodeKey;\n  @Input()\n  private originalValues: blankNode[] | nonBlankNode = [];\n  @Input()\n  private recalculatedValues: blankNode[] | nonBlankNode = [];\n  @Input()\n  private terms: ITermJSONLD[] = [];\n  @Input()\n  private filterTermTypes?: TermTermType[];\n  @Input()\n  private filterTermTypesLabel?: string;\n  @Input()\n  private logsKey?: string;\n\n  public logsUrl?: string;\n  public baseUrl = baseUrl();\n  public isExternal = isExternal();\n  public CycleFunctionalUnit = CycleFunctionalUnit;\n  public EmissionMethodTier = EmissionMethodTier;\n  public LogStatus = LogStatus;\n  public logIcon = logIcon;\n  public logColor = logColor;\n  public propertyValue = propertyValue;\n  public getModelsAt = getModelsAt;\n  public requirementKeys = requirementKeys;\n  public requirementColor = requirementColor;\n  public logValueArray = logValueArray;\n  public requirementLinkedNode = requirementLinkedNode;\n  public isSystemBoundary = isSystemBoundary;\n  public loading = true;\n  public nodeType: NodeType;\n  public blankNodes: (IBlankNodeLog | INonBlankNodeLog)[] = [];\n  public methodModelsCount = 0;\n  public onlyRequired = true;\n  public showLegend = true;\n\n  public term?: string;\n  public allTerms: (Term | ITermJSONLD)[] = [];\n  public suggestTerm = (text$: Observable<string>) =>\n    text$.pipe(\n      distinctUntilChanged(),\n      switchMap(v => this.suggestByTerm(v))\n    );\n\n  constructor(\n    private nodeService: HeNodeService,\n    private searchService: HeSearchService,\n    private engineService: HeEngineService\n  ) {}\n\n  async ngOnInit() {\n    this.logsUrl = this.nodeService.nodeLogsUrl(this.node);\n    // save as local variable to avoid \"reserved yield keyword\" issue\n    this.logs = await this.getLogs();\n    const groupedLogs = groupLogsByModel(this.logs);\n    const logs = this.logsKey ? groupedLogs[this.logsKey] : groupedLogs;\n\n    this.nodeType = this.node['@type'] || this.node.type;\n    const config = await this.engineService.ochestratorConfig(this.nodeType, this.node['@id'] || this.node.id);\n\n    const models = await this.searchTerms({\n      bool: {\n        must: [matchType(NodeType.Term), matchTermType(TermTermType.model)]\n      }\n    });\n\n    this.methodsById = await from(models)\n      .pipe(\n        filter(v => !!v),\n        distinct(v => v['@id']),\n        reduce((prev, curr) => ({ ...prev, [curr['@id']]: curr }), {})\n      )\n      .toPromise();\n\n    // from `model-links.json` file\n    const engineModels = await this.engineService.models();\n\n    this.isBlankNodes\n      ? await this.processBlankNodes(logs, engineModels, config)\n      : await this.processNonBlankNodes(logs, engineModels, config);\n\n    this.filterResults();\n\n    this.loading = false;\n  }\n\n  private getLogs() {\n    return this.nodeService.getLog(this.node).toPromise();\n  }\n\n  private suggestByTerm(term: string) {\n    return from(this.allTerms).pipe(\n      map(v => v.name),\n      filter(v => termSearch(v).includes(termSearch(term))),\n      toArray()\n    );\n  }\n\n  private async searchTerms(query: any) {\n    const { results } = await this.searchService.search<ITermJSONLD, NodeType.Term>({\n      fields: ['@type', '@id', 'name'],\n      limit: 10000,\n      query\n    });\n    return results;\n  }\n\n  private async processBlankNodes(\n    logs: INodeLogs | INodeTermLogs,\n    engineModels: IModel[],\n    config: IOrchestratorConfig\n  ) {\n    const extraTermIds = extraTermIdsFromConfig(config, this.nodeKey);\n    const matchTermTypes = [...(matchTermTypeFromKey[this.nodeKey] || []), ...(this.filterTermTypes || [])];\n    const extraTerms = await this.searchTerms({\n      bool: {\n        must: [\n          matchType(NodeType.Term),\n          matchTermTypes.length\n            ? {\n                bool: {\n                  should: matchTermTypes.map(matchTermType),\n                  minimum_should_match: 1\n                }\n              }\n            : null\n        ].filter(Boolean),\n        should: extraTermIds.map(matchId),\n        minimum_should_match: 1\n      }\n    });\n\n    this.allTerms = await computeTerms(\n      this.originalValues as blankNode[],\n      this.recalculatedValues as blankNode[],\n      this.terms,\n      this.filterTermTypes,\n      extraTerms\n    );\n    const mapFunc = groupLogsByTerm(\n      this.nodeType,\n      logs,\n      engineModels,\n      config,\n      this.originalValues as blankNode[],\n      this.recalculatedValues as blankNode[],\n      this.nodeKey\n    );\n    const allBlankNodes = this.allTerms.flatMap(mapFunc);\n    this.methodModelsCount = modelCount(allBlankNodes);\n\n    this.termsById = await of(allBlankNodes)\n      .pipe(\n        mergeMap(v => v.flatMap(vv => vv.subValues)),\n        map(v => v.id),\n        distinct(),\n        filter(v => !!v),\n        toArray(),\n        mergeMap(ids =>\n          from(\n            this.searchTerms({\n              bool: {\n                must: [matchType(NodeType.Term)],\n                should: ids.map(id => matchExactQuery('@id', id)),\n                minimum_should_match: 1\n              }\n            })\n          )\n        ),\n        mergeAll(),\n        reduce((prev, curr) => ({ ...prev, [curr['@id']]: curr }), {})\n      )\n      .toPromise();\n\n    this.allBlankNodes = allBlankNodes;\n  }\n\n  private processNonBlankNodes(logs: INodeLogs | INodeTermLogs, engineModels: IModel[], _config: IOrchestratorConfig) {\n    const mapFunc = groupdLogsByKey(\n      this.nodeType,\n      logs,\n      engineModels,\n      this.originalValues as nonBlankNode,\n      this.recalculatedValues as nonBlankNode\n    );\n    const keys = computeKeys(this.originalValues as nonBlankNode, this.recalculatedValues as nonBlankNode);\n    const allBlankNodes = keys.flatMap(mapFunc);\n    this.allBlankNodes = allBlankNodes;\n    this.methodModelsCount = 1;\n  }\n\n  public get isBlankNodes() {\n    return Array.isArray(this.originalValues) || Array.isArray(this.recalculatedValues);\n  }\n\n  public trackByBlankNode(_index: number, node: any) {\n    return node.termId || node.key;\n  }\n\n  public get filteredType() {\n    return this.filterTermTypesLabel || this.filterTermTypes?.map(termTypeLabel).join(' & ');\n  }\n\n  private filterBlankNode({ term: { name, '@id': id }, subValues, ...log }: IBlankNodeLog) {\n    return this.term\n      ? name.toLowerCase().includes(this.term.toLowerCase())\n      : !this.filterTermTypes?.length ||\n          !this.onlyRequired ||\n          isSystemBoundary(id)(log) ||\n          subValues.some(isSystemBoundary(id));\n  }\n\n  public filterResults() {\n    setTimeout(() => {\n      this.blankNodes = this.allBlankNodes.filter(log => !('term' in log) || this.filterBlankNode(log));\n    });\n  }\n\n  public methodName({ methodId, model }: IConfigModel) {\n    return this.methodsById[methodId]?.name || methodIdLabel(methodId, model);\n  }\n\n  public hasMethodTier(values: blankNode[], methodTier: EmissionMethodTier) {\n    return values.some(v => 'methodTier' in v && v.methodTier === methodTier);\n  }\n\n  public termById(id: string) {\n    return (\n      this.termsById[id] ||\n      ({\n        '@type': NodeType.Term,\n        '@id': id,\n        name: termTypeLabel(id)\n      } as ITermJSONLD)\n    );\n  }\n\n  public get functionalUnit() {\n    return (this.node as any)?.functionalUnit as CycleFunctionalUnit;\n  }\n}\n","<div class=\"px-3 pb-3\">\n  <div class=\"has-text-right mb-2\" *ngIf=\"!isExternal\">\n    <a class=\"is-size-7\" *ngIf=\"logsUrl\" [href]=\"logsUrl\" target=\"_blank\">\n      <fa-icon icon=\"external-link-alt\"></fa-icon>\n      <span class=\"pl-2\">Open Full Logs</span>\n    </a>\n  </div>\n\n  <he-data-table class=\"mb-1 is-small\" [small]=\"true\" maxHeight=\"320\">\n    <table class=\"table is-fullwidth is-narrow is-striped\">\n      <thead>\n        <tr>\n          <th class=\"width-auto has-border-right\">\n            <div class=\"field\" *ngIf=\"allTerms?.length\">\n              <div class=\"control is-expanded has-icons-right\">\n                <input\n                  class=\"input search-input is-small\"\n                  [(ngModel)]=\"term\"\n                  name=\"term\"\n                  placeholder=\"Filter by name\"\n                  [ngbTypeahead]=\"suggestTerm\"\n                  [focusFirst]=\"false\"\n                  (selectItem)=\"filterResults()\" />\n                <a class=\"icon is-small is-right\" [class.is-hidden]=\"!term\" (click)=\"term = ''; filterResults()\">\n                  <fa-icon icon=\"times\"></fa-icon>\n                </a>\n              </div>\n            </div>\n          </th>\n          <th *ngIf=\"isBlankNodes\">\n            <span class=\"is-pr-1\">Units</span>\n            <span>(per&nbsp;</span>\n            <span [ngSwitch]=\"functionalUnit\">\n              <ng-container *ngSwitchCase=\"CycleFunctionalUnit['1 ha']\">hectare</ng-container>\n              <ng-container *ngSwitchDefault>kg product</ng-container>\n            </span>\n            <span>)</span>\n          </th>\n          <th>Original</th>\n          <th>Recalculated</th>\n          <th *ngIf=\"isBlankNodes\">Difference</th>\n          <th *ngFor=\"let c of methodModelsCount | times; let i = index\">({{ i + 1 }})</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr *ngIf=\"loading\">\n          <td class=\"has-text-centered\" colspan=\"6\">\n            <div class=\"has-text-center py-3\">\n              <fa-icon icon=\"spinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n            </div>\n          </td>\n        </tr>\n        <tr *ngIf=\"!loading && blankNodes.length === 0\">\n          <td class=\"has-text-centered\" colspan=\"6\">\n            <span>No data</span>\n          </td>\n        </tr>\n        <ng-container *ngFor=\"let blankNode of blankNodes; trackBy: trackByBlankNode\">\n          <tr [class.has-sub-rows]=\"blankNode.canOpen\" [class.is-open]=\"blankNode.isOpen\">\n            <td class=\"width-auto has-border-right is-nowrap\" [attr.title]=\"blankNode.term?.name || blankNode.key\">\n              <a\n                class=\"is-inline-block is-align-top pr-2 open-node\"\n                (click)=\"blankNode.isOpen = !blankNode.isOpen\"\n                *ngIf=\"blankNode.canOpen\">\n                <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!blankNode.isOpen\"></fa-icon>\n                <fa-icon icon=\"angle-right\" [class.is-hidden]=\"blankNode.isOpen\"></fa-icon>\n              </a>\n              <he-node-link class=\"is-inline-block is-pre-wrap\" *ngIf=\"blankNode.term\" [node]=\"blankNode.term\">\n                <span [innerHtml]=\"blankNode.term.name | compound\"></span>\n              </he-node-link>\n              <span *ngIf=\"blankNode.key\">{{ blankNode.key }}</span>\n            </td>\n            <td *ngIf=\"isBlankNodes\">\n              <span class=\"is-nowrap\" [innerHtml]=\"blankNode.term?.units | compound\"></span>\n            </td>\n            <td>\n              <ng-template #defaultOriginalValue>\n                <span>{{ blankNode.originalValue | precision: 3 | default: '-' }}</span>\n              </ng-template>\n              <ng-container *ngIf=\"blankNode.allParallel; else defaultOriginalValue\">\n                <div *ngFor=\"let model of blankNode.configModels[0]\">\n                  {{ blankNode.originalValueByMethodId[model.methodId] | precision: 3 | default: '-' }}\n                </div>\n              </ng-container>\n            </td>\n            <td>\n              <ng-container *ngIf=\"!blankNode.isOriginal || blankNode.isRecalculated; else notRecalculated\">\n                <ng-template #defaultRecalculatedValue>\n                  <span>{{ blankNode.recalculatedValue | precision: 3 | default: '-' }}</span>\n                </ng-template>\n                <ng-container *ngIf=\"blankNode.allParallel; else defaultRecalculatedValue\">\n                  <div *ngFor=\"let model of blankNode.configModels[0]\">\n                    {{ blankNode.recalculatedValueByMethodId[model.methodId] | precision: 3 | default: '-' }}\n                  </div>\n                </ng-container>\n              </ng-container>\n            </td>\n            <td *ngIf=\"isBlankNodes\" class=\"is-nowrap\">\n              <ng-template #defaultDeltaValue>\n                <he-blank-node-value-delta\n                  *ngIf=\"blankNode.original.length && blankNode.isRecalculated; else noValue\"\n                  [value]=\"blankNode.recalculatedValue\"\n                  [originalValue]=\"blankNode.originalValue\"></he-blank-node-value-delta>\n              </ng-template>\n              <ng-container *ngIf=\"blankNode.allParallel; else defaultDeltaValue\">\n                <div *ngFor=\"let model of blankNode.configModels[0]\">\n                  <he-blank-node-value-delta\n                    *ngIf=\"\n                      blankNode.originalValueByMethodId[model.methodId] !== null &&\n                        blankNode.recalculatedValueByMethodId[model.methodId] !== null;\n                      else noValue\n                    \"\n                    [value]=\"blankNode.recalculatedValueByMethodId[model.methodId]\"\n                    [originalValue]=\"blankNode.originalValueByMethodId[model.methodId]\"></he-blank-node-value-delta>\n                </div>\n              </ng-container>\n            </td>\n            <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: blankNode }\"></ng-container>\n          </tr>\n\n          <tr\n            *ngFor=\"let subValue of blankNode.keys\"\n            [class.is-hidden]=\"!blankNode.isOpen\"\n            [class.has-sub-rows]=\"blankNode.subValues?.length\"\n            [class.is-sub-row]=\"blankNode.canOpen\">\n            <td class=\"width-auto has-border-right is-nowrap\">\n              <span class=\"is-inline-block is-align-top pl-3 pr-1 field-node\">Field:</span>\n\n              <a\n                class=\"is-inline-block is-pre-wrap\"\n                *ngIf=\"blankNode.type\"\n                [href]=\"baseUrl + '/schema/' + blankNode.type + '#' + subValue.key\"\n                target=\"_blank\"\n                [title]=\"subValue.key\">\n                <span>{{ subValue.key }}</span>\n              </a>\n              <span class=\"is-inline-block is-align-top\" *ngIf=\"!blankNode.type\">{{ subValue.key }}</span>\n            </td>\n            <td *ngIf=\"isBlankNodes\"></td>\n            <td>\n              <span *ngIf=\"subValue.originalValue !== null; else noValue\">\n                {{ subValue.originalValue | precision: 3 | default: '-' }}\n              </span>\n            </td>\n            <td>\n              <span *ngIf=\"subValue.isRecalculated || subValue.key === 'impactAssessment'; else notRecalculated\">\n                {{ subValue.recalculatedValue | precision: 3 | default: '-' }}\n              </span>\n            </td>\n            <td *ngIf=\"isBlankNodes\">-</td>\n            <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: subValue }\"></ng-container>\n          </tr>\n\n          <tr\n            *ngFor=\"let subValue of blankNode.subValues\"\n            [class.is-hidden]=\"!blankNode.isOpen\"\n            [class.is-sub-row]=\"blankNode.canOpen\">\n            <td class=\"width-auto has-border-right\">\n              <span class=\"is-inline-block is-align-top pl-3\">{{ subValue.key | keyToLabel }}</span>\n\n              <ng-container *ngIf=\"subValue.id\">\n                <span class=\"is-inline-block\" class=\"is-inline-block is-align-top pr-1\">:</span>\n\n                <ng-container [ngSwitch]=\"subValue.key\">\n                  <span class=\"is-inline-block\" *ngSwitchCase=\"'backgroundData'\">{{ subValue.id | keyToLabel }}</span>\n                  <he-node-link\n                    *ngSwitchDefault\n                    class=\"is-block pl-4\"\n                    [node]=\"termById(subValue.id)\"\n                    [attr.title]=\"termById(subValue.id).name\">\n                    <span [innerHtml]=\"termById(subValue.id).name | compound\"></span>\n                  </he-node-link>\n                </ng-container>\n              </ng-container>\n            </td>\n            <td *ngIf=\"isBlankNodes\">\n              <span class=\"is-nowrap\" *ngIf=\"subValue.showUnits\" [innerHtml]=\"blankNode.term?.units | compound\"></span>\n            </td>\n            <td>\n              <span *ngIf=\"subValue.originalValue !== null; else noValue\">\n                {{ subValue.originalValue | precision: 3 | default: '-' }}\n              </span>\n            </td>\n            <td>\n              <span *ngIf=\"subValue.isRecalculated; else notRecalculated\">\n                {{ subValue.recalculatedValue | precision: 3 | default: '-' }}\n              </span>\n            </td>\n            <td *ngIf=\"isBlankNodes\">-</td>\n            <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: subValue }\"></ng-container>\n          </tr>\n        </ng-container>\n      </tbody>\n    </table>\n  </he-data-table>\n\n  <div class=\"is-size-7 is-italic\">\n    <div class=\"columns is-variable is-1 my-0\">\n      <div class=\"column is-narrow\">\n        <p>\n          <a class=\"is-inline-block pr-2\" (click)=\"showLegend = !showLegend\">\n            <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!showLegend\"></fa-icon>\n            <fa-icon icon=\"angle-right\" [class.is-hidden]=\"showLegend\"></fa-icon>\n          </a>\n          <span class=\"is-inline-block\">Legend:</span>\n        </p>\n        <ul class=\"content pl-2\" [class.is-hidden]=\"!showLegend\">\n          <ng-container *ngFor=\"let status of LogStatus | keys\">\n            <li *ngIf=\"logIcon[status.value]\" class=\"has-text-{{ logColor[status.value] }}\">\n              <fa-icon [icon]=\"logIcon[status.value]\"></fa-icon>\n              <span class=\"pl-1\">{{ status.value }}</span>\n            </li>\n          </ng-container>\n        </ul>\n      </div>\n      <div class=\"column has-text-right\" *ngIf=\"filteredType\">\n        <label class=\"is-inline-block checkbox\">\n          <input\n            type=\"checkbox\"\n            class=\"selector\"\n            [(ngModel)]=\"onlyRequired\"\n            (change)=\"filterResults()\"\n            [disabled]=\"!!term\" />\n          <span class=\"ml-2\">\n            Show only {{ filteredType | pluralize }} included in the default Hestia system boundary\n          </span>\n        </label>\n      </div>\n    </div>\n  </div>\n</div>\n\n<ng-template #blankNodeModels let-data=\"data\">\n  <ng-template #notInSystemBoundary>\n    <td [attr.colspan]=\"methodModelsCount\">\n      <span>Not in Hestia system boundary</span>\n    </td>\n  </ng-template>\n\n  <ng-container *ngIf=\"isSystemBoundary(data); else noValue\">\n    <td class=\"blank-node-index-{{ i }}\" *ngFor=\"let c of methodModelsCount | times; let i = index\">\n      <ng-container *ngIf=\"getModelsAt(data, i); let models; else: noValue\">\n        <ng-template #modelSerie>\n          <ng-container *ngTemplateOutlet=\"blankNodeModel; context: { model: models, data }\"></ng-container>\n        </ng-template>\n        <div *ngIf=\"models | isArray; else modelSerie\">\n          <p *ngFor=\"let model of models\">\n            <ng-container *ngTemplateOutlet=\"blankNodeModel; context: { model, data }\"></ng-container>\n          </p>\n        </div>\n      </ng-container>\n    </td>\n  </ng-container>\n</ng-template>\n\n<ng-template #blankNodeModel let-model=\"model\" let-data=\"data\">\n  <span\n    class=\"is-nowrap\"\n    [class.trigger-popover]=\"model.showLogs\"\n    [ngbPopover]=\"logDetails\"\n    [autoClose]=\"'outside'\"\n    popoverClass=\"is-narrow\"\n    triggers=\"manual\"\n    #p=\"ngbPopover\"\n    placement=\"left\"\n    container=\"body\"\n    (click)=\"p.isOpen() ? p.close() : model.showLogs ? p.open({ logs: model.logs }) : null\">\n    <span class=\"is-capitalized\">{{ methodName(model) }}</span>\n    <span class=\"pl-1\" *ngIf=\"model.logs?.methodTier || model.model?.methodTier\">\n      [{{ model.logs?.methodTier || model.model?.methodTier }}]\n    </span>\n\n    <span\n      class=\"pl-1 has-text-{{ logColor[model.status] }} trigger-popover\"\n      [ngbPopover]=\"logStatusDetails\"\n      [autoClose]=\"'outside'\"\n      popoverClass=\"is-narrow\"\n      triggers=\"manual\"\n      #p1=\"ngbPopover\"\n      placement=\"left\"\n      container=\"body\"\n      (click)=\"$event.stopPropagation(); p1.isOpen() ? p1.close() : p1.open({ model, data })\">\n      <fa-icon [icon]=\"logIcon[model.status]\"></fa-icon>\n    </span>\n\n    <span class=\"pl-1\" *ngIf=\"model.model\">\n      (\n      <ng-container *ngTemplateOutlet=\"docsLink; context: { $implicit: model.model }\"></ng-container>\n      )\n    </span>\n  </span>\n</ng-template>\n\n<ng-template #noValue>-</ng-template>\n\n<ng-template #notRecalculated>not recalculated</ng-template>\n\n<ng-template #logDetails let-logs=\"logs\">\n  <div class=\"table-container\" *bindOnce=\"logs\">\n    <table class=\"table is-dark is-fullwidth\">\n      <tbody>\n        <ng-container *ngIf=\"logs?.requirements\">\n          <ng-container *ngFor=\"let key of requirementKeys(logs.requirements)\">\n            <ng-container *ngTemplateOutlet=\"logLine; context: { key, value: logs.requirements[key] }\"></ng-container>\n          </ng-container>\n        </ng-container>\n\n        <ng-container *ngIf=\"logs?.logs\">\n          <ng-container *ngFor=\"let key of logs.logs | keys\">\n            <ng-container *ngTemplateOutlet=\"logLine; context: key\"></ng-container>\n          </ng-container>\n        </ng-container>\n      </tbody>\n    </table>\n  </div>\n\n  <ng-container *bindOnce=\"logs\">\n    <div class=\"it-mt-2\" *ngIf=\"logs?.missingLookups?.length\">\n      <p>Optional data missing:</p>\n\n      <div class=\"table-container data-table-container\">\n        <table class=\"table is-dark is-fullwidth is-striped\">\n          <thead>\n            <tr>\n              <th class=\"has-text-white\">\n                <span>Filename</span>\n              </th>\n              <th class=\"has-text-white\">\n                <span>Column Title</span>\n              </th>\n              <th class=\"has-text-white\">\n                <span>Row (term.id)</span>\n              </th>\n            </tr>\n          </thead>\n          <tbody class=\"has-text-white\">\n            <tr *ngFor=\"let data of logs.missingLookups\">\n              <td>{{ data.filename }}</td>\n              <td>{{ data.column }}</td>\n              <td>{{ data.termId }}</td>\n            </tr>\n          </tbody>\n        </table>\n      </div>\n    </div>\n  </ng-container>\n</ng-template>\n\n<ng-template #logLineValue let-key=\"key\" let-value=\"value\">\n  <ng-template #defaultValue>\n    <span class=\"is-inline-block is-align-middle\">{{ value }}</span>\n  </ng-template>\n  <ng-container *ngIf=\"requirementLinkedNode(key, value); let linkedNode; else: defaultValue\">\n    <he-node-link\n      class=\"is-inline-block is-align-middle\"\n      linkClass=\"is-dark\"\n      [node]=\"linkedNode\"\n      [showExternalLink]=\"true\"></he-node-link>\n  </ng-container>\n</ng-template>\n\n<ng-template #logLine let-key=\"key\" let-value=\"value\">\n  <tr>\n    <td class=\"has-border-right copy-log\">\n      <span class=\"is-inline-block is-align-middle\" [ngSwitch]=\"key\">\n        <ng-container *ngSwitchDefault>{{ key | keyToLabel }}</ng-container>\n\n        <ng-container *ngSwitchCase=\"'node_type_allowed'\">\n          Is the current\n          <code>Node</code>\n          allowed to run this model\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'siteType_allowed'\">\n          Is the current\n          <code>siteType</code>\n          allowed to run this model\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'primary_product_id_allowed'\">\n          Is the current primary product\n          <code>@id</code>\n          allowed to run this model\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'primary_product_termType_allowed'\">\n          Is the current primary product\n          <code>termType</code>\n          allowed to run this model\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'geospatial_data'\">Has geospatial data necessary to run this model</ng-container>\n        <ng-container *ngSwitchCase=\"'contains_geospatial_data'\">\n          Has geospatial data necessary to run this model\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'current_size'\">Current polygon area</ng-container>\n        <ng-container *ngSwitchCase=\"'max_area_size'\">Maximum polygon area to run this model</ng-container>\n        <ng-container *ngSwitchCase=\"'below_max_area_size'\">Polygon below the maximum area</ng-container>\n        <ng-container *ngSwitchCase=\"'region_factor'\">Factor from region lookup</ng-container>\n\n        <ng-container *ngSwitchCase=\"'pesticides_complete'\">\n          Pesticide data are\n          <code>complete</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'has_pesticides_inputs'\">\n          Cycle contains\n          <code>pesticideAI</code>\n          Inputs\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'all_pesticideAI_have_lookup_value'\">\n          All\n          <code>pesticideAI</code>\n          Inputs have a lookup value\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'has_crop_residue_burnt'\">\n          <code>aboveGroundCropResidueBurnt</code>\n          is present as Product\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'liquid_slurry_sludge_P'\">Liquid, Slurry, and Sludge P</ng-container>\n\n        <ng-container *ngSwitchCase=\"'term_type_cropResidue_complete'\">\n          Data completeness for \"cropResidue\" must be\n          <code>true</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_excreta_complete'\">\n          Data completeness for \"excreta\" must be\n          <code>true</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_fertiliser_complete'\">\n          Data completeness for \"fertiliser\" must be\n          <code>true</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_material_complete'\">\n          Data completeness for \"material\" must be\n          <code>true</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_other_complete'\">\n          Data completeness for \"other\" must be\n          <code>true</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_pesticidesAntibiotics_complete'\">\n          Data completeness for \"pesticidesAntibiotics\" must be\n          <code>true</code>\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'term_type_cropResidue_incomplete'\">\n          Data completeness for \"cropResidue\" must be\n          <code>false</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_excreta_incomplete'\">\n          Data completeness for \"excreta\" must be\n          <code>false</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_fertiliser_incomplete'\">\n          Data completeness for \"fertiliser\" must be\n          <code>false</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_material_incomplete'\">\n          Data completeness for \"material\" must be\n          <code>false</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_other_incomplete'\">\n          Data completeness for \"other\" must be\n          <code>false</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_pesticidesAntibiotics_incomplete'\">\n          Data completeness for \"pesticidesAntibiotics\" must be\n          <code>false</code>\n        </ng-container>\n      </span>\n      <he-clipboard\n        class=\"is-inline-block is-align-middle\"\n        clipboardClass=\"is-size-7 is-p-1\"\n        [icon]=\"['far', 'clone']\"\n        [value]=\"key\"\n        [hideText]=\"true\"></he-clipboard>\n    </td>\n    <td>\n      <ng-template #singleValue>\n        <ng-container *ngTemplateOutlet=\"logLineValue; context: { key, value }\"></ng-container>\n      </ng-template>\n      <div *ngIf=\"logValueArray(value); let valueArray; else: singleValue\">\n        <table class=\"table is-dark is-bordered is-striped\">\n          <thead *ngIf=\"valueArray[0] | isObject\">\n            <tr>\n              <th class=\"has-text-white\" *ngFor=\"let v of valueArray[0] | keys\">{{ v.key }}</th>\n            </tr>\n          </thead>\n          <tbody>\n            <tr *ngFor=\"let v of valueArray\">\n              <ng-template #singleArrayValue>\n                <td>{{ v }}</td>\n              </ng-template>\n              <ng-container *ngIf=\"v | isObject; else singleArrayValue\">\n                <td *ngFor=\"let vv of v | keys\">{{ vv.value }}</td>\n              </ng-container>\n            </tr>\n          </tbody>\n        </table>\n      </div>\n    </td>\n  </tr>\n</ng-template>\n\n<ng-template #logStatusDetails let-model=\"model\" let-data=\"data\">\n  <ng-container *bindOnce=\"model\">\n    <div class=\"is-mb-2\">\n      <span>Status:</span>\n      <span class=\"is-pl-1\">{{ model.status }}</span>\n    </div>\n\n    <ng-container *ngIf=\"model.status === LogStatus.notRequired && model.logs?.is_not_relevant === 'True'\">\n      <ul class=\"is-pl-3 is-list-style-disc\">\n        <li *ngIf=\"model.logs.logs?.siteType_allowed === 'False'\">\n          The\n          <code>siteType</code>\n          is not relevant.\n        </li>\n        <li *ngIf=\"model.logs.logs?.product_id_allowed === 'False'\">\n          The primary product\n          <code>@id</code>\n          is not relevant.\n        </li>\n        <li *ngIf=\"model.logs.logs?.product_termType_allowed === 'False'\">\n          The primary product\n          <code>termType</code>\n          is not relevant.\n        </li>\n      </ul>\n    </ng-container>\n\n    <ng-container\n      *ngIf=\"model.logs && model.status !== LogStatus.notRequired && model.status !== LogStatus.skipHierarchy\">\n      <ul class=\"is-pl-3 is-list-style-disc\">\n        <ng-template #showRunOrchestrator>\n          <li class=\"is-run-orchestrator\">\n            <p *ngIf=\"model.logs?.shouldRun\">All the requirements were met to run the model.</p>\n            <ng-container *ngIf=\"!model.logs?.shouldRun\">\n              <p>Some of the requirements were not met to run the model.</p>\n              <p>You can click on the model name on the left to view the debugging logs.</p>\n            </ng-container>\n            <ng-container *ngIf=\"model.logs?.logs?.error\">\n              <p>The model failed to run for the following reason:</p>\n              <p>\n                <code>{{ model.logs.logs.error }}</code>\n              </p>\n            </ng-container>\n          </li>\n        </ng-template>\n\n        <li\n          class=\"is-no-run-orchestrator\"\n          *ngIf=\"model.logs?.shouldRunOrchestrator === false; else showRunOrchestrator\">\n          <ng-container *ngIf=\"!model.logs.runRequired\">\n            <span class=\"is-run-node-type-not-allowed\" *ngIf=\"model.logs.logs?.node_type_allowed === 'False'\">\n              This model should not run for {{ nodeType | pluralize: 0 }}\n            </span>\n          </ng-container>\n\n          <ng-template #runNoConfig>\n            <span class=\"is-run-not-empty\" *ngIf=\"model.logs.logs?.is_empty === 'False'\">\n              The {{ data.type || 'blank node' }} with Term\n              <code>{{ data.termId }}</code>\n              is already present or already added by another model.\n            </span>\n          </ng-template>\n\n          <ng-container *ngIf=\"model.config; else runNoConfig\">\n            <p class=\"is-run-strategy-{{ model.config.runStrategy }}\" [ngSwitch]=\"model.config.runStrategy\">\n              <span *ngSwitchCase=\"'always'\"></span>\n              <span *ngSwitchCase=\"'add_key_if_missing'\">We only gap-fill this key if not present</span>\n              <span *ngSwitchCase=\"'add_blank_node_if_missing'\">We only gap-fill this Blank Node if not present.</span>\n            </p>\n\n            <p class=\"is-mt-1\">\n              <span\n                class=\"is-run-with-measured\"\n                *ngIf=\"\n                  model.config.runArgs?.runNonMeasured && hasMethodTier(data.original, EmissionMethodTier.measured)\n                \">\n                The\n                <code>{{ model.config.value }}</code>\n                was reported as measured.\n              </span>\n            </p>\n          </ng-container>\n        </li>\n\n        <li *ngIf=\"model.logs?.replaceLowerTier !== undefined\">\n          <span>\n            The recalculated\n            <b>methodTier</b>\n            was\n          </span>\n          <span class=\"is-pl-1 is-underlined\" *ngIf=\"!model.logs.replaceLowerTier\">lower than</span>\n          <span class=\"is-pl-1 is-underlined\" *ngIf=\"model.logs.replaceLowerTier\">higher than or equal to</span>\n          <span class=\"is-pl-1\">\n            the original\n            <b>methodTier</b>\n            .\n          </span>\n        </li>\n\n        <li class=\"is-merge-replaceLowerTier\" *ngIf=\"model.logs.replaceLowerTier\">\n          <span>The recalculated</span>\n          <b class=\"is-pl-1\">{{ model.config?.mergeArgs?.replaceThreshold?.[0] || 'value' }}</b>\n          <span class=\"is-pl-1\">was</span>\n          <span class=\"is-pl-1\">\n            <ng-container *ngIf=\"model.config?.mergeArgs\">\n              <span class=\"is-underlined\" *ngIf=\"!model.logs.replaceThreshold\">less than</span>\n              <span class=\"is-underlined\" *ngIf=\"model.logs.replaceThreshold\">more than or equal to</span>\n              <b class=\"is-pl-1\">{{ model.config.mergeArgs.replaceThreshold[1] * 100 }}%</b>\n            </ng-container>\n            <ng-container *ngIf=\"!model.config?.mergeArgs\">\n              <span class=\"is-underlined\" *ngIf=\"!model.logs.replaceThreshold\">not sufficiently</span>\n              <span class=\"is-underlined\" *ngIf=\"model.logs.replaceThreshold\">sufficiently</span>\n            </ng-container>\n          </span>\n          <span class=\"is-pl-1\">different from the original</span>\n          <b class=\"is-pl-1\">{{ model.config?.mergeArgs?.replaceThreshold?.[0] || 'value' }}.</b>\n        </li>\n      </ul>\n    </ng-container>\n  </ng-container>\n</ng-template>\n\n<ng-template #docsLink let-model>\n  <a [href]=\"model.apiDocsPath || model.docPath || model.path\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\n    <span>Docs</span>\n    <fa-icon class=\"ml-1\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n  </a>\n</ng-template>\n"]}
264
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"node-logs-models.component.js","sourceRoot":"","sources":["../../../../src/node/node-logs-models/node-logs-models.component.ts","../../../../src/node/node-logs-models/node-logs-models.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { Observable, from, of } from 'rxjs';\nimport {\n  distinct,\n  filter,\n  reduce,\n  toArray,\n  map,\n  distinctUntilChanged,\n  switchMap,\n  mergeMap,\n  mergeAll\n} from 'rxjs/operators';\nimport {\n  CycleFunctionalUnit,\n  EmissionMethodTier,\n  ITermJSONLD,\n  JSONLD,\n  NodeType,\n  Term,\n  TermTermType,\n  emissionTermTermType,\n  indicatorTermTermType,\n  inputTermTermType,\n  measurementTermTermType,\n  practiceTermTermType,\n  productTermTermType\n} from '@hestia-earth/schema';\nimport { keyToLabel } from '@hestia-earth/utils';\nimport { propertyValue } from '@hestia-earth/utils/dist/term';\nimport { loadResourceKey } from '@hestia-earth/glossary';\n\nimport {\n  IBlankNodeLogSubValue,\n  IBlankNodeLog,\n  LogStatus,\n  IConfigModel,\n  blankNode,\n  groupLogsByModel,\n  groupLogsByTerm,\n  modelCount,\n  computeTerms,\n  logValueArray,\n  INodeTermLogs,\n  INodeLogs,\n  nonBlankNode,\n  groupdLogsByKey,\n  INonBlankNodeLog,\n  ILog,\n  computeKeys\n} from './node-logs-models.model';\nimport { IJSONNode, HeNodeService } from '../node.service';\nimport { HeEngineService, IModel, IOrchestratorConfig } from '../../engine/engine.service';\nimport { matchExactQuery, matchId, matchTermType, matchType } from '../../search/search.model';\nimport { HeSearchService } from '../../search/search.service';\nimport { baseUrl, isExternal, typeaheadFocus } from '../../common/utils';\nimport { termTypeLabel } from '../../terms/terms.model';\n\ntype nodeKey =\n  | 'inputs'\n  | 'products'\n  | 'completeness'\n  | 'practices'\n  | 'emissions'\n  | 'emissionsResourceUse'\n  | 'impacts'\n  | 'endpoints';\n\nconst nodeTypesLowerCase = Object.values(NodeType).map(v => v.toLowerCase());\n\nconst logIcon: {\n  [status in LogStatus]?: string | string[];\n} = {\n  [LogStatus.success]: 'check',\n  [LogStatus.error]: 'times',\n  [LogStatus.skipHierarchy]: ['far', 'circle'],\n  [LogStatus.dataProvided]: 'circle',\n  [LogStatus.notRequired]: 'dot-circle'\n};\n\nconst logColor: {\n  [status in LogStatus]?: string;\n} = {\n  [LogStatus.success]: 'success',\n  [LogStatus.error]: 'danger',\n  [LogStatus.skipHierarchy]: 'dark',\n  [LogStatus.dataProvided]: 'dark',\n  [LogStatus.notRequired]: 'grey'\n};\n\nconst methodIdLabel = (methodId: string, _model?: IModel) =>\n  (methodId\n    ? {\n        'cycle/transformation': 'Data From Transformation',\n        impact_assessment: 'Data From Cycle'\n      }[methodId]\n    : '') || (methodId.includes('/') ? methodId.split('/')[0] : keyToLabel(methodId));\n\nconst getModelsAt = (log: IBlankNodeLogSubValue | IBlankNodeLog, index: number) =>\n  ('modelsInSubValues' in log ? !log.modelsInSubValues || !log.isOpen : true) && log.configModels[index];\n\nconst requirementKeys = (requirements: { [key: string]: any }) =>\n  Object.keys(requirements).filter(k => !nodeTypesLowerCase.includes(k));\n\nconst requirementColor = (value: any) => (!value || ['None', 'False', '0', '0.0'].includes(value) ? 'danger' : 'white');\n\nconst requirementLinkedNodeByKey: {\n  [key: string]: (value: string) => Partial<JSONLD<NodeType>>;\n} = {\n  related_cycles: v => ({ '@type': NodeType.Cycle, '@id': v }),\n  cycle_id: v => ({ '@type': NodeType.Cycle, '@id': v }),\n  impact_assessment_id: v => ({ '@type': NodeType.ImpactAssessment, '@id': v }),\n  site_id: v => ({ '@type': NodeType.Site, '@id': v }),\n  source_id: v => ({ '@type': NodeType.Source, '@id': v })\n};\n\nconst requirementLinkedNode = (key: string, value: any) =>\n  key in requirementLinkedNodeByKey && requirementLinkedNodeByKey[key](value);\n\nconst isSystemBoundary =\n  (termId?: string) =>\n  ({ isRecalculated, isRequired }: Pick<ILog | IBlankNodeLogSubValue, 'isRecalculated' | 'isRequired'>) => {\n    // only exists for some terms\n    const inSystemBoundary = loadResourceKey('inHestiaDefaultSystemBoundary.json', termId);\n    return !inSystemBoundary ? [isRecalculated, isRequired].some(Boolean) : `${inSystemBoundary}` === 'true';\n  };\n\nconst isGenericTerm = (termId: string) => [termId.startsWith('excreta')].every(Boolean);\n\nconst extraTermIdsFromConfig = (config: IOrchestratorConfig, key: nodeKey) =>\n  config.models\n    .flat()\n    .filter(m => m.key === key)\n    .map(m => m.value)\n    .filter(Boolean)\n    .filter(v => !isGenericTerm(v));\n\nconst matchTermTypeFromKey: {\n  [key: string]: TermTermType[];\n} = {\n  products: productTermTermType.term,\n  inputs: inputTermTermType.term,\n  measurements: measurementTermTermType.term,\n  practices: practiceTermTermType.term,\n  emissions: emissionTermTermType.term,\n  emissionsResourceUse: indicatorTermTermType.term,\n  impacts: indicatorTermTermType.term,\n  endpoints: indicatorTermTermType.term\n};\n\nconst termSearch = (term = '') => term.replace(/[,\\s]/g, '').toLowerCase();\n\n@Component({\n  selector: 'he-node-logs-models',\n  templateUrl: './node-logs-models.component.html',\n  styleUrls: ['./node-logs-models.component.scss']\n})\nexport class NodeLogsModelsComponent implements OnInit {\n  private logs: string;\n  private allBlankNodes: (IBlankNodeLog | INonBlankNodeLog)[] = [];\n  private methodsById?: {\n    [id: string]: ITermJSONLD;\n  };\n  private termsById: {\n    [id: string]: ITermJSONLD;\n  } = {};\n\n  @Input()\n  private node?: IJSONNode;\n  @Input()\n  private nodeKey?: nodeKey;\n  @Input()\n  private originalValues: blankNode[] | nonBlankNode = [];\n  @Input()\n  private recalculatedValues: blankNode[] | nonBlankNode = [];\n  @Input()\n  private terms: ITermJSONLD[] = [];\n  @Input()\n  private filterTermTypes?: TermTermType[];\n  @Input()\n  private filterTermTypesLabel?: string;\n  @Input()\n  private logsKey?: string;\n\n  public logsUrl?: string;\n  public baseUrl = baseUrl();\n  public isExternal = isExternal();\n  public CycleFunctionalUnit = CycleFunctionalUnit;\n  public EmissionMethodTier = EmissionMethodTier;\n  public LogStatus = LogStatus;\n  public logIcon = logIcon;\n  public logColor = logColor;\n  public propertyValue = propertyValue;\n  public getModelsAt = getModelsAt;\n  public requirementKeys = requirementKeys;\n  public requirementColor = requirementColor;\n  public logValueArray = logValueArray;\n  public requirementLinkedNode = requirementLinkedNode;\n  public isSystemBoundary = isSystemBoundary;\n  public loading = true;\n  public nodeType: NodeType;\n  public blankNodes: (IBlankNodeLog | INonBlankNodeLog)[] = [];\n  public methodModelsCount = 0;\n  public onlyRequired = true;\n  public showLegend = true;\n\n  public term?: string;\n  public allTerms: (Term | ITermJSONLD)[] = [];\n  public suggestTerm = (text$: Observable<string>) =>\n    text$.pipe(\n      distinctUntilChanged(),\n      switchMap(v => this.suggestByTerm(v))\n    );\n\n  public typeaheadFocus = typeaheadFocus;\n\n  constructor(\n    private nodeService: HeNodeService,\n    private searchService: HeSearchService,\n    private engineService: HeEngineService\n  ) {}\n\n  async ngOnInit() {\n    this.logsUrl = this.nodeService.nodeLogsUrl(this.node);\n    // save as local variable to avoid \"reserved yield keyword\" issue\n    this.logs = await this.getLogs();\n    const groupedLogs = groupLogsByModel(this.logs);\n    const logs = this.logsKey ? groupedLogs[this.logsKey] : groupedLogs;\n\n    this.nodeType = this.node['@type'] || this.node.type;\n    const config = await this.engineService.ochestratorConfig(this.nodeType, this.node['@id'] || this.node.id);\n\n    const models = await this.searchTerms({\n      bool: {\n        must: [matchType(NodeType.Term), matchTermType(TermTermType.model)]\n      }\n    });\n\n    this.methodsById = await from(models)\n      .pipe(\n        filter(v => !!v),\n        distinct(v => v['@id']),\n        reduce((prev, curr) => ({ ...prev, [curr['@id']]: curr }), {})\n      )\n      .toPromise();\n\n    // from `model-links.json` file\n    const engineModels = await this.engineService.models();\n\n    this.isBlankNodes\n      ? await this.processBlankNodes(logs, engineModels, config)\n      : await this.processNonBlankNodes(logs, engineModels, config);\n\n    this.filterResults();\n\n    this.loading = false;\n  }\n\n  private getLogs() {\n    return this.nodeService.getLog(this.node).toPromise();\n  }\n\n  private suggestByTerm(term: string) {\n    return from(this.allTerms).pipe(\n      map(v => v.name),\n      filter(v => termSearch(v).includes(termSearch(term))),\n      toArray()\n    );\n  }\n\n  private async searchTerms(query: any) {\n    const { results } = await this.searchService.search<ITermJSONLD, NodeType.Term>({\n      fields: ['@type', '@id', 'name'],\n      limit: 10000,\n      query\n    });\n    return results;\n  }\n\n  private async processBlankNodes(\n    logs: INodeLogs | INodeTermLogs,\n    engineModels: IModel[],\n    config: IOrchestratorConfig\n  ) {\n    const extraTermIds = extraTermIdsFromConfig(config, this.nodeKey);\n    const matchTermTypes = [...(matchTermTypeFromKey[this.nodeKey] || []), ...(this.filterTermTypes || [])];\n    const extraTerms = await this.searchTerms({\n      bool: {\n        must: [\n          matchType(NodeType.Term),\n          matchTermTypes.length\n            ? {\n                bool: {\n                  should: matchTermTypes.map(matchTermType),\n                  minimum_should_match: 1\n                }\n              }\n            : null\n        ].filter(Boolean),\n        should: extraTermIds.map(matchId),\n        minimum_should_match: 1\n      }\n    });\n\n    this.allTerms = await computeTerms(\n      this.originalValues as blankNode[],\n      this.recalculatedValues as blankNode[],\n      this.terms,\n      this.filterTermTypes,\n      extraTerms\n    );\n    const mapFunc = groupLogsByTerm(\n      this.nodeType,\n      logs,\n      engineModels,\n      config,\n      this.originalValues as blankNode[],\n      this.recalculatedValues as blankNode[],\n      this.nodeKey\n    );\n    const allBlankNodes = this.allTerms.flatMap(mapFunc);\n    this.methodModelsCount = modelCount(allBlankNodes);\n\n    this.termsById = await of(allBlankNodes)\n      .pipe(\n        mergeMap(v => v.flatMap(vv => vv.subValues)),\n        map(v => v.id),\n        distinct(),\n        filter(v => !!v),\n        toArray(),\n        mergeMap(ids =>\n          from(\n            this.searchTerms({\n              bool: {\n                must: [matchType(NodeType.Term)],\n                should: ids.map(id => matchExactQuery('@id', id)),\n                minimum_should_match: 1\n              }\n            })\n          )\n        ),\n        mergeAll(),\n        reduce((prev, curr) => ({ ...prev, [curr['@id']]: curr }), {})\n      )\n      .toPromise();\n\n    this.allBlankNodes = allBlankNodes;\n  }\n\n  private processNonBlankNodes(logs: INodeLogs | INodeTermLogs, engineModels: IModel[], _config: IOrchestratorConfig) {\n    const mapFunc = groupdLogsByKey(\n      this.nodeType,\n      logs,\n      engineModels,\n      this.originalValues as nonBlankNode,\n      this.recalculatedValues as nonBlankNode\n    );\n    const keys = computeKeys(this.originalValues as nonBlankNode, this.recalculatedValues as nonBlankNode);\n    const allBlankNodes = keys.flatMap(mapFunc);\n    this.allBlankNodes = allBlankNodes;\n    this.methodModelsCount = 1;\n  }\n\n  public get isBlankNodes() {\n    return Array.isArray(this.originalValues) || Array.isArray(this.recalculatedValues);\n  }\n\n  public trackByBlankNode(_index: number, node: any) {\n    return node.termId || node.key;\n  }\n\n  public get filteredType() {\n    return this.filterTermTypesLabel || this.filterTermTypes?.map(termTypeLabel).join(' & ');\n  }\n\n  private filterBlankNode({ term: { name, '@id': id }, subValues, ...log }: IBlankNodeLog) {\n    return this.term\n      ? name.toLowerCase().includes(this.term.toLowerCase())\n      : !this.filterTermTypes?.length ||\n          !this.onlyRequired ||\n          isSystemBoundary(id)(log) ||\n          subValues.some(isSystemBoundary(id));\n  }\n\n  public filterResults() {\n    setTimeout(() => {\n      this.blankNodes = this.allBlankNodes.filter(log => !('term' in log) || this.filterBlankNode(log));\n    });\n  }\n\n  public methodName({ methodId, model }: IConfigModel) {\n    return this.methodsById[methodId]?.name || methodIdLabel(methodId, model);\n  }\n\n  public hasMethodTier(values: blankNode[], methodTier: EmissionMethodTier) {\n    return values.some(v => 'methodTier' in v && v.methodTier === methodTier);\n  }\n\n  public termById(id: string) {\n    return (\n      this.termsById[id] ||\n      ({\n        '@type': NodeType.Term,\n        '@id': id,\n        name: termTypeLabel(id)\n      } as ITermJSONLD)\n    );\n  }\n\n  public get functionalUnit() {\n    return (this.node as any)?.functionalUnit as CycleFunctionalUnit;\n  }\n}\n","<div class=\"px-3 pb-3\">\n  <div class=\"has-text-right mb-2\" *ngIf=\"!isExternal\">\n    <a class=\"is-size-7\" *ngIf=\"logsUrl\" [href]=\"logsUrl\" target=\"_blank\">\n      <fa-icon icon=\"external-link-alt\"></fa-icon>\n      <span class=\"pl-2\">Open Full Logs</span>\n    </a>\n  </div>\n\n  <he-data-table class=\"mb-1 is-small\" [small]=\"true\" maxHeight=\"320\">\n    <table class=\"table is-fullwidth is-narrow is-striped\">\n      <thead>\n        <tr>\n          <th class=\"width-auto has-border-right\">\n            <div class=\"field\" *ngIf=\"allTerms?.length\">\n              <div class=\"control is-expanded has-icons-right\">\n                <input\n                  class=\"input search-input is-small\"\n                  [(ngModel)]=\"term\"\n                  name=\"term\"\n                  placeholder=\"Select entry by name\"\n                  [ngbTypeahead]=\"suggestTerm\"\n                  [focusFirst]=\"true\"\n                  (focus)=\"typeaheadFocus($event)\"\n                  (selectItem)=\"filterResults()\" />\n                <a class=\"icon is-small is-right\" [class.is-hidden]=\"!term\" (click)=\"term = ''; filterResults()\">\n                  <fa-icon icon=\"times\"></fa-icon>\n                </a>\n              </div>\n            </div>\n          </th>\n          <th *ngIf=\"isBlankNodes\">\n            <span class=\"is-pr-1\">Units</span>\n            <span>(per&nbsp;</span>\n            <span [ngSwitch]=\"functionalUnit\">\n              <ng-container *ngSwitchCase=\"CycleFunctionalUnit['1 ha']\">hectare</ng-container>\n              <ng-container *ngSwitchDefault>kg product</ng-container>\n            </span>\n            <span>)</span>\n          </th>\n          <th>Original</th>\n          <th>Recalculated</th>\n          <th *ngIf=\"isBlankNodes\">Difference</th>\n          <th *ngFor=\"let c of methodModelsCount | times; let i = index\">({{ i + 1 }})</th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr *ngIf=\"loading\">\n          <td class=\"has-text-centered\" colspan=\"6\">\n            <div class=\"has-text-center py-3\">\n              <fa-icon icon=\"spinner\" [pulse]=\"true\" size=\"lg\"></fa-icon>\n            </div>\n          </td>\n        </tr>\n        <tr *ngIf=\"!loading && blankNodes.length === 0\">\n          <td class=\"has-text-centered\" colspan=\"6\">\n            <span>No data</span>\n          </td>\n        </tr>\n        <ng-container *ngFor=\"let blankNode of blankNodes; trackBy: trackByBlankNode\">\n          <tr [class.has-sub-rows]=\"blankNode.canOpen\" [class.is-open]=\"blankNode.isOpen\">\n            <td class=\"width-auto has-border-right is-nowrap\" [attr.title]=\"blankNode.term?.name || blankNode.key\">\n              <a\n                class=\"is-inline-block is-align-top pr-2 open-node\"\n                (click)=\"blankNode.isOpen = !blankNode.isOpen\"\n                *ngIf=\"blankNode.canOpen\">\n                <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!blankNode.isOpen\"></fa-icon>\n                <fa-icon icon=\"angle-right\" [class.is-hidden]=\"blankNode.isOpen\"></fa-icon>\n              </a>\n              <he-node-link class=\"is-inline-block is-pre-wrap\" *ngIf=\"blankNode.term\" [node]=\"blankNode.term\">\n                <span [innerHtml]=\"blankNode.term.name | compound\"></span>\n              </he-node-link>\n              <span *ngIf=\"blankNode.key\">{{ blankNode.key }}</span>\n            </td>\n            <td *ngIf=\"isBlankNodes\">\n              <span class=\"is-nowrap\" [innerHtml]=\"blankNode.term?.units | compound\"></span>\n            </td>\n            <td>\n              <ng-template #defaultOriginalValue>\n                <span>{{ blankNode.originalValue | precision: 3 | default: '-' }}</span>\n              </ng-template>\n              <ng-container *ngIf=\"blankNode.allParallel; else defaultOriginalValue\">\n                <div *ngFor=\"let model of blankNode.configModels[0]\">\n                  {{ blankNode.originalValueByMethodId[model.methodId] | precision: 3 | default: '-' }}\n                </div>\n              </ng-container>\n            </td>\n            <td>\n              <ng-container *ngIf=\"!blankNode.isOriginal || blankNode.isRecalculated; else notRecalculated\">\n                <ng-template #defaultRecalculatedValue>\n                  <span>{{ blankNode.recalculatedValue | precision: 3 | default: '-' }}</span>\n                </ng-template>\n                <ng-container *ngIf=\"blankNode.allParallel; else defaultRecalculatedValue\">\n                  <div *ngFor=\"let model of blankNode.configModels[0]\">\n                    {{ blankNode.recalculatedValueByMethodId[model.methodId] | precision: 3 | default: '-' }}\n                  </div>\n                </ng-container>\n              </ng-container>\n            </td>\n            <td *ngIf=\"isBlankNodes\" class=\"is-nowrap\">\n              <ng-template #defaultDeltaValue>\n                <he-blank-node-value-delta\n                  *ngIf=\"blankNode.original.length && blankNode.isRecalculated; else noValue\"\n                  [value]=\"blankNode.recalculatedValue\"\n                  [originalValue]=\"blankNode.originalValue\"></he-blank-node-value-delta>\n              </ng-template>\n              <ng-container *ngIf=\"blankNode.allParallel; else defaultDeltaValue\">\n                <div *ngFor=\"let model of blankNode.configModels[0]\">\n                  <he-blank-node-value-delta\n                    *ngIf=\"\n                      blankNode.originalValueByMethodId[model.methodId] !== null &&\n                        blankNode.recalculatedValueByMethodId[model.methodId] !== null;\n                      else noValue\n                    \"\n                    [value]=\"blankNode.recalculatedValueByMethodId[model.methodId]\"\n                    [originalValue]=\"blankNode.originalValueByMethodId[model.methodId]\"></he-blank-node-value-delta>\n                </div>\n              </ng-container>\n            </td>\n            <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: blankNode }\"></ng-container>\n          </tr>\n\n          <tr\n            *ngFor=\"let subValue of blankNode.keys\"\n            [class.is-hidden]=\"!blankNode.isOpen\"\n            [class.has-sub-rows]=\"blankNode.subValues?.length\"\n            [class.is-sub-row]=\"blankNode.canOpen\">\n            <td class=\"width-auto has-border-right is-nowrap\">\n              <span class=\"is-inline-block is-align-top pl-3 pr-1 field-node\">Field:</span>\n\n              <a\n                class=\"is-inline-block is-pre-wrap\"\n                *ngIf=\"blankNode.type\"\n                [href]=\"baseUrl + '/schema/' + blankNode.type + '#' + subValue.key\"\n                target=\"_blank\"\n                [title]=\"subValue.key\">\n                <span>{{ subValue.key }}</span>\n              </a>\n              <span class=\"is-inline-block is-align-top\" *ngIf=\"!blankNode.type\">{{ subValue.key }}</span>\n            </td>\n            <td *ngIf=\"isBlankNodes\"></td>\n            <td>\n              <span *ngIf=\"subValue.originalValue !== null; else noValue\">\n                {{ subValue.originalValue | precision: 3 | default: '-' }}\n              </span>\n            </td>\n            <td>\n              <span *ngIf=\"subValue.isRecalculated || subValue.key === 'impactAssessment'; else notRecalculated\">\n                {{ subValue.recalculatedValue | precision: 3 | default: '-' }}\n              </span>\n            </td>\n            <td *ngIf=\"isBlankNodes\">-</td>\n            <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: subValue }\"></ng-container>\n          </tr>\n\n          <tr\n            *ngFor=\"let subValue of blankNode.subValues\"\n            [class.is-hidden]=\"!blankNode.isOpen\"\n            [class.is-sub-row]=\"blankNode.canOpen\">\n            <td class=\"width-auto has-border-right\">\n              <span class=\"is-inline-block is-align-top pl-3\">{{ subValue.key | keyToLabel }}</span>\n\n              <ng-container *ngIf=\"subValue.id\">\n                <span class=\"is-inline-block\" class=\"is-inline-block is-align-top pr-1\">:</span>\n\n                <ng-container [ngSwitch]=\"subValue.key\">\n                  <span class=\"is-inline-block\" *ngSwitchCase=\"'backgroundData'\">{{ subValue.id | keyToLabel }}</span>\n                  <he-node-link\n                    *ngSwitchDefault\n                    class=\"is-block pl-4\"\n                    [node]=\"termById(subValue.id)\"\n                    [attr.title]=\"termById(subValue.id).name\">\n                    <span [innerHtml]=\"termById(subValue.id).name | compound\"></span>\n                  </he-node-link>\n                </ng-container>\n              </ng-container>\n            </td>\n            <td *ngIf=\"isBlankNodes\">\n              <span class=\"is-nowrap\" *ngIf=\"subValue.showUnits\" [innerHtml]=\"blankNode.term?.units | compound\"></span>\n            </td>\n            <td>\n              <span *ngIf=\"subValue.originalValue !== null; else noValue\">\n                {{ subValue.originalValue | precision: 3 | default: '-' }}\n              </span>\n            </td>\n            <td>\n              <span *ngIf=\"subValue.isRecalculated; else notRecalculated\">\n                {{ subValue.recalculatedValue | precision: 3 | default: '-' }}\n              </span>\n            </td>\n            <td *ngIf=\"isBlankNodes\">-</td>\n            <ng-container *ngTemplateOutlet=\"blankNodeModels; context: { data: subValue }\"></ng-container>\n          </tr>\n        </ng-container>\n      </tbody>\n    </table>\n  </he-data-table>\n\n  <div class=\"is-size-7 is-italic\">\n    <div class=\"columns is-variable is-1 my-0\">\n      <div class=\"column is-narrow\">\n        <p>\n          <a class=\"is-inline-block pr-2\" (click)=\"showLegend = !showLegend\">\n            <fa-icon icon=\"angle-down\" [class.is-hidden]=\"!showLegend\"></fa-icon>\n            <fa-icon icon=\"angle-right\" [class.is-hidden]=\"showLegend\"></fa-icon>\n          </a>\n          <span class=\"is-inline-block\">Legend:</span>\n        </p>\n        <ul class=\"content pl-2\" [class.is-hidden]=\"!showLegend\">\n          <ng-container *ngFor=\"let status of LogStatus | keys\">\n            <li *ngIf=\"logIcon[status.value]\" class=\"has-text-{{ logColor[status.value] }}\">\n              <fa-icon [icon]=\"logIcon[status.value]\"></fa-icon>\n              <span class=\"pl-1\">{{ status.value }}</span>\n            </li>\n          </ng-container>\n        </ul>\n      </div>\n      <div class=\"column has-text-right\" *ngIf=\"filteredType\">\n        <label class=\"is-inline-block checkbox\">\n          <input\n            type=\"checkbox\"\n            class=\"selector\"\n            [(ngModel)]=\"onlyRequired\"\n            (change)=\"filterResults()\"\n            [disabled]=\"!!term\" />\n          <span class=\"ml-2\">\n            Show only {{ filteredType | pluralize }} included in the default Hestia system boundary\n          </span>\n        </label>\n      </div>\n    </div>\n  </div>\n</div>\n\n<ng-template #blankNodeModels let-data=\"data\">\n  <ng-template #notInSystemBoundary>\n    <td [attr.colspan]=\"methodModelsCount\">\n      <span>Not in Hestia system boundary</span>\n    </td>\n  </ng-template>\n\n  <ng-container *ngIf=\"isSystemBoundary(data); else noValue\">\n    <td class=\"blank-node-index-{{ i }}\" *ngFor=\"let c of methodModelsCount | times; let i = index\">\n      <ng-container *ngIf=\"getModelsAt(data, i); let models; else: noValue\">\n        <ng-template #modelSerie>\n          <ng-container *ngTemplateOutlet=\"blankNodeModel; context: { model: models, data }\"></ng-container>\n        </ng-template>\n        <div *ngIf=\"models | isArray; else modelSerie\">\n          <p *ngFor=\"let model of models\">\n            <ng-container *ngTemplateOutlet=\"blankNodeModel; context: { model, data }\"></ng-container>\n          </p>\n        </div>\n      </ng-container>\n    </td>\n  </ng-container>\n</ng-template>\n\n<ng-template #blankNodeModel let-model=\"model\" let-data=\"data\">\n  <span\n    class=\"is-nowrap\"\n    [class.trigger-popover]=\"model.showLogs\"\n    [ngbPopover]=\"logDetails\"\n    [autoClose]=\"'outside'\"\n    popoverClass=\"is-narrow\"\n    triggers=\"manual\"\n    #p=\"ngbPopover\"\n    placement=\"left\"\n    container=\"body\"\n    (click)=\"p.isOpen() ? p.close() : model.showLogs ? p.open({ logs: model.logs }) : null\">\n    <span class=\"is-capitalized\">{{ methodName(model) }}</span>\n    <span class=\"pl-1\" *ngIf=\"model.logs?.methodTier || model.model?.methodTier\">\n      [{{ model.logs?.methodTier || model.model?.methodTier }}]\n    </span>\n\n    <span\n      class=\"pl-1 has-text-{{ logColor[model.status] }} trigger-popover\"\n      [ngbPopover]=\"logStatusDetails\"\n      [autoClose]=\"'outside'\"\n      popoverClass=\"is-narrow\"\n      triggers=\"manual\"\n      #p1=\"ngbPopover\"\n      placement=\"left\"\n      container=\"body\"\n      (click)=\"$event.stopPropagation(); p1.isOpen() ? p1.close() : p1.open({ model, data })\">\n      <fa-icon [icon]=\"logIcon[model.status]\"></fa-icon>\n    </span>\n\n    <span class=\"pl-1\" *ngIf=\"model.model\">\n      (\n      <ng-container *ngTemplateOutlet=\"docsLink; context: { $implicit: model.model }\"></ng-container>\n      )\n    </span>\n  </span>\n</ng-template>\n\n<ng-template #noValue>-</ng-template>\n\n<ng-template #notRecalculated>not recalculated</ng-template>\n\n<ng-template #logDetails let-logs=\"logs\">\n  <div class=\"table-container\" *bindOnce=\"logs\">\n    <table class=\"table is-dark is-fullwidth\">\n      <tbody>\n        <ng-container *ngIf=\"logs?.requirements\">\n          <ng-container *ngFor=\"let key of requirementKeys(logs.requirements)\">\n            <ng-container *ngTemplateOutlet=\"logLine; context: { key, value: logs.requirements[key] }\"></ng-container>\n          </ng-container>\n        </ng-container>\n\n        <ng-container *ngIf=\"logs?.logs\">\n          <ng-container *ngFor=\"let key of logs.logs | keys\">\n            <ng-container *ngTemplateOutlet=\"logLine; context: key\"></ng-container>\n          </ng-container>\n        </ng-container>\n      </tbody>\n    </table>\n  </div>\n\n  <ng-container *bindOnce=\"logs\">\n    <div class=\"it-mt-2\" *ngIf=\"logs?.missingLookups?.length\">\n      <p>Optional data missing:</p>\n\n      <div class=\"table-container data-table-container\">\n        <table class=\"table is-dark is-fullwidth is-striped\">\n          <thead>\n            <tr>\n              <th class=\"has-text-white\">\n                <span>Filename</span>\n              </th>\n              <th class=\"has-text-white\">\n                <span>Column Title</span>\n              </th>\n              <th class=\"has-text-white\">\n                <span>Row (term.id)</span>\n              </th>\n            </tr>\n          </thead>\n          <tbody class=\"has-text-white\">\n            <tr *ngFor=\"let data of logs.missingLookups\">\n              <td>{{ data.filename }}</td>\n              <td>{{ data.column }}</td>\n              <td>{{ data.termId }}</td>\n            </tr>\n          </tbody>\n        </table>\n      </div>\n    </div>\n  </ng-container>\n</ng-template>\n\n<ng-template #logLineValue let-key=\"key\" let-value=\"value\">\n  <ng-template #defaultValue>\n    <span class=\"is-inline-block is-align-middle\">{{ value }}</span>\n  </ng-template>\n  <ng-container *ngIf=\"requirementLinkedNode(key, value); let linkedNode; else: defaultValue\">\n    <he-node-link\n      class=\"is-inline-block is-align-middle\"\n      linkClass=\"is-dark\"\n      [node]=\"linkedNode\"\n      [showExternalLink]=\"true\"></he-node-link>\n  </ng-container>\n</ng-template>\n\n<ng-template #logLine let-key=\"key\" let-value=\"value\">\n  <tr>\n    <td class=\"has-border-right copy-log\">\n      <span class=\"is-inline-block is-align-middle\" [ngSwitch]=\"key\">\n        <ng-container *ngSwitchDefault>{{ key | keyToLabel }}</ng-container>\n\n        <ng-container *ngSwitchCase=\"'node_type_allowed'\">\n          Is the current\n          <code>Node</code>\n          allowed to run this model\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'siteType_allowed'\">\n          Is the current\n          <code>siteType</code>\n          allowed to run this model\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'primary_product_id_allowed'\">\n          Is the current primary product\n          <code>@id</code>\n          allowed to run this model\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'primary_product_termType_allowed'\">\n          Is the current primary product\n          <code>termType</code>\n          allowed to run this model\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'geospatial_data'\">Has geospatial data necessary to run this model</ng-container>\n        <ng-container *ngSwitchCase=\"'contains_geospatial_data'\">\n          Has geospatial data necessary to run this model\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'current_size'\">Current polygon area</ng-container>\n        <ng-container *ngSwitchCase=\"'max_area_size'\">Maximum polygon area to run this model</ng-container>\n        <ng-container *ngSwitchCase=\"'below_max_area_size'\">Polygon below the maximum area</ng-container>\n        <ng-container *ngSwitchCase=\"'region_factor'\">Factor from region lookup</ng-container>\n\n        <ng-container *ngSwitchCase=\"'pesticides_complete'\">\n          Pesticide data are\n          <code>complete</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'has_pesticides_inputs'\">\n          Cycle contains\n          <code>pesticideAI</code>\n          Inputs\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'all_pesticideAI_have_lookup_value'\">\n          All\n          <code>pesticideAI</code>\n          Inputs have a lookup value\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'has_crop_residue_burnt'\">\n          <code>aboveGroundCropResidueBurnt</code>\n          is present as Product\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'liquid_slurry_sludge_P'\">Liquid, Slurry, and Sludge P</ng-container>\n\n        <ng-container *ngSwitchCase=\"'term_type_cropResidue_complete'\">\n          Data completeness for \"cropResidue\" must be\n          <code>true</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_excreta_complete'\">\n          Data completeness for \"excreta\" must be\n          <code>true</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_fertiliser_complete'\">\n          Data completeness for \"fertiliser\" must be\n          <code>true</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_material_complete'\">\n          Data completeness for \"material\" must be\n          <code>true</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_other_complete'\">\n          Data completeness for \"other\" must be\n          <code>true</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_pesticidesAntibiotics_complete'\">\n          Data completeness for \"pesticidesAntibiotics\" must be\n          <code>true</code>\n        </ng-container>\n\n        <ng-container *ngSwitchCase=\"'term_type_cropResidue_incomplete'\">\n          Data completeness for \"cropResidue\" must be\n          <code>false</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_excreta_incomplete'\">\n          Data completeness for \"excreta\" must be\n          <code>false</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_fertiliser_incomplete'\">\n          Data completeness for \"fertiliser\" must be\n          <code>false</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_material_incomplete'\">\n          Data completeness for \"material\" must be\n          <code>false</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_other_incomplete'\">\n          Data completeness for \"other\" must be\n          <code>false</code>\n        </ng-container>\n        <ng-container *ngSwitchCase=\"'term_type_pesticidesAntibiotics_incomplete'\">\n          Data completeness for \"pesticidesAntibiotics\" must be\n          <code>false</code>\n        </ng-container>\n      </span>\n      <he-clipboard\n        class=\"is-inline-block is-align-middle\"\n        clipboardClass=\"is-size-7 is-p-1\"\n        [icon]=\"['far', 'clone']\"\n        [value]=\"key\"\n        [hideText]=\"true\"></he-clipboard>\n    </td>\n    <td>\n      <ng-template #singleValue>\n        <ng-container *ngTemplateOutlet=\"logLineValue; context: { key, value }\"></ng-container>\n      </ng-template>\n      <div *ngIf=\"logValueArray(value); let valueArray; else: singleValue\">\n        <table class=\"table is-dark is-bordered is-striped\">\n          <thead *ngIf=\"valueArray[0] | isObject\">\n            <tr>\n              <th class=\"has-text-white\" *ngFor=\"let v of valueArray[0] | keys\">{{ v.key }}</th>\n            </tr>\n          </thead>\n          <tbody>\n            <tr *ngFor=\"let v of valueArray\">\n              <ng-template #singleArrayValue>\n                <td>{{ v }}</td>\n              </ng-template>\n              <ng-container *ngIf=\"v | isObject; else singleArrayValue\">\n                <td *ngFor=\"let vv of v | keys\">{{ vv.value }}</td>\n              </ng-container>\n            </tr>\n          </tbody>\n        </table>\n      </div>\n    </td>\n  </tr>\n</ng-template>\n\n<ng-template #logStatusDetails let-model=\"model\" let-data=\"data\">\n  <ng-container *bindOnce=\"model\">\n    <div class=\"is-mb-2\">\n      <span>Status:</span>\n      <span class=\"is-pl-1\">{{ model.status }}</span>\n    </div>\n\n    <ng-container *ngIf=\"model.status === LogStatus.notRequired && model.logs?.is_not_relevant === 'True'\">\n      <ul class=\"is-pl-3 is-list-style-disc\">\n        <li *ngIf=\"model.logs.logs?.siteType_allowed === 'False'\">\n          The\n          <code>siteType</code>\n          is not relevant.\n        </li>\n        <li *ngIf=\"model.logs.logs?.product_id_allowed === 'False'\">\n          The primary product\n          <code>@id</code>\n          is not relevant.\n        </li>\n        <li *ngIf=\"model.logs.logs?.product_termType_allowed === 'False'\">\n          The primary product\n          <code>termType</code>\n          is not relevant.\n        </li>\n      </ul>\n    </ng-container>\n\n    <ng-container\n      *ngIf=\"model.logs && model.status !== LogStatus.notRequired && model.status !== LogStatus.skipHierarchy\">\n      <ul class=\"is-pl-3 is-list-style-disc\">\n        <ng-template #showRunOrchestrator>\n          <li class=\"is-run-orchestrator\">\n            <p *ngIf=\"model.logs?.shouldRun\">All the requirements were met to run the model.</p>\n            <ng-container *ngIf=\"!model.logs?.shouldRun\">\n              <p>Some of the requirements were not met to run the model.</p>\n              <p>You can click on the model name on the left to view the debugging logs.</p>\n            </ng-container>\n            <ng-container *ngIf=\"model.logs?.logs?.error\">\n              <p>The model failed to run for the following reason:</p>\n              <p>\n                <code>{{ model.logs.logs.error }}</code>\n              </p>\n            </ng-container>\n          </li>\n        </ng-template>\n\n        <li\n          class=\"is-no-run-orchestrator\"\n          *ngIf=\"model.logs?.shouldRunOrchestrator === false; else showRunOrchestrator\">\n          <ng-container *ngIf=\"!model.logs.runRequired\">\n            <span class=\"is-run-node-type-not-allowed\" *ngIf=\"model.logs.logs?.node_type_allowed === 'False'\">\n              This model should not run for {{ nodeType | pluralize: 0 }}\n            </span>\n          </ng-container>\n\n          <ng-template #runNoConfig>\n            <span class=\"is-run-not-empty\" *ngIf=\"model.logs.logs?.is_empty === 'False'\">\n              The {{ data.type || 'blank node' }} with Term\n              <code>{{ data.termId }}</code>\n              is already present or already added by another model.\n            </span>\n          </ng-template>\n\n          <ng-container *ngIf=\"model.config; else runNoConfig\">\n            <p class=\"is-run-strategy-{{ model.config.runStrategy }}\" [ngSwitch]=\"model.config.runStrategy\">\n              <span *ngSwitchCase=\"'always'\"></span>\n              <span *ngSwitchCase=\"'add_key_if_missing'\">We only gap-fill this key if not present</span>\n              <span *ngSwitchCase=\"'add_blank_node_if_missing'\">We only gap-fill this Blank Node if not present.</span>\n            </p>\n\n            <p class=\"is-mt-1\">\n              <span\n                class=\"is-run-with-measured\"\n                *ngIf=\"\n                  model.config.runArgs?.runNonMeasured && hasMethodTier(data.original, EmissionMethodTier.measured)\n                \">\n                The\n                <code>{{ model.config.value }}</code>\n                was reported as measured.\n              </span>\n            </p>\n          </ng-container>\n        </li>\n\n        <li *ngIf=\"model.logs?.replaceLowerTier !== undefined\">\n          <span>\n            The recalculated\n            <b>methodTier</b>\n            was\n          </span>\n          <span class=\"is-pl-1 is-underlined\" *ngIf=\"!model.logs.replaceLowerTier\">lower than</span>\n          <span class=\"is-pl-1 is-underlined\" *ngIf=\"model.logs.replaceLowerTier\">higher than or equal to</span>\n          <span class=\"is-pl-1\">\n            the original\n            <b>methodTier</b>\n            .\n          </span>\n        </li>\n\n        <li class=\"is-merge-replaceLowerTier\" *ngIf=\"model.logs.replaceLowerTier\">\n          <span>The recalculated</span>\n          <b class=\"is-pl-1\">{{ model.config?.mergeArgs?.replaceThreshold?.[0] || 'value' }}</b>\n          <span class=\"is-pl-1\">was</span>\n          <span class=\"is-pl-1\">\n            <ng-container *ngIf=\"model.config?.mergeArgs\">\n              <span class=\"is-underlined\" *ngIf=\"!model.logs.replaceThreshold\">less than</span>\n              <span class=\"is-underlined\" *ngIf=\"model.logs.replaceThreshold\">more than or equal to</span>\n              <b class=\"is-pl-1\">{{ model.config.mergeArgs.replaceThreshold[1] * 100 }}%</b>\n            </ng-container>\n            <ng-container *ngIf=\"!model.config?.mergeArgs\">\n              <span class=\"is-underlined\" *ngIf=\"!model.logs.replaceThreshold\">not sufficiently</span>\n              <span class=\"is-underlined\" *ngIf=\"model.logs.replaceThreshold\">sufficiently</span>\n            </ng-container>\n          </span>\n          <span class=\"is-pl-1\">different from the original</span>\n          <b class=\"is-pl-1\">{{ model.config?.mergeArgs?.replaceThreshold?.[0] || 'value' }}.</b>\n        </li>\n      </ul>\n    </ng-container>\n  </ng-container>\n</ng-template>\n\n<ng-template #docsLink let-model>\n  <a [href]=\"model.apiDocsPath || model.docPath || model.path\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\n    <span>Docs</span>\n    <fa-icon class=\"ml-1\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n  </a>\n</ng-template>\n"]}