@covalent/dynamic-forms 3.1.2 → 4.0.0-beta.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/covalent-dynamic-forms.d.ts +1 -0
- package/dynamic-element.component.d.ts +7 -0
- package/dynamic-elements/dynamic-checkbox/dynamic-checkbox.component.d.ts +3 -0
- package/dynamic-elements/dynamic-datepicker/dynamic-datepicker.component.d.ts +3 -0
- package/dynamic-elements/dynamic-datepicker/dynamic-datepicker.component.scss +1 -0
- package/dynamic-elements/dynamic-file-input/dynamic-file-input.component.d.ts +3 -0
- package/dynamic-elements/dynamic-file-input/dynamic-file-input.component.scss +2 -0
- package/dynamic-elements/dynamic-input/dynamic-input.component.d.ts +3 -0
- package/dynamic-elements/dynamic-input/dynamic-input.component.scss +1 -0
- package/dynamic-elements/dynamic-select/dynamic-select.component.d.ts +3 -0
- package/dynamic-elements/dynamic-select/dynamic-select.component.scss +1 -0
- package/dynamic-elements/dynamic-slide-toggle/dynamic-slide-toggle.component.d.ts +3 -0
- package/dynamic-elements/dynamic-slider/dynamic-slider.component.d.ts +3 -0
- package/dynamic-elements/dynamic-slider/dynamic-slider.component.scss +2 -0
- package/dynamic-elements/dynamic-textarea/dynamic-textarea.component.d.ts +3 -0
- package/dynamic-elements/dynamic-textarea/dynamic-textarea.component.scss +1 -0
- package/dynamic-forms.component.d.ts +3 -0
- package/dynamic-forms.component.scss +10 -12
- package/dynamic-forms.module.d.ts +27 -0
- package/esm2020/covalent-dynamic-forms.mjs +5 -0
- package/esm2020/dynamic-element.component.mjs +220 -0
- package/esm2020/dynamic-elements/dynamic-checkbox/dynamic-checkbox.component.mjs +35 -0
- package/esm2020/dynamic-elements/dynamic-datepicker/dynamic-datepicker.component.mjs +58 -0
- package/esm2020/dynamic-elements/dynamic-file-input/dynamic-file-input.component.mjs +84 -0
- package/esm2020/dynamic-elements/dynamic-input/dynamic-input.component.mjs +55 -0
- package/esm2020/dynamic-elements/dynamic-select/dynamic-select.component.mjs +67 -0
- package/esm2020/dynamic-elements/dynamic-slide-toggle/dynamic-slide-toggle.component.mjs +36 -0
- package/esm2020/dynamic-elements/dynamic-slider/dynamic-slider.component.mjs +62 -0
- package/esm2020/dynamic-elements/dynamic-textarea/dynamic-textarea.component.mjs +50 -0
- package/esm2020/dynamic-forms.component.mjs +220 -0
- package/esm2020/dynamic-forms.module.mjs +118 -0
- package/esm2020/index.mjs +2 -0
- package/esm2020/public_api.mjs +13 -0
- package/esm2020/services/dynamic-forms.service.mjs +125 -0
- package/fesm2015/covalent-dynamic-forms.mjs +1143 -0
- package/fesm2015/covalent-dynamic-forms.mjs.map +1 -0
- package/fesm2020/covalent-dynamic-forms.mjs +1063 -0
- package/fesm2020/covalent-dynamic-forms.mjs.map +1 -0
- package/package.json +29 -12
- package/services/dynamic-forms.service.d.ts +3 -0
- package/bundles/covalent-dynamic-forms.umd.js +0 -1654
- package/bundles/covalent-dynamic-forms.umd.js.map +0 -1
- package/bundles/covalent-dynamic-forms.umd.min.js +0 -16
- package/bundles/covalent-dynamic-forms.umd.min.js.map +0 -1
- package/covalent-dynamic-forms.metadata.json +0 -1
- package/esm2015/covalent-dynamic-forms.js +0 -10
- package/esm2015/dynamic-element.component.js +0 -340
- package/esm2015/dynamic-elements/dynamic-checkbox/dynamic-checkbox.component.js +0 -34
- package/esm2015/dynamic-elements/dynamic-datepicker/dynamic-datepicker.component.js +0 -49
- package/esm2015/dynamic-elements/dynamic-file-input/dynamic-file-input.component.js +0 -47
- package/esm2015/dynamic-elements/dynamic-input/dynamic-input.component.js +0 -55
- package/esm2015/dynamic-elements/dynamic-select/dynamic-select.component.js +0 -46
- package/esm2015/dynamic-elements/dynamic-slide-toggle/dynamic-slide-toggle.component.js +0 -34
- package/esm2015/dynamic-elements/dynamic-slider/dynamic-slider.component.js +0 -64
- package/esm2015/dynamic-elements/dynamic-textarea/dynamic-textarea.component.js +0 -40
- package/esm2015/dynamic-forms.component.js +0 -306
- package/esm2015/dynamic-forms.module.js +0 -73
- package/esm2015/index.js +0 -7
- package/esm2015/public_api.js +0 -18
- package/esm2015/services/dynamic-forms.service.js +0 -201
- package/fesm2015/covalent-dynamic-forms.js +0 -1269
- package/fesm2015/covalent-dynamic-forms.js.map +0 -1
|
@@ -5,6 +5,7 @@ import { FormControl } from '@angular/forms';
|
|
|
5
5
|
import { TemplatePortalDirective } from '@angular/cdk/portal';
|
|
6
6
|
import { IControlValueAccessor } from '@covalent/core/common';
|
|
7
7
|
import { TdDynamicElement, TdDynamicType, TdDynamicFormsService, ITdDynamicElementCustomConfig } from './services/dynamic-forms.service';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
8
9
|
export declare class TdDynamicElementBase {
|
|
9
10
|
_changeDetectorRef: ChangeDetectorRef;
|
|
10
11
|
constructor(_changeDetectorRef: ChangeDetectorRef);
|
|
@@ -14,10 +15,14 @@ export declare class TdDynamicFormsErrorTemplateDirective extends TemplatePortal
|
|
|
14
15
|
templateRef: TemplateRef<any>;
|
|
15
16
|
tdDynamicFormsError: string;
|
|
16
17
|
constructor(templateRef: TemplateRef<any>, viewContainerRef: ViewContainerRef);
|
|
18
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdDynamicFormsErrorTemplateDirective, never>;
|
|
19
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TdDynamicFormsErrorTemplateDirective, "[tdDynamicFormsError]ng-template", never, { "tdDynamicFormsError": "tdDynamicFormsError"; }, {}, never>;
|
|
17
20
|
}
|
|
18
21
|
export declare class TdDynamicElementDirective {
|
|
19
22
|
viewContainer: ViewContainerRef;
|
|
20
23
|
constructor(viewContainer: ViewContainerRef);
|
|
24
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdDynamicElementDirective, never>;
|
|
25
|
+
static ɵdir: i0.ɵɵDirectiveDeclaration<TdDynamicElementDirective, "[tdDynamicContainer]", never, {}, {}, never>;
|
|
21
26
|
}
|
|
22
27
|
export declare class TdDynamicElementComponent extends _TdDynamicElementMixinBase implements IControlValueAccessor, OnInit, OnChanges {
|
|
23
28
|
private _componentFactoryResolver;
|
|
@@ -93,4 +98,6 @@ export declare class TdDynamicElementComponent extends _TdDynamicElementMixinBas
|
|
|
93
98
|
* Reassign any inputs that have changed
|
|
94
99
|
*/
|
|
95
100
|
ngOnChanges(changes: SimpleChanges): void;
|
|
101
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdDynamicElementComponent, never>;
|
|
102
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TdDynamicElementComponent, "td-dynamic-element", never, { "dynamicControl": "dynamicControl"; "label": "label"; "hint": "hint"; "name": "name"; "type": "type"; "required": "required"; "min": "min"; "max": "max"; "minLength": "minLength"; "maxLength": "maxLength"; "selections": "selections"; "multiple": "multiple"; "customConfig": "customConfig"; "errorMessageTemplate": "errorMessageTemplate"; "placeholder": "placeholder"; }, {}, never, never>;
|
|
96
103
|
}
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
import { FormControl } from '@angular/forms';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
2
3
|
export declare class TdDynamicCheckboxComponent {
|
|
3
4
|
control: FormControl;
|
|
4
5
|
label: string;
|
|
5
6
|
name: string;
|
|
6
7
|
hint: string;
|
|
7
8
|
required: boolean;
|
|
9
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdDynamicCheckboxComponent, never>;
|
|
10
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TdDynamicCheckboxComponent, "td-dynamic-checkbox", never, {}, {}, never, never>;
|
|
8
11
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { TemplateRef } from '@angular/core';
|
|
2
2
|
import { FormControl } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
3
4
|
export declare class TdDynamicDatepickerComponent {
|
|
4
5
|
control: FormControl;
|
|
5
6
|
label: string;
|
|
@@ -11,4 +12,6 @@ export declare class TdDynamicDatepickerComponent {
|
|
|
11
12
|
max: number;
|
|
12
13
|
errorMessageTemplate: TemplateRef<any>;
|
|
13
14
|
placeholder: string;
|
|
15
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdDynamicDatepickerComponent, never>;
|
|
16
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TdDynamicDatepickerComponent, "td-dynamic-datepicker", never, {}, {}, never, never>;
|
|
14
17
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { TemplateRef } from '@angular/core';
|
|
2
2
|
import { FormControl } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
3
4
|
export declare class TdDynamicFileInputComponent {
|
|
4
5
|
control: FormControl;
|
|
5
6
|
required: boolean;
|
|
@@ -9,4 +10,6 @@ export declare class TdDynamicFileInputComponent {
|
|
|
9
10
|
errorMessageTemplate: TemplateRef<any>;
|
|
10
11
|
placeholder: string;
|
|
11
12
|
_handlefileDrop(value: File): void;
|
|
13
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdDynamicFileInputComponent, never>;
|
|
14
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TdDynamicFileInputComponent, "td-dynamic-file-input", never, {}, {}, never, never>;
|
|
12
15
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { TemplateRef } from '@angular/core';
|
|
2
2
|
import { FormControl } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
3
4
|
export declare class TdDynamicInputComponent {
|
|
4
5
|
control: FormControl;
|
|
5
6
|
label: string;
|
|
@@ -13,4 +14,6 @@ export declare class TdDynamicInputComponent {
|
|
|
13
14
|
maxLength: number;
|
|
14
15
|
errorMessageTemplate: TemplateRef<any>;
|
|
15
16
|
placeholder: string;
|
|
17
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdDynamicInputComponent, never>;
|
|
18
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TdDynamicInputComponent, "td-dynamic-input", never, {}, {}, never, never>;
|
|
16
19
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { TemplateRef } from '@angular/core';
|
|
2
2
|
import { FormControl } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
3
4
|
export declare class TdDynamicSelectComponent {
|
|
4
5
|
control: FormControl;
|
|
5
6
|
label: string;
|
|
@@ -10,4 +11,6 @@ export declare class TdDynamicSelectComponent {
|
|
|
10
11
|
multiple: boolean;
|
|
11
12
|
errorMessageTemplate: TemplateRef<any>;
|
|
12
13
|
placeholder: string;
|
|
14
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdDynamicSelectComponent, never>;
|
|
15
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TdDynamicSelectComponent, "td-dynamic-select", never, {}, {}, never, never>;
|
|
13
16
|
}
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
import { FormControl } from '@angular/forms';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
2
3
|
export declare class TdDynamicSlideToggleComponent {
|
|
3
4
|
control: FormControl;
|
|
4
5
|
label: string;
|
|
5
6
|
name: string;
|
|
6
7
|
hint: string;
|
|
7
8
|
required: boolean;
|
|
9
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdDynamicSlideToggleComponent, never>;
|
|
10
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TdDynamicSlideToggleComponent, "td-dynamic-slide-toggle", never, {}, {}, never, never>;
|
|
8
11
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectorRef } from '@angular/core';
|
|
2
2
|
import { FormControl } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
3
4
|
export declare class TdDynamicSliderComponent {
|
|
4
5
|
private _changeDetectorRef;
|
|
5
6
|
control: FormControl;
|
|
@@ -11,4 +12,6 @@ export declare class TdDynamicSliderComponent {
|
|
|
11
12
|
max: number;
|
|
12
13
|
constructor(_changeDetectorRef: ChangeDetectorRef);
|
|
13
14
|
_handleBlur(): void;
|
|
15
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdDynamicSliderComponent, never>;
|
|
16
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TdDynamicSliderComponent, "td-dynamic-slider", never, {}, {}, never, never>;
|
|
14
17
|
}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { TemplateRef } from '@angular/core';
|
|
2
2
|
import { FormControl } from '@angular/forms';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
3
4
|
export declare class TdDynamicTextareaComponent {
|
|
4
5
|
control: FormControl;
|
|
5
6
|
label: string;
|
|
@@ -8,4 +9,6 @@ export declare class TdDynamicTextareaComponent {
|
|
|
8
9
|
required: boolean;
|
|
9
10
|
errorMessageTemplate: TemplateRef<any>;
|
|
10
11
|
placeholder: string;
|
|
12
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdDynamicTextareaComponent, never>;
|
|
13
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TdDynamicTextareaComponent, "td-dynamic-textarea", never, {}, {}, never, never>;
|
|
11
14
|
}
|
|
@@ -2,6 +2,7 @@ import { ChangeDetectorRef, TemplateRef, QueryList, AfterContentInit, OnDestroy
|
|
|
2
2
|
import { FormGroup, FormBuilder, AbstractControl } from '@angular/forms';
|
|
3
3
|
import { TdDynamicFormsService, ITdDynamicElementConfig } from './services/dynamic-forms.service';
|
|
4
4
|
import { TdDynamicFormsErrorTemplateDirective } from './dynamic-element.component';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
5
6
|
export declare class TdDynamicFormsComponent implements AfterContentInit, OnDestroy {
|
|
6
7
|
private _formBuilder;
|
|
7
8
|
private _dynamicFormsService;
|
|
@@ -62,4 +63,6 @@ export declare class TdDynamicFormsComponent implements AfterContentInit, OnDest
|
|
|
62
63
|
private _rerenderElements;
|
|
63
64
|
private _clearRemovedElements;
|
|
64
65
|
private _subscribeToControlStatusChanges;
|
|
66
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<TdDynamicFormsComponent, never>;
|
|
67
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TdDynamicFormsComponent, "td-dynamic-forms", never, { "elements": "elements"; }, {}, ["_errorTemplates"], ["*"]>;
|
|
65
68
|
}
|
|
@@ -1,25 +1,23 @@
|
|
|
1
1
|
.td-dynamic-form-wrapper {
|
|
2
|
+
flex-flow: row wrap;
|
|
3
|
+
box-sizing: border-box;
|
|
4
|
+
display: flex;
|
|
5
|
+
align-items: center;
|
|
6
|
+
align-content: center;
|
|
7
|
+
max-width: 100%;
|
|
8
|
+
justify-content: flex-start;
|
|
9
|
+
|
|
2
10
|
::ng-deep {
|
|
3
11
|
.mat-form-field-infix {
|
|
4
12
|
width: auto;
|
|
5
13
|
}
|
|
14
|
+
|
|
6
15
|
.td-dynamic-element-hint {
|
|
7
16
|
font-size: 75%;
|
|
8
17
|
display: block;
|
|
9
18
|
}
|
|
10
19
|
}
|
|
11
|
-
|
|
12
|
-
flex-wrap: wrap;
|
|
13
|
-
// [layout]
|
|
14
|
-
box-sizing: border-box;
|
|
15
|
-
display: flex;
|
|
16
|
-
// [layout="row"]
|
|
17
|
-
flex-direction: row;
|
|
18
|
-
// [layout-align="start center"]
|
|
19
|
-
align-items: center;
|
|
20
|
-
align-content: center;
|
|
21
|
-
max-width: 100%;
|
|
22
|
-
justify-content: flex-start;
|
|
20
|
+
|
|
23
21
|
.td-dynamic-element-wrapper {
|
|
24
22
|
max-height: 100%;
|
|
25
23
|
box-sizing: border-box;
|
|
@@ -1,2 +1,29 @@
|
|
|
1
|
+
import * as i0 from "@angular/core";
|
|
2
|
+
import * as i1 from "./dynamic-forms.component";
|
|
3
|
+
import * as i2 from "./dynamic-element.component";
|
|
4
|
+
import * as i3 from "./dynamic-elements/dynamic-input/dynamic-input.component";
|
|
5
|
+
import * as i4 from "./dynamic-elements/dynamic-file-input/dynamic-file-input.component";
|
|
6
|
+
import * as i5 from "./dynamic-elements/dynamic-textarea/dynamic-textarea.component";
|
|
7
|
+
import * as i6 from "./dynamic-elements/dynamic-slide-toggle/dynamic-slide-toggle.component";
|
|
8
|
+
import * as i7 from "./dynamic-elements/dynamic-checkbox/dynamic-checkbox.component";
|
|
9
|
+
import * as i8 from "./dynamic-elements/dynamic-slider/dynamic-slider.component";
|
|
10
|
+
import * as i9 from "./dynamic-elements/dynamic-select/dynamic-select.component";
|
|
11
|
+
import * as i10 from "./dynamic-elements/dynamic-datepicker/dynamic-datepicker.component";
|
|
12
|
+
import * as i11 from "@angular/common";
|
|
13
|
+
import * as i12 from "@angular/forms";
|
|
14
|
+
import * as i13 from "@angular/material/form-field";
|
|
15
|
+
import * as i14 from "@angular/material/input";
|
|
16
|
+
import * as i15 from "@angular/material/select";
|
|
17
|
+
import * as i16 from "@angular/material/checkbox";
|
|
18
|
+
import * as i17 from "@angular/material/slider";
|
|
19
|
+
import * as i18 from "@angular/material/slide-toggle";
|
|
20
|
+
import * as i19 from "@angular/material/icon";
|
|
21
|
+
import * as i20 from "@angular/material/button";
|
|
22
|
+
import * as i21 from "@angular/material/datepicker";
|
|
23
|
+
import * as i22 from "@covalent/core/common";
|
|
24
|
+
import * as i23 from "@covalent/core/file";
|
|
1
25
|
export declare class CovalentDynamicFormsModule {
|
|
26
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<CovalentDynamicFormsModule, never>;
|
|
27
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<CovalentDynamicFormsModule, [typeof i1.TdDynamicFormsComponent, typeof i2.TdDynamicElementComponent, typeof i2.TdDynamicElementDirective, typeof i2.TdDynamicFormsErrorTemplateDirective, typeof i3.TdDynamicInputComponent, typeof i4.TdDynamicFileInputComponent, typeof i5.TdDynamicTextareaComponent, typeof i6.TdDynamicSlideToggleComponent, typeof i7.TdDynamicCheckboxComponent, typeof i8.TdDynamicSliderComponent, typeof i9.TdDynamicSelectComponent, typeof i10.TdDynamicDatepickerComponent], [typeof i11.CommonModule, typeof i12.ReactiveFormsModule, typeof i13.MatFormFieldModule, typeof i14.MatInputModule, typeof i15.MatSelectModule, typeof i16.MatCheckboxModule, typeof i17.MatSliderModule, typeof i18.MatSlideToggleModule, typeof i19.MatIconModule, typeof i20.MatButtonModule, typeof i21.MatDatepickerModule, typeof i22.CovalentCommonModule, typeof i23.CovalentFileModule], [typeof i1.TdDynamicFormsComponent, typeof i2.TdDynamicElementComponent, typeof i2.TdDynamicElementDirective, typeof i2.TdDynamicFormsErrorTemplateDirective, typeof i3.TdDynamicInputComponent, typeof i4.TdDynamicFileInputComponent, typeof i5.TdDynamicTextareaComponent, typeof i6.TdDynamicSlideToggleComponent, typeof i7.TdDynamicCheckboxComponent, typeof i8.TdDynamicSliderComponent, typeof i9.TdDynamicSelectComponent, typeof i10.TdDynamicDatepickerComponent]>;
|
|
28
|
+
static ɵinj: i0.ɵɵInjectorDeclaration<CovalentDynamicFormsModule>;
|
|
2
29
|
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY292YWxlbnQtZHluYW1pYy1mb3Jtcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9wbGF0Zm9ybS9keW5hbWljLWZvcm1zL2NvdmFsZW50LWR5bmFtaWMtZm9ybXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
|
|
@@ -0,0 +1,220 @@
|
|
|
1
|
+
import { Component, Directive, Input, HostBinding, TemplateRef, ChangeDetectorRef, Type, } from '@angular/core';
|
|
2
|
+
import { ViewChild, ViewContainerRef } from '@angular/core';
|
|
3
|
+
import { ComponentFactoryResolver, forwardRef } from '@angular/core';
|
|
4
|
+
import { NG_VALUE_ACCESSOR, FormControl } from '@angular/forms';
|
|
5
|
+
import { TemplatePortalDirective } from '@angular/cdk/portal';
|
|
6
|
+
import { mixinControlValueAccessor } from '@covalent/core/common';
|
|
7
|
+
import { TdDynamicFormsService, } from './services/dynamic-forms.service';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "./services/dynamic-forms.service";
|
|
10
|
+
export class TdDynamicElementBase {
|
|
11
|
+
constructor(_changeDetectorRef) {
|
|
12
|
+
this._changeDetectorRef = _changeDetectorRef;
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
/* tslint:disable-next-line */
|
|
16
|
+
export const _TdDynamicElementMixinBase = mixinControlValueAccessor(TdDynamicElementBase);
|
|
17
|
+
export class TdDynamicFormsErrorTemplateDirective extends TemplatePortalDirective {
|
|
18
|
+
constructor(templateRef, viewContainerRef) {
|
|
19
|
+
super(templateRef, viewContainerRef);
|
|
20
|
+
this.templateRef = templateRef;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
/** @nocollapse */ /** @nocollapse */ TdDynamicFormsErrorTemplateDirective.ɵfac = function TdDynamicFormsErrorTemplateDirective_Factory(t) { return new (t || TdDynamicFormsErrorTemplateDirective)(i0.ɵɵdirectiveInject(i0.TemplateRef), i0.ɵɵdirectiveInject(i0.ViewContainerRef)); };
|
|
24
|
+
/** @nocollapse */ /** @nocollapse */ TdDynamicFormsErrorTemplateDirective.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: TdDynamicFormsErrorTemplateDirective, selectors: [["ng-template", "tdDynamicFormsError", ""]], inputs: { tdDynamicFormsError: "tdDynamicFormsError" }, features: [i0.ɵɵInheritDefinitionFeature] });
|
|
25
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdDynamicFormsErrorTemplateDirective, [{
|
|
26
|
+
type: Directive,
|
|
27
|
+
args: [{ selector: '[tdDynamicFormsError]ng-template' }]
|
|
28
|
+
}], function () { return [{ type: i0.TemplateRef }, { type: i0.ViewContainerRef }]; }, { tdDynamicFormsError: [{
|
|
29
|
+
type: Input
|
|
30
|
+
}] }); })();
|
|
31
|
+
export class TdDynamicElementDirective {
|
|
32
|
+
constructor(viewContainer) {
|
|
33
|
+
this.viewContainer = viewContainer;
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
/** @nocollapse */ /** @nocollapse */ TdDynamicElementDirective.ɵfac = function TdDynamicElementDirective_Factory(t) { return new (t || TdDynamicElementDirective)(i0.ɵɵdirectiveInject(i0.ViewContainerRef)); };
|
|
37
|
+
/** @nocollapse */ /** @nocollapse */ TdDynamicElementDirective.ɵdir = /** @pureOrBreakMyCode */ i0.ɵɵdefineDirective({ type: TdDynamicElementDirective, selectors: [["", "tdDynamicContainer", ""]] });
|
|
38
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdDynamicElementDirective, [{
|
|
39
|
+
type: Directive,
|
|
40
|
+
args: [{
|
|
41
|
+
selector: '[tdDynamicContainer]',
|
|
42
|
+
}]
|
|
43
|
+
}], function () { return [{ type: i0.ViewContainerRef }]; }, null); })();
|
|
44
|
+
export class TdDynamicElementComponent extends _TdDynamicElementMixinBase {
|
|
45
|
+
constructor(_componentFactoryResolver, _dynamicFormsService, _changeDetectorRef) {
|
|
46
|
+
super(_changeDetectorRef);
|
|
47
|
+
this._componentFactoryResolver = _componentFactoryResolver;
|
|
48
|
+
this._dynamicFormsService = _dynamicFormsService;
|
|
49
|
+
/**
|
|
50
|
+
* Sets label to be displayed.
|
|
51
|
+
*/
|
|
52
|
+
this.label = '';
|
|
53
|
+
/**
|
|
54
|
+
* Sets hint to be displayed.
|
|
55
|
+
*/
|
|
56
|
+
this.hint = '';
|
|
57
|
+
/**
|
|
58
|
+
* Sets name to be displayed as attribute.
|
|
59
|
+
*/
|
|
60
|
+
this.name = '';
|
|
61
|
+
/**
|
|
62
|
+
* Sets type or element of element to be rendered.
|
|
63
|
+
* Throws error if does not exist or no supported.
|
|
64
|
+
*/
|
|
65
|
+
this.type = undefined;
|
|
66
|
+
/**
|
|
67
|
+
* Sets required validation checkup (if supported by element).
|
|
68
|
+
*/
|
|
69
|
+
this.required = undefined;
|
|
70
|
+
/**
|
|
71
|
+
* Sets min validation checkup (if supported by element).
|
|
72
|
+
*/
|
|
73
|
+
this.min = undefined;
|
|
74
|
+
/**
|
|
75
|
+
* Sets max validation checkup (if supported by element).
|
|
76
|
+
*/
|
|
77
|
+
this.max = undefined;
|
|
78
|
+
/**
|
|
79
|
+
* Sets minLength validation checkup (if supported by element).
|
|
80
|
+
*/
|
|
81
|
+
this.minLength = undefined;
|
|
82
|
+
/**
|
|
83
|
+
* Sets maxLength validation checkup (if supported by element).
|
|
84
|
+
*/
|
|
85
|
+
this.maxLength = undefined;
|
|
86
|
+
/**
|
|
87
|
+
* Sets selections for array elements (if supported by element).
|
|
88
|
+
*/
|
|
89
|
+
this.selections = undefined;
|
|
90
|
+
/**
|
|
91
|
+
* Sets multiple property for array elements (if supported by element).
|
|
92
|
+
*/
|
|
93
|
+
this.multiple = undefined;
|
|
94
|
+
/**
|
|
95
|
+
* Sets error message template so it can be injected into dynamic components.
|
|
96
|
+
*/
|
|
97
|
+
this.errorMessageTemplate = undefined;
|
|
98
|
+
/**
|
|
99
|
+
* Sets the placeholder message
|
|
100
|
+
*/
|
|
101
|
+
this.placeholder = '';
|
|
102
|
+
}
|
|
103
|
+
get maxAttr() {
|
|
104
|
+
return this.max;
|
|
105
|
+
}
|
|
106
|
+
get minAttr() {
|
|
107
|
+
return this.min;
|
|
108
|
+
}
|
|
109
|
+
ngOnInit() {
|
|
110
|
+
const component = this.type instanceof Type ? this.type : this._dynamicFormsService.getDynamicElement(this.type);
|
|
111
|
+
const ref = this._componentFactoryResolver
|
|
112
|
+
.resolveComponentFactory(component)
|
|
113
|
+
.create(this.childElement.viewContainer.injector);
|
|
114
|
+
this.childElement.viewContainer.insert(ref.hostView);
|
|
115
|
+
this._instance = ref.instance;
|
|
116
|
+
this._instance.control = this.dynamicControl;
|
|
117
|
+
this._instance.label = this.label;
|
|
118
|
+
this._instance.hint = this.hint;
|
|
119
|
+
this._instance.name = this.name;
|
|
120
|
+
this._instance.type = this.type;
|
|
121
|
+
this._instance.value = this.value;
|
|
122
|
+
this._instance.required = this.required;
|
|
123
|
+
this._instance.min = this.min;
|
|
124
|
+
this._instance.max = this.max;
|
|
125
|
+
this._instance.minLength = this.minLength;
|
|
126
|
+
this._instance.maxLength = this.maxLength;
|
|
127
|
+
this._instance.selections = this.selections;
|
|
128
|
+
this._instance.multiple = this.multiple;
|
|
129
|
+
this._instance.errorMessageTemplate = this.errorMessageTemplate;
|
|
130
|
+
this._instance.placeholder = this.placeholder;
|
|
131
|
+
if (this.customConfig) {
|
|
132
|
+
Object.getOwnPropertyNames(this.customConfig).forEach((name) => {
|
|
133
|
+
this._instance[name] = this.customConfig[name];
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Reassign any inputs that have changed
|
|
139
|
+
*/
|
|
140
|
+
ngOnChanges(changes) {
|
|
141
|
+
if (this._instance) {
|
|
142
|
+
for (const prop of Object.keys(changes)) {
|
|
143
|
+
this._instance[prop] = changes[prop].currentValue;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
/** @nocollapse */ /** @nocollapse */ TdDynamicElementComponent.ɵfac = function TdDynamicElementComponent_Factory(t) { return new (t || TdDynamicElementComponent)(i0.ɵɵdirectiveInject(i0.ComponentFactoryResolver), i0.ɵɵdirectiveInject(i1.TdDynamicFormsService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); };
|
|
149
|
+
/** @nocollapse */ /** @nocollapse */ TdDynamicElementComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TdDynamicElementComponent, selectors: [["td-dynamic-element"]], viewQuery: function TdDynamicElementComponent_Query(rf, ctx) { if (rf & 1) {
|
|
150
|
+
i0.ɵɵviewQuery(TdDynamicElementDirective, 7);
|
|
151
|
+
} if (rf & 2) {
|
|
152
|
+
let _t;
|
|
153
|
+
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.childElement = _t.first);
|
|
154
|
+
} }, hostVars: 2, hostBindings: function TdDynamicElementComponent_HostBindings(rf, ctx) { if (rf & 2) {
|
|
155
|
+
i0.ɵɵattribute("max", ctx.maxAttr)("min", ctx.minAttr);
|
|
156
|
+
} }, inputs: { dynamicControl: "dynamicControl", label: "label", hint: "hint", name: "name", type: "type", required: "required", min: "min", max: "max", minLength: "minLength", maxLength: "maxLength", selections: "selections", multiple: "multiple", customConfig: "customConfig", errorMessageTemplate: "errorMessageTemplate", placeholder: "placeholder" }, features: [i0.ɵɵProvidersFeature([
|
|
157
|
+
TdDynamicFormsService,
|
|
158
|
+
{
|
|
159
|
+
provide: NG_VALUE_ACCESSOR,
|
|
160
|
+
useExisting: forwardRef((() => TdDynamicElementComponent)),
|
|
161
|
+
multi: true,
|
|
162
|
+
},
|
|
163
|
+
]), i0.ɵɵInheritDefinitionFeature, i0.ɵɵNgOnChangesFeature], decls: 1, vars: 0, consts: [["tdDynamicContainer", ""]], template: function TdDynamicElementComponent_Template(rf, ctx) { if (rf & 1) {
|
|
164
|
+
i0.ɵɵelement(0, "div", 0);
|
|
165
|
+
} }, directives: [TdDynamicElementDirective], encapsulation: 2 });
|
|
166
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdDynamicElementComponent, [{
|
|
167
|
+
type: Component,
|
|
168
|
+
args: [{
|
|
169
|
+
providers: [
|
|
170
|
+
TdDynamicFormsService,
|
|
171
|
+
{
|
|
172
|
+
provide: NG_VALUE_ACCESSOR,
|
|
173
|
+
useExisting: forwardRef((() => TdDynamicElementComponent)),
|
|
174
|
+
multi: true,
|
|
175
|
+
},
|
|
176
|
+
],
|
|
177
|
+
selector: 'td-dynamic-element',
|
|
178
|
+
template: '<div tdDynamicContainer></div>',
|
|
179
|
+
}]
|
|
180
|
+
}], function () { return [{ type: i0.ComponentFactoryResolver }, { type: i1.TdDynamicFormsService }, { type: i0.ChangeDetectorRef }]; }, { dynamicControl: [{
|
|
181
|
+
type: Input
|
|
182
|
+
}], label: [{
|
|
183
|
+
type: Input
|
|
184
|
+
}], hint: [{
|
|
185
|
+
type: Input
|
|
186
|
+
}], name: [{
|
|
187
|
+
type: Input
|
|
188
|
+
}], type: [{
|
|
189
|
+
type: Input
|
|
190
|
+
}], required: [{
|
|
191
|
+
type: Input
|
|
192
|
+
}], min: [{
|
|
193
|
+
type: Input
|
|
194
|
+
}], max: [{
|
|
195
|
+
type: Input
|
|
196
|
+
}], minLength: [{
|
|
197
|
+
type: Input
|
|
198
|
+
}], maxLength: [{
|
|
199
|
+
type: Input
|
|
200
|
+
}], selections: [{
|
|
201
|
+
type: Input
|
|
202
|
+
}], multiple: [{
|
|
203
|
+
type: Input
|
|
204
|
+
}], customConfig: [{
|
|
205
|
+
type: Input
|
|
206
|
+
}], errorMessageTemplate: [{
|
|
207
|
+
type: Input
|
|
208
|
+
}], placeholder: [{
|
|
209
|
+
type: Input
|
|
210
|
+
}], childElement: [{
|
|
211
|
+
type: ViewChild,
|
|
212
|
+
args: [TdDynamicElementDirective, { static: true }]
|
|
213
|
+
}], maxAttr: [{
|
|
214
|
+
type: HostBinding,
|
|
215
|
+
args: ['attr.max']
|
|
216
|
+
}], minAttr: [{
|
|
217
|
+
type: HostBinding,
|
|
218
|
+
args: ['attr.min']
|
|
219
|
+
}] }); })();
|
|
220
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-element.component.js","sourceRoot":"","sources":["../../../../src/platform/dynamic-forms/dynamic-element.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Directive,\n  Input,\n  HostBinding,\n  OnInit,\n  SimpleChanges,\n  OnChanges,\n  TemplateRef,\n  ChangeDetectorRef,\n  Type,\n} from '@angular/core';\nimport { ViewChild, ViewContainerRef } from '@angular/core';\nimport { ComponentFactoryResolver, ComponentRef, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR, FormControl } from '@angular/forms';\nimport { TemplatePortalDirective } from '@angular/cdk/portal';\n\nimport { mixinControlValueAccessor, IControlValueAccessor } from '@covalent/core/common';\n\nimport {\n  TdDynamicElement,\n  TdDynamicType,\n  TdDynamicFormsService,\n  ITdDynamicElementCustomConfig,\n} from './services/dynamic-forms.service';\n\nexport class TdDynamicElementBase {\n  constructor(public _changeDetectorRef: ChangeDetectorRef) {}\n}\n\n/* tslint:disable-next-line */\nexport const _TdDynamicElementMixinBase = mixinControlValueAccessor(TdDynamicElementBase);\n\n@Directive({ selector: '[tdDynamicFormsError]ng-template' })\nexport class TdDynamicFormsErrorTemplateDirective extends TemplatePortalDirective {\n  @Input() tdDynamicFormsError: string;\n  constructor(public templateRef: TemplateRef<any>, viewContainerRef: ViewContainerRef) {\n    super(templateRef, viewContainerRef);\n  }\n}\n\n@Directive({\n  selector: '[tdDynamicContainer]',\n})\nexport class TdDynamicElementDirective {\n  constructor(public viewContainer: ViewContainerRef) {}\n}\n\n@Component({\n  providers: [\n    TdDynamicFormsService,\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => TdDynamicElementComponent),\n      multi: true,\n    },\n  ],\n  selector: 'td-dynamic-element',\n  template: '<div tdDynamicContainer></div>',\n})\nexport class TdDynamicElementComponent\n  extends _TdDynamicElementMixinBase\n  implements IControlValueAccessor, OnInit, OnChanges\n{\n  private _instance: any;\n\n  /**\n   * Sets form control of the element.\n   */\n  @Input() dynamicControl: FormControl;\n\n  /**\n   * Sets label to be displayed.\n   */\n  @Input() label: string = '';\n\n  /**\n   * Sets hint to be displayed.\n   */\n  @Input() hint: string = '';\n\n  /**\n   * Sets name to be displayed as attribute.\n   */\n  @Input() name: string = '';\n\n  /**\n   * Sets type or element of element to be rendered.\n   * Throws error if does not exist or no supported.\n   */\n  @Input() type: TdDynamicElement | TdDynamicType | Type<any> = undefined;\n\n  /**\n   * Sets required validation checkup (if supported by element).\n   */\n  @Input() required: boolean = undefined;\n\n  /**\n   * Sets min validation checkup (if supported by element).\n   */\n  @Input() min: number = undefined;\n\n  /**\n   * Sets max validation checkup (if supported by element).\n   */\n  @Input() max: number = undefined;\n\n  /**\n   * Sets minLength validation checkup (if supported by element).\n   */\n  @Input() minLength: number = undefined;\n\n  /**\n   * Sets maxLength validation checkup (if supported by element).\n   */\n  @Input() maxLength: number = undefined;\n\n  /**\n   * Sets selections for array elements (if supported by element).\n   */\n  @Input() selections: any[] = undefined;\n\n  /**\n   * Sets multiple property for array elements (if supported by element).\n   */\n  @Input() multiple: boolean = undefined;\n\n  /**\n   * Sets any additional properties on custom component.\n   */\n  @Input() customConfig: ITdDynamicElementCustomConfig;\n\n  /**\n   * Sets error message template so it can be injected into dynamic components.\n   */\n  @Input() errorMessageTemplate: TemplateRef<any> = undefined;\n\n  /**\n   * Sets the placeholder message\n   */\n  @Input() placeholder: string = '';\n\n  @ViewChild(TdDynamicElementDirective, { static: true }) childElement: TdDynamicElementDirective;\n\n  @HostBinding('attr.max')\n  get maxAttr(): any {\n    return this.max;\n  }\n\n  @HostBinding('attr.min')\n  get minAttr(): any {\n    return this.min;\n  }\n\n  constructor(\n    private _componentFactoryResolver: ComponentFactoryResolver,\n    private _dynamicFormsService: TdDynamicFormsService,\n    _changeDetectorRef: ChangeDetectorRef,\n  ) {\n    super(_changeDetectorRef);\n  }\n\n  ngOnInit(): void {\n    const component: any =\n      <any>this.type instanceof Type ? this.type : this._dynamicFormsService.getDynamicElement(this.type);\n    const ref: ComponentRef<any> = this._componentFactoryResolver\n      .resolveComponentFactory(component)\n      .create(this.childElement.viewContainer.injector);\n    this.childElement.viewContainer.insert(ref.hostView);\n    this._instance = ref.instance;\n    this._instance.control = this.dynamicControl;\n    this._instance.label = this.label;\n    this._instance.hint = this.hint;\n    this._instance.name = this.name;\n    this._instance.type = this.type;\n    this._instance.value = this.value;\n    this._instance.required = this.required;\n    this._instance.min = this.min;\n    this._instance.max = this.max;\n    this._instance.minLength = this.minLength;\n    this._instance.maxLength = this.maxLength;\n    this._instance.selections = this.selections;\n    this._instance.multiple = this.multiple;\n    this._instance.errorMessageTemplate = this.errorMessageTemplate;\n    this._instance.placeholder = this.placeholder;\n    if (this.customConfig) {\n      Object.getOwnPropertyNames(this.customConfig).forEach((name: string) => {\n        this._instance[name] = this.customConfig[name];\n      });\n    }\n  }\n\n  /**\n   * Reassign any inputs that have changed\n   */\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this._instance) {\n      for (const prop of Object.keys(changes)) {\n        this._instance[prop] = changes[prop].currentValue;\n      }\n    }\n  }\n}\n"]}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { Component } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/material/checkbox";
|
|
4
|
+
import * as i2 from "@angular/forms";
|
|
5
|
+
export class TdDynamicCheckboxComponent {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.label = '';
|
|
8
|
+
this.name = '';
|
|
9
|
+
this.hint = '';
|
|
10
|
+
this.required = false;
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
/** @nocollapse */ /** @nocollapse */ TdDynamicCheckboxComponent.ɵfac = function TdDynamicCheckboxComponent_Factory(t) { return new (t || TdDynamicCheckboxComponent)(); };
|
|
14
|
+
/** @nocollapse */ /** @nocollapse */ TdDynamicCheckboxComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TdDynamicCheckboxComponent, selectors: [["td-dynamic-checkbox"]], decls: 5, vars: 5, consts: [[1, "td-dynamic-checkbox-wrapper"], [3, "formControl", "name", "required"], [1, "mat-hint", "td-dynamic-element-hint"]], template: function TdDynamicCheckboxComponent_Template(rf, ctx) { if (rf & 1) {
|
|
15
|
+
i0.ɵɵelementStart(0, "div", 0);
|
|
16
|
+
i0.ɵɵelementStart(1, "mat-checkbox", 1);
|
|
17
|
+
i0.ɵɵtext(2);
|
|
18
|
+
i0.ɵɵelementEnd();
|
|
19
|
+
i0.ɵɵelementStart(3, "span", 2);
|
|
20
|
+
i0.ɵɵtext(4);
|
|
21
|
+
i0.ɵɵelementEnd();
|
|
22
|
+
i0.ɵɵelementEnd();
|
|
23
|
+
} if (rf & 2) {
|
|
24
|
+
i0.ɵɵadvance(1);
|
|
25
|
+
i0.ɵɵproperty("formControl", ctx.control)("name", ctx.name)("required", ctx.required);
|
|
26
|
+
i0.ɵɵadvance(1);
|
|
27
|
+
i0.ɵɵtextInterpolate1(" ", ctx.label, " ");
|
|
28
|
+
i0.ɵɵadvance(2);
|
|
29
|
+
i0.ɵɵtextInterpolate(ctx.hint);
|
|
30
|
+
} }, directives: [i1.MatCheckbox, i1.MatCheckboxRequiredValidator, i2.NgControlStatus, i2.FormControlDirective, i2.RequiredValidator], styles: [""] });
|
|
31
|
+
(function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdDynamicCheckboxComponent, [{
|
|
32
|
+
type: Component,
|
|
33
|
+
args: [{ selector: 'td-dynamic-checkbox', template: "<div class=\"td-dynamic-checkbox-wrapper\">\n <mat-checkbox [formControl]=\"control\" [name]=\"name\" [required]=\"required\">\n {{ label }}\n </mat-checkbox>\n <span class=\"mat-hint td-dynamic-element-hint\">{{ hint }}</span>\n</div>\n", styles: [""] }]
|
|
34
|
+
}], null, null); })();
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1jaGVja2JveC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvcGxhdGZvcm0vZHluYW1pYy1mb3Jtcy9keW5hbWljLWVsZW1lbnRzL2R5bmFtaWMtY2hlY2tib3gvZHluYW1pYy1jaGVja2JveC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvcGxhdGZvcm0vZHluYW1pYy1mb3Jtcy9keW5hbWljLWVsZW1lbnRzL2R5bmFtaWMtY2hlY2tib3gvZHluYW1pYy1jaGVja2JveC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sZUFBZSxDQUFDOzs7O0FBUTFDLE1BQU0sT0FBTywwQkFBMEI7SUFMdkM7UUFRRSxVQUFLLEdBQVcsRUFBRSxDQUFDO1FBRW5CLFNBQUksR0FBVyxFQUFFLENBQUM7UUFFbEIsU0FBSSxHQUFXLEVBQUUsQ0FBQztRQUVsQixhQUFRLEdBQVksS0FBSyxDQUFDO0tBQzNCOzswSUFWWSwwQkFBMEI7K0hBQTFCLDBCQUEwQjtRQ1J2Qyw4QkFBeUM7UUFDdkMsdUNBQTBFO1FBQ3hFLFlBQ0Y7UUFBQSxpQkFBZTtRQUNmLCtCQUErQztRQUFBLFlBQVU7UUFBQSxpQkFBTztRQUNsRSxpQkFBTTs7UUFKVSxlQUF1QjtRQUF2Qix5Q0FBdUIsa0JBQUEsMEJBQUE7UUFDbkMsZUFDRjtRQURFLDBDQUNGO1FBQytDLGVBQVU7UUFBViw4QkFBVTs7dUZESTlDLDBCQUEwQjtjQUx0QyxTQUFTOzJCQUNFLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUNvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3RkLWR5bmFtaWMtY2hlY2tib3gnLFxuICBzdHlsZVVybHM6IFsnLi9keW5hbWljLWNoZWNrYm94LmNvbXBvbmVudC5zY3NzJ10sXG4gIHRlbXBsYXRlVXJsOiAnLi9keW5hbWljLWNoZWNrYm94LmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgVGREeW5hbWljQ2hlY2tib3hDb21wb25lbnQge1xuICBjb250cm9sOiBGb3JtQ29udHJvbDtcblxuICBsYWJlbDogc3RyaW5nID0gJyc7XG5cbiAgbmFtZTogc3RyaW5nID0gJyc7XG5cbiAgaGludDogc3RyaW5nID0gJyc7XG5cbiAgcmVxdWlyZWQ6IGJvb2xlYW4gPSBmYWxzZTtcbn1cbiIsIjxkaXYgY2xhc3M9XCJ0ZC1keW5hbWljLWNoZWNrYm94LXdyYXBwZXJcIj5cbiAgPG1hdC1jaGVja2JveCBbZm9ybUNvbnRyb2xdPVwiY29udHJvbFwiIFtuYW1lXT1cIm5hbWVcIiBbcmVxdWlyZWRdPVwicmVxdWlyZWRcIj5cbiAgICB7eyBsYWJlbCB9fVxuICA8L21hdC1jaGVja2JveD5cbiAgPHNwYW4gY2xhc3M9XCJtYXQtaGludCB0ZC1keW5hbWljLWVsZW1lbnQtaGludFwiPnt7IGhpbnQgfX08L3NwYW4+XG48L2Rpdj5cbiJdfQ==
|