@covalent/dynamic-forms 4.0.0-beta.2 → 4.1.0-develop.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (57) hide show
  1. package/README.md +26 -18
  2. package/covalent-dynamic-forms.d.ts +1 -1
  3. package/esm2020/covalent-dynamic-forms.mjs +2 -2
  4. package/esm2020/lib/dynamic-element.component.mjs +178 -0
  5. package/esm2020/lib/dynamic-elements/dynamic-checkbox/dynamic-checkbox.component.mjs +19 -0
  6. package/esm2020/lib/dynamic-elements/dynamic-datepicker/dynamic-datepicker.component.mjs +23 -0
  7. package/esm2020/lib/dynamic-elements/dynamic-file-input/dynamic-file-input.component.mjs +28 -0
  8. package/esm2020/lib/dynamic-elements/dynamic-input/dynamic-input.component.mjs +22 -0
  9. package/esm2020/lib/dynamic-elements/dynamic-select/dynamic-select.component.mjs +23 -0
  10. package/esm2020/lib/dynamic-elements/dynamic-slide-toggle/dynamic-slide-toggle.component.mjs +19 -0
  11. package/esm2020/lib/dynamic-elements/dynamic-slider/dynamic-slider.component.mjs +26 -0
  12. package/esm2020/lib/dynamic-elements/dynamic-textarea/dynamic-textarea.component.mjs +22 -0
  13. package/esm2020/lib/dynamic-forms.component.mjs +185 -0
  14. package/esm2020/lib/dynamic-forms.module.mjs +127 -0
  15. package/esm2020/lib/services/dynamic-forms.service.mjs +140 -0
  16. package/esm2020/public_api.mjs +13 -13
  17. package/fesm2015/covalent-dynamic-forms.mjs +177 -572
  18. package/fesm2015/covalent-dynamic-forms.mjs.map +1 -1
  19. package/fesm2020/covalent-dynamic-forms.mjs +248 -565
  20. package/fesm2020/covalent-dynamic-forms.mjs.map +1 -1
  21. package/{dynamic-element.component.d.ts → lib/dynamic-element.component.d.ts} +17 -17
  22. package/{dynamic-elements → lib/dynamic-elements}/dynamic-checkbox/dynamic-checkbox.component.d.ts +0 -0
  23. package/{dynamic-elements → lib/dynamic-elements}/dynamic-datepicker/dynamic-datepicker.component.d.ts +3 -3
  24. package/{dynamic-elements → lib/dynamic-elements}/dynamic-file-input/dynamic-file-input.component.d.ts +1 -1
  25. package/{dynamic-elements → lib/dynamic-elements}/dynamic-input/dynamic-input.component.d.ts +4 -4
  26. package/{dynamic-elements → lib/dynamic-elements}/dynamic-select/dynamic-select.component.d.ts +2 -2
  27. package/{dynamic-elements → lib/dynamic-elements}/dynamic-slide-toggle/dynamic-slide-toggle.component.d.ts +0 -0
  28. package/{dynamic-elements → lib/dynamic-elements}/dynamic-slider/dynamic-slider.component.d.ts +2 -2
  29. package/{dynamic-elements → lib/dynamic-elements}/dynamic-textarea/dynamic-textarea.component.d.ts +0 -0
  30. package/{dynamic-forms.component.d.ts → lib/dynamic-forms.component.d.ts} +1 -1
  31. package/{dynamic-forms.module.d.ts → lib/dynamic-forms.module.d.ts} +2 -3
  32. package/{services → lib/services}/dynamic-forms.service.d.ts +2 -2
  33. package/package.json +17 -19
  34. package/public_api.d.ts +12 -12
  35. package/dynamic-elements/dynamic-checkbox/dynamic-checkbox.component.scss +0 -0
  36. package/dynamic-elements/dynamic-datepicker/dynamic-datepicker.component.scss +0 -13
  37. package/dynamic-elements/dynamic-file-input/dynamic-file-input.component.scss +0 -17
  38. package/dynamic-elements/dynamic-input/dynamic-input.component.scss +0 -13
  39. package/dynamic-elements/dynamic-select/dynamic-select.component.scss +0 -13
  40. package/dynamic-elements/dynamic-slide-toggle/dynamic-slide-toggle.component.scss +0 -0
  41. package/dynamic-elements/dynamic-slider/dynamic-slider.component.scss +0 -19
  42. package/dynamic-elements/dynamic-textarea/dynamic-textarea.component.scss +0 -13
  43. package/dynamic-forms.component.scss +0 -27
  44. package/esm2020/dynamic-element.component.mjs +0 -220
  45. package/esm2020/dynamic-elements/dynamic-checkbox/dynamic-checkbox.component.mjs +0 -35
  46. package/esm2020/dynamic-elements/dynamic-datepicker/dynamic-datepicker.component.mjs +0 -58
  47. package/esm2020/dynamic-elements/dynamic-file-input/dynamic-file-input.component.mjs +0 -84
  48. package/esm2020/dynamic-elements/dynamic-input/dynamic-input.component.mjs +0 -55
  49. package/esm2020/dynamic-elements/dynamic-select/dynamic-select.component.mjs +0 -67
  50. package/esm2020/dynamic-elements/dynamic-slide-toggle/dynamic-slide-toggle.component.mjs +0 -36
  51. package/esm2020/dynamic-elements/dynamic-slider/dynamic-slider.component.mjs +0 -62
  52. package/esm2020/dynamic-elements/dynamic-textarea/dynamic-textarea.component.mjs +0 -50
  53. package/esm2020/dynamic-forms.component.mjs +0 -220
  54. package/esm2020/dynamic-forms.module.mjs +0 -118
  55. package/esm2020/index.mjs +0 -2
  56. package/esm2020/services/dynamic-forms.service.mjs +0 -125
  57. package/index.d.ts +0 -1
