@hestia-earth/ui-components 0.0.26 → 0.0.29
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/hestia-earth-ui-components.umd.js +455 -236
- package/bundles/hestia-earth-ui-components.umd.js.map +1 -1
- package/common/blank-node-state/blank-node-state.component.d.ts +1 -10
- package/common/common.module.d.ts +8 -7
- package/common/index.d.ts +1 -0
- package/common/is-array.pipe.d.ts +7 -0
- package/common/node-utils.d.ts +51 -0
- package/common/utils.d.ts +0 -41
- package/cycles/cycles-activity/cycles-activity.component.d.ts +1 -1
- package/cycles/cycles-emissions/cycles-emissions.component.d.ts +1 -1
- package/cycles/cycles-emissions-chart/cycles-emissions-chart.component.d.ts +1 -1
- package/cycles/cycles-practices/cycles-practices.component.d.ts +1 -1
- package/engine/engine-requirements-form/engine-requirements-form.component.d.ts +26 -0
- package/engine/engine.module.d.ts +6 -4
- package/engine/engine.service.d.ts +24 -5
- package/engine/index.d.ts +1 -0
- package/esm2015/common/blank-node-state/blank-node-state.component.js +12 -14
- package/esm2015/common/common.module.js +8 -4
- package/esm2015/common/index.js +2 -1
- package/esm2015/common/is-array.pipe.js +16 -0
- package/esm2015/common/node-utils.js +80 -0
- package/esm2015/common/utils.js +2 -62
- package/esm2015/cycles/cycles-activity/cycles-activity.component.js +4 -3
- package/esm2015/cycles/cycles-activity-logs/cycles-activity-logs.component.js +3 -3
- package/esm2015/cycles/cycles-emissions/cycles-emissions.component.js +4 -3
- package/esm2015/cycles/cycles-emissions-chart/cycles-emissions-chart.component.js +3 -2
- package/esm2015/cycles/cycles-practices/cycles-practices.component.js +4 -3
- package/esm2015/cycles/cycles-result/cycles-result.component.js +3 -2
- package/esm2015/engine/engine-requirements-form/engine-requirements-form.component.js +75 -0
- package/esm2015/engine/engine.module.js +11 -6
- package/esm2015/engine/engine.service.js +22 -7
- package/esm2015/engine/index.js +2 -1
- package/esm2015/files/files-form/files-form.component.js +10 -3
- package/esm2015/impact-assessments/impact-assessments-indicator-breakdown-chart/impact-assessments-indicator-breakdown-chart.component.js +15 -8
- package/esm2015/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.js +3 -2
- package/esm2015/impact-assessments/impact-assessments-products/impact-assessments-products.component.js +4 -3
- package/esm2015/node/node-logs-models/node-logs-models.component.js +141 -61
- package/esm2015/node/node-value-details/node-value-details.component.js +3 -2
- package/esm2015/node/node.service.js +1 -1
- package/esm2015/sites/sites-measurements/sites-measurements.component.js +4 -3
- package/esm2015/sites/sites.model.js +1 -1
- package/fesm2015/hestia-earth-ui-components.js +371 -166
- package/fesm2015/hestia-earth-ui-components.js.map +1 -1
- package/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.d.ts +1 -1
- package/impact-assessments/impact-assessments-products/impact-assessments-products.component.d.ts +1 -1
- package/node/node-logs-models/node-logs-models.component.d.ts +26 -17
- package/node/node-value-details/node-value-details.component.d.ts +1 -1
- package/node/node.service.d.ts +16 -15
- package/package.json +1 -1
- package/sites/sites-measurements/sites-measurements.component.d.ts +2 -2
- package/sites/sites.model.d.ts +1 -1
|
@@ -1,15 +1,7 @@
|
|
|
1
|
-
import { Completeness, Infrastructure, Input as HestiaInput, Emission, Measurement, Practice, Product, Property } from '@hestia-earth/schema';
|
|
2
1
|
import { HeAggregationEngineService } from '../../engine/aggregation-engine.service';
|
|
3
2
|
import { HeEngineService } from '../../engine/engine.service';
|
|
3
|
+
import { NodeKeyState, blankNode } from '../node-utils';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
-
declare type blankNode = Completeness | Infrastructure | HestiaInput | Emission | Measurement | Practice | Product | Property;
|
|
6
|
-
export declare enum NodeKeyState {
|
|
7
|
-
added = "added",
|
|
8
|
-
updated = "updated",
|
|
9
|
-
aggregated = "aggregated",
|
|
10
|
-
deleted = "deleted",
|
|
11
|
-
unchanged = "unchanged"
|
|
12
|
-
}
|
|
13
5
|
export declare class BlankNodeStateComponent {
|
|
14
6
|
private aggregationEngineService;
|
|
15
7
|
private engineService;
|
|
@@ -34,4 +26,3 @@ export declare class BlankNodeStateComponent {
|
|
|
34
26
|
static ɵfac: i0.ɵɵFactoryDeclaration<BlankNodeStateComponent, never>;
|
|
35
27
|
static ɵcmp: i0.ɵɵComponentDeclaration<BlankNodeStateComponent, "he-blank-node-state", never, { "nodeType": "nodeType"; "dataKey": "dataKey"; "key": "key"; "node": "node"; "state": "state"; }, {}, never, never>;
|
|
36
28
|
}
|
|
37
|
-
export {};
|
|
@@ -14,14 +14,15 @@ import * as i12 from "./times.pipe";
|
|
|
14
14
|
import * as i13 from "./click-outside.directive";
|
|
15
15
|
import * as i14 from "./skeleton-text/skeleton-text.component";
|
|
16
16
|
import * as i15 from "./get.pipe";
|
|
17
|
-
import * as i16 from "
|
|
18
|
-
import * as i17 from "@angular/
|
|
19
|
-
import * as i18 from "@angular/
|
|
20
|
-
import * as i19 from "@
|
|
21
|
-
import * as i20 from "@
|
|
22
|
-
import * as i21 from "
|
|
17
|
+
import * as i16 from "./is-array.pipe";
|
|
18
|
+
import * as i17 from "@angular/common";
|
|
19
|
+
import * as i18 from "@angular/forms";
|
|
20
|
+
import * as i19 from "@angular/router";
|
|
21
|
+
import * as i20 from "@ng-bootstrap/ng-bootstrap";
|
|
22
|
+
import * as i21 from "@angular/google-maps";
|
|
23
|
+
import * as i22 from "./common.light.module";
|
|
23
24
|
export declare class HeCommonModule {
|
|
24
25
|
static ɵfac: i0.ɵɵFactoryDeclaration<HeCommonModule, never>;
|
|
25
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<HeCommonModule, [typeof i1.ClipboardComponent, typeof i2.PopoverComponent, typeof i3.PopoverConfirmComponent, typeof i4.TagsInputDirective, typeof i5.LinkKeyValueComponent, typeof i6.MapsDrawingConfirmComponent, typeof i7.BlankNodeStateComponent, typeof i8.BlankNodeStateNoticeComponent, typeof i9.BlankNodeValueDeltaComponent, typeof i10.SchemaVersionLinkComponent, typeof i11.UnitConverterComponent, typeof i12.TimesPipe, typeof i13.ClickOutsideDirective, typeof i14.SkeletonTextComponent, typeof i15.GetPipe], [typeof
|
|
26
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<HeCommonModule, [typeof i1.ClipboardComponent, typeof i2.PopoverComponent, typeof i3.PopoverConfirmComponent, typeof i4.TagsInputDirective, typeof i5.LinkKeyValueComponent, typeof i6.MapsDrawingConfirmComponent, typeof i7.BlankNodeStateComponent, typeof i8.BlankNodeStateNoticeComponent, typeof i9.BlankNodeValueDeltaComponent, typeof i10.SchemaVersionLinkComponent, typeof i11.UnitConverterComponent, typeof i12.TimesPipe, typeof i13.ClickOutsideDirective, typeof i14.SkeletonTextComponent, typeof i15.GetPipe, typeof i16.IsArrayPipe], [typeof i17.CommonModule, typeof i18.FormsModule, typeof i19.RouterModule, typeof i20.NgbTypeaheadModule, typeof i20.NgbTooltipModule, typeof i20.NgbPopoverModule, typeof i21.GoogleMapsModule, typeof i22.HeCommonLightModule], [typeof i20.NgbTypeaheadModule, typeof i20.NgbTooltipModule, typeof i20.NgbPopoverModule, typeof i21.GoogleMapsModule, typeof i22.HeCommonLightModule, typeof i1.ClipboardComponent, typeof i2.PopoverComponent, typeof i3.PopoverConfirmComponent, typeof i4.TagsInputDirective, typeof i5.LinkKeyValueComponent, typeof i6.MapsDrawingConfirmComponent, typeof i7.BlankNodeStateComponent, typeof i8.BlankNodeStateNoticeComponent, typeof i9.BlankNodeValueDeltaComponent, typeof i10.SchemaVersionLinkComponent, typeof i11.UnitConverterComponent, typeof i12.TimesPipe, typeof i13.ClickOutsideDirective, typeof i14.SkeletonTextComponent, typeof i15.GetPipe, typeof i16.IsArrayPipe]>;
|
|
26
27
|
static ɵinj: i0.ɵɵInjectorDeclaration<HeCommonModule>;
|
|
27
28
|
}
|
package/common/index.d.ts
CHANGED
|
@@ -24,6 +24,7 @@ export { ClickOutsideDirective } from './click-outside.directive';
|
|
|
24
24
|
export { DefaultPipe } from './default.pipe';
|
|
25
25
|
export { EllipsisPipe } from './ellipsis.pipe';
|
|
26
26
|
export { GetPipe } from './get.pipe';
|
|
27
|
+
export { IsArrayPipe } from './is-array.pipe';
|
|
27
28
|
export { KeyToLabelPipe } from './key-to-label.pipe';
|
|
28
29
|
export { KeysPipe } from './keys.pipe';
|
|
29
30
|
export { PluralizePipe } from './pluralize.pipe';
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { PipeTransform } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export declare class IsArrayPipe implements PipeTransform {
|
|
4
|
+
transform(value: any[]): boolean;
|
|
5
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<IsArrayPipe, never>;
|
|
6
|
+
static ɵpipe: i0.ɵɵPipeDeclaration<IsArrayPipe, "isArray">;
|
|
7
|
+
}
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { Term, ICycleJSONLD, ISiteJSONLD, IImpactAssessmentJSONLD, ITermJSONLD, Completeness, Infrastructure, Emission, Measurement, Practice, Product, Input, Property } from '@hestia-earth/schema';
|
|
2
|
+
export declare enum NodeKeyState {
|
|
3
|
+
added = "added",
|
|
4
|
+
updated = "updated",
|
|
5
|
+
aggregated = "aggregated",
|
|
6
|
+
deleted = "deleted",
|
|
7
|
+
unchanged = "unchanged"
|
|
8
|
+
}
|
|
9
|
+
export declare type blankNode = Completeness | Infrastructure | Input | Emission | Measurement | Practice | Product | Property;
|
|
10
|
+
export declare const isState: (node: blankNode, key: string, state: NodeKeyState) => any;
|
|
11
|
+
export interface IGroupedNode<T> {
|
|
12
|
+
node: T;
|
|
13
|
+
nodes: T[];
|
|
14
|
+
index: number;
|
|
15
|
+
value: number[];
|
|
16
|
+
dates?: any[];
|
|
17
|
+
sd?: number[];
|
|
18
|
+
min?: number[];
|
|
19
|
+
max?: number[];
|
|
20
|
+
inputs?: any[];
|
|
21
|
+
depthUpper?: number[];
|
|
22
|
+
depthLower?: number[];
|
|
23
|
+
startDate?: string[];
|
|
24
|
+
endDate?: string[];
|
|
25
|
+
}
|
|
26
|
+
export interface IGroupedNodesValues<T> {
|
|
27
|
+
[nodeId: string]: IGroupedNode<T>;
|
|
28
|
+
}
|
|
29
|
+
export interface IGroupedNodesValue<T> {
|
|
30
|
+
term: ITermJSONLD;
|
|
31
|
+
/**
|
|
32
|
+
* Enable ordering ny methodTier
|
|
33
|
+
*/
|
|
34
|
+
methodTierOrder: number;
|
|
35
|
+
values: IGroupedNodesValues<T>;
|
|
36
|
+
originalValues: {
|
|
37
|
+
[nodeId: string]: {
|
|
38
|
+
value: number;
|
|
39
|
+
};
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
export interface IGroupedNodes<T> {
|
|
43
|
+
[termId: string]: IGroupedNodesValue<T>;
|
|
44
|
+
}
|
|
45
|
+
export interface IGroupedKeys<T> {
|
|
46
|
+
key: string;
|
|
47
|
+
value: IGroupedNodesValue<T>;
|
|
48
|
+
}
|
|
49
|
+
export declare const grouppedKeys: <T>(values: IGroupedNodes<T>) => IGroupedKeys<T>[];
|
|
50
|
+
export declare const grouppedValueKeys: string[];
|
|
51
|
+
export declare const groupNodesByTerm: <T extends IImpactAssessmentJSONLD | ISiteJSONLD | ICycleJSONLD, R>(nodes: T[], key: 'impacts' | 'emissionsResourceUse' | 'inputs' | 'products' | 'practices' | 'emissions' | 'measurements', originalValues?: T[], filterMethod?: Term) => IGroupedNodes<R>;
|
package/common/utils.d.ts
CHANGED
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { Term, ICycleJSONLD, ISiteJSONLD, IImpactAssessmentJSONLD, ITermJSONLD } from '@hestia-earth/schema';
|
|
2
1
|
export declare const gitHome = "https://gitlab.com/hestia-earth";
|
|
3
2
|
export declare const gitRawBaseUrl = "https://glcdn.githack.com/hestia-earth";
|
|
4
3
|
export declare const gitBranch: () => "develop" | "master";
|
|
@@ -18,46 +17,6 @@ export declare const scrollTop: () => void;
|
|
|
18
17
|
export declare const safeJSONParse: <T>(value: string, defaultValue?: any) => any;
|
|
19
18
|
export declare const safeJSONStringify: (value: string) => string;
|
|
20
19
|
export declare const arrayValue: (values: any[], isAverage: boolean) => number;
|
|
21
|
-
export interface IGroupedNode<T> {
|
|
22
|
-
nodes: T[];
|
|
23
|
-
index: number;
|
|
24
|
-
value: number[];
|
|
25
|
-
dates?: any[];
|
|
26
|
-
sd?: number[];
|
|
27
|
-
min?: number[];
|
|
28
|
-
max?: number[];
|
|
29
|
-
inputs?: any[];
|
|
30
|
-
depthUpper?: number[];
|
|
31
|
-
depthLower?: number[];
|
|
32
|
-
startDate?: string[];
|
|
33
|
-
endDate?: string[];
|
|
34
|
-
}
|
|
35
|
-
export interface IGroupedNodesValues<T> {
|
|
36
|
-
[nodeId: string]: IGroupedNode<T>;
|
|
37
|
-
}
|
|
38
|
-
export interface IGroupedNodesValue<T> {
|
|
39
|
-
term: ITermJSONLD;
|
|
40
|
-
/**
|
|
41
|
-
* Enable ordering ny methodTier
|
|
42
|
-
*/
|
|
43
|
-
methodTierOrder: number;
|
|
44
|
-
values: IGroupedNodesValues<T>;
|
|
45
|
-
originalValues: {
|
|
46
|
-
[nodeId: string]: {
|
|
47
|
-
value: number;
|
|
48
|
-
};
|
|
49
|
-
};
|
|
50
|
-
}
|
|
51
|
-
export interface IGroupedNodes<T> {
|
|
52
|
-
[termId: string]: IGroupedNodesValue<T>;
|
|
53
|
-
}
|
|
54
|
-
export interface IGroupedKeys<T> {
|
|
55
|
-
key: string;
|
|
56
|
-
value: IGroupedNodesValue<T>;
|
|
57
|
-
}
|
|
58
|
-
export declare const grouppedKeys: <T>(values: IGroupedNodes<T>) => IGroupedKeys<T>[];
|
|
59
|
-
export declare const grouppedValueKeys: string[];
|
|
60
|
-
export declare const groupNodesByTerm: <T extends IImpactAssessmentJSONLD | ISiteJSONLD | ICycleJSONLD, R>(nodes: T[], key: 'impacts' | 'emissionsResourceUse' | 'inputs' | 'products' | 'practices' | 'emissions' | 'measurements', originalValues?: T[], filterMethod?: Term) => IGroupedNodes<R>;
|
|
61
20
|
export declare const ellipsis: (text?: string, maxlength?: number) => string;
|
|
62
21
|
export declare const mapsUrl: (location?: {
|
|
63
22
|
lat?: number;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { OnChanges, SimpleChanges } from '@angular/core';
|
|
2
2
|
import { DataState } from '@hestia-earth/api';
|
|
3
3
|
import { ICycleJSONLD, Input as HestiaInput, Product } from '@hestia-earth/schema';
|
|
4
|
-
import { IGroupedKeys } from '../../common/utils';
|
|
4
|
+
import { IGroupedKeys } from '../../common/node-utils';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
declare enum View {
|
|
7
7
|
table = "table",
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { OnChanges, SimpleChanges } from '@angular/core';
|
|
2
2
|
import { DataState } from '@hestia-earth/api';
|
|
3
3
|
import { ICycleJSONLD, Emission } from '@hestia-earth/schema';
|
|
4
|
-
import { IGroupedKeys } from '../../common/utils';
|
|
4
|
+
import { IGroupedKeys } from '../../common/node-utils';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
declare enum View {
|
|
7
7
|
table = "table",
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { OnChanges, SimpleChanges, AfterViewInit } from '@angular/core';
|
|
2
2
|
import { Emission, ITermJSONLD } from '@hestia-earth/schema';
|
|
3
|
-
import { IGroupedNodes } from '../../common/utils';
|
|
3
|
+
import { IGroupedNodes } from '../../common/node-utils';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare class CyclesEmissionsChartComponent implements AfterViewInit, OnChanges {
|
|
6
6
|
private chartRef?;
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { OnChanges, SimpleChanges } from '@angular/core';
|
|
2
2
|
import { DataState } from '@hestia-earth/api';
|
|
3
3
|
import { ICycleJSONLD, Practice } from '@hestia-earth/schema';
|
|
4
|
-
import { IGroupedKeys } from '../../common/utils';
|
|
4
|
+
import { IGroupedKeys } from '../../common/node-utils';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
declare enum View {
|
|
7
7
|
table = "table",
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { FormBuilder } from '@angular/forms';
|
|
2
|
+
import { Observable } from 'rxjs';
|
|
3
|
+
import { SiteSiteType, EmissionMethodTier, ITermJSONLD } from '@hestia-earth/schema';
|
|
4
|
+
import { ICalculationsModelsParams } from '../engine.service';
|
|
5
|
+
import { HeSearchService } from '../../search/search.service';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export declare class EngineRequirementsFormComponent {
|
|
8
|
+
private formBuilder;
|
|
9
|
+
private searchService;
|
|
10
|
+
form: import("@angular/forms").FormGroup;
|
|
11
|
+
productTermTermType: import("@hestia-earth/schema").TermTermType[];
|
|
12
|
+
EmissionMethodTier: typeof EmissionMethodTier;
|
|
13
|
+
SiteSiteType: typeof SiteSiteType;
|
|
14
|
+
suggestingProductTermId: boolean;
|
|
15
|
+
suggestProductTermId: (text$: Observable<string>) => Observable<any>;
|
|
16
|
+
inputFormatterProductTermId: ({ name }: ITermJSONLD) => string;
|
|
17
|
+
constructor(formBuilder: FormBuilder, searchService: HeSearchService);
|
|
18
|
+
private suggestTerm;
|
|
19
|
+
/**
|
|
20
|
+
* Return if form is valid.
|
|
21
|
+
*/
|
|
22
|
+
get valid(): boolean;
|
|
23
|
+
formValue(): ICalculationsModelsParams;
|
|
24
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<EngineRequirementsFormComponent, never>;
|
|
25
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<EngineRequirementsFormComponent, "he-engine-requirements-form", never, {}, {}, never, never>;
|
|
26
|
+
}
|
|
@@ -1,10 +1,12 @@
|
|
|
1
1
|
import * as i0 from "@angular/core";
|
|
2
2
|
import * as i1 from "./engine-orchestrator-edit/engine-orchestrator-edit.component";
|
|
3
|
-
import * as i2 from "
|
|
4
|
-
import * as i3 from "
|
|
5
|
-
import * as i4 from "
|
|
3
|
+
import * as i2 from "./engine-requirements-form/engine-requirements-form.component";
|
|
4
|
+
import * as i3 from "@angular/common";
|
|
5
|
+
import * as i4 from "@angular/forms";
|
|
6
|
+
import * as i5 from "../common/common.module";
|
|
7
|
+
import * as i6 from "../node/node.module";
|
|
6
8
|
export declare class HeEngineModule {
|
|
7
9
|
static ɵfac: i0.ɵɵFactoryDeclaration<HeEngineModule, never>;
|
|
8
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<HeEngineModule, [typeof i1.EngineOrchestratorEditComponent], [typeof
|
|
10
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<HeEngineModule, [typeof i1.EngineOrchestratorEditComponent, typeof i2.EngineRequirementsFormComponent], [typeof i3.CommonModule, typeof i4.ReactiveFormsModule, typeof i5.HeCommonModule, typeof i6.HeNodeModule], [typeof i1.EngineOrchestratorEditComponent, typeof i2.EngineRequirementsFormComponent]>;
|
|
9
11
|
static ɵinj: i0.ɵɵInjectorDeclaration<HeEngineModule>;
|
|
10
12
|
}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { InjectionToken } from '@angular/core';
|
|
2
2
|
import { HttpClient } from '@angular/common/http';
|
|
3
|
-
import { NodeType } from '@hestia-earth/schema';
|
|
3
|
+
import { EmissionMethodTier, NodeType, SiteSiteType, JSONLD } from '@hestia-earth/schema';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
|
+
export declare const HE_CALCULATIONS_BASE_URL: InjectionToken<string>;
|
|
5
6
|
export declare const HE_ORCHESTRATOR_BASE_URL: InjectionToken<string>;
|
|
6
7
|
export declare const engineGitUrl: () => string;
|
|
7
8
|
/**
|
|
@@ -9,11 +10,11 @@ export declare const engineGitUrl: () => string;
|
|
|
9
10
|
*
|
|
10
11
|
* @param config The orchestrator configuration content.
|
|
11
12
|
* @param termId The `@id` of the Term.
|
|
12
|
-
* @param
|
|
13
|
+
* @param modelKey The key of the configuration (e.g. "products", "inputs")
|
|
13
14
|
* @param models Optional - list of models from `model-links.json` to default when orchestrator does not contain config.
|
|
14
15
|
* @returns List of models from orchestrator or models if set.
|
|
15
16
|
*/
|
|
16
|
-
export declare const findConfigModels: (config: IOrchestratorConfig, termId: string,
|
|
17
|
+
export declare const findConfigModels: (config: IOrchestratorConfig, termId: string, modelKey: string, models?: IModel[]) => IModel[] | IOrchestratorModelConfig[];
|
|
17
18
|
export declare const pathToApiDocsPath: (model: string, term?: string) => string;
|
|
18
19
|
export interface IModel {
|
|
19
20
|
/**
|
|
@@ -41,27 +42,45 @@ export interface IModel {
|
|
|
41
42
|
*/
|
|
42
43
|
modelKey?: string;
|
|
43
44
|
}
|
|
45
|
+
export interface ICalculationsModelsParams {
|
|
46
|
+
productTermId?: string;
|
|
47
|
+
productTermType?: string;
|
|
48
|
+
tier?: EmissionMethodTier;
|
|
49
|
+
siteType?: SiteSiteType;
|
|
50
|
+
}
|
|
51
|
+
export interface ICalculationsRequirementsParams extends ICalculationsModelsParams {
|
|
52
|
+
format?: 'csv';
|
|
53
|
+
}
|
|
54
|
+
export interface ICalculationsModel {
|
|
55
|
+
model: string;
|
|
56
|
+
key: string;
|
|
57
|
+
}
|
|
44
58
|
export interface IOrchestratorModelConfig {
|
|
45
59
|
key: string;
|
|
46
60
|
model: string;
|
|
47
61
|
value: string;
|
|
48
62
|
}
|
|
49
63
|
export interface IOrchestratorConfig {
|
|
50
|
-
models: IOrchestratorModelConfig[];
|
|
64
|
+
models: (IOrchestratorModelConfig | IOrchestratorModelConfig[])[];
|
|
51
65
|
}
|
|
52
66
|
export declare class HeEngineService {
|
|
67
|
+
private _calculationsBaseUrl;
|
|
53
68
|
private _orchestratorBaseUrl;
|
|
54
69
|
protected http: HttpClient;
|
|
55
70
|
private modelsLoading;
|
|
56
71
|
private modelsLoaded;
|
|
57
72
|
private _models;
|
|
58
|
-
constructor(_orchestratorBaseUrl: string, http: HttpClient);
|
|
73
|
+
constructor(_calculationsBaseUrl: string, _orchestratorBaseUrl: string, http: HttpClient);
|
|
59
74
|
private init;
|
|
60
75
|
private loadModels;
|
|
61
76
|
get models$(): import("rxjs").Observable<IModel[]>;
|
|
62
77
|
models(): Promise<IModel[]>;
|
|
63
78
|
model$(model: Partial<IModel>): import("rxjs").Observable<IModel>;
|
|
64
79
|
model(model: Partial<IModel>): Promise<IModel>;
|
|
80
|
+
listModels(params: ICalculationsModelsParams): Promise<{
|
|
81
|
+
models: ICalculationsModel[];
|
|
82
|
+
}>;
|
|
83
|
+
getRequirements(params: ICalculationsRequirementsParams): Promise<JSONLD<NodeType>>;
|
|
65
84
|
orchestratorConfigUrl(type?: NodeType): string;
|
|
66
85
|
ochestratorConfig(type: NodeType): Promise<IOrchestratorConfig>;
|
|
67
86
|
static ɵfac: i0.ɵɵFactoryDeclaration<HeEngineService, never>;
|
package/engine/index.d.ts
CHANGED
|
@@ -2,3 +2,4 @@ export * from './aggregation-engine.service';
|
|
|
2
2
|
export * from './engine.service';
|
|
3
3
|
export * from './engine.module';
|
|
4
4
|
export { EngineOrchestratorEditComponent } from './engine-orchestrator-edit/engine-orchestrator-edit.component';
|
|
5
|
+
export { EngineRequirementsFormComponent } from './engine-requirements-form/engine-requirements-form.component';
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
2
|
import { of } from 'rxjs';
|
|
3
3
|
import { mergeMap } from 'rxjs/operators';
|
|
4
|
+
import { NodeKeyState, isState } from '../node-utils';
|
|
4
5
|
import { filterParams } from '../utils';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "../../engine/aggregation-engine.service";
|
|
@@ -8,14 +9,6 @@ import * as i2 from "../../engine/engine.service";
|
|
|
8
9
|
import * as i3 from "@fortawesome/angular-fontawesome";
|
|
9
10
|
import * as i4 from "../bind-once.directive";
|
|
10
11
|
import * as i5 from "@angular/common";
|
|
11
|
-
export var NodeKeyState;
|
|
12
|
-
(function (NodeKeyState) {
|
|
13
|
-
NodeKeyState["added"] = "added";
|
|
14
|
-
NodeKeyState["updated"] = "updated";
|
|
15
|
-
NodeKeyState["aggregated"] = "aggregated";
|
|
16
|
-
NodeKeyState["deleted"] = "deleted";
|
|
17
|
-
NodeKeyState["unchanged"] = "unchanged";
|
|
18
|
-
})(NodeKeyState || (NodeKeyState = {}));
|
|
19
12
|
export class BlankNodeStateComponent {
|
|
20
13
|
constructor(aggregationEngineService, engineService) {
|
|
21
14
|
this.aggregationEngineService = aggregationEngineService;
|
|
@@ -25,13 +18,18 @@ export class BlankNodeStateComponent {
|
|
|
25
18
|
is(state) {
|
|
26
19
|
return (
|
|
27
20
|
// forcing state
|
|
28
|
-
!!this.state && this.state === state) || (
|
|
29
|
-
this.node[state] :
|
|
30
|
-
this.node[state].includes(this.key)));
|
|
21
|
+
!!this.state && this.state === state) || isState(this.node, this.key, state);
|
|
31
22
|
}
|
|
32
23
|
get stars() {
|
|
33
|
-
return this.is(NodeKeyState.deleted)
|
|
34
|
-
|
|
24
|
+
return this.is(NodeKeyState.deleted)
|
|
25
|
+
? [0, 1, 2, 3]
|
|
26
|
+
: this.is(NodeKeyState.updated)
|
|
27
|
+
? [0, 1]
|
|
28
|
+
: this.is(NodeKeyState.aggregated) // handle here because aggregated can be updated
|
|
29
|
+
? [0, 1, 2]
|
|
30
|
+
: this.is(NodeKeyState.added)
|
|
31
|
+
? [0]
|
|
32
|
+
: [];
|
|
35
33
|
}
|
|
36
34
|
get showLink() {
|
|
37
35
|
return !!this.dataKey;
|
|
@@ -90,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
90
88
|
}], state: [{
|
|
91
89
|
type: Input
|
|
92
90
|
}] } });
|
|
93
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"blank-node-state.component.js","sourceRoot":"","sources":["../../../../src/common/blank-node-state/blank-node-state.component.ts","../../../../src/common/blank-node-state/blank-node-state.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport {\n  Completeness, Infrastructure, Input as HestiaInput, Emission, Measurement, Practice, Product, Property, NodeType\n} from '@hestia-earth/schema';\nimport { of } from 'rxjs';\nimport { mergeMap } from 'rxjs/operators';\n\nimport { HeAggregationEngineService } from '../../engine/aggregation-engine.service';\nimport { HeEngineService } from '../../engine/engine.service';\nimport { filterParams } from '../utils';\n\ntype blankNode = Completeness | Infrastructure | HestiaInput | Emission | Measurement | Practice | Product | Property;\n\nexport enum NodeKeyState {\n  added = 'added',\n  updated = 'updated',\n  aggregated = 'aggregated',\n  deleted = 'deleted',\n  unchanged = 'unchanged'\n}\n\n@Component({\n  selector: 'he-blank-node-state',\n  templateUrl: './blank-node-state.component.html',\n  styleUrls: ['./blank-node-state.component.scss']\n})\nexport class BlankNodeStateComponent {\n  @Input()\n  private nodeType?: NodeType;\n  @Input()\n  private dataKey?: string;\n  @Input()\n  private key?: string;\n  @Input()\n  public node?: blankNode;\n  /**\n   * Force override state.\n   */\n  @Input()\n  public state?: NodeKeyState;\n\n  public NodeKeyState = NodeKeyState;\n\n  constructor(\n    private aggregationEngineService: HeAggregationEngineService,\n    private engineService: HeEngineService\n  ) { }\n\n  public is(state: NodeKeyState) {\n    return (\n      // forcing state\n      !!this.state && this.state === state\n    ) || (\n      state in this.node! && (\n        typeof this.node![state] === 'boolean' ?\n          this.node![state] :\n          this.node![state].includes(this.key)\n      )\n    );\n  }\n\n  public get stars() {\n    return this.is(NodeKeyState.deleted) ? [0, 1, 2, 3] :\n      (this.is(NodeKeyState.aggregated) ? [0, 1, 2] : (\n        this.is(NodeKeyState.updated) ? [0, 1] : (\n          this.is(NodeKeyState.added) ? [0] : []\n        )\n      ));\n  }\n\n  public get showLink() {\n    return !!this.dataKey;\n  }\n\n  private get aggregatedModelParams() {\n    return filterParams({\n      type: this.nodeType,\n      dataPath: [this.dataKey, this.key].filter(Boolean).join('.')\n    });\n  }\n\n  public get aggregatedModel$() {\n    return this.aggregationEngineService.model$(this.aggregatedModelParams);\n  }\n\n  private get modelParams() {\n    return filterParams({\n      model: 'methodModel' in this.node! ? this.node?.methodModel!['@id'] : undefined,\n      term: 'term' in this.node! ? this.node?.term!['@id'] : undefined\n    });\n  }\n\n  private get modelKeyParams() {\n    return filterParams({\n      model: (this.node!['@type'] || this.node?.type).toLowerCase(),\n      modelKey: this.key\n    });\n  }\n\n  public get engineModel$() {\n    return this.engineService.model$(this.modelParams).pipe(\n      // fallback to modelKey\n      mergeMap(value => value ? of(value) : this.engineService.model$(this.modelKeyParams)),\n      // defaults to methodModel\n      mergeMap(value => value ? of(value) : (\n        'methodModel' in this.node! ? this.engineService.model$({ model: this.node?.methodModel!['@id'] }) : of(null)\n      ))\n    );\n  }\n}\n","<ng-container *bindOnce=\"node\">\n  <span *ngFor=\"let star of stars\">*</span>\n  <span *ngIf=\"is(NodeKeyState.unchanged)\">†</span>\n\n  <ng-container *ngIf=\"showLink\">\n    <!-- <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.aggregated)\">\n      <ng-container *ngIf=\"aggregatedModel$ | async as model\">\n        <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n      </ng-container>\n    </span> -->\n\n    <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.added); else showUpdated\">\n      <ng-container *ngIf=\"engineModel$ | async as model\">\n        <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n      </ng-container>\n    </span>\n  </ng-container>\n</ng-container>\n\n<ng-template #showUpdated>\n  <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.updated)\">\n    <ng-container *ngIf=\"engineModel$ | async as model\">\n      <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n    </ng-container>\n  </span>\n</ng-template>\n\n<ng-template #docsLink let-model>\n  <a [href]=\"model.apiDocsPath || model.docPath || model.path\" target=\"_blank\"\n    (click)=\"$event.stopPropagation()\"\n  >\n    <span>Docs</span>\n    <fa-icon class=\"ml-2\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n  </a>\n</ng-template>\n"]}
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"blank-node-state.component.js","sourceRoot":"","sources":["../../../../src/common/blank-node-state/blank-node-state.component.ts","../../../../src/common/blank-node-state/blank-node-state.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport { NodeType } from '@hestia-earth/schema';\nimport { of } from 'rxjs';\nimport { mergeMap } from 'rxjs/operators';\n\nimport { HeAggregationEngineService } from '../../engine/aggregation-engine.service';\nimport { HeEngineService } from '../../engine/engine.service';\nimport { NodeKeyState, blankNode, isState } from '../node-utils';\nimport { filterParams } from '../utils';\n\n@Component({\n  selector: 'he-blank-node-state',\n  templateUrl: './blank-node-state.component.html',\n  styleUrls: ['./blank-node-state.component.scss']\n})\nexport class BlankNodeStateComponent {\n  @Input()\n  private nodeType?: NodeType;\n  @Input()\n  private dataKey?: string;\n  @Input()\n  private key?: string;\n  @Input()\n  public node?: blankNode;\n  /**\n   * Force override state.\n   */\n  @Input()\n  public state?: NodeKeyState;\n\n  public NodeKeyState = NodeKeyState;\n\n  constructor(\n    private aggregationEngineService: HeAggregationEngineService,\n    private engineService: HeEngineService\n  ) { }\n\n  public is(state: NodeKeyState) {\n    return (\n      // forcing state\n      !!this.state && this.state === state\n    ) || isState(this.node, this.key, state);\n  }\n\n  public get stars() {\n    return this.is(NodeKeyState.deleted)\n      ? [0, 1, 2, 3]\n      : this.is(NodeKeyState.updated)\n      ? [0, 1]\n      : this.is(NodeKeyState.aggregated) // handle here because aggregated can be updated\n      ? [0, 1, 2]\n      : this.is(NodeKeyState.added)\n      ? [0]\n      : []\n      ;\n  }\n\n  public get showLink() {\n    return !!this.dataKey;\n  }\n\n  private get aggregatedModelParams() {\n    return filterParams({\n      type: this.nodeType,\n      dataPath: [this.dataKey, this.key].filter(Boolean).join('.')\n    });\n  }\n\n  public get aggregatedModel$() {\n    return this.aggregationEngineService.model$(this.aggregatedModelParams);\n  }\n\n  private get modelParams() {\n    return filterParams({\n      model: 'methodModel' in this.node! ? this.node?.methodModel!['@id'] : undefined,\n      term: 'term' in this.node! ? this.node?.term!['@id'] : undefined\n    });\n  }\n\n  private get modelKeyParams() {\n    return filterParams({\n      model: (this.node!['@type'] || this.node?.type).toLowerCase(),\n      modelKey: this.key\n    });\n  }\n\n  public get engineModel$() {\n    return this.engineService.model$(this.modelParams).pipe(\n      // fallback to modelKey\n      mergeMap(value => value ? of(value) : this.engineService.model$(this.modelKeyParams)),\n      // defaults to methodModel\n      mergeMap(value => value ? of(value) : (\n        'methodModel' in this.node! ? this.engineService.model$({ model: this.node?.methodModel!['@id'] }) : of(null)\n      ))\n    );\n  }\n}\n","<ng-container *bindOnce=\"node\">\n  <span *ngFor=\"let star of stars\">*</span>\n  <span *ngIf=\"is(NodeKeyState.unchanged)\">†</span>\n\n  <ng-container *ngIf=\"showLink\">\n    <!-- <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.aggregated)\">\n      <ng-container *ngIf=\"aggregatedModel$ | async as model\">\n        <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n      </ng-container>\n    </span> -->\n\n    <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.added); else showUpdated\">\n      <ng-container *ngIf=\"engineModel$ | async as model\">\n        <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n      </ng-container>\n    </span>\n  </ng-container>\n</ng-container>\n\n<ng-template #showUpdated>\n  <span class=\"ml-2\" *ngIf=\"is(NodeKeyState.updated)\">\n    <ng-container *ngIf=\"engineModel$ | async as model\">\n      <ng-container *ngTemplateOutlet=\"docsLink; context: {$implicit: model}\"></ng-container>\n    </ng-container>\n  </span>\n</ng-template>\n\n<ng-template #docsLink let-model>\n  <a [href]=\"model.apiDocsPath || model.docPath || model.path\" target=\"_blank\"\n    (click)=\"$event.stopPropagation()\"\n  >\n    <span>Docs</span>\n    <fa-icon class=\"ml-2\" icon=\"external-link-alt\" size=\"sm\"></fa-icon>\n  </a>\n</ng-template>\n"]}
|
|
@@ -20,6 +20,7 @@ import { ClickOutsideDirective } from './click-outside.directive';
|
|
|
20
20
|
import { GetPipe } from './get.pipe';
|
|
21
21
|
import { TagsInputDirective } from './tags-input.directive';
|
|
22
22
|
import { TimesPipe } from './times.pipe';
|
|
23
|
+
import { IsArrayPipe } from './is-array.pipe';
|
|
23
24
|
import * as i0 from "@angular/core";
|
|
24
25
|
const components = [
|
|
25
26
|
ClipboardComponent,
|
|
@@ -36,7 +37,8 @@ const components = [
|
|
|
36
37
|
TimesPipe,
|
|
37
38
|
ClickOutsideDirective,
|
|
38
39
|
SkeletonTextComponent,
|
|
39
|
-
GetPipe
|
|
40
|
+
GetPipe,
|
|
41
|
+
IsArrayPipe
|
|
40
42
|
];
|
|
41
43
|
export class HeCommonModule {
|
|
42
44
|
}
|
|
@@ -55,7 +57,8 @@ HeCommonModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version:
|
|
|
55
57
|
TimesPipe,
|
|
56
58
|
ClickOutsideDirective,
|
|
57
59
|
SkeletonTextComponent,
|
|
58
|
-
GetPipe
|
|
60
|
+
GetPipe,
|
|
61
|
+
IsArrayPipe], imports: [CommonModule, FormsModule, RouterModule,
|
|
59
62
|
NgbTypeaheadModule, NgbTooltipModule, NgbPopoverModule,
|
|
60
63
|
GoogleMapsModule,
|
|
61
64
|
HeCommonLightModule], exports: [NgbTypeaheadModule, NgbTooltipModule, NgbPopoverModule,
|
|
@@ -74,7 +77,8 @@ HeCommonModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version:
|
|
|
74
77
|
TimesPipe,
|
|
75
78
|
ClickOutsideDirective,
|
|
76
79
|
SkeletonTextComponent,
|
|
77
|
-
GetPipe
|
|
80
|
+
GetPipe,
|
|
81
|
+
IsArrayPipe] });
|
|
78
82
|
HeCommonModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: HeCommonModule, imports: [[
|
|
79
83
|
CommonModule, FormsModule, RouterModule,
|
|
80
84
|
NgbTypeaheadModule, NgbTooltipModule, NgbPopoverModule,
|
|
@@ -101,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
101
105
|
]
|
|
102
106
|
}]
|
|
103
107
|
}] });
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tb24vY29tbW9uLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3BHLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBRXhELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBRTVELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLCtDQUErQyxDQUFDO0FBQ3hGLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLDZEQUE2RCxDQUFDO0FBQzVHLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBQ3pHLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ2xGLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLHVEQUF1RCxDQUFDO0FBQ3BHLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQy9ELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDZDQUE2QyxDQUFDO0FBQ3RGLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLHFEQUFxRCxDQUFDO0FBQ2pHLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ2hGLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFDckMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDNUQsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUN6QyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0saUJBQWlCLENBQUM7O0FBRTlDLE1BQU0sVUFBVSxHQUFHO0lBQ2pCLGtCQUFrQjtJQUNsQixnQkFBZ0I7SUFDaEIsdUJBQXVCO0lBQ3ZCLGtCQUFrQjtJQUNsQixxQkFBcUI7SUFDckIsMkJBQTJCO0lBQzNCLHVCQUF1QjtJQUN2Qiw2QkFBNkI7SUFDN0IsNEJBQTRCO0lBQzVCLDBCQUEwQjtJQUMxQixzQkFBc0I7SUFDdEIsU0FBUztJQUNULHFCQUFxQjtJQUNyQixxQkFBcUI7SUFDckIsT0FBTztJQUNQLFdBQVc7Q0FDWixDQUFDO0FBaUJGLE1BQU0sT0FBTyxjQUFjOzs0R0FBZCxjQUFjOzZHQUFkLGNBQWMsaUJBakN6QixrQkFBa0I7UUFDbEIsZ0JBQWdCO1FBQ2hCLHVCQUF1QjtRQUN2QixrQkFBa0I7UUFDbEIscUJBQXFCO1FBQ3JCLDJCQUEyQjtRQUMzQix1QkFBdUI7UUFDdkIsNkJBQTZCO1FBQzdCLDRCQUE0QjtRQUM1QiwwQkFBMEI7UUFDMUIsc0JBQXNCO1FBQ3RCLFNBQVM7UUFDVCxxQkFBcUI7UUFDckIscUJBQXFCO1FBQ3JCLE9BQU87UUFDUCxXQUFXLGFBWVQsWUFBWSxFQUFFLFdBQVcsRUFBRSxZQUFZO1FBQ3ZDLGtCQUFrQixFQUFFLGdCQUFnQixFQUFFLGdCQUFnQjtRQUN0RCxnQkFBZ0I7UUFDaEIsbUJBQW1CLGFBVG5CLGtCQUFrQixFQUFFLGdCQUFnQixFQUFFLGdCQUFnQjtRQUN0RCxnQkFBZ0I7UUFDaEIsbUJBQW1CLEVBdkJyQixrQkFBa0I7UUFDbEIsZ0JBQWdCO1FBQ2hCLHVCQUF1QjtRQUN2QixrQkFBa0I7UUFDbEIscUJBQXFCO1FBQ3JCLDJCQUEyQjtRQUMzQix1QkFBdUI7UUFDdkIsNkJBQTZCO1FBQzdCLDRCQUE0QjtRQUM1QiwwQkFBMEI7UUFDMUIsc0JBQXNCO1FBQ3RCLFNBQVM7UUFDVCxxQkFBcUI7UUFDckIscUJBQXFCO1FBQ3JCLE9BQU87UUFDUCxXQUFXOzZHQWtCQSxjQUFjLFlBUGhCO1lBQ1AsWUFBWSxFQUFFLFdBQVcsRUFBRSxZQUFZO1lBQ3ZDLGtCQUFrQixFQUFFLGdCQUFnQixFQUFFLGdCQUFnQjtZQUN0RCxnQkFBZ0I7WUFDaEIsbUJBQW1CO1NBQ3BCLEVBVkMsa0JBQWtCLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCO1FBQ3RELGdCQUFnQjtRQUNoQixtQkFBbUI7NEZBVVYsY0FBYztrQkFmMUIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsVUFBVTtvQkFDeEIsT0FBTyxFQUFFO3dCQUNQLGtCQUFrQixFQUFFLGdCQUFnQixFQUFFLGdCQUFnQjt3QkFDdEQsZ0JBQWdCO3dCQUNoQixtQkFBbUI7d0JBQ25CLEdBQUcsVUFBVTtxQkFDZDtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWSxFQUFFLFdBQVcsRUFBRSxZQUFZO3dCQUN2QyxrQkFBa0IsRUFBRSxnQkFBZ0IsRUFBRSxnQkFBZ0I7d0JBQ3RELGdCQUFnQjt3QkFDaEIsbUJBQW1CO3FCQUNwQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBSb3V0ZXJNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9yb3V0ZXInO1xuaW1wb3J0IHsgTmdiVHlwZWFoZWFkTW9kdWxlLCBOZ2JUb29sdGlwTW9kdWxlLCBOZ2JQb3BvdmVyTW9kdWxlIH0gZnJvbSAnQG5nLWJvb3RzdHJhcC9uZy1ib290c3RyYXAnO1xuaW1wb3J0IHsgR29vZ2xlTWFwc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2dvb2dsZS1tYXBzJztcblxuaW1wb3J0IHsgSGVDb21tb25MaWdodE1vZHVsZSB9IGZyb20gJy4vY29tbW9uLmxpZ2h0Lm1vZHVsZSc7XG5cbmltcG9ydCB7IEJsYW5rTm9kZVN0YXRlQ29tcG9uZW50IH0gZnJvbSAnLi9ibGFuay1ub2RlLXN0YXRlL2JsYW5rLW5vZGUtc3RhdGUuY29tcG9uZW50JztcbmltcG9ydCB7IEJsYW5rTm9kZVN0YXRlTm90aWNlQ29tcG9uZW50IH0gZnJvbSAnLi9ibGFuay1ub2RlLXN0YXRlLW5vdGljZS9ibGFuay1ub2RlLXN0YXRlLW5vdGljZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQmxhbmtOb2RlVmFsdWVEZWx0YUNvbXBvbmVudCB9IGZyb20gJy4vYmxhbmstbm9kZS12YWx1ZS1kZWx0YS9ibGFuay1ub2RlLXZhbHVlLWRlbHRhLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDbGlwYm9hcmRDb21wb25lbnQgfSBmcm9tICcuL2NsaXBib2FyZC9jbGlwYm9hcmQuY29tcG9uZW50JztcbmltcG9ydCB7IExpbmtLZXlWYWx1ZUNvbXBvbmVudCB9IGZyb20gJy4vbGluay1rZXktdmFsdWUvbGluay1rZXktdmFsdWUuY29tcG9uZW50JztcbmltcG9ydCB7IE1hcHNEcmF3aW5nQ29uZmlybUNvbXBvbmVudCB9IGZyb20gJy4vbWFwcy1kcmF3aW5nLWNvbmZpcm0vbWFwcy1kcmF3aW5nLWNvbmZpcm0uY29tcG9uZW50JztcbmltcG9ydCB7IFBvcG92ZXJDb21wb25lbnQgfSBmcm9tICcuL3BvcG92ZXIvcG9wb3Zlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgUG9wb3ZlckNvbmZpcm1Db21wb25lbnQgfSBmcm9tICcuL3BvcG92ZXItY29uZmlybS9wb3BvdmVyLWNvbmZpcm0uY29tcG9uZW50JztcbmltcG9ydCB7IFNjaGVtYVZlcnNpb25MaW5rQ29tcG9uZW50IH0gZnJvbSAnLi9zY2hlbWEtdmVyc2lvbi1saW5rL3NjaGVtYS12ZXJzaW9uLWxpbmsuY29tcG9uZW50JztcbmltcG9ydCB7IFNrZWxldG9uVGV4dENvbXBvbmVudCB9IGZyb20gJy4vc2tlbGV0b24tdGV4dC9za2VsZXRvbi10ZXh0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBVbml0Q29udmVydGVyQ29tcG9uZW50IH0gZnJvbSAnLi91bml0LWNvbnZlcnRlci91bml0LWNvbnZlcnRlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2xpY2tPdXRzaWRlRGlyZWN0aXZlIH0gZnJvbSAnLi9jbGljay1vdXRzaWRlLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBHZXRQaXBlIH0gZnJvbSAnLi9nZXQucGlwZSc7XG5pbXBvcnQgeyBUYWdzSW5wdXREaXJlY3RpdmUgfSBmcm9tICcuL3RhZ3MtaW5wdXQuZGlyZWN0aXZlJztcbmltcG9ydCB7IFRpbWVzUGlwZSB9IGZyb20gJy4vdGltZXMucGlwZSc7XG5pbXBvcnQgeyBJc0FycmF5UGlwZSB9IGZyb20gJy4vaXMtYXJyYXkucGlwZSc7XG5cbmNvbnN0IGNvbXBvbmVudHMgPSBbXG4gIENsaXBib2FyZENvbXBvbmVudCxcbiAgUG9wb3ZlckNvbXBvbmVudCxcbiAgUG9wb3ZlckNvbmZpcm1Db21wb25lbnQsXG4gIFRhZ3NJbnB1dERpcmVjdGl2ZSxcbiAgTGlua0tleVZhbHVlQ29tcG9uZW50LFxuICBNYXBzRHJhd2luZ0NvbmZpcm1Db21wb25lbnQsXG4gIEJsYW5rTm9kZVN0YXRlQ29tcG9uZW50LFxuICBCbGFua05vZGVTdGF0ZU5vdGljZUNvbXBvbmVudCxcbiAgQmxhbmtOb2RlVmFsdWVEZWx0YUNvbXBvbmVudCxcbiAgU2NoZW1hVmVyc2lvbkxpbmtDb21wb25lbnQsXG4gIFVuaXRDb252ZXJ0ZXJDb21wb25lbnQsXG4gIFRpbWVzUGlwZSxcbiAgQ2xpY2tPdXRzaWRlRGlyZWN0aXZlLFxuICBTa2VsZXRvblRleHRDb21wb25lbnQsXG4gIEdldFBpcGUsXG4gIElzQXJyYXlQaXBlXG5dO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IGNvbXBvbmVudHMsXG4gIGV4cG9ydHM6IFtcbiAgICBOZ2JUeXBlYWhlYWRNb2R1bGUsIE5nYlRvb2x0aXBNb2R1bGUsIE5nYlBvcG92ZXJNb2R1bGUsXG4gICAgR29vZ2xlTWFwc01vZHVsZSxcbiAgICBIZUNvbW1vbkxpZ2h0TW9kdWxlLFxuICAgIC4uLmNvbXBvbmVudHNcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSwgRm9ybXNNb2R1bGUsIFJvdXRlck1vZHVsZSxcbiAgICBOZ2JUeXBlYWhlYWRNb2R1bGUsIE5nYlRvb2x0aXBNb2R1bGUsIE5nYlBvcG92ZXJNb2R1bGUsXG4gICAgR29vZ2xlTWFwc01vZHVsZSxcbiAgICBIZUNvbW1vbkxpZ2h0TW9kdWxlXG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgSGVDb21tb25Nb2R1bGUgeyB9XG4iXX0=
|
package/esm2015/common/index.js
CHANGED
|
@@ -24,10 +24,11 @@ export { ClickOutsideDirective } from './click-outside.directive';
|
|
|
24
24
|
export { DefaultPipe } from './default.pipe';
|
|
25
25
|
export { EllipsisPipe } from './ellipsis.pipe';
|
|
26
26
|
export { GetPipe } from './get.pipe';
|
|
27
|
+
export { IsArrayPipe } from './is-array.pipe';
|
|
27
28
|
export { KeyToLabelPipe } from './key-to-label.pipe';
|
|
28
29
|
export { KeysPipe } from './keys.pipe';
|
|
29
30
|
export { PluralizePipe } from './pluralize.pipe';
|
|
30
31
|
export { PrecisionPipe } from './precision.pipe';
|
|
31
32
|
export { TagsInputDirective } from './tags-input.directive';
|
|
32
33
|
export { TimesPipe } from './times.pipe';
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tbW9uL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxTQUFTLENBQUM7QUFFeEIsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sK0NBQStDLENBQUM7QUFDeEYsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sNkRBQTZELENBQUM7QUFDNUcsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sMkRBQTJELENBQUM7QUFDekcsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDckUsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sdURBQXVELENBQUM7QUFDcEcsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDL0QsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sNkNBQTZDLENBQUM7QUFDdEYsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0scURBQXFELENBQUM7QUFDakcsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDaEYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDMUUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzFELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFlBQVksQ0FBQztBQUNyQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDOUMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDdkMsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNqRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUM1RCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9jb21tb24ubGlnaHQubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vY29tbW9uLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL2NvbW1vbi5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vdG9hc3Quc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL2RlbHRhLXV0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vbG9ncy11dGlscyc7XG5leHBvcnQgKiBmcm9tICcuL21hcHMtdXRpbHMnO1xuZXhwb3J0ICogZnJvbSAnLi91dGlscyc7XG5cbmV4cG9ydCB7IEJsYW5rTm9kZVN0YXRlQ29tcG9uZW50IH0gZnJvbSAnLi9ibGFuay1ub2RlLXN0YXRlL2JsYW5rLW5vZGUtc3RhdGUuY29tcG9uZW50JztcbmV4cG9ydCB7IEJsYW5rTm9kZVN0YXRlTm90aWNlQ29tcG9uZW50IH0gZnJvbSAnLi9ibGFuay1ub2RlLXN0YXRlLW5vdGljZS9ibGFuay1ub2RlLXN0YXRlLW5vdGljZS5jb21wb25lbnQnO1xuZXhwb3J0IHsgQmxhbmtOb2RlVmFsdWVEZWx0YUNvbXBvbmVudCB9IGZyb20gJy4vYmxhbmstbm9kZS12YWx1ZS1kZWx0YS9ibGFuay1ub2RlLXZhbHVlLWRlbHRhLmNvbXBvbmVudCc7XG5leHBvcnQgeyBDbGlwYm9hcmRDb21wb25lbnQgfSBmcm9tICcuL2NsaXBib2FyZC9jbGlwYm9hcmQuY29tcG9uZW50JztcbmV4cG9ydCB7IExpbmtLZXlWYWx1ZUNvbXBvbmVudCB9IGZyb20gJy4vbGluay1rZXktdmFsdWUvbGluay1rZXktdmFsdWUuY29tcG9uZW50JztcbmV4cG9ydCB7IE1hcHNEcmF3aW5nQ29uZmlybUNvbXBvbmVudCB9IGZyb20gJy4vbWFwcy1kcmF3aW5nLWNvbmZpcm0vbWFwcy1kcmF3aW5nLWNvbmZpcm0uY29tcG9uZW50JztcbmV4cG9ydCB7IFBvcG92ZXJDb21wb25lbnQgfSBmcm9tICcuL3BvcG92ZXIvcG9wb3Zlci5jb21wb25lbnQnO1xuZXhwb3J0IHsgUG9wb3ZlckNvbmZpcm1Db21wb25lbnQgfSBmcm9tICcuL3BvcG92ZXItY29uZmlybS9wb3BvdmVyLWNvbmZpcm0uY29tcG9uZW50JztcbmV4cG9ydCB7IFNjaGVtYVZlcnNpb25MaW5rQ29tcG9uZW50IH0gZnJvbSAnLi9zY2hlbWEtdmVyc2lvbi1saW5rL3NjaGVtYS12ZXJzaW9uLWxpbmsuY29tcG9uZW50JztcbmV4cG9ydCB7IFNrZWxldG9uVGV4dENvbXBvbmVudCB9IGZyb20gJy4vc2tlbGV0b24tdGV4dC9za2VsZXRvbi10ZXh0LmNvbXBvbmVudCc7XG5leHBvcnQgeyBTb2NpYWxUYWdzQ29tcG9uZW50IH0gZnJvbSAnLi9zb2NpYWwtdGFncy9zb2NpYWwtdGFncy5jb21wb25lbnQnO1xuZXhwb3J0IHsgVG9hc3RDb21wb25lbnQgfSBmcm9tICcuL3RvYXN0L3RvYXN0LmNvbXBvbmVudCc7XG5leHBvcnQgeyBVbml0Q29udmVydGVyQ29tcG9uZW50IH0gZnJvbSAnLi91bml0LWNvbnZlcnRlci91bml0LWNvbnZlcnRlci5jb21wb25lbnQnO1xuZXhwb3J0IHsgQmluZE9uY2VEaXJlY3RpdmUgfSBmcm9tICcuL2JpbmQtb25jZS5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgQ2xpY2tPdXRzaWRlRGlyZWN0aXZlIH0gZnJvbSAnLi9jbGljay1vdXRzaWRlLmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBEZWZhdWx0UGlwZSB9IGZyb20gJy4vZGVmYXVsdC5waXBlJztcbmV4cG9ydCB7IEVsbGlwc2lzUGlwZSB9IGZyb20gJy4vZWxsaXBzaXMucGlwZSc7XG5leHBvcnQgeyBHZXRQaXBlIH0gZnJvbSAnLi9nZXQucGlwZSc7XG5leHBvcnQgeyBJc0FycmF5UGlwZSB9IGZyb20gJy4vaXMtYXJyYXkucGlwZSc7XG5leHBvcnQgeyBLZXlUb0xhYmVsUGlwZSB9IGZyb20gJy4va2V5LXRvLWxhYmVsLnBpcGUnO1xuZXhwb3J0IHsgS2V5c1BpcGUgfSBmcm9tICcuL2tleXMucGlwZSc7XG5leHBvcnQgeyBQbHVyYWxpemVQaXBlIH0gZnJvbSAnLi9wbHVyYWxpemUucGlwZSc7XG5leHBvcnQgeyBQcmVjaXNpb25QaXBlIH0gZnJvbSAnLi9wcmVjaXNpb24ucGlwZSc7XG5leHBvcnQgeyBUYWdzSW5wdXREaXJlY3RpdmUgfSBmcm9tICcuL3RhZ3MtaW5wdXQuZGlyZWN0aXZlJztcbmV4cG9ydCB7IFRpbWVzUGlwZSB9IGZyb20gJy4vdGltZXMucGlwZSc7XG4iXX0=
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { Pipe } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class IsArrayPipe {
|
|
4
|
+
transform(value) {
|
|
5
|
+
return Array.isArray(value);
|
|
6
|
+
}
|
|
7
|
+
}
|
|
8
|
+
IsArrayPipe.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: IsArrayPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe });
|
|
9
|
+
IsArrayPipe.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: IsArrayPipe, name: "isArray" });
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: IsArrayPipe, decorators: [{
|
|
11
|
+
type: Pipe,
|
|
12
|
+
args: [{
|
|
13
|
+
name: 'isArray'
|
|
14
|
+
}]
|
|
15
|
+
}] });
|
|
16
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXMtYXJyYXkucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21tb24vaXMtYXJyYXkucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7QUFLcEQsTUFBTSxPQUFPLFdBQVc7SUFDdEIsU0FBUyxDQUFDLEtBQVk7UUFDcEIsT0FBTyxLQUFLLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzlCLENBQUM7O3lHQUhVLFdBQVc7dUdBQVgsV0FBVzs0RkFBWCxXQUFXO2tCQUh2QixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxTQUFTO2lCQUNoQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQFBpcGUoe1xuICBuYW1lOiAnaXNBcnJheSdcbn0pXG5leHBvcnQgY2xhc3MgSXNBcnJheVBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcbiAgdHJhbnNmb3JtKHZhbHVlOiBhbnlbXSkge1xuICAgIHJldHVybiBBcnJheS5pc0FycmF5KHZhbHVlKTtcbiAgfVxufVxuIl19
|