@hestia-earth/ui-components 0.0.9 → 0.0.10
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/README.md +5 -22
- package/bibliographies/bibliographies-search-confirm/bibliographies-search-confirm.component.d.ts +1 -1
- package/bundles/hestia-earth-ui-components.umd.js +1509 -8
- package/bundles/hestia-earth-ui-components.umd.js.map +1 -1
- package/common/blank-node-state/blank-node-state.component.d.ts +2 -2
- package/common/delta-utils.d.ts +1 -1
- package/common/link-key-value/link-key-value.component.d.ts +1 -1
- package/common/maps-utils.d.ts +2 -2
- package/common/precision.pipe.d.ts +1 -1
- package/common/tags-input.directive.d.ts +1 -1
- package/common/utils.d.ts +7 -7
- package/cycles/cycles-emissions-chart/cycles-emissions-chart.component.d.ts +2 -2
- package/cycles/cycles-suggest-form/cycles-suggest-form.component.d.ts +1 -2
- package/cycles/cycles.model.d.ts +1 -1
- package/engine/aggregation-engine.service.d.ts +2 -2
- package/engine/engine.service.d.ts +3 -3
- package/esm2015/common/tags-input.directive.js +3 -3
- package/esm2015/tags-input/defaultOptions.js +26 -0
- package/esm2015/tags-input/index.js +1053 -0
- package/esm2015/tags-input/templates/dropdown-item.js +3 -0
- package/esm2015/tags-input/templates/tag.js +6 -0
- package/esm2015/tags-input/templates/wrapper.js +10 -0
- package/esm2015/tags-input/utils/component.js +80 -0
- package/esm2015/tags-input/utils/dom.js +98 -0
- package/esm2015/tags-input/utils/events.js +147 -0
- package/esm2015/tags-input/utils/type.js +41 -0
- package/esm2015/tags-input/utils/uuid.js +3 -0
- package/fesm2015/hestia-earth-ui-components.js +1506 -55
- package/fesm2015/hestia-earth-ui-components.js.map +1 -1
- package/files/files-error.model.d.ts +5 -5
- package/files/files-form/files-form.component.d.ts +7 -7
- package/files/files-form.model.d.ts +10 -10
- package/impact-assessments/impact-assessments-indicators-chart/impact-assessments-indicators-chart.component.d.ts +2 -2
- package/impact-assessments/impact-assessments-products/impact-assessments-products.component.d.ts +2 -2
- package/node/node-icon/node-icon.component.d.ts +1 -1
- package/node/node-link/node-link.component.d.ts +1 -1
- package/node/node-logs-models/node-logs-models.component.d.ts +1 -1
- package/node/node.service.d.ts +2 -2
- package/package.json +1 -2
- package/schema/schema.service.d.ts +1 -1
- package/search/search.model.d.ts +18 -17
- package/search/search.service.d.ts +7 -7
- package/sites/sites-maps/sites-maps.component.d.ts +1 -1
- package/sites/sites-measurements/sites-measurements.component.d.ts +1 -1
- package/sites/sites.model.d.ts +1 -1
- package/styles.scss +1 -1
- package/tags-input/defaultOptions.d.ts +25 -0
- package/tags-input/index.d.ts +277 -0
- package/tags-input/styles.sass +154 -0
- package/tags-input/templates/dropdown-item.d.ts +2 -0
- package/tags-input/templates/tag.d.ts +2 -0
- package/tags-input/templates/wrapper.d.ts +2 -0
- package/tags-input/utils/component.d.ts +22 -0
- package/tags-input/utils/dom.d.ts +38 -0
- package/tags-input/utils/events.d.ts +72 -0
- package/tags-input/utils/type.d.ts +17 -0
- package/tags-input/utils/uuid.d.ts +2 -0
- package/terms/terms.model.d.ts +1 -1
|
@@ -26,10 +26,10 @@ export declare class BlankNodeStateComponent {
|
|
|
26
26
|
get stars(): number[];
|
|
27
27
|
get showLink(): boolean;
|
|
28
28
|
private get aggregatedModelParams();
|
|
29
|
-
get aggregatedModel$(): import("rxjs").Observable<import("../../engine/aggregation-engine.service").IAggregationModel
|
|
29
|
+
get aggregatedModel$(): import("rxjs").Observable<import("../../engine/aggregation-engine.service").IAggregationModel>;
|
|
30
30
|
private get modelParams();
|
|
31
31
|
private get modelKeyParams();
|
|
32
|
-
get engineModel$(): import("rxjs").Observable<
|
|
32
|
+
get engineModel$(): import("rxjs").Observable<any>;
|
|
33
33
|
static ɵfac: i0.ɵɵFactoryDeclaration<BlankNodeStateComponent, never>;
|
|
34
34
|
static ɵcmp: i0.ɵɵComponentDeclaration<BlankNodeStateComponent, "he-blank-node-state", never, { "nodeType": "nodeType"; "dataKey": "dataKey"; "key": "key"; "node": "node"; "state": "state"; }, {}, never, never>;
|
|
35
35
|
}
|
package/common/delta-utils.d.ts
CHANGED
|
@@ -11,7 +11,7 @@ declare type deltaTypeMapping = {
|
|
|
11
11
|
[type in DeltaDisplayType]?: (value: number, original: number) => number;
|
|
12
12
|
};
|
|
13
13
|
export declare const roundValue: (value: any) => number;
|
|
14
|
-
export declare const delta: (value: any, originalValue: any, displayType?: DeltaDisplayType, mapping?: deltaTypeMapping
|
|
14
|
+
export declare const delta: (value: any, originalValue: any, displayType?: DeltaDisplayType, mapping?: deltaTypeMapping) => number;
|
|
15
15
|
export declare const calculatePercentDelta: (recalculated: number, original: number) => number;
|
|
16
16
|
export declare const customDeltaFuncs: {
|
|
17
17
|
percent: (recalculated: number, original: number) => number;
|
|
@@ -9,7 +9,7 @@ export declare class LinkKeyValueComponent {
|
|
|
9
9
|
get type(): any;
|
|
10
10
|
get value(): any;
|
|
11
11
|
get valueString(): any;
|
|
12
|
-
get valueLink(): string
|
|
12
|
+
get valueLink(): string;
|
|
13
13
|
get isUndefined(): boolean;
|
|
14
14
|
static ɵfac: i0.ɵɵFactoryDeclaration<LinkKeyValueComponent, never>;
|
|
15
15
|
static ɵcmp: i0.ɵɵComponentDeclaration<LinkKeyValueComponent, "he-link-key-value", never, { "node": "node"; "nodeType": "nodeType"; "dataKey": "dataKey"; "key": "key"; }, {}, never, never>;
|
package/common/maps-utils.d.ts
CHANGED
|
@@ -35,7 +35,7 @@ export declare const markerPie: (configs: IMarkerPieConfig[], size?: number) =>
|
|
|
35
35
|
labelOrigin: google.maps.Point;
|
|
36
36
|
};
|
|
37
37
|
export declare const markerIcon: (scale?: number) => google.maps.Symbol;
|
|
38
|
-
export declare const createMarker: (position?: google.maps.LatLng | google.maps.ReadonlyLatLngLiteral
|
|
38
|
+
export declare const createMarker: (position?: google.maps.LatLng | google.maps.ReadonlyLatLngLiteral, text?: string, color?: string, scale?: number) => google.maps.Marker;
|
|
39
39
|
interface IPolygon {
|
|
40
40
|
type: 'Polygon';
|
|
41
41
|
coordinates: number[][][];
|
|
@@ -66,5 +66,5 @@ export declare const coordinatesToPoint: (values: (number | number[])[]) => any;
|
|
|
66
66
|
export declare const polygonToCoordinates: (polygon: google.maps.Polygon) => number[][];
|
|
67
67
|
export declare const addPolygonToFeature: (feat: feature, polygon: google.maps.Polygon) => any;
|
|
68
68
|
export declare const polygonsFromFeature: (feat: feature) => google.maps.Polygon[];
|
|
69
|
-
export declare const polygonBounds: (polygon?: google.maps.Polygon | google.maps.Polygon[]
|
|
69
|
+
export declare const polygonBounds: (polygon?: google.maps.Polygon | google.maps.Polygon[]) => any;
|
|
70
70
|
export {};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { PipeTransform } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export declare class PrecisionPipe implements PipeTransform {
|
|
4
|
-
transform(value: string | number, precision?: string | number): string | number
|
|
4
|
+
transform(value: string | number, precision?: string | number): string | number;
|
|
5
5
|
static ɵfac: i0.ɵɵFactoryDeclaration<PrecisionPipe, never>;
|
|
6
6
|
static ɵpipe: i0.ɵɵPipeDeclaration<PrecisionPipe, "precision">;
|
|
7
7
|
}
|
|
@@ -2,7 +2,7 @@ import { AfterViewInit, ElementRef, OnDestroy } from '@angular/core';
|
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export declare class TagsInputDirective implements AfterViewInit, OnDestroy {
|
|
4
4
|
private elementRef;
|
|
5
|
-
private tagsInput
|
|
5
|
+
private tagsInput?;
|
|
6
6
|
private inputEvents;
|
|
7
7
|
private appTagsInput;
|
|
8
8
|
constructor(elementRef: ElementRef);
|
package/common/utils.d.ts
CHANGED
|
@@ -19,7 +19,7 @@ export declare const safeJSONParse: <T>(value: string, defaultValue?: any) => an
|
|
|
19
19
|
export declare const safeJSONStringify: (value: string) => string;
|
|
20
20
|
export declare const arrayValue: (values: any[], isAverage: boolean) => number;
|
|
21
21
|
export declare const propertyValue: (value: string | number | ((string | number)[]), isAverage?: boolean) => number;
|
|
22
|
-
export declare const dataValue: (data: any, index: number, property: string) => number
|
|
22
|
+
export declare const dataValue: (data: any, index: number, property: string) => number;
|
|
23
23
|
export interface IGroupedNode<T> {
|
|
24
24
|
nodes: T[];
|
|
25
25
|
index: number;
|
|
@@ -59,15 +59,15 @@ export interface IGroupedKeys<T> {
|
|
|
59
59
|
}
|
|
60
60
|
export declare const grouppedKeys: <T>(value: IGroupedNodes<T>) => IGroupedKeys<T>[];
|
|
61
61
|
export declare const grouppedValueKeys: string[];
|
|
62
|
-
export declare const groupNodesByTerm: <T extends IImpactAssessmentJSONLD | ISiteJSONLD | ICycleJSONLD, R>(nodes: T[]
|
|
62
|
+
export declare const groupNodesByTerm: <T extends IImpactAssessmentJSONLD | ISiteJSONLD | ICycleJSONLD, R>(nodes: T[], key: 'impacts' | 'emissionsResourceUse' | 'inputs' | 'products' | 'emissions' | 'measurements', originalValues?: T[], filterMethod?: Term) => IGroupedNodes<R>;
|
|
63
63
|
export declare const ellipsis: (text?: string, maxlength?: number) => string;
|
|
64
64
|
export declare const mapsUrl: (location?: {
|
|
65
|
-
lat?: number
|
|
66
|
-
lng?: number
|
|
67
|
-
name?: string
|
|
68
|
-
}
|
|
65
|
+
lat?: number;
|
|
66
|
+
lng?: number;
|
|
67
|
+
name?: string;
|
|
68
|
+
}) => string;
|
|
69
69
|
export declare const keyToLabel: (key: string) => string;
|
|
70
|
-
export declare const toDashCase: (value?: string
|
|
70
|
+
export declare const toDashCase: (value?: string) => string;
|
|
71
71
|
export declare const defaultLabel: (node?: any) => any;
|
|
72
72
|
export declare const itemColor: (index: number) => any;
|
|
73
73
|
export declare const listColor: <T>(_v: T, index: number) => string;
|
|
@@ -9,8 +9,8 @@ export declare class CyclesEmissionsChartComponent implements AfterViewInit, OnC
|
|
|
9
9
|
emissionPerCycle: IGroupedNodes<Emission>;
|
|
10
10
|
terms: Term[];
|
|
11
11
|
selectedTerm?: Term;
|
|
12
|
-
ngAfterViewInit(): void
|
|
13
|
-
ngOnChanges(changes: SimpleChanges): void
|
|
12
|
+
ngAfterViewInit(): void;
|
|
13
|
+
ngOnChanges(changes: SimpleChanges): void;
|
|
14
14
|
private init;
|
|
15
15
|
updateChart(): void;
|
|
16
16
|
static ɵfac: i0.ɵɵFactoryDeclaration<CyclesEmissionsChartComponent, never>;
|
|
@@ -1,5 +1,4 @@
|
|
|
1
1
|
import { FormBuilder } from '@angular/forms';
|
|
2
|
-
import { NodeType } from '@hestia-earth/schema';
|
|
3
2
|
import { Observable } from 'rxjs';
|
|
4
3
|
import { HeNodeService } from '../../node/node.service';
|
|
5
4
|
import { HeSearchService } from '../../search/search.service';
|
|
@@ -14,7 +13,7 @@ export declare class CyclesSuggestFormComponent {
|
|
|
14
13
|
loading: boolean;
|
|
15
14
|
suggesting: boolean;
|
|
16
15
|
formatter: ({ "@id": id }: any) => any;
|
|
17
|
-
suggestCycle: (text$: Observable<string>) => Observable<
|
|
16
|
+
suggestCycle: (text$: Observable<string>) => Observable<any[]>;
|
|
18
17
|
constructor(formBuilder: FormBuilder, nodeService: HeNodeService, searchService: HeSearchService);
|
|
19
18
|
private suggest;
|
|
20
19
|
private loadCycle;
|
package/cycles/cycles.model.d.ts
CHANGED
|
@@ -4,4 +4,4 @@ export interface ICycleJSONLDExtended extends ICycleJSONLD {
|
|
|
4
4
|
[type in NodeType]?: string[];
|
|
5
5
|
};
|
|
6
6
|
}
|
|
7
|
-
export declare const primaryProduct: ({ products }: Partial<ICycleJSONLD>) => import("@hestia-earth/schema").Product
|
|
7
|
+
export declare const primaryProduct: ({ products }: Partial<ICycleJSONLD>) => import("@hestia-earth/schema").Product;
|
|
@@ -42,8 +42,8 @@ export declare class HeAggregationEngineService {
|
|
|
42
42
|
private loadModels;
|
|
43
43
|
get models$(): import("rxjs").Observable<IAggregationModel[]>;
|
|
44
44
|
models(): Promise<IAggregationModel[]>;
|
|
45
|
-
model$(model: Partial<IAggregationModel>): import("rxjs").Observable<IAggregationModel
|
|
46
|
-
model(model: Partial<IAggregationModel>): Promise<IAggregationModel
|
|
45
|
+
model$(model: Partial<IAggregationModel>): import("rxjs").Observable<IAggregationModel>;
|
|
46
|
+
model(model: Partial<IAggregationModel>): Promise<IAggregationModel>;
|
|
47
47
|
private loadLookup;
|
|
48
48
|
private loadLookups;
|
|
49
49
|
get lookups$(): import("rxjs").Observable<{
|
|
@@ -4,7 +4,7 @@ import { NodeType } from '@hestia-earth/schema';
|
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export declare const HE_ORCHESTRATOR_BASE_URL: InjectionToken<string>;
|
|
6
6
|
export declare const findConfigModels: ({ models }: IOrchestratorConfig, modelId: string, modelKey: string) => IOrchestratorModelConfig[];
|
|
7
|
-
export declare const pathToApiDocsPath: (model: string, term?: string
|
|
7
|
+
export declare const pathToApiDocsPath: (model: string, term?: string) => string;
|
|
8
8
|
export interface IModel {
|
|
9
9
|
/**
|
|
10
10
|
* Path to the implementation (code) of the model.
|
|
@@ -50,8 +50,8 @@ export declare class HeEngineService {
|
|
|
50
50
|
private loadModels;
|
|
51
51
|
get models$(): import("rxjs").Observable<IModel[]>;
|
|
52
52
|
models(): Promise<IModel[]>;
|
|
53
|
-
model$(model: Partial<IModel>): import("rxjs").Observable<IModel
|
|
54
|
-
model(model: Partial<IModel>): Promise<IModel
|
|
53
|
+
model$(model: Partial<IModel>): import("rxjs").Observable<IModel>;
|
|
54
|
+
model(model: Partial<IModel>): Promise<IModel>;
|
|
55
55
|
ochestratorConfig(type: NodeType): Promise<IOrchestratorConfig>;
|
|
56
56
|
static ɵfac: i0.ɵɵFactoryDeclaration<HeEngineService, never>;
|
|
57
57
|
static ɵprov: i0.ɵɵInjectableDeclaration<HeEngineService>;
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { __rest } from "tslib";
|
|
2
2
|
import { Directive, Input } from '@angular/core';
|
|
3
|
-
import BulmaTagsInput from '
|
|
3
|
+
import BulmaTagsInput from '../tags-input';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
const restrictToType = {
|
|
6
6
|
number: val => parseFloat(val) === +val ? val : false
|
|
@@ -19,7 +19,7 @@ export class TagsInputDirective {
|
|
|
19
19
|
ngOnDestroy() {
|
|
20
20
|
this.inputEvents.map(({ event, listener }) => this.tagsInputInput.removeEventListener(event, listener));
|
|
21
21
|
this.inputEvents = [];
|
|
22
|
-
this.tagsInput =
|
|
22
|
+
this.tagsInput = undefined;
|
|
23
23
|
}
|
|
24
24
|
get input() {
|
|
25
25
|
return this.elementRef.nativeElement;
|
|
@@ -71,4 +71,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
|
|
|
71
71
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { appTagsInput: [{
|
|
72
72
|
type: Input
|
|
73
73
|
}] } });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tags-input.directive.js","sourceRoot":"","sources":["../../../src/common/tags-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, ElementRef, Input, OnDestroy } from '@angular/core';\nimport BulmaTagsInput from '../tags-input';\n\ninterface ITagsInputOptions {\n  enabled?: boolean;\n  items?: any;\n  allowDuplicates?: boolean;\n\tcaseSensitive?: boolean;\n\tclearSelectionOnTyping?: boolean;\n\tcloseDropdownOnItemSelect?: boolean;\n\tdelimiter?: string;\n\tfreeInput?: boolean;\n\thighlightDuplicate?: boolean;\n\thighlightMatchesString?: boolean;\n\titemValue?: string;\n  itemText?: string;\n\tmaxTags?: number;\n\tmaxChars?: number;\n\tminChars?: number;\n\tnoResultsLabel?: string;\n\tplaceholder?: string;\n\tremovable?: boolean;\n\tsearchMinChars?: number;\n\tsearchOn?: 'text'|'value';\n\tselectable?: boolean;\n\tsource?: any;\n\ttagClass?: string;\n\ttrim?: boolean;\n}\n\nconst restrictToType: {\n  [type: string]: (value: string) => string|number|boolean;\n} = {\n  number: val => parseFloat(val) === +val ? val : false\n};\n\ninterface IEvent {\n  event: any;\n  listener: any;\n}\n\n@Directive({\n  selector: '[appTagsInput]'\n})\nexport class TagsInputDirective implements AfterViewInit, OnDestroy {\n  private tagsInput?: BulmaTagsInput;\n  private inputEvents: IEvent[] = [];\n\n  @Input()\n  private appTagsInput: ITagsInputOptions = {};\n\n  constructor(private elementRef: ElementRef) {}\n\n  ngAfterViewInit() {\n    const { enabled } = this.appTagsInput;\n    const { localName } = this.input;\n    setTimeout(() => !this.tagsInput && enabled && localName === 'input' && this.enableTagsInput());\n  }\n\n  ngOnDestroy() {\n    this.inputEvents.map(({ event, listener }) => this.tagsInputInput.removeEventListener(event, listener));\n    this.inputEvents = [];\n    this.tagsInput = undefined;\n  }\n\n  private get input() {\n    return this.elementRef.nativeElement as HTMLInputElement;\n  }\n\n  private get tagsInputNode() {\n    return this.elementRef.nativeElement.parentNode.querySelectorAll('.tags-input')[0];\n  }\n\n  private get tagsInputInput() {\n    return this.tagsInputNode.querySelectorAll('.input')[0] as HTMLInputElement;\n  }\n\n  private setInputEvent({ event, listener }: IEvent) {\n    this.tagsInputInput.addEventListener(event, listener);\n    this.inputEvents.push({ event, listener });\n  }\n\n  private mapValue(value: string) {\n    return this.appTagsInput.items.type in restrictToType ? restrictToType[this.appTagsInput.items.type](value) : value;\n  }\n\n  private addInputValue(value?: string) {\n    if (value && this.mapValue(value)) {\n      this.tagsInput!.add(value);\n      this.tagsInputInput.value = '';\n    }\n  }\n\n  private enableTagsInput() {\n    try {\n      const { enabled, items, ...options } = this.appTagsInput;\n      this.tagsInput = new BulmaTagsInput(this.input, options);\n\n      // TODO: remove when fixed, @see https://github.com/CreativeBulma/bulma-tagsinput/issues/23\n      const classes = ['is-small', 'is-large'].filter(v => this.input.classList.contains(v));\n      classes.map(v => this.tagsInputNode.classList.add(v));\n\n      // regex pattern matching\n      this.tagsInput.on('before.add', value => this.mapValue(value));\n\n      // add item on blur if value\n      const onBlur = () => this.addInputValue(this.tagsInputInput.value);\n      this.setInputEvent({ event: 'blur', listener: onBlur });\n    }\n    catch (err) {\n      console.error(err);\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
const defaultOptions = {
|
|
2
|
+
allowDuplicates: false,
|
|
3
|
+
caseSensitive: true,
|
|
4
|
+
clearSelectionOnTyping: false,
|
|
5
|
+
closeDropdownOnItemSelect: true,
|
|
6
|
+
delimiter: ',',
|
|
7
|
+
freeInput: true,
|
|
8
|
+
highlightDuplicate: true,
|
|
9
|
+
highlightMatchesString: true,
|
|
10
|
+
itemValue: undefined,
|
|
11
|
+
itemText: undefined,
|
|
12
|
+
maxTags: undefined,
|
|
13
|
+
maxChars: undefined,
|
|
14
|
+
minChars: 1,
|
|
15
|
+
noResultsLabel: 'No results found',
|
|
16
|
+
placeholder: '',
|
|
17
|
+
removable: true,
|
|
18
|
+
searchMinChars: 1,
|
|
19
|
+
searchOn: 'text',
|
|
20
|
+
selectable: true,
|
|
21
|
+
source: undefined,
|
|
22
|
+
tagClass: 'is-rounded',
|
|
23
|
+
trim: true // Should we trim value before processing them ?
|
|
24
|
+
};
|
|
25
|
+
export default defaultOptions;
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVmYXVsdE9wdGlvbnMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdGFncy1pbnB1dC9kZWZhdWx0T3B0aW9ucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLGNBQWMsR0FBRztJQUN0QixlQUFlLEVBQUUsS0FBSztJQUN0QixhQUFhLEVBQUUsSUFBSTtJQUNuQixzQkFBc0IsRUFBRSxLQUFLO0lBQzdCLHlCQUF5QixFQUFFLElBQUk7SUFDL0IsU0FBUyxFQUFFLEdBQUc7SUFDZCxTQUFTLEVBQUUsSUFBSTtJQUNmLGtCQUFrQixFQUFFLElBQUk7SUFDeEIsc0JBQXNCLEVBQUUsSUFBSTtJQUM1QixTQUFTLEVBQUUsU0FBUztJQUNsQixRQUFRLEVBQUUsU0FBUztJQUNyQixPQUFPLEVBQUUsU0FBUztJQUNsQixRQUFRLEVBQUUsU0FBUztJQUNuQixRQUFRLEVBQUUsQ0FBQztJQUNYLGNBQWMsRUFBRSxrQkFBa0I7SUFDbEMsV0FBVyxFQUFFLEVBQUU7SUFDZixTQUFTLEVBQUUsSUFBSTtJQUNmLGNBQWMsRUFBRSxDQUFDO0lBQ2pCLFFBQVEsRUFBRSxNQUFNO0lBQ2hCLFVBQVUsRUFBRSxJQUFJO0lBQ2hCLE1BQU0sRUFBRSxTQUFTO0lBQ2pCLFFBQVEsRUFBRSxZQUFZO0lBQ3RCLElBQUksRUFBRSxJQUFJLENBQVEsZ0RBQWdEO0NBQ2xFLENBQUM7QUFFRixlQUFlLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IGRlZmF1bHRPcHRpb25zID0ge1xuXHRhbGxvd0R1cGxpY2F0ZXM6IGZhbHNlLFx0XHRcdFx0XHQvLyBBcmUgZHVwbGljYXRlIHRhZ3MgYWxsb3dlZCA/XG5cdGNhc2VTZW5zaXRpdmU6IHRydWUsXHRcdFx0XHRcdC8vIElzIGR1cGxpY2F0ZSB0YWdzIGlkZW50aWZpY2F0aW9uIGNhc2Ugc2Vuc2l0aXZlID9cblx0Y2xlYXJTZWxlY3Rpb25PblR5cGluZzogZmFsc2UsXHRcdFx0Ly8gU2hvdWxkIHNlbGVjdGVkIHRhZyBiZSBjbGVhcmVkIHdoZW4gdHlwaW5nIGEgbmV3IGlucHV0ID9cblx0Y2xvc2VEcm9wZG93bk9uSXRlbVNlbGVjdDogdHJ1ZSxcdFx0Ly8gU2hvdWxkIGRyb3Bkb3duIGJlIGNsb3NlZCBvbmNlIGFuIGl0ZW0gaGFzIGJlZW4gY2xpY2tlZCA/XG5cdGRlbGltaXRlcjogJywnLFx0XHRcdFx0XHRcdFx0Ly8gTXVsdGlwbGUgdGFncyBkZWxpbWl0ZXJcblx0ZnJlZUlucHV0OiB0cnVlLFx0XHRcdFx0XHRcdC8vIFNob3VsZCB1c2VyIGJlIGFibGUgdG8gaW5wdXQgbmV3IHRhZyBtYW51YWxseSA/XG5cdGhpZ2hsaWdodER1cGxpY2F0ZTogdHJ1ZSxcdFx0XHRcdC8vIFNob3VsZCB3ZSB0ZW1wb3Jhcmx5IGhpZ2hsaWdodCBpZGVudGlmaWVkIGR1cGxpY2F0ZSB0YWdzID9cblx0aGlnaGxpZ2h0TWF0Y2hlc1N0cmluZzogdHJ1ZSxcdFx0XHQvLyBTaG91bGQgd2UgaGlnaGxpZ2h0IGlkZW50aWZpZWQgbWF0Y2hlcyBzdHJpbmdzIHdoZW4gc2VhcmNoaW5nID9cblx0aXRlbVZhbHVlOiB1bmRlZmluZWQsXHRcdFx0XHRcdC8vIFdoYXQgaXMgdGhlIG9iamVjdCBwcm9wZXJ0eSB0byB1c2UgYXMgdmFsdWUgd2hlbiB3ZSB3b3JrIHdpdGggT2JqZWN0IHRhZ3MgP1xuICBcdGl0ZW1UZXh0OiB1bmRlZmluZWQsXHRcdFx0XHRcdC8vIFdoYXQgaXMgdGhlIG9iamVjdCBwcm9wZXJ0eSB0byB1c2UgYXMgdGV4dCB3aGVuIHdlIHdvcmsgd2l0aCBPYmplY3QgdGFncyA/XG5cdG1heFRhZ3M6IHVuZGVmaW5lZCxcdFx0XHRcdFx0XHQvLyBNYXhpbXVtIG51bWJlciBvZiB0YWdzIGFsbG93ZWRcblx0bWF4Q2hhcnM6IHVuZGVmaW5lZCxcdFx0XHRcdFx0Ly8gTWF4aW11bSBvZiBjaGFyYWN0ZXJzIGFsbG93ZWQgZm9yIGEgc2luZ2xlIHRhZ1xuXHRtaW5DaGFyczogMSxcdFx0XHRcdFx0XHRcdC8vIE1pbmltdW0gb2YgY2hhcmFjdGVycyBiZWZvcmUgcHJvY2Vzc2luZyBhIG5ldyB0YWdcblx0bm9SZXN1bHRzTGFiZWw6ICdObyByZXN1bHRzIGZvdW5kJyxcdFx0Ly8gQ3VzdG9taXplIHRoZSBkcm9wZG93biBwbGFjZWNob2xlciB3aGVuIG5vIHJlc3VsdHMgZm91bmRcblx0cGxhY2Vob2xkZXI6ICcnLFx0XHRcdFx0XHRcdC8vIEN1c3RvbWl6ZSB0aGUgaW5wdXQgcGxhY2hvbGRlclxuXHRyZW1vdmFibGU6IHRydWUsXHRcdFx0XHRcdFx0Ly8gQXJlIHRhZ3MgcmVtb3ZhYmxlID9cblx0c2VhcmNoTWluQ2hhcnM6IDEsXHRcdFx0XHRcdFx0Ly8gSG93IG1hbnkgY2hhcmFjdGVycyBzaG91bGQgd2UgZW50ZXIgYmVmb3JlIHN0YXJ0aW5nIGR5bmFtaWMgc2VhcmNoID9cblx0c2VhcmNoT246ICd0ZXh0JyxcdFx0XHRcdFx0XHQvLyBPbiB3aGF0IGRyb3Bkb3duIGl0ZW0gZGF0YSBkbyB3ZSBzZWFyY2ggdGhlIGVudGVyZWQgdmFsdWUgOiAndmFsdWUnIG9yICd0ZXh0JyA/XG5cdHNlbGVjdGFibGU6IHRydWUsXHRcdFx0XHRcdFx0Ly8gQXJlIHRhZ3Mgc2VsZWN0YWJsZSA/XG5cdHNvdXJjZTogdW5kZWZpbmVkLFx0XHRcdFx0XHRcdC8vIEFycmF5L0Z1bmN0aW9uL1Byb21pc2UgdG8gZ2V0IGV4dGVybmFsIGRhdGFcblx0dGFnQ2xhc3M6ICdpcy1yb3VuZGVkJyxcdFx0XHRcdFx0Ly8gQ3VzdG9taXplIHRhZ3Mgc3R5bGUgYnkgcGFzc2luZyBjbGFzc2VzIC0gVGhleSB3aWxsIGJlIGFkZGVkIHRvIHRoZSB0YWcgZWxlbWVudFxuXHR0cmltOiB0cnVlXHRcdFx0XHRcdFx0XHRcdC8vIFNob3VsZCB3ZSB0cmltIHZhbHVlIGJlZm9yZSBwcm9jZXNzaW5nIHRoZW0gP1xufTtcblxuZXhwb3J0IGRlZmF1bHQgZGVmYXVsdE9wdGlvbnM7XG4iXX0=
|