@hestia-earth/ui-components 0.29.2 → 0.29.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/common/navigation-menu/navigation-menu.component.d.ts +1 -0
- package/common/semver-utils.d.ts +0 -1
- package/engine/engine-models-version-link/engine-models-version-link.component.d.ts +1 -1
- package/esm2022/bibliographies/bibliographies-search-confirm/bibliographies-search-confirm.component.mjs +3 -3
- package/esm2022/chart/chart.component.mjs +3 -3
- package/esm2022/common/blank-node-state/blank-node-state.component.mjs +3 -3
- package/esm2022/common/clipboard/clipboard.component.mjs +3 -3
- package/esm2022/common/collapsible-box/collapsible-box.component.mjs +3 -3
- package/esm2022/common/data-table/data-table.component.mjs +3 -3
- package/esm2022/common/drawer-container/drawer-container.component.mjs +3 -3
- package/esm2022/common/link-key-value/link-key-value.component.mjs +3 -3
- package/esm2022/common/maps-drawing-confirm/maps-drawing-confirm.component.mjs +3 -3
- package/esm2022/common/mobile-shell/mobile-shell.component.mjs +3 -3
- package/esm2022/common/navigation-menu/navigation-menu.component.mjs +7 -3
- package/esm2022/common/schema-version-link/schema-version-link.component.mjs +3 -3
- package/esm2022/common/search-extend/search-extend.component.mjs +3 -3
- package/esm2022/common/semver-utils.mjs +2 -3
- package/esm2022/common/shelf-dialog/shelf-dialog.component.mjs +3 -3
- package/esm2022/common/shell/shell.component.mjs +3 -3
- package/esm2022/common/sort-select/sort-select.component.mjs +3 -3
- package/esm2022/cycles/cycles-completeness/cycles-completeness.component.mjs +3 -3
- package/esm2022/cycles/cycles-nodes/cycles-nodes.component.mjs +3 -3
- package/esm2022/cycles/cycles-nodes-timeline/cycles-nodes-timeline.component.mjs +3 -3
- package/esm2022/engine/engine-models-stage-deep/engine-models-stage-deep.component.mjs +3 -3
- package/esm2022/engine/engine-models-version-link/engine-models-version-link.component.mjs +3 -3
- package/esm2022/engine/engine-requirements-form/engine-requirements-form.component.mjs +3 -3
- package/esm2022/files/files-error-summary/files-error-summary-item/files-error-summary-item.component.mjs +3 -3
- package/esm2022/files/files-upload-errors/files-upload-errors.component.mjs +3 -3
- package/esm2022/impact-assessments/impact-assessments-graph/impact-assessments-graph.component.mjs +3 -3
- package/esm2022/impact-assessments/impact-assessments-indicator-breakdown-chart/impact-assessments-indicator-breakdown-chart.component.mjs +3 -3
- package/esm2022/impact-assessments/impact-assessments-products/impact-assessments-products.component.mjs +3 -3
- package/esm2022/node/node-csv-export-confirm/node-csv-export-confirm.component.mjs +3 -3
- package/esm2022/node/node-csv-select-headers/node-csv-select-headers.component.mjs +3 -3
- package/esm2022/node/node-diffs/node-diffs.component.mjs +3 -3
- package/esm2022/node/node-link/node-link.component.mjs +3 -3
- package/esm2022/node/node-logs-file/node-logs-file.component.mjs +3 -3
- package/esm2022/node/node-missing-lookup-factors/node-missing-lookup-factors.component.mjs +3 -3
- package/esm2022/node/node-recommendations/node-recommendations.component.mjs +3 -3
- package/esm2022/node/node-value-details/node-value-details.component.mjs +5 -3
- package/esm2022/schema/schema-info/schema-info.component.mjs +3 -3
- package/esm2022/select/select-option/select-option.component.mjs +3 -3
- package/esm2022/select/select-option-group/select-option-group.component.mjs +3 -3
- package/esm2022/select/select.component.mjs +3 -3
- package/esm2022/sites/sites-nodes/sites-nodes.component.mjs +3 -3
- package/esm2022/terms/terms-property-content/terms-property-content.component.mjs +3 -3
- package/esm2022/terms/terms-sub-class-of-content/terms-sub-class-of-content.component.mjs +3 -3
- package/esm2022/terms/terms-units-description/terms-units-description.component.mjs +3 -3
- package/fesm2022/hestia-earth-ui-components.mjs +93 -88
- package/fesm2022/hestia-earth-ui-components.mjs.map +1 -1
- package/node/node-logs-models/node-logs-models.component.d.ts +1 -1
- package/package.json +1 -1
- package/styles.scss +0 -34
|
@@ -83,7 +83,7 @@ export class EngineModelsStageDeepComponent {
|
|
|
83
83
|
return jsonldPath(node['@type'], node['@id']);
|
|
84
84
|
}
|
|
85
85
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: EngineModelsStageDeepComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
86
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: EngineModelsStageDeepComponent, isStandalone: true, selector: "he-engine-models-stage-deep", inputs: { node: { classPropertyName: "node", publicName: "node", isSignal: true, isRequired: true, transformFunction: null }, expanded: { classPropertyName: "expanded", publicName: "expanded", isSignal: true, isRequired: false, transformFunction: null }, expandedNode: { classPropertyName: "expandedNode", publicName: "expandedNode", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { expanded: "expandedChange" }, ngImport: i0, template: "<div\n class=\"is-flex is-flex-direction-column is-gap-8 is-py-2 is-pl-2 | engine-models-stage--container is-type-{{ type }}\"\n [style.border-color]=\"nodeColour()\">\n <div class=\"is-flex is-flex-direction-row is-justify-content-space-between is-gap-8\">\n @if (canExpand()) {\n <div (click)=\"expanded.set(!expanded())\" pointer>\n <fa-icon [icon]=\"expanded() ? faAngleDown : faAngleRight\"
|
|
86
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: EngineModelsStageDeepComponent, isStandalone: true, selector: "he-engine-models-stage-deep", inputs: { node: { classPropertyName: "node", publicName: "node", isSignal: true, isRequired: true, transformFunction: null }, expanded: { classPropertyName: "expanded", publicName: "expanded", isSignal: true, isRequired: false, transformFunction: null }, expandedNode: { classPropertyName: "expandedNode", publicName: "expandedNode", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { expanded: "expandedChange" }, ngImport: i0, template: "<div\n class=\"is-flex is-flex-direction-column is-gap-8 is-py-2 is-pl-2 | engine-models-stage--container is-type-{{ type }}\"\n [style.border-color]=\"nodeColour()\">\n <div class=\"is-flex is-flex-direction-row is-justify-content-space-between is-gap-8\">\n @if (canExpand()) {\n <div (click)=\"expanded.set(!expanded())\" pointer>\n <fa-icon [icon]=\"expanded() ? faAngleDown : faAngleRight\" />\n </div>\n }\n\n <div\n class=\"is-flex is-flex-direction-row is-justify-content-space-between is-gap-8 is-flex-wrap-wrap is-flex-grow-1\">\n <he-node-link class=\"is-flex-grow-1\" [node]=\"node()\" [showExternalLink]=\"true\">\n <span>{{ type() }} {{ id() }}</span>\n </he-node-link>\n\n <div class=\"is-flex is-flex-direction-column is-gap-4 | engine-models-stage--calculations\">\n <div class=\"is-flex is-gap-4 is-pr-2\">\n <span class=\"has-text-secondary has-text-weight-bold\">Calculations:</span>\n\n @if (inProgress()) {\n <span [class.has-text-danger]=\"stage() === 0\" [class.has-text-warning]=\"stage() > 0\">\n stage {{ stage() }} / {{ maxstage() }}\n </span>\n } @else {\n <span\n class=\"trigger-popover\"\n [ngbPopover]=\"popoverDetails\"\n autoClose=\"outside\"\n popoverClass=\"is-narrow\"\n placement=\"left\"\n container=\"body\">\n <span class=\"has-text-success\">complete</span>\n </span>\n }\n </div>\n </div>\n </div>\n </div>\n\n @if (expanded()) {\n @if (loading() && nodesLength() > 0) {\n @for (node of nodesLength() | times; track $index) {\n <he-skeleton-text [width]=\"60\" />\n }\n }\n\n @for (relatedNode of expandableNodes(); track trackNode(relatedNode)) {\n <div class=\"related-node\">\n <he-engine-models-stage-deep\n [node]=\"relatedNode\"\n [expanded]=\"false\"\n [expandedNode]=\"expandedNode() || node()\" />\n </div>\n }\n }\n</div>\n\n<ng-template #popoverDetails>\n <div class=\"is-flex is-flex-direction-column is-gap-4 has-text-white w-100\">\n <div class=\"is-flex is-align-items-center is-gap-8 w-100\">\n <span class=\"has-text-weight-bold\">Calculated Date:</span>\n <span>{{ recalculatedAt() | date: 'mediumDate' }}</span>\n </div>\n <div class=\"is-flex is-align-items-center is-gap-8 w-100\">\n <span class=\"has-text-weight-bold\">Calculated Version:</span>\n <he-engine-models-version-link [node]=\"node()\" [showDetails]=\"true\"></he-engine-models-version-link>\n </div>\n </div>\n</ng-template>\n", styles: [".engine-models-stage--container{border:1px solid transparent;border-radius:3px}.engine-models-stage--calculations{width:175px}he-engine-models-stage-deep ::ng-deep .engine-models-stage--container{border-right:0px;border-top-right-radius:0;border-bottom-right-radius:0}\n"], dependencies: [{ kind: "component", type: EngineModelsStageDeepComponent, selector: "he-engine-models-stage-deep", inputs: ["node", "expanded", "expandedNode"], outputs: ["expandedChange"] }, { kind: "pipe", type: DatePipe, name: "date" }, { kind: "component", type: FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "mask", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }, { kind: "ngmodule", type: NgbPopoverModule }, { kind: "directive", type: i1.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: EngineModelsVersionLinkComponent, selector: "he-engine-models-version-link", inputs: ["node", "showDetails"] }, { kind: "component", type: SkeletonTextComponent, selector: "he-skeleton-text", inputs: ["animated", "width", "height"] }, { kind: "pipe", type: TimesPipe, name: "times" }, { kind: "component", type: NodeLinkComponent, selector: "he-node-link", inputs: ["node", "showExternalLink", "linkClass"] }] }); }
|
|
87
87
|
}
|
|
88
88
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: EngineModelsStageDeepComponent, decorators: [{
|
|
89
89
|
type: Component,
|
|
@@ -95,6 +95,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
|
|
|
95
95
|
SkeletonTextComponent,
|
|
96
96
|
TimesPipe,
|
|
97
97
|
NodeLinkComponent
|
|
98
|
-
], template: "<div\n class=\"is-flex is-flex-direction-column is-gap-8 is-py-2 is-pl-2 | engine-models-stage--container is-type-{{ type }}\"\n [style.border-color]=\"nodeColour()\">\n <div class=\"is-flex is-flex-direction-row is-justify-content-space-between is-gap-8\">\n @if (canExpand()) {\n <div (click)=\"expanded.set(!expanded())\" pointer>\n <fa-icon [icon]=\"expanded() ? faAngleDown : faAngleRight\"
|
|
98
|
+
], template: "<div\n class=\"is-flex is-flex-direction-column is-gap-8 is-py-2 is-pl-2 | engine-models-stage--container is-type-{{ type }}\"\n [style.border-color]=\"nodeColour()\">\n <div class=\"is-flex is-flex-direction-row is-justify-content-space-between is-gap-8\">\n @if (canExpand()) {\n <div (click)=\"expanded.set(!expanded())\" pointer>\n <fa-icon [icon]=\"expanded() ? faAngleDown : faAngleRight\" />\n </div>\n }\n\n <div\n class=\"is-flex is-flex-direction-row is-justify-content-space-between is-gap-8 is-flex-wrap-wrap is-flex-grow-1\">\n <he-node-link class=\"is-flex-grow-1\" [node]=\"node()\" [showExternalLink]=\"true\">\n <span>{{ type() }} {{ id() }}</span>\n </he-node-link>\n\n <div class=\"is-flex is-flex-direction-column is-gap-4 | engine-models-stage--calculations\">\n <div class=\"is-flex is-gap-4 is-pr-2\">\n <span class=\"has-text-secondary has-text-weight-bold\">Calculations:</span>\n\n @if (inProgress()) {\n <span [class.has-text-danger]=\"stage() === 0\" [class.has-text-warning]=\"stage() > 0\">\n stage {{ stage() }} / {{ maxstage() }}\n </span>\n } @else {\n <span\n class=\"trigger-popover\"\n [ngbPopover]=\"popoverDetails\"\n autoClose=\"outside\"\n popoverClass=\"is-narrow\"\n placement=\"left\"\n container=\"body\">\n <span class=\"has-text-success\">complete</span>\n </span>\n }\n </div>\n </div>\n </div>\n </div>\n\n @if (expanded()) {\n @if (loading() && nodesLength() > 0) {\n @for (node of nodesLength() | times; track $index) {\n <he-skeleton-text [width]=\"60\" />\n }\n }\n\n @for (relatedNode of expandableNodes(); track trackNode(relatedNode)) {\n <div class=\"related-node\">\n <he-engine-models-stage-deep\n [node]=\"relatedNode\"\n [expanded]=\"false\"\n [expandedNode]=\"expandedNode() || node()\" />\n </div>\n }\n }\n</div>\n\n<ng-template #popoverDetails>\n <div class=\"is-flex is-flex-direction-column is-gap-4 has-text-white w-100\">\n <div class=\"is-flex is-align-items-center is-gap-8 w-100\">\n <span class=\"has-text-weight-bold\">Calculated Date:</span>\n <span>{{ recalculatedAt() | date: 'mediumDate' }}</span>\n </div>\n <div class=\"is-flex is-align-items-center is-gap-8 w-100\">\n <span class=\"has-text-weight-bold\">Calculated Version:</span>\n <he-engine-models-version-link [node]=\"node()\" [showDetails]=\"true\"></he-engine-models-version-link>\n </div>\n </div>\n</ng-template>\n", styles: [".engine-models-stage--container{border:1px solid transparent;border-radius:3px}.engine-models-stage--calculations{width:175px}he-engine-models-stage-deep ::ng-deep .engine-models-stage--container{border-right:0px;border-top-right-radius:0;border-bottom-right-radius:0}\n"] }]
|
|
99
99
|
}], ctorParameters: () => [] });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"engine-models-stage-deep.component.js","sourceRoot":"","sources":["../../../../src/engine/engine-models-stage-deep/engine-models-stage-deep.component.ts","../../../../src/engine/engine-models-stage-deep/engine-models-stage-deep.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, effect, inject, input, model, signal } from '@angular/core';\nimport { DatePipe } from '@angular/common';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { ICycleJSONLD, IImpactAssessmentJSONLD, JSONLD, jsonldPath, NodeType } from '@hestia-earth/schema';\nimport { DataState } from '@hestia-earth/api';\nimport { catchError, filter, map, mergeMap, tap, toArray } from 'rxjs/operators';\nimport { combineLatest, from, of } from 'rxjs';\nimport { FaIconComponent } from '@fortawesome/angular-fontawesome';\nimport { faAngleDown, faAngleRight } from '@fortawesome/free-solid-svg-icons';\nimport { NgbPopoverModule } from '@ng-bootstrap/ng-bootstrap';\n\nimport { distinctUntilChangedDeep } from '../../common/rxjs-utils';\nimport { TimesPipe } from '../../common/times.pipe';\nimport { SkeletonTextComponent } from '../../common/skeleton-text/skeleton-text.component';\nimport { NODE_MAX_STAGE, HeNodeService, IRelatedNode, nodeColours } from '../../node/node.service';\nimport { nodes, HeNodeStoreService, mergeDataWithHeaders } from '../../node/node-store.service';\nimport { EngineModelsVersionLinkComponent } from '../engine-models-version-link/engine-models-version-link.component';\nimport { NodeLinkComponent } from '../../node/node-link/node-link.component';\n\ninterface IJSONLDExtended extends JSONLD<NodeType> {\n  stage?: number;\n  maxstage?: number;\n}\n\nconst nestedNodesByType: {\n  [type in NodeType]?: (node: IJSONLDExtended) => (JSONLD<NodeType> | JSONLD<NodeType>[])[];\n} = {\n  [NodeType.Cycle]: (node: ICycleJSONLD) => [\n    node.site,\n    node.otherSites,\n    node.inputs?.map(input => input.impactAssessment as any)?.flat(),\n    node.animals?.flatMap(animal => animal.inputs?.map(input => input.impactAssessment as any)?.flat())\n  ],\n  [NodeType.ImpactAssessment]: (node: IImpactAssessmentJSONLD) => [node.cycle]\n};\n\nconst relatedNodesByType: {\n  [type in NodeType]?: NodeType[];\n} = {\n  [NodeType.Site]: [NodeType.Cycle]\n};\n\n@Component({\n  selector: 'he-engine-models-stage-deep',\n  standalone: true,\n  imports: [\n    DatePipe,\n    FaIconComponent,\n    NgbPopoverModule,\n    EngineModelsVersionLinkComponent,\n    SkeletonTextComponent,\n    TimesPipe,\n    NodeLinkComponent\n  ],\n  templateUrl: './engine-models-stage-deep.component.html',\n  styleUrl: './engine-models-stage-deep.component.scss'\n})\nexport class EngineModelsStageDeepComponent<T extends NodeType> {\n  private readonly nodeService = inject(HeNodeService);\n  private readonly nodeStoreService = inject(HeNodeStoreService);\n\n  protected readonly faAngleRight = faAngleRight;\n  protected readonly faAngleDown = faAngleDown;\n\n  protected readonly node = input.required<IJSONLDExtended>();\n\n  protected readonly expanded = model(false);\n  /**\n   * When nesting the components, avoid allowing expansion on the top-level node.\n   */\n  protected readonly expandedNode = input<IJSONLDExtended>();\n\n  protected readonly id = computed(() => this.node()?.['@id']);\n  protected readonly type = computed(() => this.node()?.['@type']);\n\n  protected readonly nodeColour = computed(() => nodeColours[this.type()]);\n  protected readonly recalculatedAt = computed(\n    () => (this.node() as any)?.updatedAt || (this.node() as any)?.createdAt\n  );\n\n  protected readonly loading = signal(true);\n\n  private readonly relatedNodes = signal<(JSONLD<NodeType> | IRelatedNode)[]>([]);\n  private readonly relatedNodes$ = toObservable(this.relatedNodes);\n  protected readonly nodesLength = toSignal(this.relatedNodes$.pipe(map(nodes => nodes?.length ?? 0)));\n\n  private readonly nodes = toSignal(\n    combineLatest([this.relatedNodes$, this.nodeStoreService.nodes$()]).pipe(\n      filter(([nodes]) => nodes?.length > 0),\n      distinctUntilChangedDeep(),\n      tap(() => this.loading.set(true)),\n      mergeMap(([nodes, allNodes]) =>\n        from(nodes).pipe(\n          mergeMap(node => this.findNode(allNodes, node)),\n          filter(v => !!v),\n          toArray()\n        )\n      ),\n      tap(() => this.loading.set(false))\n    )\n  );\n  protected readonly expandableNodes = computed(\n    () =>\n      this.nodes()?.filter(\n        n => this.expandedNode()?.['@type'] !== n['@type'] || this.expandedNode()?.['@id'] !== n['@id']\n      ) ?? []\n  );\n\n  private readonly defaultMaxStage = computed(() => NODE_MAX_STAGE[this.type()]);\n  protected readonly stage = computed(() => +this.node().stage || 0);\n  protected readonly maxstage = computed(() => +this.node().maxstage || this.defaultMaxStage());\n  protected readonly inProgress = computed(() => this.stage() < this.maxstage());\n\n  protected readonly canExpand = computed(() => this.expandableNodes()?.length);\n\n  constructor() {\n    effect(\n      () => {\n        const node = this.node();\n        const nestedNodes = nestedNodesByType[node['@type']]?.(node)?.flat()?.filter(Boolean) ?? [];\n        const relatedNodes = relatedNodesByType[node['@type']] ?? [];\n\n        from(relatedNodes)\n          .pipe(\n            mergeMap(nodeType => this.nodeService.getRelated$(node, nodeType).pipe(mergeMap(({ results }) => results))),\n            toArray()\n          )\n          .subscribe(values => this.relatedNodes.set([...values, ...nestedNodes]));\n      },\n      { allowSignalWrites: true }\n    );\n  }\n\n  private loadNode$(node: JSONLD<NodeType> | IRelatedNode, dataState: DataState) {\n    return this.nodeService\n      .getWithHeaders$<JSONLD<T>>({\n        ...node,\n        dataState\n      })\n      .pipe(map(({ data, headers }) => mergeDataWithHeaders<IJSONLDExtended>(data, headers)));\n  }\n\n  private findNode(allNodes: nodes, node: JSONLD<NodeType> | IRelatedNode) {\n    const matchedNode = allNodes?.[node['@type']]?.find(v => v?.id === node['@id']);\n    return matchedNode\n      ? of((matchedNode.recalculated || matchedNode.original) as IJSONLDExtended)\n      : this.loadNode$(node, DataState.recalculated).pipe(catchError(() => this.loadNode$(node, DataState.original)));\n  }\n\n  protected trackNode(node: IJSONLDExtended) {\n    return jsonldPath(node['@type'], node['@id']);\n  }\n}\n","<div\n  class=\"is-flex is-flex-direction-column is-gap-8 is-py-2 is-pl-2 | engine-models-stage--container is-type-{{ type }}\"\n  [style.border-color]=\"nodeColour()\">\n  <div class=\"is-flex is-flex-direction-row is-justify-content-space-between is-gap-8\">\n    @if (canExpand()) {\n      <div (click)=\"expanded.set(!expanded())\" pointer>\n        <fa-icon [icon]=\"expanded() ? faAngleDown : faAngleRight\"></fa-icon>\n      </div>\n    }\n\n    <div\n      class=\"is-flex is-flex-direction-row is-justify-content-space-between is-gap-8 is-flex-wrap-wrap is-flex-grow-1\">\n      <he-node-link class=\"is-flex-grow-1\" [node]=\"node()\" [showExternalLink]=\"true\">\n        <span>{{ type() }} {{ id() }}</span>\n      </he-node-link>\n\n      <div class=\"is-flex is-flex-direction-column is-gap-4 | engine-models-stage--calculations\">\n        <div class=\"is-flex is-gap-4 is-pr-2\">\n          <span class=\"has-text-secondary has-text-weight-bold\">Calculations:</span>\n\n          @if (inProgress()) {\n            <span [class.has-text-danger]=\"stage() === 0\" [class.has-text-warning]=\"stage() > 0\">\n              stage {{ stage() }} / {{ maxstage() }}\n            </span>\n          } @else {\n            <span\n              class=\"trigger-popover\"\n              [ngbPopover]=\"popoverDetails\"\n              autoClose=\"outside\"\n              popoverClass=\"is-narrow\"\n              placement=\"left\"\n              container=\"body\">\n              <span class=\"has-text-success\">complete</span>\n            </span>\n          }\n        </div>\n      </div>\n    </div>\n  </div>\n\n  @if (expanded()) {\n    @if (loading() && nodesLength() > 0) {\n      @for (node of nodesLength() | times; track $index) {\n        <he-skeleton-text [width]=\"60\" />\n      }\n    }\n\n    @for (relatedNode of expandableNodes(); track trackNode(relatedNode)) {\n      <div class=\"related-node\">\n        <he-engine-models-stage-deep\n          [node]=\"relatedNode\"\n          [expanded]=\"false\"\n          [expandedNode]=\"expandedNode() || node()\" />\n      </div>\n    }\n  }\n</div>\n\n<ng-template #popoverDetails>\n  <div class=\"is-flex is-flex-direction-column is-gap-4 has-text-white w-100\">\n    <div class=\"is-flex is-align-items-center is-gap-8 w-100\">\n      <span class=\"has-text-weight-bold\">Calculated Date:</span>\n      <span>{{ recalculatedAt() | date: 'mediumDate' }}</span>\n    </div>\n    <div class=\"is-flex is-align-items-center is-gap-8 w-100\">\n      <span class=\"has-text-weight-bold\">Calculated Version:</span>\n      <he-engine-models-version-link [node]=\"node()\" [showDetails]=\"true\"></he-engine-models-version-link>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"engine-models-stage-deep.component.js","sourceRoot":"","sources":["../../../../src/engine/engine-models-stage-deep/engine-models-stage-deep.component.ts","../../../../src/engine/engine-models-stage-deep/engine-models-stage-deep.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, effect, inject, input, model, signal } from '@angular/core';\nimport { DatePipe } from '@angular/common';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\nimport { ICycleJSONLD, IImpactAssessmentJSONLD, JSONLD, jsonldPath, NodeType } from '@hestia-earth/schema';\nimport { DataState } from '@hestia-earth/api';\nimport { catchError, filter, map, mergeMap, tap, toArray } from 'rxjs/operators';\nimport { combineLatest, from, of } from 'rxjs';\nimport { FaIconComponent } from '@fortawesome/angular-fontawesome';\nimport { faAngleDown, faAngleRight } from '@fortawesome/free-solid-svg-icons';\nimport { NgbPopoverModule } from '@ng-bootstrap/ng-bootstrap';\n\nimport { distinctUntilChangedDeep } from '../../common/rxjs-utils';\nimport { TimesPipe } from '../../common/times.pipe';\nimport { SkeletonTextComponent } from '../../common/skeleton-text/skeleton-text.component';\nimport { NODE_MAX_STAGE, HeNodeService, IRelatedNode, nodeColours } from '../../node/node.service';\nimport { nodes, HeNodeStoreService, mergeDataWithHeaders } from '../../node/node-store.service';\nimport { EngineModelsVersionLinkComponent } from '../engine-models-version-link/engine-models-version-link.component';\nimport { NodeLinkComponent } from '../../node/node-link/node-link.component';\n\ninterface IJSONLDExtended extends JSONLD<NodeType> {\n  stage?: number;\n  maxstage?: number;\n}\n\nconst nestedNodesByType: {\n  [type in NodeType]?: (node: IJSONLDExtended) => (JSONLD<NodeType> | JSONLD<NodeType>[])[];\n} = {\n  [NodeType.Cycle]: (node: ICycleJSONLD) => [\n    node.site,\n    node.otherSites,\n    node.inputs?.map(input => input.impactAssessment as any)?.flat(),\n    node.animals?.flatMap(animal => animal.inputs?.map(input => input.impactAssessment as any)?.flat())\n  ],\n  [NodeType.ImpactAssessment]: (node: IImpactAssessmentJSONLD) => [node.cycle]\n};\n\nconst relatedNodesByType: {\n  [type in NodeType]?: NodeType[];\n} = {\n  [NodeType.Site]: [NodeType.Cycle]\n};\n\n@Component({\n  selector: 'he-engine-models-stage-deep',\n  standalone: true,\n  imports: [\n    DatePipe,\n    FaIconComponent,\n    NgbPopoverModule,\n    EngineModelsVersionLinkComponent,\n    SkeletonTextComponent,\n    TimesPipe,\n    NodeLinkComponent\n  ],\n  templateUrl: './engine-models-stage-deep.component.html',\n  styleUrl: './engine-models-stage-deep.component.scss'\n})\nexport class EngineModelsStageDeepComponent<T extends NodeType> {\n  private readonly nodeService = inject(HeNodeService);\n  private readonly nodeStoreService = inject(HeNodeStoreService);\n\n  protected readonly faAngleRight = faAngleRight;\n  protected readonly faAngleDown = faAngleDown;\n\n  protected readonly node = input.required<IJSONLDExtended>();\n\n  protected readonly expanded = model(false);\n  /**\n   * When nesting the components, avoid allowing expansion on the top-level node.\n   */\n  protected readonly expandedNode = input<IJSONLDExtended>();\n\n  protected readonly id = computed(() => this.node()?.['@id']);\n  protected readonly type = computed(() => this.node()?.['@type']);\n\n  protected readonly nodeColour = computed(() => nodeColours[this.type()]);\n  protected readonly recalculatedAt = computed(\n    () => (this.node() as any)?.updatedAt || (this.node() as any)?.createdAt\n  );\n\n  protected readonly loading = signal(true);\n\n  private readonly relatedNodes = signal<(JSONLD<NodeType> | IRelatedNode)[]>([]);\n  private readonly relatedNodes$ = toObservable(this.relatedNodes);\n  protected readonly nodesLength = toSignal(this.relatedNodes$.pipe(map(nodes => nodes?.length ?? 0)));\n\n  private readonly nodes = toSignal(\n    combineLatest([this.relatedNodes$, this.nodeStoreService.nodes$()]).pipe(\n      filter(([nodes]) => nodes?.length > 0),\n      distinctUntilChangedDeep(),\n      tap(() => this.loading.set(true)),\n      mergeMap(([nodes, allNodes]) =>\n        from(nodes).pipe(\n          mergeMap(node => this.findNode(allNodes, node)),\n          filter(v => !!v),\n          toArray()\n        )\n      ),\n      tap(() => this.loading.set(false))\n    )\n  );\n  protected readonly expandableNodes = computed(\n    () =>\n      this.nodes()?.filter(\n        n => this.expandedNode()?.['@type'] !== n['@type'] || this.expandedNode()?.['@id'] !== n['@id']\n      ) ?? []\n  );\n\n  private readonly defaultMaxStage = computed(() => NODE_MAX_STAGE[this.type()]);\n  protected readonly stage = computed(() => +this.node().stage || 0);\n  protected readonly maxstage = computed(() => +this.node().maxstage || this.defaultMaxStage());\n  protected readonly inProgress = computed(() => this.stage() < this.maxstage());\n\n  protected readonly canExpand = computed(() => this.expandableNodes()?.length);\n\n  constructor() {\n    effect(\n      () => {\n        const node = this.node();\n        const nestedNodes = nestedNodesByType[node['@type']]?.(node)?.flat()?.filter(Boolean) ?? [];\n        const relatedNodes = relatedNodesByType[node['@type']] ?? [];\n\n        from(relatedNodes)\n          .pipe(\n            mergeMap(nodeType => this.nodeService.getRelated$(node, nodeType).pipe(mergeMap(({ results }) => results))),\n            toArray()\n          )\n          .subscribe(values => this.relatedNodes.set([...values, ...nestedNodes]));\n      },\n      { allowSignalWrites: true }\n    );\n  }\n\n  private loadNode$(node: JSONLD<NodeType> | IRelatedNode, dataState: DataState) {\n    return this.nodeService\n      .getWithHeaders$<JSONLD<T>>({\n        ...node,\n        dataState\n      })\n      .pipe(map(({ data, headers }) => mergeDataWithHeaders<IJSONLDExtended>(data, headers)));\n  }\n\n  private findNode(allNodes: nodes, node: JSONLD<NodeType> | IRelatedNode) {\n    const matchedNode = allNodes?.[node['@type']]?.find(v => v?.id === node['@id']);\n    return matchedNode\n      ? of((matchedNode.recalculated || matchedNode.original) as IJSONLDExtended)\n      : this.loadNode$(node, DataState.recalculated).pipe(catchError(() => this.loadNode$(node, DataState.original)));\n  }\n\n  protected trackNode(node: IJSONLDExtended) {\n    return jsonldPath(node['@type'], node['@id']);\n  }\n}\n","<div\n  class=\"is-flex is-flex-direction-column is-gap-8 is-py-2 is-pl-2 | engine-models-stage--container is-type-{{ type }}\"\n  [style.border-color]=\"nodeColour()\">\n  <div class=\"is-flex is-flex-direction-row is-justify-content-space-between is-gap-8\">\n    @if (canExpand()) {\n      <div (click)=\"expanded.set(!expanded())\" pointer>\n        <fa-icon [icon]=\"expanded() ? faAngleDown : faAngleRight\" />\n      </div>\n    }\n\n    <div\n      class=\"is-flex is-flex-direction-row is-justify-content-space-between is-gap-8 is-flex-wrap-wrap is-flex-grow-1\">\n      <he-node-link class=\"is-flex-grow-1\" [node]=\"node()\" [showExternalLink]=\"true\">\n        <span>{{ type() }} {{ id() }}</span>\n      </he-node-link>\n\n      <div class=\"is-flex is-flex-direction-column is-gap-4 | engine-models-stage--calculations\">\n        <div class=\"is-flex is-gap-4 is-pr-2\">\n          <span class=\"has-text-secondary has-text-weight-bold\">Calculations:</span>\n\n          @if (inProgress()) {\n            <span [class.has-text-danger]=\"stage() === 0\" [class.has-text-warning]=\"stage() > 0\">\n              stage {{ stage() }} / {{ maxstage() }}\n            </span>\n          } @else {\n            <span\n              class=\"trigger-popover\"\n              [ngbPopover]=\"popoverDetails\"\n              autoClose=\"outside\"\n              popoverClass=\"is-narrow\"\n              placement=\"left\"\n              container=\"body\">\n              <span class=\"has-text-success\">complete</span>\n            </span>\n          }\n        </div>\n      </div>\n    </div>\n  </div>\n\n  @if (expanded()) {\n    @if (loading() && nodesLength() > 0) {\n      @for (node of nodesLength() | times; track $index) {\n        <he-skeleton-text [width]=\"60\" />\n      }\n    }\n\n    @for (relatedNode of expandableNodes(); track trackNode(relatedNode)) {\n      <div class=\"related-node\">\n        <he-engine-models-stage-deep\n          [node]=\"relatedNode\"\n          [expanded]=\"false\"\n          [expandedNode]=\"expandedNode() || node()\" />\n      </div>\n    }\n  }\n</div>\n\n<ng-template #popoverDetails>\n  <div class=\"is-flex is-flex-direction-column is-gap-4 has-text-white w-100\">\n    <div class=\"is-flex is-align-items-center is-gap-8 w-100\">\n      <span class=\"has-text-weight-bold\">Calculated Date:</span>\n      <span>{{ recalculatedAt() | date: 'mediumDate' }}</span>\n    </div>\n    <div class=\"is-flex is-align-items-center is-gap-8 w-100\">\n      <span class=\"has-text-weight-bold\">Calculated Version:</span>\n      <he-engine-models-version-link [node]=\"node()\" [showDetails]=\"true\"></he-engine-models-version-link>\n    </div>\n  </div>\n</ng-template>\n"]}
|
|
@@ -16,10 +16,10 @@ export class EngineModelsVersionLinkComponent {
|
|
|
16
16
|
this.url = computed(() => [engineGitBaseUrl(), '-', 'tree', `v${this.version()}`].filter(Boolean).join('/'));
|
|
17
17
|
}
|
|
18
18
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: EngineModelsVersionLinkComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
19
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: EngineModelsVersionLinkComponent, isStandalone: true, selector: "he-engine-models-version-link", inputs: { node: { classPropertyName: "node", publicName: "node", isSignal: true, isRequired: true, transformFunction: null }, showDetails: { classPropertyName: "showDetails", publicName: "showDetails", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "@if (version()) {\n <div class=\"tags has-addons\">\n <a class=\"tag is-info\" [href]=\"url()\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\n {{ version() }}\n <fa-icon class=\"ml-2\" [icon]=\"faExternalLinkAlt\" size=\"sm\"
|
|
19
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: EngineModelsVersionLinkComponent, isStandalone: true, selector: "he-engine-models-version-link", inputs: { node: { classPropertyName: "node", publicName: "node", isSignal: true, isRequired: true, transformFunction: null }, showDetails: { classPropertyName: "showDetails", publicName: "showDetails", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "@if (version()) {\n <div class=\"tags has-addons\">\n <a class=\"tag is-info\" [href]=\"url()\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\n {{ version() }}\n <fa-icon class=\"ml-2\" [icon]=\"faExternalLinkAlt\" size=\"sm\" />\n </a>\n @if (showDetails()) {\n @if (version() === ENGINE_VERSION) {\n <span class=\"tag is-success\">latest recalculations</span>\n } @else {\n <span class=\"tag is-warning\">outdated recalculations</span>\n }\n }\n </div>\n}\n", styles: [":host{display:inline-block}a{color:inherit}\n"], dependencies: [{ kind: "component", type: FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "mask", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
20
20
|
}
|
|
21
21
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: EngineModelsVersionLinkComponent, decorators: [{
|
|
22
22
|
type: Component,
|
|
23
|
-
args: [{ selector: 'he-engine-models-version-link', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [FaIconComponent, NgTemplateOutlet, AsyncPipe], template: "@if (version()) {\n <div class=\"tags has-addons\">\n <a class=\"tag is-info\" [href]=\"url()\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\n {{ version() }}\n <fa-icon class=\"ml-2\" [icon]=\"faExternalLinkAlt\" size=\"sm\"
|
|
23
|
+
args: [{ selector: 'he-engine-models-version-link', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [FaIconComponent, NgTemplateOutlet, AsyncPipe], template: "@if (version()) {\n <div class=\"tags has-addons\">\n <a class=\"tag is-info\" [href]=\"url()\" target=\"_blank\" (click)=\"$event.stopPropagation()\">\n {{ version() }}\n <fa-icon class=\"ml-2\" [icon]=\"faExternalLinkAlt\" size=\"sm\" />\n </a>\n @if (showDetails()) {\n @if (version() === ENGINE_VERSION) {\n <span class=\"tag is-success\">latest recalculations</span>\n } @else {\n <span class=\"tag is-warning\">outdated recalculations</span>\n }\n }\n </div>\n}\n", styles: [":host{display:inline-block}a{color:inherit}\n"] }]
|
|
24
24
|
}] });
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW5naW5lLW1vZGVscy12ZXJzaW9uLWxpbmsuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2VuZ2luZS9lbmdpbmUtbW9kZWxzLXZlcnNpb24tbGluay9lbmdpbmUtbW9kZWxzLXZlcnNpb24tbGluay5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi9zcmMvZW5naW5lL2VuZ2luZS1tb2RlbHMtdmVyc2lvbi1saW5rL2VuZ2luZS1tb2RlbHMtdmVyc2lvbi1saW5rLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNwRixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsU0FBUyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDOUQsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3RFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUU3RCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sbUJBQW1CLENBQUM7O0FBVXJELE1BQU0sT0FBTyxnQ0FBZ0M7SUFSN0M7UUFTcUIsc0JBQWlCLEdBQUcsaUJBQWlCLENBQUM7UUFFdEMsU0FBSSxHQUFHLEtBQUssQ0FBQyxRQUFRLEVBQU8sQ0FBQztRQUM3QixnQkFBVyxHQUFHLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUUzQixtQkFBYyxHQUFHLGNBQWMsQ0FBQztRQUNoQyxZQUFPLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ25ELFFBQUcsR0FBRyxRQUFRLENBQUMsR0FBRyxFQUFFLENBQ3JDLENBQUMsZ0JBQWdCLEVBQUUsRUFBRSxHQUFHLEVBQUUsTUFBTSxFQUFFLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUNsRixDQUFDO0tBQ0g7K0dBWFksZ0NBQWdDO21HQUFoQyxnQ0FBZ0MsbVdDakI3Qyw0Z0JBZUEsdUdEQVksZUFBZTs7NEZBRWQsZ0NBQWdDO2tCQVI1QyxTQUFTOytCQUNFLCtCQUErQixtQkFHeEIsdUJBQXVCLENBQUMsTUFBTSxjQUNuQyxJQUFJLFdBQ1AsQ0FBQyxlQUFlLEVBQUUsZ0JBQWdCLEVBQUUsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgY29tcHV0ZWQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ1RlbXBsYXRlT3V0bGV0LCBBc3luY1BpcGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRmFJY29uQ29tcG9uZW50IH0gZnJvbSAnQGZvcnRhd2Vzb21lL2FuZ3VsYXItZm9udGF3ZXNvbWUnO1xuaW1wb3J0IHsgZmFFeHRlcm5hbExpbmtBbHQgfSBmcm9tICdAZm9ydGF3ZXNvbWUvZnJlZS1zb2xpZC1zdmctaWNvbnMnO1xuaW1wb3J0IHsgRU5HSU5FX1ZFUlNJT04gfSBmcm9tICdAaGVzdGlhLWVhcnRoL2VuZ2luZS1tb2RlbHMnO1xuXG5pbXBvcnQgeyBub2RlVmVyc2lvbiB9IGZyb20gJy4uLy4uL25vZGUvbm9kZS1tb2RlbC12ZXJzaW9uJztcbmltcG9ydCB7IGVuZ2luZUdpdEJhc2VVcmwgfSBmcm9tICcuLi9lbmdpbmUuc2VydmljZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2hlLWVuZ2luZS1tb2RlbHMtdmVyc2lvbi1saW5rJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2VuZ2luZS1tb2RlbHMtdmVyc2lvbi1saW5rLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZW5naW5lLW1vZGVscy12ZXJzaW9uLWxpbmsuY29tcG9uZW50LnNjc3MnXSxcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtGYUljb25Db21wb25lbnQsIE5nVGVtcGxhdGVPdXRsZXQsIEFzeW5jUGlwZV1cbn0pXG5leHBvcnQgY2xhc3MgRW5naW5lTW9kZWxzVmVyc2lvbkxpbmtDb21wb25lbnQge1xuICBwcm90ZWN0ZWQgcmVhZG9ubHkgZmFFeHRlcm5hbExpbmtBbHQgPSBmYUV4dGVybmFsTGlua0FsdDtcblxuICBwcm90ZWN0ZWQgcmVhZG9ubHkgbm9kZSA9IGlucHV0LnJlcXVpcmVkPGFueT4oKTtcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IHNob3dEZXRhaWxzID0gaW5wdXQoZmFsc2UpO1xuXG4gIHByb3RlY3RlZCByZWFkb25seSBFTkdJTkVfVkVSU0lPTiA9IEVOR0lORV9WRVJTSU9OO1xuICBwcm90ZWN0ZWQgcmVhZG9ubHkgdmVyc2lvbiA9IGNvbXB1dGVkKCgpID0+IG5vZGVWZXJzaW9uKHRoaXMubm9kZSgpKSk7XG4gIHByb3RlY3RlZCByZWFkb25seSB1cmwgPSBjb21wdXRlZCgoKSA9PlxuICAgIFtlbmdpbmVHaXRCYXNlVXJsKCksICctJywgJ3RyZWUnLCBgdiR7dGhpcy52ZXJzaW9uKCl9YF0uZmlsdGVyKEJvb2xlYW4pLmpvaW4oJy8nKVxuICApO1xufVxuIiwiQGlmICh2ZXJzaW9uKCkpIHtcbiAgPGRpdiBjbGFzcz1cInRhZ3MgaGFzLWFkZG9uc1wiPlxuICAgIDxhIGNsYXNzPVwidGFnIGlzLWluZm9cIiBbaHJlZl09XCJ1cmwoKVwiIHRhcmdldD1cIl9ibGFua1wiIChjbGljayk9XCIkZXZlbnQuc3RvcFByb3BhZ2F0aW9uKClcIj5cbiAgICAgIHt7IHZlcnNpb24oKSB9fVxuICAgICAgPGZhLWljb24gY2xhc3M9XCJtbC0yXCIgW2ljb25dPVwiZmFFeHRlcm5hbExpbmtBbHRcIiBzaXplPVwic21cIiAvPlxuICAgIDwvYT5cbiAgICBAaWYgKHNob3dEZXRhaWxzKCkpIHtcbiAgICAgIEBpZiAodmVyc2lvbigpID09PSBFTkdJTkVfVkVSU0lPTikge1xuICAgICAgICA8c3BhbiBjbGFzcz1cInRhZyBpcy1zdWNjZXNzXCI+bGF0ZXN0IHJlY2FsY3VsYXRpb25zPC9zcGFuPlxuICAgICAgfSBAZWxzZSB7XG4gICAgICAgIDxzcGFuIGNsYXNzPVwidGFnIGlzLXdhcm5pbmdcIj5vdXRkYXRlZCByZWNhbGN1bGF0aW9uczwvc3Bhbj5cbiAgICAgIH1cbiAgICB9XG4gIDwvZGl2PlxufVxuIl19
|
|
@@ -64,10 +64,10 @@ export class EngineRequirementsFormComponent {
|
|
|
64
64
|
};
|
|
65
65
|
}
|
|
66
66
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: EngineRequirementsFormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
67
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: EngineRequirementsFormComponent, isStandalone: true, selector: "he-engine-requirements-form", ngImport: i0, template: "<form class=\"needs-validation mt-3\" novalidate [formGroup]=\"form\">\n <div class=\"field is-horizontal\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"productTermId\">\n <span>Product Term ID</span>\n </label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\" [class.has-icons-right]=\"suggestingProductTermId()\">\n <input\n class=\"input\"\n formControlName=\"productTermId\"\n name=\"productTermId\"\n placeholder=\"Search product by ID or name\"\n [editable]=\"false\"\n [ngbTypeahead]=\"suggestProductTermId\"\n [resultTemplate]=\"suggestionProductTermId\"\n [inputFormatter]=\"inputFormatterProductTermId\" />\n <span class=\"icon is-right has-text-grey-dark\" [class.is-hidden]=\"!suggestingProductTermId()\">\n <fa-icon [icon]=\"faSpinner\" animation=\"spin\"
|
|
67
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: EngineRequirementsFormComponent, isStandalone: true, selector: "he-engine-requirements-form", ngImport: i0, template: "<form class=\"needs-validation mt-3\" novalidate [formGroup]=\"form\">\n <div class=\"field is-horizontal\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"productTermId\">\n <span>Product Term ID</span>\n </label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\" [class.has-icons-right]=\"suggestingProductTermId()\">\n <input\n class=\"input\"\n formControlName=\"productTermId\"\n name=\"productTermId\"\n placeholder=\"Search product by ID or name\"\n [editable]=\"false\"\n [ngbTypeahead]=\"suggestProductTermId\"\n [resultTemplate]=\"suggestionProductTermId\"\n [inputFormatter]=\"inputFormatterProductTermId\" />\n <span class=\"icon is-right has-text-grey-dark\" [class.is-hidden]=\"!suggestingProductTermId()\">\n <fa-icon [icon]=\"faSpinner\" animation=\"spin\" />\n </span>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"field is-horizontal mt-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"productTermType\">\n <span>Product Term Type</span>\n </label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth\">\n <select formControlName=\"productTermType\" name=\"productTermType\">\n <option [ngValue]=\"undefined\">Select a Type</option>\n @for (termType of productTermTermType; track termType) {\n <option [value]=\"termType\">\n {{ termType | keyToLabel }}\n </option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"field is-horizontal mt-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"tier\">\n <span>Emissions Method Tier</span>\n </label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth\">\n <select formControlName=\"tier\" name=\"tier\">\n <option [ngValue]=\"undefined\">Select a Tier</option>\n @for (tier of EmissionMethodTier | keyvalue; track tier) {\n <option [value]=\"tier.value\">{{ tier.value }}</option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"field is-horizontal mt-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"siteType\">\n <span>Site Type</span>\n </label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth\">\n <select formControlName=\"siteType\" name=\"siteType\">\n <option [ngValue]=\"undefined\">Select a Type</option>\n @for (siteType of SiteSiteType | keyvalue; track siteType) {\n <option [value]=\"siteType.value\">\n {{ siteType.value }}\n </option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n</form>\n\n<ng-template #suggestionProductTermId let-r=\"result\" let-t=\"term\">\n <ngb-highlight [result]=\"r.name\" [term]=\"t\"></ngb-highlight>\n</ng-template>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i1.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: i1.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "pipe", type: KeyValuePipe, name: "keyvalue" }, { kind: "directive", type: NgbTypeahead, selector: "input[ngbTypeahead]", inputs: ["autocomplete", "container", "editable", "focusFirst", "inputFormatter", "ngbTypeahead", "resultFormatter", "resultTemplate", "selectOnExact", "showHint", "placement", "popperOptions", "popupClass"], outputs: ["selectItem"], exportAs: ["ngbTypeahead"] }, { kind: "component", type: FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "mask", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }, { kind: "component", type: NgbHighlight, selector: "ngb-highlight", inputs: ["highlightClass", "result", "term", "accentSensitive"] }, { kind: "pipe", type: KeyToLabelPipe, name: "keyToLabel" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
68
68
|
}
|
|
69
69
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: EngineRequirementsFormComponent, decorators: [{
|
|
70
70
|
type: Component,
|
|
71
|
-
args: [{ selector: 'he-engine-requirements-form', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [FormsModule, ReactiveFormsModule, KeyValuePipe, NgbTypeahead, FaIconComponent, NgbHighlight, KeyToLabelPipe], template: "<form class=\"needs-validation mt-3\" novalidate [formGroup]=\"form\">\n <div class=\"field is-horizontal\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"productTermId\">\n <span>Product Term ID</span>\n </label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\" [class.has-icons-right]=\"suggestingProductTermId()\">\n <input\n class=\"input\"\n formControlName=\"productTermId\"\n name=\"productTermId\"\n placeholder=\"Search product by ID or name\"\n [editable]=\"false\"\n [ngbTypeahead]=\"suggestProductTermId\"\n [resultTemplate]=\"suggestionProductTermId\"\n [inputFormatter]=\"inputFormatterProductTermId\" />\n <span class=\"icon is-right has-text-grey-dark\" [class.is-hidden]=\"!suggestingProductTermId()\">\n <fa-icon [icon]=\"faSpinner\" animation=\"spin\"
|
|
71
|
+
args: [{ selector: 'he-engine-requirements-form', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [FormsModule, ReactiveFormsModule, KeyValuePipe, NgbTypeahead, FaIconComponent, NgbHighlight, KeyToLabelPipe], template: "<form class=\"needs-validation mt-3\" novalidate [formGroup]=\"form\">\n <div class=\"field is-horizontal\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"productTermId\">\n <span>Product Term ID</span>\n </label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\" [class.has-icons-right]=\"suggestingProductTermId()\">\n <input\n class=\"input\"\n formControlName=\"productTermId\"\n name=\"productTermId\"\n placeholder=\"Search product by ID or name\"\n [editable]=\"false\"\n [ngbTypeahead]=\"suggestProductTermId\"\n [resultTemplate]=\"suggestionProductTermId\"\n [inputFormatter]=\"inputFormatterProductTermId\" />\n <span class=\"icon is-right has-text-grey-dark\" [class.is-hidden]=\"!suggestingProductTermId()\">\n <fa-icon [icon]=\"faSpinner\" animation=\"spin\" />\n </span>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"field is-horizontal mt-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"productTermType\">\n <span>Product Term Type</span>\n </label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth\">\n <select formControlName=\"productTermType\" name=\"productTermType\">\n <option [ngValue]=\"undefined\">Select a Type</option>\n @for (termType of productTermTermType; track termType) {\n <option [value]=\"termType\">\n {{ termType | keyToLabel }}\n </option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"field is-horizontal mt-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"tier\">\n <span>Emissions Method Tier</span>\n </label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth\">\n <select formControlName=\"tier\" name=\"tier\">\n <option [ngValue]=\"undefined\">Select a Tier</option>\n @for (tier of EmissionMethodTier | keyvalue; track tier) {\n <option [value]=\"tier.value\">{{ tier.value }}</option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n\n <div class=\"field is-horizontal mt-3\">\n <div class=\"field-label is-normal\">\n <label class=\"label\" for=\"siteType\">\n <span>Site Type</span>\n </label>\n </div>\n <div class=\"field-body\">\n <div class=\"field\">\n <div class=\"control is-expanded\">\n <div class=\"select is-fullwidth\">\n <select formControlName=\"siteType\" name=\"siteType\">\n <option [ngValue]=\"undefined\">Select a Type</option>\n @for (siteType of SiteSiteType | keyvalue; track siteType) {\n <option [value]=\"siteType.value\">\n {{ siteType.value }}\n </option>\n }\n </select>\n </div>\n </div>\n </div>\n </div>\n </div>\n</form>\n\n<ng-template #suggestionProductTermId let-r=\"result\" let-t=\"term\">\n <ngb-highlight [result]=\"r.name\" [term]=\"t\"></ngb-highlight>\n</ng-template>\n" }]
|
|
72
72
|
}] });
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"engine-requirements-form.component.js","sourceRoot":"","sources":["../../../../src/engine/engine-requirements-form/engine-requirements-form.component.ts","../../../../src/engine/engine-requirements-form/engine-requirements-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, inject, signal } from '@angular/core';\nimport { KeyValuePipe } from '@angular/common';\nimport { UntypedFormBuilder, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { Observable } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, switchMap, tap } from 'rxjs/operators';\nimport { productTermTermType, SiteSiteType, EmissionMethodTier, NodeType, ITermJSONLD } from '@hestia-earth/schema';\nimport { FaIconComponent } from '@fortawesome/angular-fontawesome';\nimport { NgbTypeahead, NgbHighlight } from '@ng-bootstrap/ng-bootstrap';\nimport { faSpinner } from '@fortawesome/free-solid-svg-icons';\n\nimport { ICalculationsModelsParams } from '../engine.service';\nimport { matchType, matchTermType } from '../../search/search.model';\nimport { HeSearchService, suggestMatchQuery } from '../../search/search.service';\nimport { KeyToLabelPipe } from '../../common/key-to-label.pipe';\n\n@Component({\n  selector: 'he-engine-requirements-form',\n  templateUrl: './engine-requirements-form.component.html',\n  styleUrls: ['./engine-requirements-form.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [FormsModule, ReactiveFormsModule, KeyValuePipe, NgbTypeahead, FaIconComponent, NgbHighlight, KeyToLabelPipe]\n})\nexport class EngineRequirementsFormComponent {\n  private readonly formBuilder = inject(UntypedFormBuilder);\n  private readonly searchService = inject(HeSearchService);\n\n  protected readonly faSpinner = faSpinner;\n\n  protected readonly form = this.formBuilder.group({\n    productTermId: [undefined],\n    productTermType: [undefined],\n    tier: [undefined],\n    siteType: [undefined]\n  });\n\n  protected readonly productTermTermType = productTermTermType.term;\n  protected readonly EmissionMethodTier = EmissionMethodTier;\n  protected readonly SiteSiteType = SiteSiteType;\n\n  protected readonly suggestingProductTermId = signal(false);\n  protected readonly suggestProductTermId = (text$: Observable<string>) =>\n    text$.pipe(\n      debounceTime(300),\n      distinctUntilChanged(),\n      tap(() => this.suggestingProductTermId.set(true)),\n      switchMap(term => (term.length < 1 ? [] : this.suggestTerm(term))),\n      tap(() => this.suggestingProductTermId.set(false))\n    );\n  protected readonly inputFormatterProductTermId = ({ name }: ITermJSONLD) => name;\n\n  private suggestTerm(term: string) {\n    return this.searchService.suggest$(term, NodeType.Term, null, {\n      bool: {\n        must: [\n          matchType(NodeType.Term),\n          {\n            bool: {\n              should: suggestMatchQuery(term),\n              minimum_should_match: 1\n            }\n          },\n          {\n            bool: {\n              should: productTermTermType.term.map(matchTermType),\n              minimum_should_match: 1\n            }\n          }\n        ]\n      }\n    });\n  }\n\n  /**\n   * Return if form is valid.\n   */\n  public get valid() {\n    return this.form ? !this.form.invalid : true;\n  }\n\n  public formValue(): ICalculationsModelsParams {\n    const { productTermId, ...value } = this.form ? this.form.getRawValue() : { productTermId: undefined };\n    return {\n      ...value,\n      ...(productTermId ? { productTermId: productTermId['@id'] } : {}) // selected as a JSON-LD Object\n    };\n  }\n}\n","<form class=\"needs-validation mt-3\" novalidate [formGroup]=\"form\">\n  <div class=\"field is-horizontal\">\n    <div class=\"field-label is-normal\">\n      <label class=\"label\" for=\"productTermId\">\n        <span>Product Term ID</span>\n      </label>\n    </div>\n    <div class=\"field-body\">\n      <div class=\"field\">\n        <div class=\"control is-expanded\" [class.has-icons-right]=\"suggestingProductTermId()\">\n          <input\n            class=\"input\"\n            formControlName=\"productTermId\"\n            name=\"productTermId\"\n            placeholder=\"Search product by ID or name\"\n            [editable]=\"false\"\n            [ngbTypeahead]=\"suggestProductTermId\"\n            [resultTemplate]=\"suggestionProductTermId\"\n            [inputFormatter]=\"inputFormatterProductTermId\" />\n          <span class=\"icon is-right has-text-grey-dark\" [class.is-hidden]=\"!suggestingProductTermId()\">\n            <fa-icon [icon]=\"faSpinner\" animation=\"spin\"></fa-icon>\n          </span>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"field is-horizontal mt-3\">\n    <div class=\"field-label is-normal\">\n      <label class=\"label\" for=\"productTermType\">\n        <span>Product Term Type</span>\n      </label>\n    </div>\n    <div class=\"field-body\">\n      <div class=\"field\">\n        <div class=\"control is-expanded\">\n          <div class=\"select is-fullwidth\">\n            <select formControlName=\"productTermType\" name=\"productTermType\">\n              <option [ngValue]=\"undefined\">Select a Type</option>\n              @for (termType of productTermTermType; track termType) {\n                <option [value]=\"termType\">\n                  {{ termType | keyToLabel }}\n                </option>\n              }\n            </select>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"field is-horizontal mt-3\">\n    <div class=\"field-label is-normal\">\n      <label class=\"label\" for=\"tier\">\n        <span>Emissions Method Tier</span>\n      </label>\n    </div>\n    <div class=\"field-body\">\n      <div class=\"field\">\n        <div class=\"control is-expanded\">\n          <div class=\"select is-fullwidth\">\n            <select formControlName=\"tier\" name=\"tier\">\n              <option [ngValue]=\"undefined\">Select a Tier</option>\n              @for (tier of EmissionMethodTier | keyvalue; track tier) {\n                <option [value]=\"tier.value\">{{ tier.value }}</option>\n              }\n            </select>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"field is-horizontal mt-3\">\n    <div class=\"field-label is-normal\">\n      <label class=\"label\" for=\"siteType\">\n        <span>Site Type</span>\n      </label>\n    </div>\n    <div class=\"field-body\">\n      <div class=\"field\">\n        <div class=\"control is-expanded\">\n          <div class=\"select is-fullwidth\">\n            <select formControlName=\"siteType\" name=\"siteType\">\n              <option [ngValue]=\"undefined\">Select a Type</option>\n              @for (siteType of SiteSiteType | keyvalue; track siteType) {\n                <option [value]=\"siteType.value\">\n                  {{ siteType.value }}\n                </option>\n              }\n            </select>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n</form>\n\n<ng-template #suggestionProductTermId let-r=\"result\" let-t=\"term\">\n  <ngb-highlight [result]=\"r.name\" [term]=\"t\"></ngb-highlight>\n</ng-template>\n"]}
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"engine-requirements-form.component.js","sourceRoot":"","sources":["../../../../src/engine/engine-requirements-form/engine-requirements-form.component.ts","../../../../src/engine/engine-requirements-form/engine-requirements-form.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnF,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAEtF,OAAO,EAAE,YAAY,EAAE,oBAAoB,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACpF,OAAO,EAAE,mBAAmB,EAAE,YAAY,EAAE,kBAAkB,EAAE,QAAQ,EAAe,MAAM,sBAAsB,CAAC;AACpH,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,4BAA4B,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,MAAM,mCAAmC,CAAC;AAG9D,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AACrE,OAAO,EAAE,eAAe,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;AACjF,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;;;AAUhE,MAAM,OAAO,+BAA+B;IAR5C;QASmB,gBAAW,GAAG,MAAM,CAAC,kBAAkB,CAAC,CAAC;QACzC,kBAAa,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;QAEtC,cAAS,GAAG,SAAS,CAAC;QAEtB,SAAI,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC;YAC/C,aAAa,EAAE,CAAC,SAAS,CAAC;YAC1B,eAAe,EAAE,CAAC,SAAS,CAAC;YAC5B,IAAI,EAAE,CAAC,SAAS,CAAC;YACjB,QAAQ,EAAE,CAAC,SAAS,CAAC;SACtB,CAAC,CAAC;QAEgB,wBAAmB,GAAG,mBAAmB,CAAC,IAAI,CAAC;QAC/C,uBAAkB,GAAG,kBAAkB,CAAC;QACxC,iBAAY,GAAG,YAAY,CAAC;QAE5B,4BAAuB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QACxC,yBAAoB,GAAG,CAAC,KAAyB,EAAE,EAAE,CACtE,KAAK,CAAC,IAAI,CACR,YAAY,CAAC,GAAG,CAAC,EACjB,oBAAoB,EAAE,EACtB,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,EACjD,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC,EAClE,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,uBAAuB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CACnD,CAAC;QACe,gCAA2B,GAAG,CAAC,EAAE,IAAI,EAAe,EAAE,EAAE,CAAC,IAAI,CAAC;KAsClF;IApCS,WAAW,CAAC,IAAY;QAC9B,OAAO,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,IAAI,EAAE,IAAI,EAAE;YAC5D,IAAI,EAAE;gBACJ,IAAI,EAAE;oBACJ,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC;oBACxB;wBACE,IAAI,EAAE;4BACJ,MAAM,EAAE,iBAAiB,CAAC,IAAI,CAAC;4BAC/B,oBAAoB,EAAE,CAAC;yBACxB;qBACF;oBACD;wBACE,IAAI,EAAE;4BACJ,MAAM,EAAE,mBAAmB,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC;4BACnD,oBAAoB,EAAE,CAAC;yBACxB;qBACF;iBACF;aACF;SACF,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACH,IAAW,KAAK;QACd,OAAO,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC;IAC/C,CAAC;IAEM,SAAS;QACd,MAAM,EAAE,aAAa,EAAE,GAAG,KAAK,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,SAAS,EAAE,CAAC;QACvG,OAAO;YACL,GAAG,KAAK;YACR,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,aAAa,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,+BAA+B;SAClG,CAAC;IACJ,CAAC;+GA/DU,+BAA+B;mGAA/B,+BAA+B,uFCvB5C,yhHAqGA,yDDhFY,WAAW,sjCAAE,mBAAmB,2UAAE,YAAY,iDAAE,YAAY,sUAAE,eAAe,4MAAE,YAAY,sHAAE,cAAc;;4FAE1G,+BAA+B;kBAR3C,SAAS;+BACE,6BAA6B,mBAGtB,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP,CAAC,WAAW,EAAE,mBAAmB,EAAE,YAAY,EAAE,YAAY,EAAE,eAAe,EAAE,YAAY,EAAE,cAAc,CAAC","sourcesContent":["import { ChangeDetectionStrategy, Component, inject, signal } from '@angular/core';\nimport { KeyValuePipe } from '@angular/common';\nimport { UntypedFormBuilder, FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { Observable } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, switchMap, tap } from 'rxjs/operators';\nimport { productTermTermType, SiteSiteType, EmissionMethodTier, NodeType, ITermJSONLD } from '@hestia-earth/schema';\nimport { FaIconComponent } from '@fortawesome/angular-fontawesome';\nimport { NgbTypeahead, NgbHighlight } from '@ng-bootstrap/ng-bootstrap';\nimport { faSpinner } from '@fortawesome/free-solid-svg-icons';\n\nimport { ICalculationsModelsParams } from '../engine.service';\nimport { matchType, matchTermType } from '../../search/search.model';\nimport { HeSearchService, suggestMatchQuery } from '../../search/search.service';\nimport { KeyToLabelPipe } from '../../common/key-to-label.pipe';\n\n@Component({\n  selector: 'he-engine-requirements-form',\n  templateUrl: './engine-requirements-form.component.html',\n  styleUrls: ['./engine-requirements-form.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [FormsModule, ReactiveFormsModule, KeyValuePipe, NgbTypeahead, FaIconComponent, NgbHighlight, KeyToLabelPipe]\n})\nexport class EngineRequirementsFormComponent {\n  private readonly formBuilder = inject(UntypedFormBuilder);\n  private readonly searchService = inject(HeSearchService);\n\n  protected readonly faSpinner = faSpinner;\n\n  protected readonly form = this.formBuilder.group({\n    productTermId: [undefined],\n    productTermType: [undefined],\n    tier: [undefined],\n    siteType: [undefined]\n  });\n\n  protected readonly productTermTermType = productTermTermType.term;\n  protected readonly EmissionMethodTier = EmissionMethodTier;\n  protected readonly SiteSiteType = SiteSiteType;\n\n  protected readonly suggestingProductTermId = signal(false);\n  protected readonly suggestProductTermId = (text$: Observable<string>) =>\n    text$.pipe(\n      debounceTime(300),\n      distinctUntilChanged(),\n      tap(() => this.suggestingProductTermId.set(true)),\n      switchMap(term => (term.length < 1 ? [] : this.suggestTerm(term))),\n      tap(() => this.suggestingProductTermId.set(false))\n    );\n  protected readonly inputFormatterProductTermId = ({ name }: ITermJSONLD) => name;\n\n  private suggestTerm(term: string) {\n    return this.searchService.suggest$(term, NodeType.Term, null, {\n      bool: {\n        must: [\n          matchType(NodeType.Term),\n          {\n            bool: {\n              should: suggestMatchQuery(term),\n              minimum_should_match: 1\n            }\n          },\n          {\n            bool: {\n              should: productTermTermType.term.map(matchTermType),\n              minimum_should_match: 1\n            }\n          }\n        ]\n      }\n    });\n  }\n\n  /**\n   * Return if form is valid.\n   */\n  public get valid() {\n    return this.form ? !this.form.invalid : true;\n  }\n\n  public formValue(): ICalculationsModelsParams {\n    const { productTermId, ...value } = this.form ? this.form.getRawValue() : { productTermId: undefined };\n    return {\n      ...value,\n      ...(productTermId ? { productTermId: productTermId['@id'] } : {}) // selected as a JSON-LD Object\n    };\n  }\n}\n","<form class=\"needs-validation mt-3\" novalidate [formGroup]=\"form\">\n  <div class=\"field is-horizontal\">\n    <div class=\"field-label is-normal\">\n      <label class=\"label\" for=\"productTermId\">\n        <span>Product Term ID</span>\n      </label>\n    </div>\n    <div class=\"field-body\">\n      <div class=\"field\">\n        <div class=\"control is-expanded\" [class.has-icons-right]=\"suggestingProductTermId()\">\n          <input\n            class=\"input\"\n            formControlName=\"productTermId\"\n            name=\"productTermId\"\n            placeholder=\"Search product by ID or name\"\n            [editable]=\"false\"\n            [ngbTypeahead]=\"suggestProductTermId\"\n            [resultTemplate]=\"suggestionProductTermId\"\n            [inputFormatter]=\"inputFormatterProductTermId\" />\n          <span class=\"icon is-right has-text-grey-dark\" [class.is-hidden]=\"!suggestingProductTermId()\">\n            <fa-icon [icon]=\"faSpinner\" animation=\"spin\" />\n          </span>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"field is-horizontal mt-3\">\n    <div class=\"field-label is-normal\">\n      <label class=\"label\" for=\"productTermType\">\n        <span>Product Term Type</span>\n      </label>\n    </div>\n    <div class=\"field-body\">\n      <div class=\"field\">\n        <div class=\"control is-expanded\">\n          <div class=\"select is-fullwidth\">\n            <select formControlName=\"productTermType\" name=\"productTermType\">\n              <option [ngValue]=\"undefined\">Select a Type</option>\n              @for (termType of productTermTermType; track termType) {\n                <option [value]=\"termType\">\n                  {{ termType | keyToLabel }}\n                </option>\n              }\n            </select>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"field is-horizontal mt-3\">\n    <div class=\"field-label is-normal\">\n      <label class=\"label\" for=\"tier\">\n        <span>Emissions Method Tier</span>\n      </label>\n    </div>\n    <div class=\"field-body\">\n      <div class=\"field\">\n        <div class=\"control is-expanded\">\n          <div class=\"select is-fullwidth\">\n            <select formControlName=\"tier\" name=\"tier\">\n              <option [ngValue]=\"undefined\">Select a Tier</option>\n              @for (tier of EmissionMethodTier | keyvalue; track tier) {\n                <option [value]=\"tier.value\">{{ tier.value }}</option>\n              }\n            </select>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"field is-horizontal mt-3\">\n    <div class=\"field-label is-normal\">\n      <label class=\"label\" for=\"siteType\">\n        <span>Site Type</span>\n      </label>\n    </div>\n    <div class=\"field-body\">\n      <div class=\"field\">\n        <div class=\"control is-expanded\">\n          <div class=\"select is-fullwidth\">\n            <select formControlName=\"siteType\" name=\"siteType\">\n              <option [ngValue]=\"undefined\">Select a Type</option>\n              @for (siteType of SiteSiteType | keyvalue; track siteType) {\n                <option [value]=\"siteType.value\">\n                  {{ siteType.value }}\n                </option>\n              }\n            </select>\n          </div>\n        </div>\n      </div>\n    </div>\n  </div>\n</form>\n\n<ng-template #suggestionProductTermId let-r=\"result\" let-t=\"term\">\n  <ngb-highlight [result]=\"r.name\" [term]=\"t\"></ngb-highlight>\n</ng-template>\n"]}
|
|
@@ -27,10 +27,10 @@ export class FilesErrorSummaryItemComponent {
|
|
|
27
27
|
this.maxLength.set(Math.max(minimumMaxLength, width / 3));
|
|
28
28
|
}
|
|
29
29
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: FilesErrorSummaryItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
30
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: FilesErrorSummaryItemComponent, isStandalone: true, selector: "he-files-error-summary-item", inputs: { summary: { classPropertyName: "summary", publicName: "summary", isSignal: true, isRequired: true, transformFunction: null }, resolved: { classPropertyName: "resolved", publicName: "resolved", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { resolved: "resolvedChange" }, ngImport: i0, template: "<div class=\"is-flex is-justify-content-center is-align-items-center is-align-self-stretch is-gap-8 is-mb-2\">\n <div class=\"is-flex is-flex-grow-1 | errors-path border-right\">\n <span class=\"has-text-weight-bold\">{{ summary().path || '-' }}</span>\n </div>\n\n <div class=\"is-flex is-align-items-center is-gap-4 | errors-count\">\n <div\n class=\"is-flex is-justify-content-center is-align-items-center has-background-{{\n errorColor()\n }} | errors-count--number\">\n <span class=\"has-text-weight-bold has-text-white\">{{ summary().count }}</span>\n </div>\n <span class=\"has-text-{{ errorColor() }} is-capitalized\">\n {{ summary().level | pluralize: summary().count }}\n </span>\n </div>\n</div>\n\n<div class=\"py-2 w-100 border-y\">\n @if (summary().terms) {\n <p class=\"is-size-7\">\n <span class=\"is-pr-1 has-text-weight-bold\">Terms:</span>\n <span [innerHtml]=\"summary().terms\"></span>\n </p>\n }\n\n @if (hasAutoGeneratedNodes()) {\n <p class=\"is-size-7 has-text-info\">\n <span>Some nodes are auto-generated and the {{ summary().level }} might come from other nodes</span>\n </p>\n }\n\n <p class=\"is-italic has-text-weight-semilight has-text-grey-dark\" (resized)=\"onResized($event)\">\n <span [innerHTML]=\"message() | ellipsis: textMaxLength()\"></span>\n @if (showMoreButton()) {\n <a class=\"has-text-weight-semibold\" (click)=\"$event.stopPropagation(); showMore.set(!showMore())\">\n @if (showMore()) {\n less\n } @else {\n more\n }\n </a>\n }\n </p>\n</div>\n<div class=\"px-1 py-3 w-100\">\n <div class=\"is-flex is-align-items-center is-gap-8 | resolved-actions\">\n <p class=\"has-text-weight-bold is-size-7\">Resolved?</p>\n\n <a\n (click)=\"$event.stopPropagation(); resolved.set(false)\"\n class=\"resolved-actions--unresolve\"\n [class.is-resolved]=\"resolved()\">\n <fa-icon [icon]=\"faTimesCircle\" />\n </a>\n\n <a\n (click)=\"$event.stopPropagation(); resolved.set(true)\"\n class=\"resolved-actions--resolve\"\n [class.is-resolved]=\"resolved()\">\n <fa-icon [icon]=\"faCheckCircle\" />\n </a>\n </div>\n</div>\n", styles: [":host{--summary-files-border-edge: 1px solid #f5f5f5}:host .border-top{border-top:var(--summary-files-border-edge)}:host .border-bottom{border-bottom:var(--summary-files-border-edge)}:host .border-right{border-right:var(--summary-files-border-edge)}:host .border-x{border-left:var(--summary-files-border-edge);border-right:var(--summary-files-border-edge)}:host .border-y{border-bottom:var(--summary-files-border-edge);border-top:var(--summary-files-border-edge)}p,span{word-break:break-word}.
|
|
30
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.11", type: FilesErrorSummaryItemComponent, isStandalone: true, selector: "he-files-error-summary-item", inputs: { summary: { classPropertyName: "summary", publicName: "summary", isSignal: true, isRequired: true, transformFunction: null }, resolved: { classPropertyName: "resolved", publicName: "resolved", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { resolved: "resolvedChange" }, ngImport: i0, template: "<div class=\"is-flex is-justify-content-center is-align-items-center is-align-self-stretch is-gap-8 is-mb-2\">\n <div class=\"is-flex is-flex-grow-1 | errors-path border-right\">\n <span class=\"has-text-weight-bold\">{{ summary().path || '-' }}</span>\n </div>\n\n <div class=\"is-flex is-align-items-center is-gap-4 | errors-count\">\n <div\n class=\"is-flex is-justify-content-center is-align-items-center has-background-{{\n errorColor()\n }} | errors-count--number\">\n <span class=\"has-text-weight-bold has-text-white\">{{ summary().count }}</span>\n </div>\n <span class=\"has-text-{{ errorColor() }} is-capitalized\">\n {{ summary().level | pluralize: summary().count }}\n </span>\n </div>\n</div>\n\n<div class=\"py-2 w-100 border-y\">\n @if (summary().terms) {\n <p class=\"is-size-7\">\n <span class=\"is-pr-1 has-text-weight-bold\">Terms:</span>\n <span [innerHtml]=\"summary().terms\"></span>\n </p>\n }\n\n @if (hasAutoGeneratedNodes()) {\n <p class=\"is-size-7 has-text-info\">\n <span>Some nodes are auto-generated and the {{ summary().level }} might come from other nodes</span>\n </p>\n }\n\n <p class=\"is-italic has-text-weight-semilight has-text-grey-dark\" (resized)=\"onResized($event)\">\n <span [innerHTML]=\"message() | ellipsis: textMaxLength()\"></span>\n @if (showMoreButton()) {\n <a class=\"has-text-weight-semibold\" (click)=\"$event.stopPropagation(); showMore.set(!showMore())\">\n @if (showMore()) {\n less\n } @else {\n more\n }\n </a>\n }\n </p>\n</div>\n<div class=\"px-1 py-3 w-100\">\n <div class=\"is-flex is-align-items-center is-gap-8 | resolved-actions\">\n <p class=\"has-text-weight-bold is-size-7\">Resolved?</p>\n\n <a\n (click)=\"$event.stopPropagation(); resolved.set(false)\"\n class=\"resolved-actions--unresolve\"\n [class.is-resolved]=\"resolved()\">\n <fa-icon [icon]=\"faTimesCircle\" />\n </a>\n\n <a\n (click)=\"$event.stopPropagation(); resolved.set(true)\"\n class=\"resolved-actions--resolve\"\n [class.is-resolved]=\"resolved()\">\n <fa-icon [icon]=\"faCheckCircle\" />\n </a>\n </div>\n</div>\n", styles: [":host{--summary-files-border-edge: 1px solid #f5f5f5}:host .border-top{border-top:var(--summary-files-border-edge)}:host .border-bottom{border-bottom:var(--summary-files-border-edge)}:host .border-right{border-right:var(--summary-files-border-edge)}:host .border-x{border-left:var(--summary-files-border-edge);border-right:var(--summary-files-border-edge)}:host .border-y{border-bottom:var(--summary-files-border-edge);border-top:var(--summary-files-border-edge)}p,span{word-break:break-word}.errors-path{color:#4c7194}.errors-count{width:110px}.errors-count--number{line-height:1.3;border-radius:1px;padding:1px 5px}.resolved-actions--resolve{color:#b5b5b5}.resolved-actions--resolve.is-resolved,.resolved-actions--resolve:hover{color:#48c78e}.resolved-actions--unresolve{color:#b5b5b5}.resolved-actions--unresolve:not(.is-resolved),.resolved-actions--unresolve:hover{color:#f14668}\n"], dependencies: [{ kind: "component", type: FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "animation", "mask", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "transform", "a11yRole"] }, { kind: "pipe", type: EllipsisPipe, name: "ellipsis" }, { kind: "pipe", type: PluralizePipe, name: "pluralize" }, { kind: "directive", type: ResizedDirective, selector: "[resized]", outputs: ["resized"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
31
31
|
}
|
|
32
32
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: FilesErrorSummaryItemComponent, decorators: [{
|
|
33
33
|
type: Component,
|
|
34
|
-
args: [{ selector: 'he-files-error-summary-item', standalone: true, imports: [FaIconComponent, EllipsisPipe, PluralizePipe, ResizedDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"is-flex is-justify-content-center is-align-items-center is-align-self-stretch is-gap-8 is-mb-2\">\n <div class=\"is-flex is-flex-grow-1 | errors-path border-right\">\n <span class=\"has-text-weight-bold\">{{ summary().path || '-' }}</span>\n </div>\n\n <div class=\"is-flex is-align-items-center is-gap-4 | errors-count\">\n <div\n class=\"is-flex is-justify-content-center is-align-items-center has-background-{{\n errorColor()\n }} | errors-count--number\">\n <span class=\"has-text-weight-bold has-text-white\">{{ summary().count }}</span>\n </div>\n <span class=\"has-text-{{ errorColor() }} is-capitalized\">\n {{ summary().level | pluralize: summary().count }}\n </span>\n </div>\n</div>\n\n<div class=\"py-2 w-100 border-y\">\n @if (summary().terms) {\n <p class=\"is-size-7\">\n <span class=\"is-pr-1 has-text-weight-bold\">Terms:</span>\n <span [innerHtml]=\"summary().terms\"></span>\n </p>\n }\n\n @if (hasAutoGeneratedNodes()) {\n <p class=\"is-size-7 has-text-info\">\n <span>Some nodes are auto-generated and the {{ summary().level }} might come from other nodes</span>\n </p>\n }\n\n <p class=\"is-italic has-text-weight-semilight has-text-grey-dark\" (resized)=\"onResized($event)\">\n <span [innerHTML]=\"message() | ellipsis: textMaxLength()\"></span>\n @if (showMoreButton()) {\n <a class=\"has-text-weight-semibold\" (click)=\"$event.stopPropagation(); showMore.set(!showMore())\">\n @if (showMore()) {\n less\n } @else {\n more\n }\n </a>\n }\n </p>\n</div>\n<div class=\"px-1 py-3 w-100\">\n <div class=\"is-flex is-align-items-center is-gap-8 | resolved-actions\">\n <p class=\"has-text-weight-bold is-size-7\">Resolved?</p>\n\n <a\n (click)=\"$event.stopPropagation(); resolved.set(false)\"\n class=\"resolved-actions--unresolve\"\n [class.is-resolved]=\"resolved()\">\n <fa-icon [icon]=\"faTimesCircle\" />\n </a>\n\n <a\n (click)=\"$event.stopPropagation(); resolved.set(true)\"\n class=\"resolved-actions--resolve\"\n [class.is-resolved]=\"resolved()\">\n <fa-icon [icon]=\"faCheckCircle\" />\n </a>\n </div>\n</div>\n", styles: [":host{--summary-files-border-edge: 1px solid #f5f5f5}:host .border-top{border-top:var(--summary-files-border-edge)}:host .border-bottom{border-bottom:var(--summary-files-border-edge)}:host .border-right{border-right:var(--summary-files-border-edge)}:host .border-x{border-left:var(--summary-files-border-edge);border-right:var(--summary-files-border-edge)}:host .border-y{border-bottom:var(--summary-files-border-edge);border-top:var(--summary-files-border-edge)}p,span{word-break:break-word}.
|
|
34
|
+
args: [{ selector: 'he-files-error-summary-item', standalone: true, imports: [FaIconComponent, EllipsisPipe, PluralizePipe, ResizedDirective], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"is-flex is-justify-content-center is-align-items-center is-align-self-stretch is-gap-8 is-mb-2\">\n <div class=\"is-flex is-flex-grow-1 | errors-path border-right\">\n <span class=\"has-text-weight-bold\">{{ summary().path || '-' }}</span>\n </div>\n\n <div class=\"is-flex is-align-items-center is-gap-4 | errors-count\">\n <div\n class=\"is-flex is-justify-content-center is-align-items-center has-background-{{\n errorColor()\n }} | errors-count--number\">\n <span class=\"has-text-weight-bold has-text-white\">{{ summary().count }}</span>\n </div>\n <span class=\"has-text-{{ errorColor() }} is-capitalized\">\n {{ summary().level | pluralize: summary().count }}\n </span>\n </div>\n</div>\n\n<div class=\"py-2 w-100 border-y\">\n @if (summary().terms) {\n <p class=\"is-size-7\">\n <span class=\"is-pr-1 has-text-weight-bold\">Terms:</span>\n <span [innerHtml]=\"summary().terms\"></span>\n </p>\n }\n\n @if (hasAutoGeneratedNodes()) {\n <p class=\"is-size-7 has-text-info\">\n <span>Some nodes are auto-generated and the {{ summary().level }} might come from other nodes</span>\n </p>\n }\n\n <p class=\"is-italic has-text-weight-semilight has-text-grey-dark\" (resized)=\"onResized($event)\">\n <span [innerHTML]=\"message() | ellipsis: textMaxLength()\"></span>\n @if (showMoreButton()) {\n <a class=\"has-text-weight-semibold\" (click)=\"$event.stopPropagation(); showMore.set(!showMore())\">\n @if (showMore()) {\n less\n } @else {\n more\n }\n </a>\n }\n </p>\n</div>\n<div class=\"px-1 py-3 w-100\">\n <div class=\"is-flex is-align-items-center is-gap-8 | resolved-actions\">\n <p class=\"has-text-weight-bold is-size-7\">Resolved?</p>\n\n <a\n (click)=\"$event.stopPropagation(); resolved.set(false)\"\n class=\"resolved-actions--unresolve\"\n [class.is-resolved]=\"resolved()\">\n <fa-icon [icon]=\"faTimesCircle\" />\n </a>\n\n <a\n (click)=\"$event.stopPropagation(); resolved.set(true)\"\n class=\"resolved-actions--resolve\"\n [class.is-resolved]=\"resolved()\">\n <fa-icon [icon]=\"faCheckCircle\" />\n </a>\n </div>\n</div>\n", styles: [":host{--summary-files-border-edge: 1px solid #f5f5f5}:host .border-top{border-top:var(--summary-files-border-edge)}:host .border-bottom{border-bottom:var(--summary-files-border-edge)}:host .border-right{border-right:var(--summary-files-border-edge)}:host .border-x{border-left:var(--summary-files-border-edge);border-right:var(--summary-files-border-edge)}:host .border-y{border-bottom:var(--summary-files-border-edge);border-top:var(--summary-files-border-edge)}p,span{word-break:break-word}.errors-path{color:#4c7194}.errors-count{width:110px}.errors-count--number{line-height:1.3;border-radius:1px;padding:1px 5px}.resolved-actions--resolve{color:#b5b5b5}.resolved-actions--resolve.is-resolved,.resolved-actions--resolve:hover{color:#48c78e}.resolved-actions--unresolve{color:#b5b5b5}.resolved-actions--unresolve:not(.is-resolved),.resolved-actions--unresolve:hover{color:#f14668}\n"] }]
|
|
35
35
|
}] });
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"files-error-summary-item.component.js","sourceRoot":"","sources":["../../../../../src/files/files-error-summary/files-error-summary-item/files-error-summary-item.component.ts","../../../../../src/files/files-error-summary/files-error-summary-item/files-error-summary-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,KAAK,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACnG,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,mCAAmC,CAAC;AAEjF,OAAO,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAC7D,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,gBAAgB,EAAgB,MAAM,mCAAmC,CAAC;;AAGnF,MAAM,gBAAgB,GAAG,GAAG,CAAC;AAU7B,MAAM,OAAO,8BAA8B;IAR3C;QASqB,kBAAa,GAAG,aAAa,CAAC;QAC9B,kBAAa,GAAG,aAAa,CAAC;QAEjC,YAAO,GAAG,KAAK,CAAC,QAAQ,EAAY,CAAC;QACrD;;WAEG;QACa,aAAQ,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC;QAEvB,cAAS,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;QACnC,kBAAa,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QAC/F,aAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;QACzB,mBAAc,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,gBAAgB,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;QAC5F,YAAO,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,gBAAgB,CAAC,CAAC;QAC1D,eAAU,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC;QAEzF,0BAAqB,GAAG,QAAQ,CAAC,GAAG,EAAE,CACvD,IAAI,CAAC,OAAO,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,CAAE,IAAY,EAAE,aAAa,CAAC,CACvE,CAAC;KAKH;IAHW,SAAS,CAAC,EAAE,OAAO,EAAE,EAAE,KAAK,EAAE,EAAgB;QACtD,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,gBAAgB,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC;IAC5D,CAAC;+GAvBU,8BAA8B;mGAA9B,8BAA8B,0YCnB3C,8sEAgEA,+6BDlDY,eAAe,uMAAE,YAAY,4CAAE,aAAa,kDAAE,gBAAgB;;4FAK7D,8BAA8B;kBAR1C,SAAS;+BACE,6BAA6B,cAC3B,IAAI,WACP,CAAC,eAAe,EAAE,YAAY,EAAE,aAAa,EAAE,gBAAgB,CAAC,mBACxD,uBAAuB,CAAC,MAAM","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, input, model, signal } from '@angular/core';\nimport { FaIconComponent } from '@fortawesome/angular-fontawesome';\nimport { faCheckCircle, faTimesCircle } from '@fortawesome/free-solid-svg-icons';\n\nimport { EllipsisPipe } from '../../../common/ellipsis.pipe';\nimport { PluralizePipe } from '../../../common/pluralize.pipe';\nimport { ResizedDirective, ResizedEvent } from '../../../common/resized.directive';\nimport { ISummary } from '../files-error-summary.model';\n\nconst minimumMaxLength = 150;\n\n@Component({\n  selector: 'he-files-error-summary-item',\n  standalone: true,\n  imports: [FaIconComponent, EllipsisPipe, PluralizePipe, ResizedDirective],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  templateUrl: './files-error-summary-item.component.html',\n  styleUrl: './files-error-summary-item.component.scss'\n})\nexport class FilesErrorSummaryItemComponent {\n  protected readonly faCheckCircle = faCheckCircle;\n  protected readonly faTimesCircle = faTimesCircle;\n\n  public readonly summary = input.required<ISummary>();\n  /**\n   * Error is resolved and should not be displayed anymore.\n   */\n  public readonly resolved = model(false);\n\n  private readonly maxLength = signal(minimumMaxLength);\n  protected readonly textMaxLength = computed(() => (this.showMore() ? Number.MAX_SAFE_INTEGER : this.maxLength()));\n  protected readonly showMore = signal(false);\n  protected readonly showMoreButton = computed(() => this.summary().formattedMessage.length >= this.maxLength());\n  protected readonly message = computed(() => this.summary().formattedMessage);\n  protected readonly errorColor = computed(() => (this.summary().level === 'warning' ? 'warning' : 'danger'));\n\n  protected readonly hasAutoGeneratedNodes = computed(() =>\n    this.summary().errors.some(({ node }) => (node as any)?.autoGenerated)\n  );\n\n  protected onResized({ newRect: { width } }: ResizedEvent) {\n    this.maxLength.set(Math.max(minimumMaxLength, width / 3));\n  }\n}\n","<div class=\"is-flex is-justify-content-center is-align-items-center is-align-self-stretch is-gap-8 is-mb-2\">\n  <div class=\"is-flex is-flex-grow-1 | errors-path border-right\">\n    <span class=\"has-text-weight-bold\">{{ summary().path || '-' }}</span>\n  </div>\n\n  <div class=\"is-flex is-align-items-center is-gap-4 | errors-count\">\n    <div\n      class=\"is-flex is-justify-content-center is-align-items-center has-background-{{\n        errorColor()\n      }} | errors-count--number\">\n      <span class=\"has-text-weight-bold has-text-white\">{{ summary().count }}</span>\n    </div>\n    <span class=\"has-text-{{ errorColor() }} is-capitalized\">\n      {{ summary().level | pluralize: summary().count }}\n    </span>\n  </div>\n</div>\n\n<div class=\"py-2 w-100 border-y\">\n  @if (summary().terms) {\n    <p class=\"is-size-7\">\n      <span class=\"is-pr-1 has-text-weight-bold\">Terms:</span>\n      <span [innerHtml]=\"summary().terms\"></span>\n    </p>\n  }\n\n  @if (hasAutoGeneratedNodes()) {\n    <p class=\"is-size-7 has-text-info\">\n      <span>Some nodes are auto-generated and the {{ summary().level }} might come from other nodes</span>\n    </p>\n  }\n\n  <p class=\"is-italic has-text-weight-semilight has-text-grey-dark\" (resized)=\"onResized($event)\">\n    <span [innerHTML]=\"message() | ellipsis: textMaxLength()\"></span>\n    @if (showMoreButton()) {\n      <a class=\"has-text-weight-semibold\" (click)=\"$event.stopPropagation(); showMore.set(!showMore())\">\n        @if (showMore()) {\n          less\n        } @else {\n          more\n        }\n      </a>\n    }\n  </p>\n</div>\n<div class=\"px-1 py-3 w-100\">\n  <div class=\"is-flex is-align-items-center is-gap-8 | resolved-actions\">\n    <p class=\"has-text-weight-bold is-size-7\">Resolved?</p>\n\n    <a\n      (click)=\"$event.stopPropagation(); resolved.set(false)\"\n      class=\"resolved-actions--unresolve\"\n      [class.is-resolved]=\"resolved()\">\n      <fa-icon [icon]=\"faTimesCircle\" />\n    </a>\n\n    <a\n      (click)=\"$event.stopPropagation(); resolved.set(true)\"\n      class=\"resolved-actions--resolve\"\n      [class.is-resolved]=\"resolved()\">\n      <fa-icon [icon]=\"faCheckCircle\" />\n    </a>\n  </div>\n</div>\n"]}
|