@@ -1,67 +0,0 @@
1
- import { Component } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/material/form-field";
4
- import * as i2 from "@angular/material/select";
5
- import * as i3 from "@angular/forms";
6
- import * as i4 from "@angular/common";
7
- import * as i5 from "@angular/material/core";
8
- function TdDynamicSelectComponent_mat_option_5_Template(rf, ctx) { if (rf & 1) {
9
- i0.ɵɵelementStart(0, "mat-option", 5);
10
- i0.ɵɵtext(1);
11
- i0.ɵɵelementEnd();
12
- } if (rf & 2) {
13
- const selection_r2 = ctx.$implicit;
14
- i0.ɵɵproperty("value", selection_r2.value || selection_r2);
15
- i0.ɵɵadvance(1);
16
- i0.ɵɵtextInterpolate1(" ", selection_r2.label || selection_r2, " ");
17
- } }
18
- function TdDynamicSelectComponent_ng_template_9_Template(rf, ctx) { }
19
- const _c0 = function (a0, a1) { return { control: a0, errors: a1 }; };
20
- export class TdDynamicSelectComponent {
21
- constructor() {
22
- this.label = '';
23
- this.hint = '';
24
- this.name = '';
25
- this.required = undefined;
26
- this.selections = undefined;
27
- this.multiple = undefined;
28
- this.errorMessageTemplate = undefined;
29
- this.placeholder = '';
30
- }
31
- }
32
- /** @nocollapse */ /** @nocollapse */ TdDynamicSelectComponent.ɵfac = function TdDynamicSelectComponent_Factory(t) { return new (t || TdDynamicSelectComponent)(); };
33
- /** @nocollapse */ /** @nocollapse */ TdDynamicSelectComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TdDynamicSelectComponent, selectors: [["td-dynamic-select"]], decls: 10, vars: 13, consts: [[1, "td-dynamic-select-wrapper"], [1, "td-dynamic-select-field"], [3, "formControl", "placeholder", "required", "multiple"], [3, "value", 4, "ngFor", "ngForOf"], [3, "ngTemplateOutlet", "ngTemplateOutletContext"], [3, "value"]], template: function TdDynamicSelectComponent_Template(rf, ctx) { if (rf & 1) {
34
- i0.ɵɵelementStart(0, "div", 0);
35
- i0.ɵɵelementStart(1, "mat-form-field", 1);
36
- i0.ɵɵelementStart(2, "mat-label");
37
- i0.ɵɵtext(3);
38
- i0.ɵɵelementEnd();
39
- i0.ɵɵelementStart(4, "mat-select", 2);
40
- i0.ɵɵtemplate(5, TdDynamicSelectComponent_mat_option_5_Template, 2, 2, "mat-option", 3);
41
- i0.ɵɵelementEnd();
42
- i0.ɵɵelementStart(6, "mat-hint");
43
- i0.ɵɵtext(7);
44
- i0.ɵɵelementEnd();
45
- i0.ɵɵelementStart(8, "mat-error");
46
- i0.ɵɵtemplate(9, TdDynamicSelectComponent_ng_template_9_Template, 0, 0, "ng-template", 4);
47
- i0.ɵɵelementEnd();
48
- i0.ɵɵelementEnd();
49
- i0.ɵɵelementEnd();
50
- } if (rf & 2) {
51
- i0.ɵɵadvance(3);
52
- i0.ɵɵtextInterpolate(ctx.label);
53
- i0.ɵɵadvance(1);
54
- i0.ɵɵproperty("formControl", ctx.control)("placeholder", ctx.placeholder)("required", ctx.required)("multiple", ctx.multiple);
55
- i0.ɵɵattribute("name", ctx.name);
56
- i0.ɵɵadvance(1);
57
- i0.ɵɵproperty("ngForOf", ctx.selections);
58
- i0.ɵɵadvance(2);
59
- i0.ɵɵtextInterpolate(ctx.hint);
60
- i0.ɵɵadvance(2);
61
- i0.ɵɵproperty("ngTemplateOutlet", ctx.errorMessageTemplate)("ngTemplateOutletContext", i0.ɵɵpureFunction2(10, _c0, ctx.control, ctx.control == null ? null : ctx.control.errors));
62
- } }, directives: [i1.MatFormField, i1.MatLabel, i2.MatSelect, i3.NgControlStatus, i3.FormControlDirective, i3.RequiredValidator, i4.NgForOf, i5.MatOption, i1.MatHint, i1.MatError, i4.NgTemplateOutlet], styles: [".td-dynamic-select-wrapper[_ngcontent-%COMP%]{-ms-flex-direction:row;flex-direction:row;display:-ms-flexbox;display:flex;box-sizing:border-box}.td-dynamic-select-wrapper[_ngcontent-%COMP%] .td-dynamic-select-field[_ngcontent-%COMP%]{-ms-flex:1;flex:1;box-sizing:border-box}"] });
63
- (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdDynamicSelectComponent, [{
64
- type: Component,
65
- args: [{ selector: 'td-dynamic-select', template: "<div class=\"td-dynamic-select-wrapper\">\n <mat-form-field class=\"td-dynamic-select-field\">\n <mat-label>{{ label }}</mat-label>\n <mat-select\n [formControl]=\"control\"\n [placeholder]=\"placeholder\"\n [required]=\"required\"\n [attr.name]=\"name\"\n [multiple]=\"multiple\"\n >\n <mat-option *ngFor=\"let selection of selections\" [value]=\"selection.value || selection\">\n {{ selection.label || selection }}\n </mat-option>\n </mat-select>\n <mat-hint>{{ hint }}</mat-hint>\n <mat-error>\n <ng-template\n [ngTemplateOutlet]=\"errorMessageTemplate\"\n [ngTemplateOutletContext]=\"{ control: control, errors: control?.errors }\"\n ></ng-template>\n </mat-error>\n </mat-form-field>\n</div>\n", styles: [".td-dynamic-select-wrapper{-ms-flex-direction:row;flex-direction:row;display:-ms-flexbox;display:flex;box-sizing:border-box}.td-dynamic-select-wrapper .td-dynamic-select-field{-ms-flex:1;flex:1;box-sizing:border-box}\n"] }]
66
- }], null, null); })();
67
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1zZWxlY3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3BsYXRmb3JtL2R5bmFtaWMtZm9ybXMvZHluYW1pYy1lbGVtZW50cy9keW5hbWljLXNlbGVjdC9keW5hbWljLXNlbGVjdC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvcGxhdGZvcm0vZHluYW1pYy1mb3Jtcy9keW5hbWljLWVsZW1lbnRzL2R5bmFtaWMtc2VsZWN0L2R5bmFtaWMtc2VsZWN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQWUsTUFBTSxlQUFlLENBQUM7Ozs7Ozs7O0lDVWpELHFDQUF3RjtJQUN0RixZQUNGO0lBQUEsaUJBQWE7OztJQUZvQywwREFBc0M7SUFDckYsZUFDRjtJQURFLG1FQUNGOzs7O0FESk4sTUFBTSxPQUFPLHdCQUF3QjtJQUxyQztRQVFFLFVBQUssR0FBVyxFQUFFLENBQUM7UUFFbkIsU0FBSSxHQUFXLEVBQUUsQ0FBQztRQUVsQixTQUFJLEdBQVcsRUFBRSxDQUFDO1FBRWxCLGFBQVEsR0FBWSxTQUFTLENBQUM7UUFFOUIsZUFBVSxHQUFVLFNBQVMsQ0FBQztRQUU5QixhQUFRLEdBQVksU0FBUyxDQUFDO1FBRTlCLHlCQUFvQixHQUFxQixTQUFTLENBQUM7UUFFbkQsZ0JBQVcsR0FBVyxFQUFFLENBQUM7S0FDMUI7O3NJQWxCWSx3QkFBd0I7NkhBQXhCLHdCQUF3QjtRQ1JyQyw4QkFBdUM7UUFDckMseUNBQWdEO1FBQzlDLGlDQUFXO1FBQUEsWUFBVztRQUFBLGlCQUFZO1FBQ2xDLHFDQU1DO1FBQ0MsdUZBRWE7UUFDZixpQkFBYTtRQUNiLGdDQUFVO1FBQUEsWUFBVTtRQUFBLGlCQUFXO1FBQy9CLGlDQUFXO1FBQ1QseUZBR2U7UUFDakIsaUJBQVk7UUFDZCxpQkFBaUI7UUFDbkIsaUJBQU07O1FBcEJTLGVBQVc7UUFBWCwrQkFBVztRQUVwQixlQUF1QjtRQUF2Qix5Q0FBdUIsZ0NBQUEsMEJBQUEsMEJBQUE7UUFHdkIsZ0NBQWtCO1FBR2dCLGVBQWE7UUFBYix3Q0FBYTtRQUl2QyxlQUFVO1FBQVYsOEJBQVU7UUFHaEIsZUFBeUM7UUFBekMsMkRBQXlDLHNIQUFBOzt1RkRUcEMsd0JBQXdCO2NBTHBDLFNBQVM7MkJBQ0UsbUJBQW1CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUNvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3RkLWR5bmFtaWMtc2VsZWN0JyxcbiAgc3R5bGVVcmxzOiBbJy4vZHluYW1pYy1zZWxlY3QuY29tcG9uZW50LnNjc3MnXSxcbiAgdGVtcGxhdGVVcmw6ICcuL2R5bmFtaWMtc2VsZWN0LmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgVGREeW5hbWljU2VsZWN0Q29tcG9uZW50IHtcbiAgY29udHJvbDogRm9ybUNvbnRyb2w7XG5cbiAgbGFiZWw6IHN0cmluZyA9ICcnO1xuXG4gIGhpbnQ6IHN0cmluZyA9ICcnO1xuXG4gIG5hbWU6IHN0cmluZyA9ICcnO1xuXG4gIHJlcXVpcmVkOiBib29sZWFuID0gdW5kZWZpbmVkO1xuXG4gIHNlbGVjdGlvbnM6IGFueVtdID0gdW5kZWZpbmVkO1xuXG4gIG11bHRpcGxlOiBib29sZWFuID0gdW5kZWZpbmVkO1xuXG4gIGVycm9yTWVzc2FnZVRlbXBsYXRlOiBUZW1wbGF0ZVJlZjxhbnk+ID0gdW5kZWZpbmVkO1xuXG4gIHBsYWNlaG9sZGVyOiBzdHJpbmcgPSAnJztcbn1cbiIsIjxkaXYgY2xhc3M9XCJ0ZC1keW5hbWljLXNlbGVjdC13cmFwcGVyXCI+XG4gIDxtYXQtZm9ybS1maWVsZCBjbGFzcz1cInRkLWR5bmFtaWMtc2VsZWN0LWZpZWxkXCI+XG4gICAgPG1hdC1sYWJlbD57eyBsYWJlbCB9fTwvbWF0LWxhYmVsPlxuICAgIDxtYXQtc2VsZWN0XG4gICAgICBbZm9ybUNvbnRyb2xdPVwiY29udHJvbFwiXG4gICAgICBbcGxhY2Vob2xkZXJdPVwicGxhY2Vob2xkZXJcIlxuICAgICAgW3JlcXVpcmVkXT1cInJlcXVpcmVkXCJcbiAgICAgIFthdHRyLm5hbWVdPVwibmFtZVwiXG4gICAgICBbbXVsdGlwbGVdPVwibXVsdGlwbGVcIlxuICAgID5cbiAgICAgIDxtYXQtb3B0aW9uICpuZ0Zvcj1cImxldCBzZWxlY3Rpb24gb2Ygc2VsZWN0aW9uc1wiIFt2YWx1ZV09XCJzZWxlY3Rpb24udmFsdWUgfHwgc2VsZWN0aW9uXCI+XG4gICAgICAgIHt7IHNlbGVjdGlvbi5sYWJlbCB8fCBzZWxlY3Rpb24gfX1cbiAgICAgIDwvbWF0LW9wdGlvbj5cbiAgICA8L21hdC1zZWxlY3Q+XG4gICAgPG1hdC1oaW50Pnt7IGhpbnQgfX08L21hdC1oaW50PlxuICAgIDxtYXQtZXJyb3I+XG4gICAgICA8bmctdGVtcGxhdGVcbiAgICAgICAgW25nVGVtcGxhdGVPdXRsZXRdPVwiZXJyb3JNZXNzYWdlVGVtcGxhdGVcIlxuICAgICAgICBbbmdUZW1wbGF0ZU91dGxldENvbnRleHRdPVwieyBjb250cm9sOiBjb250cm9sLCBlcnJvcnM6IGNvbnRyb2w/LmVycm9ycyB9XCJcbiAgICAgID48L25nLXRlbXBsYXRlPlxuICAgIDwvbWF0LWVycm9yPlxuICA8L21hdC1mb3JtLWZpZWxkPlxuPC9kaXY+XG4iXX0=
@@ -1,36 +0,0 @@
1
- import { Component } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/material/slide-toggle";
4
- import * as i2 from "@angular/forms";
5
- export class TdDynamicSlideToggleComponent {
6
- constructor() {
7
- this.label = '';
8
- this.name = '';
9
- this.hint = '';
10
- this.required = false;
11
- }
12
- }
13
- /** @nocollapse */ /** @nocollapse */ TdDynamicSlideToggleComponent.ɵfac = function TdDynamicSlideToggleComponent_Factory(t) { return new (t || TdDynamicSlideToggleComponent)(); };
14
- /** @nocollapse */ /** @nocollapse */ TdDynamicSlideToggleComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TdDynamicSlideToggleComponent, selectors: [["td-dynamic-slide-toggle"]], decls: 5, vars: 5, consts: [[1, "td-dynamic-slide-toggle-wrapper"], [3, "formControl", "required"], [1, "mat-hint", "td-dynamic-element-hint"]], template: function TdDynamicSlideToggleComponent_Template(rf, ctx) { if (rf & 1) {
15
- i0.ɵɵelementStart(0, "div", 0);
16
- i0.ɵɵelementStart(1, "mat-slide-toggle", 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)("required", ctx.required);
26
- i0.ɵɵattribute("name", ctx.name);
27
- i0.ɵɵadvance(1);
28
- i0.ɵɵtextInterpolate1(" ", ctx.label, " ");
29
- i0.ɵɵadvance(2);
30
- i0.ɵɵtextInterpolate(ctx.hint);
31
- } }, directives: [i1.MatSlideToggle, i1.MatSlideToggleRequiredValidator, i2.NgControlStatus, i2.FormControlDirective, i2.RequiredValidator], styles: [""] });
32
- (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdDynamicSlideToggleComponent, [{
33
- type: Component,
34
- args: [{ selector: 'td-dynamic-slide-toggle', template: "<div class=\"td-dynamic-slide-toggle-wrapper\">\n <mat-slide-toggle [formControl]=\"control\" [attr.name]=\"name\" [required]=\"required\">\n {{ label }}\n </mat-slide-toggle>\n <span class=\"mat-hint td-dynamic-element-hint\">{{ hint }}</span>\n</div>\n", styles: [""] }]
35
- }], null, null); })();
36
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1zbGlkZS10b2dnbGUuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3BsYXRmb3JtL2R5bmFtaWMtZm9ybXMvZHluYW1pYy1lbGVtZW50cy9keW5hbWljLXNsaWRlLXRvZ2dsZS9keW5hbWljLXNsaWRlLXRvZ2dsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvcGxhdGZvcm0vZHluYW1pYy1mb3Jtcy9keW5hbWljLWVsZW1lbnRzL2R5bmFtaWMtc2xpZGUtdG9nZ2xlL2R5bmFtaWMtc2xpZGUtdG9nZ2xlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFRMUMsTUFBTSxPQUFPLDZCQUE2QjtJQUwxQztRQVFFLFVBQUssR0FBVyxFQUFFLENBQUM7UUFFbkIsU0FBSSxHQUFXLEVBQUUsQ0FBQztRQUVsQixTQUFJLEdBQVcsRUFBRSxDQUFDO1FBRWxCLGFBQVEsR0FBWSxLQUFLLENBQUM7S0FDM0I7O2dKQVZZLDZCQUE2QjtrSUFBN0IsNkJBQTZCO1FDUjFDLDhCQUE2QztRQUMzQywyQ0FBbUY7UUFDakYsWUFDRjtRQUFBLGlCQUFtQjtRQUNuQiwrQkFBK0M7UUFBQSxZQUFVO1FBQUEsaUJBQU87UUFDbEUsaUJBQU07O1FBSmMsZUFBdUI7UUFBdkIseUNBQXVCLDBCQUFBO1FBQUMsZ0NBQWtCO1FBQzFELGVBQ0Y7UUFERSwwQ0FDRjtRQUMrQyxlQUFVO1FBQVYsOEJBQVU7O3VGREk5Qyw2QkFBNkI7Y0FMekMsU0FBUzsyQkFDRSx5QkFBeUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1Db250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd0ZC1keW5hbWljLXNsaWRlLXRvZ2dsZScsXG4gIHN0eWxlVXJsczogWycuL2R5bmFtaWMtc2xpZGUtdG9nZ2xlLmNvbXBvbmVudC5zY3NzJ10sXG4gIHRlbXBsYXRlVXJsOiAnLi9keW5hbWljLXNsaWRlLXRvZ2dsZS5jb21wb25lbnQuaHRtbCcsXG59KVxuZXhwb3J0IGNsYXNzIFRkRHluYW1pY1NsaWRlVG9nZ2xlQ29tcG9uZW50IHtcbiAgY29udHJvbDogRm9ybUNvbnRyb2w7XG5cbiAgbGFiZWw6IHN0cmluZyA9ICcnO1xuXG4gIG5hbWU6IHN0cmluZyA9ICcnO1xuXG4gIGhpbnQ6IHN0cmluZyA9ICcnO1xuXG4gIHJlcXVpcmVkOiBib29sZWFuID0gZmFsc2U7XG59XG4iLCI8ZGl2IGNsYXNzPVwidGQtZHluYW1pYy1zbGlkZS10b2dnbGUtd3JhcHBlclwiPlxuICA8bWF0LXNsaWRlLXRvZ2dsZSBbZm9ybUNvbnRyb2xdPVwiY29udHJvbFwiIFthdHRyLm5hbWVdPVwibmFtZVwiIFtyZXF1aXJlZF09XCJyZXF1aXJlZFwiPlxuICAgIHt7IGxhYmVsIH19XG4gIDwvbWF0LXNsaWRlLXRvZ2dsZT5cbiAgPHNwYW4gY2xhc3M9XCJtYXQtaGludCB0ZC1keW5hbWljLWVsZW1lbnQtaGludFwiPnt7IGhpbnQgfX08L3NwYW4+XG48L2Rpdj5cbiJdfQ==
@@ -1,62 +0,0 @@
1
- import { Component, ChangeDetectorRef } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/common";
4
- import * as i2 from "@angular/material/slider";
5
- import * as i3 from "@angular/forms";
6
- function TdDynamicSliderComponent_span_4_Template(rf, ctx) { if (rf & 1) {
7
- i0.ɵɵelementStart(0, "span", 8);
8
- i0.ɵɵtext(1, "*");
9
- i0.ɵɵelementEnd();
10
- } }
11
- export class TdDynamicSliderComponent {
12
- constructor(_changeDetectorRef) {
13
- this._changeDetectorRef = _changeDetectorRef;
14
- this.label = '';
15
- this.required = undefined;
16
- this.name = '';
17
- this.hint = '';
18
- this.min = undefined;
19
- this.max = undefined;
20
- }
21
- _handleBlur() {
22
- setTimeout(() => {
23
- this._changeDetectorRef.markForCheck();
24
- });
25
- }
26
- }
27
- /** @nocollapse */ /** @nocollapse */ TdDynamicSliderComponent.ɵfac = function TdDynamicSliderComponent_Factory(t) { return new (t || TdDynamicSliderComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); };
28
- /** @nocollapse */ /** @nocollapse */ TdDynamicSliderComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TdDynamicSliderComponent, selectors: [["td-dynamic-slider"]], decls: 10, vars: 10, consts: [[1, "td-dynamic-slider-wrapper", "mat-form-field", "mat-form-field-can-float", "mat-form-field-should-float"], [1, "mat-form-field-label-wrapper"], [1, "mat-form-field-label", "mat-primary", "td-slider-label"], ["class", "mat-form-field-required-marker", 4, "ngIf"], [1, "td-dynamic-slider-field"], ["thumbLabel", "", "tickInterval", "auto", 1, "td-dynamic-slider", 3, "formControl", "min", "max", "required", "blur"], ["slider", ""], [1, "mat-hint", "td-dynamic-element-hint"], [1, "mat-form-field-required-marker"]], template: function TdDynamicSliderComponent_Template(rf, ctx) { if (rf & 1) {
29
- i0.ɵɵelementStart(0, "div", 0);
30
- i0.ɵɵelementStart(1, "span", 1);
31
- i0.ɵɵelementStart(2, "label", 2);
32
- i0.ɵɵtext(3);
33
- i0.ɵɵtemplate(4, TdDynamicSliderComponent_span_4_Template, 2, 0, "span", 3);
34
- i0.ɵɵelementEnd();
35
- i0.ɵɵelementEnd();
36
- i0.ɵɵelementStart(5, "div", 4);
37
- i0.ɵɵelementStart(6, "mat-slider", 5, 6);
38
- i0.ɵɵlistener("blur", function TdDynamicSliderComponent_Template_mat_slider_blur_6_listener() { return ctx._handleBlur(); });
39
- i0.ɵɵelementEnd();
40
- i0.ɵɵelementEnd();
41
- i0.ɵɵelementStart(8, "span", 7);
42
- i0.ɵɵtext(9);
43
- i0.ɵɵelementEnd();
44
- i0.ɵɵelementEnd();
45
- } if (rf & 2) {
46
- const _r1 = i0.ɵɵreference(7);
47
- i0.ɵɵclassProp("mat-focused", _r1._isActive);
48
- i0.ɵɵadvance(3);
49
- i0.ɵɵtextInterpolate1(" ", ctx.label, " ");
50
- i0.ɵɵadvance(1);
51
- i0.ɵɵproperty("ngIf", ctx.required && !(ctx.control == null ? null : ctx.control.disabled));
52
- i0.ɵɵadvance(2);
53
- i0.ɵɵproperty("formControl", ctx.control)("min", ctx.min)("max", ctx.max)("required", ctx.required);
54
- i0.ɵɵattribute("name", ctx.name);
55
- i0.ɵɵadvance(3);
56
- i0.ɵɵtextInterpolate(ctx.hint);
57
- } }, directives: [i1.NgIf, i2.MatSlider, i3.NgControlStatus, i3.FormControlDirective, i3.RequiredValidator], styles: ["[_nghost-%COMP%] .td-dynamic-slider-wrapper[_ngcontent-%COMP%]{display:block}.td-dynamic-slider-field[_ngcontent-%COMP%]{position:relative;-ms-flex-direction:row;flex-direction:row;display:-ms-flexbox;display:flex;box-sizing:border-box}.td-dynamic-slider-field[_ngcontent-%COMP%] .td-dynamic-slider[_ngcontent-%COMP%]{-ms-flex:1;flex:1}"] });
58
- (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdDynamicSliderComponent, [{
59
- type: Component,
60
- args: [{ selector: 'td-dynamic-slider', template: "<div\n class=\"td-dynamic-slider-wrapper mat-form-field mat-form-field-can-float mat-form-field-should-float\"\n [class.mat-focused]=\"slider._isActive\"\n>\n <span class=\"mat-form-field-label-wrapper\">\n <label class=\"mat-form-field-label mat-primary td-slider-label\">\n {{ label }}\n <span *ngIf=\"required && !control?.disabled\" class=\"mat-form-field-required-marker\">*</span>\n </label>\n </span>\n <div class=\"td-dynamic-slider-field\">\n <mat-slider\n #slider\n class=\"td-dynamic-slider\"\n [formControl]=\"control\"\n [attr.name]=\"name\"\n [min]=\"min\"\n [max]=\"max\"\n thumbLabel\n tickInterval=\"auto\"\n [required]=\"required\"\n (blur)=\"_handleBlur()\"\n ></mat-slider>\n </div>\n <span class=\"mat-hint td-dynamic-element-hint\">{{ hint }}</span>\n</div>\n", styles: [":host .td-dynamic-slider-wrapper{display:block}.td-dynamic-slider-field{position:relative;-ms-flex-direction:row;flex-direction:row;display:-ms-flexbox;display:flex;box-sizing:border-box}.td-dynamic-slider-field .td-dynamic-slider{-ms-flex:1;flex:1}\n"] }]
61
- }], function () { return [{ type: i0.ChangeDetectorRef }]; }, null); })();
62
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1zbGlkZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vc3JjL3BsYXRmb3JtL2R5bmFtaWMtZm9ybXMvZHluYW1pYy1lbGVtZW50cy9keW5hbWljLXNsaWRlci9keW5hbWljLXNsaWRlci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvcGxhdGZvcm0vZHluYW1pYy1mb3Jtcy9keW5hbWljLWVsZW1lbnRzL2R5bmFtaWMtc2xpZGVyL2R5bmFtaWMtc2xpZGVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7OztJQ092RCwrQkFBb0Y7SUFBQSxpQkFBQztJQUFBLGlCQUFPOztBRENsRyxNQUFNLE9BQU8sd0JBQXdCO0lBZW5DLFlBQW9CLGtCQUFxQztRQUFyQyx1QkFBa0IsR0FBbEIsa0JBQWtCLENBQW1CO1FBWnpELFVBQUssR0FBVyxFQUFFLENBQUM7UUFFbkIsYUFBUSxHQUFZLFNBQVMsQ0FBQztRQUU5QixTQUFJLEdBQVcsRUFBRSxDQUFDO1FBRWxCLFNBQUksR0FBVyxFQUFFLENBQUM7UUFFbEIsUUFBRyxHQUFXLFNBQVMsQ0FBQztRQUV4QixRQUFHLEdBQVcsU0FBUyxDQUFDO0lBRW9DLENBQUM7SUFFN0QsV0FBVztRQUNULFVBQVUsQ0FBQyxHQUFHLEVBQUU7WUFDZCxJQUFJLENBQUMsa0JBQWtCLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDekMsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDOztzSUFyQlUsd0JBQXdCOzZIQUF4Qix3QkFBd0I7UUNSckMsOEJBR0M7UUFDQywrQkFBMkM7UUFDekMsZ0NBQWdFO1FBQzlELFlBQ0E7UUFBQSwyRUFBNEY7UUFDOUYsaUJBQVE7UUFDVixpQkFBTztRQUNQLDhCQUFxQztRQUNuQyx3Q0FXQztRQURDLHVHQUFRLGlCQUFhLElBQUM7UUFDdkIsaUJBQWE7UUFDaEIsaUJBQU07UUFDTiwrQkFBK0M7UUFBQSxZQUFVO1FBQUEsaUJBQU87UUFDbEUsaUJBQU07OztRQXZCSiw0Q0FBc0M7UUFJbEMsZUFDQTtRQURBLDBDQUNBO1FBQU8sZUFBb0M7UUFBcEMsMkZBQW9DO1FBTzNDLGVBQXVCO1FBQXZCLHlDQUF1QixnQkFBQSxnQkFBQSwwQkFBQTtRQUN2QixnQ0FBa0I7UUFTeUIsZUFBVTtRQUFWLDhCQUFVOzt1RkRoQjlDLHdCQUF3QjtjQUxwQyxTQUFTOzJCQUNFLG1CQUFtQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgQ2hhbmdlRGV0ZWN0b3JSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEZvcm1Db250cm9sIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd0ZC1keW5hbWljLXNsaWRlcicsXG4gIHN0eWxlVXJsczogWycuL2R5bmFtaWMtc2xpZGVyLmNvbXBvbmVudC5zY3NzJ10sXG4gIHRlbXBsYXRlVXJsOiAnLi9keW5hbWljLXNsaWRlci5jb21wb25lbnQuaHRtbCcsXG59KVxuZXhwb3J0IGNsYXNzIFRkRHluYW1pY1NsaWRlckNvbXBvbmVudCB7XG4gIGNvbnRyb2w6IEZvcm1Db250cm9sO1xuXG4gIGxhYmVsOiBzdHJpbmcgPSAnJztcblxuICByZXF1aXJlZDogYm9vbGVhbiA9IHVuZGVmaW5lZDtcblxuICBuYW1lOiBzdHJpbmcgPSAnJztcblxuICBoaW50OiBzdHJpbmcgPSAnJztcblxuICBtaW46IG51bWJlciA9IHVuZGVmaW5lZDtcblxuICBtYXg6IG51bWJlciA9IHVuZGVmaW5lZDtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIF9jaGFuZ2VEZXRlY3RvclJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHt9XG5cbiAgX2hhbmRsZUJsdXIoKTogdm9pZCB7XG4gICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICB0aGlzLl9jaGFuZ2VEZXRlY3RvclJlZi5tYXJrRm9yQ2hlY2soKTtcbiAgICB9KTtcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cInRkLWR5bmFtaWMtc2xpZGVyLXdyYXBwZXIgbWF0LWZvcm0tZmllbGQgbWF0LWZvcm0tZmllbGQtY2FuLWZsb2F0IG1hdC1mb3JtLWZpZWxkLXNob3VsZC1mbG9hdFwiXG4gIFtjbGFzcy5tYXQtZm9jdXNlZF09XCJzbGlkZXIuX2lzQWN0aXZlXCJcbj5cbiAgPHNwYW4gY2xhc3M9XCJtYXQtZm9ybS1maWVsZC1sYWJlbC13cmFwcGVyXCI+XG4gICAgPGxhYmVsIGNsYXNzPVwibWF0LWZvcm0tZmllbGQtbGFiZWwgbWF0LXByaW1hcnkgdGQtc2xpZGVyLWxhYmVsXCI+XG4gICAgICB7eyBsYWJlbCB9fVxuICAgICAgPHNwYW4gKm5nSWY9XCJyZXF1aXJlZCAmJiAhY29udHJvbD8uZGlzYWJsZWRcIiBjbGFzcz1cIm1hdC1mb3JtLWZpZWxkLXJlcXVpcmVkLW1hcmtlclwiPio8L3NwYW4+XG4gICAgPC9sYWJlbD5cbiAgPC9zcGFuPlxuICA8ZGl2IGNsYXNzPVwidGQtZHluYW1pYy1zbGlkZXItZmllbGRcIj5cbiAgICA8bWF0LXNsaWRlclxuICAgICAgI3NsaWRlclxuICAgICAgY2xhc3M9XCJ0ZC1keW5hbWljLXNsaWRlclwiXG4gICAgICBbZm9ybUNvbnRyb2xdPVwiY29udHJvbFwiXG4gICAgICBbYXR0ci5uYW1lXT1cIm5hbWVcIlxuICAgICAgW21pbl09XCJtaW5cIlxuICAgICAgW21heF09XCJtYXhcIlxuICAgICAgdGh1bWJMYWJlbFxuICAgICAgdGlja0ludGVydmFsPVwiYXV0b1wiXG4gICAgICBbcmVxdWlyZWRdPVwicmVxdWlyZWRcIlxuICAgICAgKGJsdXIpPVwiX2hhbmRsZUJsdXIoKVwiXG4gICAgPjwvbWF0LXNsaWRlcj5cbiAgPC9kaXY+XG4gIDxzcGFuIGNsYXNzPVwibWF0LWhpbnQgdGQtZHluYW1pYy1lbGVtZW50LWhpbnRcIj57eyBoaW50IH19PC9zcGFuPlxuPC9kaXY+XG4iXX0=
@@ -1,50 +0,0 @@
1
- import { Component } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- import * as i1 from "@angular/material/form-field";
4
- import * as i2 from "@angular/material/input";
5
- import * as i3 from "@angular/forms";
6
- import * as i4 from "@angular/common";
7
- function TdDynamicTextareaComponent_ng_template_9_Template(rf, ctx) { }
8
- const _c0 = function (a0, a1) { return { control: a0, errors: a1 }; };
9
- export class TdDynamicTextareaComponent {
10
- constructor() {
11
- this.label = '';
12
- this.hint = '';
13
- this.name = '';
14
- this.required = undefined;
15
- this.errorMessageTemplate = undefined;
16
- this.placeholder = '';
17
- }
18
- }
19
- /** @nocollapse */ /** @nocollapse */ TdDynamicTextareaComponent.ɵfac = function TdDynamicTextareaComponent_Factory(t) { return new (t || TdDynamicTextareaComponent)(); };
20
- /** @nocollapse */ /** @nocollapse */ TdDynamicTextareaComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TdDynamicTextareaComponent, selectors: [["td-dynamic-textarea"]], decls: 10, vars: 11, consts: [[1, "td-dynamic-textarea-wrapper"], [1, "td-dynamic-textarea-field"], ["matInput", "", "rows", "4", 3, "formControl", "placeholder", "required"], ["elementInput", ""], [3, "ngTemplateOutlet", "ngTemplateOutletContext"]], template: function TdDynamicTextareaComponent_Template(rf, ctx) { if (rf & 1) {
21
- i0.ɵɵelementStart(0, "div", 0);
22
- i0.ɵɵelementStart(1, "mat-form-field", 1);
23
- i0.ɵɵelementStart(2, "mat-label");
24
- i0.ɵɵtext(3);
25
- i0.ɵɵelementEnd();
26
- i0.ɵɵelement(4, "textarea", 2, 3);
27
- i0.ɵɵelementStart(6, "mat-hint");
28
- i0.ɵɵtext(7);
29
- i0.ɵɵelementEnd();
30
- i0.ɵɵelementStart(8, "mat-error");
31
- i0.ɵɵtemplate(9, TdDynamicTextareaComponent_ng_template_9_Template, 0, 0, "ng-template", 4);
32
- i0.ɵɵelementEnd();
33
- i0.ɵɵelementEnd();
34
- i0.ɵɵelementEnd();
35
- } if (rf & 2) {
36
- i0.ɵɵadvance(3);
37
- i0.ɵɵtextInterpolate(ctx.label);
38
- i0.ɵɵadvance(1);
39
- i0.ɵɵproperty("formControl", ctx.control)("placeholder", ctx.placeholder)("required", ctx.required);
40
- i0.ɵɵattribute("name", ctx.name);
41
- i0.ɵɵadvance(3);
42
- i0.ɵɵtextInterpolate(ctx.hint);
43
- i0.ɵɵadvance(2);
44
- i0.ɵɵproperty("ngTemplateOutlet", ctx.errorMessageTemplate)("ngTemplateOutletContext", i0.ɵɵpureFunction2(8, _c0, ctx.control, ctx.control == null ? null : ctx.control.errors));
45
- } }, directives: [i1.MatFormField, i1.MatLabel, i2.MatInput, i3.DefaultValueAccessor, i3.NgControlStatus, i3.FormControlDirective, i3.RequiredValidator, i1.MatHint, i1.MatError, i4.NgTemplateOutlet], styles: [".td-dynamic-textarea-wrapper[_ngcontent-%COMP%]{-ms-flex-direction:row;flex-direction:row;display:-ms-flexbox;display:flex;box-sizing:border-box}.td-dynamic-textarea-wrapper[_ngcontent-%COMP%] .td-dynamic-textarea-field[_ngcontent-%COMP%]{-ms-flex:1;flex:1;box-sizing:border-box}"] });
46
- (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdDynamicTextareaComponent, [{
47
- type: Component,
48
- args: [{ selector: 'td-dynamic-textarea', template: "<div class=\"td-dynamic-textarea-wrapper\">\n <mat-form-field class=\"td-dynamic-textarea-field\">\n <mat-label>{{ label }}</mat-label>\n <textarea\n #elementInput\n matInput\n [formControl]=\"control\"\n [placeholder]=\"placeholder\"\n [required]=\"required\"\n [attr.name]=\"name\"\n rows=\"4\"\n ></textarea>\n <mat-hint>{{ hint }}</mat-hint>\n <mat-error>\n <ng-template\n [ngTemplateOutlet]=\"errorMessageTemplate\"\n [ngTemplateOutletContext]=\"{ control: control, errors: control?.errors }\"\n ></ng-template>\n </mat-error>\n </mat-form-field>\n</div>\n", styles: [".td-dynamic-textarea-wrapper{-ms-flex-direction:row;flex-direction:row;display:-ms-flexbox;display:flex;box-sizing:border-box}.td-dynamic-textarea-wrapper .td-dynamic-textarea-field{-ms-flex:1;flex:1;box-sizing:border-box}\n"] }]
49
- }], null, null); })();
50
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy10ZXh0YXJlYS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvcGxhdGZvcm0vZHluYW1pYy1mb3Jtcy9keW5hbWljLWVsZW1lbnRzL2R5bmFtaWMtdGV4dGFyZWEvZHluYW1pYy10ZXh0YXJlYS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9zcmMvcGxhdGZvcm0vZHluYW1pYy1mb3Jtcy9keW5hbWljLWVsZW1lbnRzL2R5bmFtaWMtdGV4dGFyZWEvZHluYW1pYy10ZXh0YXJlYS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFlLE1BQU0sZUFBZSxDQUFDOzs7Ozs7OztBQVF2RCxNQUFNLE9BQU8sMEJBQTBCO0lBTHZDO1FBUUUsVUFBSyxHQUFXLEVBQUUsQ0FBQztRQUVuQixTQUFJLEdBQVcsRUFBRSxDQUFDO1FBRWxCLFNBQUksR0FBVyxFQUFFLENBQUM7UUFFbEIsYUFBUSxHQUFZLFNBQVMsQ0FBQztRQUU5Qix5QkFBb0IsR0FBcUIsU0FBUyxDQUFDO1FBRW5ELGdCQUFXLEdBQVcsRUFBRSxDQUFDO0tBQzFCOzswSUFkWSwwQkFBMEI7K0hBQTFCLDBCQUEwQjtRQ1J2Qyw4QkFBeUM7UUFDdkMseUNBQWtEO1FBQ2hELGlDQUFXO1FBQUEsWUFBVztRQUFBLGlCQUFZO1FBQ2xDLGlDQVFZO1FBQ1osZ0NBQVU7UUFBQSxZQUFVO1FBQUEsaUJBQVc7UUFDL0IsaUNBQVc7UUFDVCwyRkFHZTtRQUNqQixpQkFBWTtRQUNkLGlCQUFpQjtRQUNuQixpQkFBTTs7UUFsQlMsZUFBVztRQUFYLCtCQUFXO1FBSXBCLGVBQXVCO1FBQXZCLHlDQUF1QixnQ0FBQSwwQkFBQTtRQUd2QixnQ0FBa0I7UUFHVixlQUFVO1FBQVYsOEJBQVU7UUFHaEIsZUFBeUM7UUFBekMsMkRBQXlDLHFIQUFBOzt1RkRQcEMsMEJBQTBCO2NBTHRDLFNBQVM7MkJBQ0UscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBUZW1wbGF0ZVJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybUNvbnRyb2wgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3RkLWR5bmFtaWMtdGV4dGFyZWEnLFxuICBzdHlsZVVybHM6IFsnLi9keW5hbWljLXRleHRhcmVhLmNvbXBvbmVudC5zY3NzJ10sXG4gIHRlbXBsYXRlVXJsOiAnLi9keW5hbWljLXRleHRhcmVhLmNvbXBvbmVudC5odG1sJyxcbn0pXG5leHBvcnQgY2xhc3MgVGREeW5hbWljVGV4dGFyZWFDb21wb25lbnQge1xuICBjb250cm9sOiBGb3JtQ29udHJvbDtcblxuICBsYWJlbDogc3RyaW5nID0gJyc7XG5cbiAgaGludDogc3RyaW5nID0gJyc7XG5cbiAgbmFtZTogc3RyaW5nID0gJyc7XG5cbiAgcmVxdWlyZWQ6IGJvb2xlYW4gPSB1bmRlZmluZWQ7XG5cbiAgZXJyb3JNZXNzYWdlVGVtcGxhdGU6IFRlbXBsYXRlUmVmPGFueT4gPSB1bmRlZmluZWQ7XG5cbiAgcGxhY2Vob2xkZXI6IHN0cmluZyA9ICcnO1xufVxuIiwiPGRpdiBjbGFzcz1cInRkLWR5bmFtaWMtdGV4dGFyZWEtd3JhcHBlclwiPlxuICA8bWF0LWZvcm0tZmllbGQgY2xhc3M9XCJ0ZC1keW5hbWljLXRleHRhcmVhLWZpZWxkXCI+XG4gICAgPG1hdC1sYWJlbD57eyBsYWJlbCB9fTwvbWF0LWxhYmVsPlxuICAgIDx0ZXh0YXJlYVxuICAgICAgI2VsZW1lbnRJbnB1dFxuICAgICAgbWF0SW5wdXRcbiAgICAgIFtmb3JtQ29udHJvbF09XCJjb250cm9sXCJcbiAgICAgIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiXG4gICAgICBbcmVxdWlyZWRdPVwicmVxdWlyZWRcIlxuICAgICAgW2F0dHIubmFtZV09XCJuYW1lXCJcbiAgICAgIHJvd3M9XCI0XCJcbiAgICA+PC90ZXh0YXJlYT5cbiAgICA8bWF0LWhpbnQ+e3sgaGludCB9fTwvbWF0LWhpbnQ+XG4gICAgPG1hdC1lcnJvcj5cbiAgICAgIDxuZy10ZW1wbGF0ZVxuICAgICAgICBbbmdUZW1wbGF0ZU91dGxldF09XCJlcnJvck1lc3NhZ2VUZW1wbGF0ZVwiXG4gICAgICAgIFtuZ1RlbXBsYXRlT3V0bGV0Q29udGV4dF09XCJ7IGNvbnRyb2w6IGNvbnRyb2wsIGVycm9yczogY29udHJvbD8uZXJyb3JzIH1cIlxuICAgICAgPjwvbmctdGVtcGxhdGU+XG4gICAgPC9tYXQtZXJyb3I+XG4gIDwvbWF0LWZvcm0tZmllbGQ+XG48L2Rpdj5cbiJdfQ==
@@ -1,220 +0,0 @@
1
- import { Component, Input, ChangeDetectionStrategy, ChangeDetectorRef, ContentChildren, QueryList, } from '@angular/core';
2
- import { FormBuilder } from '@angular/forms';
3
- import { TdDynamicFormsService } from './services/dynamic-forms.service';
4
- import { TdDynamicFormsErrorTemplateDirective } from './dynamic-element.component';
5
- import { timer, Subject } from 'rxjs';
6
- import { takeUntil, filter } from 'rxjs/operators';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "@angular/forms";
9
- import * as i2 from "./services/dynamic-forms.service";
10
- import * as i3 from "@angular/common";
11
- import * as i4 from "./dynamic-element.component";
12
- function TdDynamicFormsComponent_ng_template_2_td_dynamic_element_1_Template(rf, ctx) { if (rf & 1) {
13
- i0.ɵɵelement(0, "td-dynamic-element", 5, 6);
14
- } if (rf & 2) {
15
- const element_r1 = i0.ɵɵnextContext().$implicit;
16
- const ctx_r2 = i0.ɵɵnextContext();
17
- i0.ɵɵproperty("formControlName", element_r1.name)("dynamicControl", ctx_r2.dynamicForm.controls[element_r1.name])("id", element_r1.name)("name", element_r1.name)("label", element_r1.label || element_r1.name)("hint", element_r1.hint)("type", element_r1.type)("required", element_r1.required)("min", element_r1.min)("max", element_r1.max)("minLength", element_r1.minLength)("maxLength", element_r1.maxLength)("selections", element_r1.selections)("multiple", element_r1.multiple)("customConfig", element_r1.customConfig)("errorMessageTemplate", ctx_r2.getErrorTemplateRef(element_r1.name))("placeholder", element_r1.placeholder);
18
- } }
19
- function TdDynamicFormsComponent_ng_template_2_Template(rf, ctx) { if (rf & 1) {
20
- i0.ɵɵelementStart(0, "div", 3);
21
- i0.ɵɵtemplate(1, TdDynamicFormsComponent_ng_template_2_td_dynamic_element_1_Template, 2, 17, "td-dynamic-element", 4);
22
- i0.ɵɵelementEnd();
23
- } if (rf & 2) {
24
- const element_r1 = ctx.$implicit;
25
- const ctx_r0 = i0.ɵɵnextContext();
26
- i0.ɵɵstyleProp("max-width", element_r1.flex ? element_r1.flex : 100, "%")("flex", "1 1 " + (element_r1.flex ? element_r1.flex : 100) + "%")("-ms-flex", "1 1 " + (element_r1.flex ? element_r1.flex : 100) + "%")("-webkit-box-flex", 1);
27
- i0.ɵɵadvance(1);
28
- i0.ɵɵproperty("ngIf", ctx_r0.dynamicForm.controls[element_r1.name]);
29
- } }
30
- const _c0 = ["*"];
31
- export class TdDynamicFormsComponent {
32
- constructor(_formBuilder, _dynamicFormsService, _changeDetectorRef) {
33
- this._formBuilder = _formBuilder;
34
- this._dynamicFormsService = _dynamicFormsService;
35
- this._changeDetectorRef = _changeDetectorRef;
36
- this._renderedElements = [];
37
- this._templateMap = new Map();
38
- this._destroy$ = new Subject();
39
- this._destroyControl$ = new Subject();
40
- this.dynamicForm = this._formBuilder.group({});
41
- }
42
- /**
43
- * elements: ITdDynamicElementConfig[]
44
- * JS Object that will render the elements depending on its config.
45
- * [name] property is required.
46
- */
47
- set elements(elements) {
48
- if (elements) {
49
- this._elements = elements;
50
- }
51
- else {
52
- this._elements = [];
53
- }
54
- this._rerenderElements();
55
- }
56
- get elements() {
57
- return this._renderedElements;
58
- }
59
- /**
60
- * Getter property for dynamic [FormGroup].
61
- */
62
- get form() {
63
- return this.dynamicForm;
64
- }
65
- /**
66
- * Getter property for [valid] of dynamic [FormGroup].
67
- */
68
- get valid() {
69
- if (this.dynamicForm) {
70
- return this.dynamicForm.valid;
71
- }
72
- return false;
73
- }
74
- /**
75
- * Getter property for [value] of dynamic [FormGroup].
76
- */
77
- get value() {
78
- if (this.dynamicForm) {
79
- return this.dynamicForm.value;
80
- }
81
- return {};
82
- }
83
- /**
84
- * Getter property for [errors] of dynamic [FormGroup].
85
- */
86
- get errors() {
87
- if (this.dynamicForm) {
88
- const errors = {};
89
- for (const name of Object.keys(this.dynamicForm.controls)) {
90
- errors[name] = this.dynamicForm.controls[name].errors;
91
- }
92
- return errors;
93
- }
94
- return {};
95
- }
96
- /**
97
- * Getter property for [controls] of dynamic [FormGroup].
98
- */
99
- get controls() {
100
- if (this.dynamicForm) {
101
- return this.dynamicForm.controls;
102
- }
103
- return {};
104
- }
105
- ngAfterContentInit() {
106
- this._updateErrorTemplates();
107
- }
108
- ngOnDestroy() {
109
- this._destroy$.next();
110
- this._destroy$.complete();
111
- this._destroyControl$.complete();
112
- }
113
- /**
114
- * Refreshes the form and rerenders all validator/element modifications.
115
- */
116
- refresh() {
117
- this._rerenderElements();
118
- this._updateErrorTemplates();
119
- }
120
- /**
121
- * Getter method for error template references
122
- */
123
- getErrorTemplateRef(name) {
124
- return this._templateMap.get(name);
125
- }
126
- /**
127
- * Loads error templates and sets them in a map for faster access.
128
- */
129
- _updateErrorTemplates() {
130
- this._templateMap = new Map();
131
- for (const errorTemplate of this._errorTemplates.toArray()) {
132
- this._templateMap.set(errorTemplate.tdDynamicFormsError, errorTemplate.templateRef);
133
- }
134
- }
135
- _rerenderElements() {
136
- this._clearRemovedElements();
137
- this._renderedElements = [];
138
- const duplicates = [];
139
- this._elements.forEach((elem) => {
140
- this._dynamicFormsService.validateDynamicElementName(elem.name);
141
- if (duplicates.indexOf(elem.name) > -1) {
142
- throw new Error(`Dynamic element name: "${elem.name}" is duplicated`);
143
- }
144
- duplicates.push(elem.name);
145
- const dynamicElement = this.dynamicForm.get(elem.name);
146
- if (!dynamicElement) {
147
- this.dynamicForm.addControl(elem.name, this._dynamicFormsService.createFormControl(elem));
148
- this._subscribeToControlStatusChanges(elem.name);
149
- }
150
- else {
151
- dynamicElement.setValue(elem.default);
152
- dynamicElement.markAsPristine();
153
- dynamicElement.markAsUntouched();
154
- if (elem.disabled) {
155
- dynamicElement.disable();
156
- }
157
- else {
158
- dynamicElement.enable();
159
- }
160
- dynamicElement.setValidators(this._dynamicFormsService.createValidators(elem));
161
- }
162
- // copy objects so they are only changes when calling this method
163
- this._renderedElements.push(Object.assign({}, elem));
164
- });
165
- // call a change detection since the whole form might change
166
- this._changeDetectorRef.detectChanges();
167
- timer()
168
- .toPromise()
169
- .then(() => {
170
- // call a markForCheck so elements are rendered correctly in OnPush
171
- this._changeDetectorRef.markForCheck();
172
- });
173
- }
174
- _clearRemovedElements() {
175
- this._renderedElements = this._renderedElements.filter((renderedElement) => !this._elements.some((element) => element.name === renderedElement.name));
176
- // remove elements that were removed from the array
177
- this._renderedElements.forEach((elem) => {
178
- this._destroyControl$.next(elem.name);
179
- this.dynamicForm.removeControl(elem.name);
180
- });
181
- }
182
- // Updates component when manually adding errors to controls
183
- _subscribeToControlStatusChanges(elementName) {
184
- const control = this.controls[elementName];
185
- const controlDestroyed$ = this._destroyControl$.pipe(filter((destroyedElementName) => destroyedElementName === elementName));
186
- control.statusChanges.pipe(takeUntil(this._destroy$), takeUntil(controlDestroyed$)).subscribe(() => {
187
- this._changeDetectorRef.markForCheck();
188
- });
189
- }
190
- }
191
- /** @nocollapse */ /** @nocollapse */ TdDynamicFormsComponent.ɵfac = function TdDynamicFormsComponent_Factory(t) { return new (t || TdDynamicFormsComponent)(i0.ɵɵdirectiveInject(i1.FormBuilder), i0.ɵɵdirectiveInject(i2.TdDynamicFormsService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); };
192
- /** @nocollapse */ /** @nocollapse */ TdDynamicFormsComponent.ɵcmp = /** @pureOrBreakMyCode */ i0.ɵɵdefineComponent({ type: TdDynamicFormsComponent, selectors: [["td-dynamic-forms"]], contentQueries: function TdDynamicFormsComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
193
- i0.ɵɵcontentQuery(dirIndex, TdDynamicFormsErrorTemplateDirective, 5);
194
- } if (rf & 2) {
195
- let _t;
196
- i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx._errorTemplates = _t);
197
- } }, inputs: { elements: "elements" }, ngContentSelectors: _c0, decls: 4, vars: 2, consts: [["novalidate", "", 3, "formGroup"], [1, "td-dynamic-form-wrapper"], ["ngFor", "", 3, "ngForOf"], [1, "td-dynamic-element-wrapper"], [3, "formControlName", "dynamicControl", "id", "name", "label", "hint", "type", "required", "min", "max", "minLength", "maxLength", "selections", "multiple", "customConfig", "errorMessageTemplate", "placeholder", 4, "ngIf"], [3, "formControlName", "dynamicControl", "id", "name", "label", "hint", "type", "required", "min", "max", "minLength", "maxLength", "selections", "multiple", "customConfig", "errorMessageTemplate", "placeholder"], ["dynamicElement", ""]], template: function TdDynamicFormsComponent_Template(rf, ctx) { if (rf & 1) {
198
- i0.ɵɵprojectionDef();
199
- i0.ɵɵelementStart(0, "form", 0);
200
- i0.ɵɵelementStart(1, "div", 1);
201
- i0.ɵɵtemplate(2, TdDynamicFormsComponent_ng_template_2_Template, 2, 9, "ng-template", 2);
202
- i0.ɵɵelementEnd();
203
- i0.ɵɵprojection(3);
204
- i0.ɵɵelementEnd();
205
- } if (rf & 2) {
206
- i0.ɵɵproperty("formGroup", ctx.dynamicForm);
207
- i0.ɵɵadvance(2);
208
- i0.ɵɵproperty("ngForOf", ctx.elements);
209
- } }, directives: [i1.ɵNgNoValidate, i1.NgControlStatusGroup, i1.FormGroupDirective, i3.NgForOf, i3.NgIf, i4.TdDynamicElementComponent, i1.NgControlStatus, i1.FormControlName, i1.RequiredValidator], styles: [".td-dynamic-form-wrapper[_ngcontent-%COMP%]{-ms-flex-flow:row wrap;flex-flow:row wrap;box-sizing:border-box;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-line-pack:center;align-content:center;max-width:100%;-ms-flex-pack:start;justify-content:flex-start}.td-dynamic-form-wrapper[_ngcontent-%COMP%] .mat-form-field-infix{width:auto}.td-dynamic-form-wrapper[_ngcontent-%COMP%] .td-dynamic-element-hint{font-size:75%;display:block}.td-dynamic-form-wrapper[_ngcontent-%COMP%] .td-dynamic-element-wrapper[_ngcontent-%COMP%]{max-height:100%;box-sizing:border-box;position:relative;padding:4px 4px 8px}"], changeDetection: 0 });
210
- (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TdDynamicFormsComponent, [{
211
- type: Component,
212
- args: [{ selector: 'td-dynamic-forms', changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"dynamicForm\" novalidate>\n <div class=\"td-dynamic-form-wrapper\">\n <ng-template let-element ngFor [ngForOf]=\"elements\">\n <div\n class=\"td-dynamic-element-wrapper\"\n [style.max-width.%]=\"element.flex ? element.flex : 100\"\n [style.flex]=\"'1 1 ' + (element.flex ? element.flex : 100) + '%'\"\n [style.-ms-flex]=\"'1 1 ' + (element.flex ? element.flex : 100) + '%'\"\n [style.-webkit-box-flex]=\"1\"\n >\n <td-dynamic-element\n #dynamicElement\n *ngIf=\"dynamicForm.controls[element.name]\"\n [formControlName]=\"element.name\"\n [dynamicControl]=\"dynamicForm.controls[element.name]\"\n [id]=\"element.name\"\n [name]=\"element.name\"\n [label]=\"element.label || element.name\"\n [hint]=\"element.hint\"\n [type]=\"element.type\"\n [required]=\"element.required\"\n [min]=\"element.min\"\n [max]=\"element.max\"\n [minLength]=\"element.minLength\"\n [maxLength]=\"element.maxLength\"\n [selections]=\"element.selections\"\n [multiple]=\"element.multiple\"\n [customConfig]=\"element.customConfig\"\n [errorMessageTemplate]=\"getErrorTemplateRef(element.name)\"\n [placeholder]=\"element.placeholder\"\n ></td-dynamic-element>\n </div>\n </ng-template>\n </div>\n <ng-content></ng-content>\n</form>\n", styles: [".td-dynamic-form-wrapper{-ms-flex-flow:row wrap;flex-flow:row wrap;box-sizing:border-box;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-line-pack:center;align-content:center;max-width:100%;-ms-flex-pack:start;justify-content:flex-start}.td-dynamic-form-wrapper ::ng-deep .mat-form-field-infix{width:auto}.td-dynamic-form-wrapper ::ng-deep .td-dynamic-element-hint{font-size:75%;display:block}.td-dynamic-form-wrapper .td-dynamic-element-wrapper{max-height:100%;box-sizing:border-box;position:relative;padding:4px 4px 8px}\n"] }]
213
- }], function () { return [{ type: i1.FormBuilder }, { type: i2.TdDynamicFormsService }, { type: i0.ChangeDetectorRef }]; }, { _errorTemplates: [{
214
- type: ContentChildren,
215
- args: [TdDynamicFormsErrorTemplateDirective, { descendants: true }]
216
- }], elements: [{
217
- type: Input,
218
- args: ['elements']
219
- }] }); })();
220
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-forms.component.js","sourceRoot":"","sources":["../../../../src/platform/dynamic-forms/dynamic-forms.component.ts","../../../../src/platform/dynamic-forms/dynamic-forms.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  ContentChildren,\n  TemplateRef,\n  QueryList,\n  AfterContentInit,\n  OnDestroy,\n} from '@angular/core';\nimport { FormGroup, FormBuilder, AbstractControl } from '@angular/forms';\n\nimport { TdDynamicFormsService, ITdDynamicElementConfig } from './services/dynamic-forms.service';\nimport { TdDynamicFormsErrorTemplateDirective } from './dynamic-element.component';\n\nimport { timer, Subject, Observable } from 'rxjs';\nimport { takeUntil, filter } from 'rxjs/operators';\n\n@Component({\n  selector: 'td-dynamic-forms',\n  templateUrl: './dynamic-forms.component.html',\n  styleUrls: ['./dynamic-forms.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TdDynamicFormsComponent implements AfterContentInit, OnDestroy {\n  private _renderedElements: ITdDynamicElementConfig[] = [];\n  private _elements: ITdDynamicElementConfig[];\n  private _templateMap: Map<string, TemplateRef<any>> = new Map<string, TemplateRef<any>>();\n  private _destroy$: Subject<any> = new Subject();\n  private _destroyControl$: Subject<string> = new Subject();\n\n  @ContentChildren(TdDynamicFormsErrorTemplateDirective, { descendants: true })\n  _errorTemplates: QueryList<TdDynamicFormsErrorTemplateDirective>;\n  dynamicForm: FormGroup;\n\n  /**\n   * elements: ITdDynamicElementConfig[]\n   * JS Object that will render the elements depending on its config.\n   * [name] property is required.\n   */\n  @Input('elements')\n  set elements(elements: ITdDynamicElementConfig[]) {\n    if (elements) {\n      this._elements = elements;\n    } else {\n      this._elements = [];\n    }\n    this._rerenderElements();\n  }\n  get elements(): ITdDynamicElementConfig[] {\n    return this._renderedElements;\n  }\n\n  /**\n   * Getter property for dynamic [FormGroup].\n   */\n  get form(): FormGroup {\n    return this.dynamicForm;\n  }\n\n  /**\n   * Getter property for [valid] of dynamic [FormGroup].\n   */\n  get valid(): boolean {\n    if (this.dynamicForm) {\n      return this.dynamicForm.valid;\n    }\n    return false;\n  }\n\n  /**\n   * Getter property for [value] of dynamic [FormGroup].\n   */\n  get value(): any {\n    if (this.dynamicForm) {\n      return this.dynamicForm.value;\n    }\n    return {};\n  }\n\n  /**\n   * Getter property for [errors] of dynamic [FormGroup].\n   */\n  get errors(): { [name: string]: any } {\n    if (this.dynamicForm) {\n      const errors: { [name: string]: any } = {};\n      for (const name of Object.keys(this.dynamicForm.controls)) {\n        errors[name] = this.dynamicForm.controls[name].errors;\n      }\n      return errors;\n    }\n    return {};\n  }\n\n  /**\n   * Getter property for [controls] of dynamic [FormGroup].\n   */\n  get controls(): { [key: string]: AbstractControl } {\n    if (this.dynamicForm) {\n      return this.dynamicForm.controls;\n    }\n    return {};\n  }\n\n  constructor(\n    private _formBuilder: FormBuilder,\n    private _dynamicFormsService: TdDynamicFormsService,\n    private _changeDetectorRef: ChangeDetectorRef,\n  ) {\n    this.dynamicForm = this._formBuilder.group({});\n  }\n\n  ngAfterContentInit(): void {\n    this._updateErrorTemplates();\n  }\n\n  ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n    this._destroyControl$.complete();\n  }\n\n  /**\n   * Refreshes the form and rerenders all validator/element modifications.\n   */\n  refresh(): void {\n    this._rerenderElements();\n    this._updateErrorTemplates();\n  }\n\n  /**\n   * Getter method for error template references\n   */\n  getErrorTemplateRef(name: string): TemplateRef<any> {\n    return this._templateMap.get(name);\n  }\n\n  /**\n   * Loads error templates and sets them in a map for faster access.\n   */\n  private _updateErrorTemplates(): void {\n    this._templateMap = new Map<string, TemplateRef<any>>();\n    for (const errorTemplate of this._errorTemplates.toArray()) {\n      this._templateMap.set(errorTemplate.tdDynamicFormsError, errorTemplate.templateRef);\n    }\n  }\n\n  private _rerenderElements(): void {\n    this._clearRemovedElements();\n    this._renderedElements = [];\n    const duplicates: string[] = [];\n    this._elements.forEach((elem: ITdDynamicElementConfig) => {\n      this._dynamicFormsService.validateDynamicElementName(elem.name);\n      if (duplicates.indexOf(elem.name) > -1) {\n        throw new Error(`Dynamic element name: \"${elem.name}\" is duplicated`);\n      }\n      duplicates.push(elem.name);\n      const dynamicElement: AbstractControl = this.dynamicForm.get(elem.name);\n      if (!dynamicElement) {\n        this.dynamicForm.addControl(elem.name, this._dynamicFormsService.createFormControl(elem));\n        this._subscribeToControlStatusChanges(elem.name);\n      } else {\n        dynamicElement.setValue(elem.default);\n        dynamicElement.markAsPristine();\n        dynamicElement.markAsUntouched();\n        if (elem.disabled) {\n          dynamicElement.disable();\n        } else {\n          dynamicElement.enable();\n        }\n        dynamicElement.setValidators(this._dynamicFormsService.createValidators(elem));\n      }\n      // copy objects so they are only changes when calling this method\n      this._renderedElements.push(Object.assign({}, elem));\n    });\n    // call a change detection since the whole form might change\n    this._changeDetectorRef.detectChanges();\n    timer()\n      .toPromise()\n      .then(() => {\n        // call a markForCheck so elements are rendered correctly in OnPush\n        this._changeDetectorRef.markForCheck();\n      });\n  }\n\n  private _clearRemovedElements(): void {\n    this._renderedElements = this._renderedElements.filter(\n      (renderedElement: ITdDynamicElementConfig) =>\n        !this._elements.some((element: ITdDynamicElementConfig) => element.name === renderedElement.name),\n    );\n    // remove elements that were removed from the array\n    this._renderedElements.forEach((elem: ITdDynamicElementConfig) => {\n      this._destroyControl$.next(elem.name);\n      this.dynamicForm.removeControl(elem.name);\n    });\n  }\n\n  // Updates component when manually adding errors to controls\n  private _subscribeToControlStatusChanges(elementName: string): void {\n    const control: AbstractControl = this.controls[elementName];\n\n    const controlDestroyed$: Observable<any> = this._destroyControl$.pipe(\n      filter((destroyedElementName: string) => destroyedElementName === elementName),\n    );\n\n    control.statusChanges.pipe(takeUntil(this._destroy$), takeUntil(controlDestroyed$)).subscribe(() => {\n      this._changeDetectorRef.markForCheck();\n    });\n  }\n}\n","<form [formGroup]=\"dynamicForm\" novalidate>\n  <div class=\"td-dynamic-form-wrapper\">\n    <ng-template let-element ngFor [ngForOf]=\"elements\">\n      <div\n        class=\"td-dynamic-element-wrapper\"\n        [style.max-width.%]=\"element.flex ? element.flex : 100\"\n        [style.flex]=\"'1 1 ' + (element.flex ? element.flex : 100) + '%'\"\n        [style.-ms-flex]=\"'1 1 ' + (element.flex ? element.flex : 100) + '%'\"\n        [style.-webkit-box-flex]=\"1\"\n      >\n        <td-dynamic-element\n          #dynamicElement\n          *ngIf=\"dynamicForm.controls[element.name]\"\n          [formControlName]=\"element.name\"\n          [dynamicControl]=\"dynamicForm.controls[element.name]\"\n          [id]=\"element.name\"\n          [name]=\"element.name\"\n          [label]=\"element.label || element.name\"\n          [hint]=\"element.hint\"\n          [type]=\"element.type\"\n          [required]=\"element.required\"\n          [min]=\"element.min\"\n          [max]=\"element.max\"\n          [minLength]=\"element.minLength\"\n          [maxLength]=\"element.maxLength\"\n          [selections]=\"element.selections\"\n          [multiple]=\"element.multiple\"\n          [customConfig]=\"element.customConfig\"\n          [errorMessageTemplate]=\"getErrorTemplateRef(element.name)\"\n          [placeholder]=\"element.placeholder\"\n        ></td-dynamic-element>\n      </div>\n    </ng-template>\n  </div>\n  <ng-content></ng-content>\n</form>\n"]}