@3kles/kles-material-dynamicforms 16.1.4 → 17.0.0

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 (46) hide show
  1. package/esm2022/lib/directive/dynamic-component.directive.mjs +5 -5
  2. package/esm2022/lib/directive/dynamic-field.directive.mjs +5 -5
  3. package/esm2022/lib/dynamic-form.component.mjs +19 -16
  4. package/esm2022/lib/fields/array.component.mjs +25 -21
  5. package/esm2022/lib/fields/badge.component.mjs +5 -5
  6. package/esm2022/lib/fields/button-form.component.mjs +3 -3
  7. package/esm2022/lib/fields/button-submit.component.mjs +5 -5
  8. package/esm2022/lib/fields/button-toogle-group.component.mjs +17 -15
  9. package/esm2022/lib/fields/buttonchecker-form.component.mjs +3 -3
  10. package/esm2022/lib/fields/buttonfile-form.component.mjs +3 -3
  11. package/esm2022/lib/fields/checkbox.component.mjs +33 -17
  12. package/esm2022/lib/fields/chip.component.mjs +11 -7
  13. package/esm2022/lib/fields/clear.component.mjs +4 -4
  14. package/esm2022/lib/fields/color.component.mjs +43 -23
  15. package/esm2022/lib/fields/date-time.component.mjs +39 -17
  16. package/esm2022/lib/fields/date.component.mjs +39 -17
  17. package/esm2022/lib/fields/field.abstract.mjs +5 -5
  18. package/esm2022/lib/fields/group.component.mjs +17 -13
  19. package/esm2022/lib/fields/icon.component.mjs +4 -4
  20. package/esm2022/lib/fields/input.clearable.component.mjs +95 -61
  21. package/esm2022/lib/fields/input.component.mjs +93 -59
  22. package/esm2022/lib/fields/label.component.mjs +4 -4
  23. package/esm2022/lib/fields/line-break.component.mjs +4 -4
  24. package/esm2022/lib/fields/link.component.mjs +4 -4
  25. package/esm2022/lib/fields/list-field.component.mjs +59 -38
  26. package/esm2022/lib/fields/radio.component.mjs +48 -16
  27. package/esm2022/lib/fields/range.component.mjs +33 -17
  28. package/esm2022/lib/fields/select.component.mjs +192 -134
  29. package/esm2022/lib/fields/select.lazy-search.component.mjs +194 -142
  30. package/esm2022/lib/fields/select.search.component.mjs +196 -136
  31. package/esm2022/lib/fields/selection-list.component.mjs +33 -27
  32. package/esm2022/lib/fields/slide-toggle.component.mjs +35 -17
  33. package/esm2022/lib/fields/text.component.mjs +5 -5
  34. package/esm2022/lib/fields/textarea.component.mjs +51 -23
  35. package/esm2022/lib/forms/button-control.component.mjs +21 -9
  36. package/esm2022/lib/forms/buttonchecker-control.component.mjs +57 -44
  37. package/esm2022/lib/forms/buttonfile-control.component.mjs +3 -3
  38. package/esm2022/lib/kles-material-dynamicforms.module.mjs +5 -5
  39. package/esm2022/lib/matcher/form-error.matcher.mjs +4 -4
  40. package/esm2022/lib/modules/material.module.mjs +4 -4
  41. package/esm2022/lib/pipe/array.pipe.mjs +3 -3
  42. package/esm2022/lib/pipe/transform.pipe.mjs +3 -3
  43. package/fesm2022/3kles-kles-material-dynamicforms.mjs +1411 -928
  44. package/fesm2022/3kles-kles-material-dynamicforms.mjs.map +1 -1
  45. package/lib/fields/radio.component.d.ts +2 -0
  46. package/package.json +12 -12
@@ -70,99 +70,133 @@ let KlesFormInputComponent = class KlesFormInputComponent extends KlesFieldAbstr
70
70
  ngOnDestroy() {
71
71
  super.ngOnDestroy();
72
72
  }
73
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: KlesFormInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
74
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: KlesFormInputComponent, selector: "kles-form-input", usesInheritance: true, ngImport: i0, template: `
73
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: KlesFormInputComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
74
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.2", type: KlesFormInputComponent, selector: "kles-form-input", usesInheritance: true, ngImport: i0, template: `
75
75
  <mat-form-field [formGroup]="group" [color]="field.color" class="form-element">
76
+ @if (field.label) {
77
+ <mat-label>{{field.label}}</mat-label>
78
+ }
76
79
 
77
- <ng-container *ngIf="field.autocomplete; else notAutoComplete">
80
+ @if (field.autocomplete) {
78
81
  <input matInput matTooltip="{{field.tooltip}}" [attr.id]="field.id" [ngClass]="field.ngClass" [formControlName]="field.name" [placeholder]="field.placeholder | translate" [type]="field.inputType"
79
82
  [maxLength]="field.maxLength" [min]="field.min" [max]="field.max" [step]="field.step"
80
83
  [matAutocomplete]="auto">
81
84
 
82
85
  <mat-autocomplete #auto="matAutocomplete" [displayWith]="displayFn.bind(this)" [panelWidth]="this.field.panelWidth">
83
- <ng-container *ngIf="!field.autocompleteComponent">
84
- <mat-option *ngFor="let option of filteredOption | async" [value]="option">
85
- {{field.property ? option[field.property] : option}}
86
- </mat-option>
87
- </ng-container>
88
-
89
- <ng-container *ngIf="field.autocompleteComponent">
90
- <mat-option *ngFor="let option of filteredOption | async" [value]="option">
91
- <ng-container klesComponent [component]="field.autocompleteComponent" [value]="option" [field]="field">
92
- </ng-container>
93
- </mat-option>
94
- </ng-container>
86
+ @if (!field.autocompleteComponent) {
87
+ @for (option of filteredOption | async; track option) {
88
+ <mat-option [value]="option">
89
+ {{field.property ? option[field.property] : option}}
90
+ </mat-option>
91
+ }
92
+ }
93
+ @else {
94
+ @for (option of filteredOption | async; track option) {
95
+ <mat-option [value]="option">
96
+ <ng-container klesComponent [component]="field.autocompleteComponent" [value]="option" [field]="field">
97
+ </ng-container>
98
+ </mat-option>
99
+ }
100
+ }
95
101
  </mat-autocomplete>
96
- </ng-container>
97
-
98
- <ng-template #notAutoComplete>
102
+ }
103
+ @else {
99
104
  <input matInput matTooltip="{{field.tooltip}}" [attr.id]="field.id" [ngClass]="field.ngClass" [formControlName]="field.name" [placeholder]="field.placeholder | translate" [type]="field.inputType"
100
105
  [maxLength]="field.maxLength" [min]="field.min" [max]="field.max" [step]="field.step">
101
- </ng-template>
106
+ }
102
107
 
103
- <mat-spinner matSuffix mode="indeterminate" *ngIf="isPending()" diameter="17"></mat-spinner>
108
+ @if (isPending()) {
109
+ <mat-spinner matSuffix mode="indeterminate" diameter="17"></mat-spinner>
110
+ }
104
111
 
105
- <div matSuffix *ngIf="field.subComponents || field.clearable">
106
- <ng-content></ng-content>
107
- </div>
112
+ @if (field.subComponents || field.clearable) {
113
+ <div matSuffix>
114
+ <ng-content></ng-content>
115
+ </div>
116
+ }
108
117
 
109
- <ng-container *ngFor="let validation of field.validations;" ngProjectAs="mat-error">
110
- <mat-error *ngIf="group.get(field.name).hasError(validation.name)">{{validation.message | translate}}</mat-error>
111
- </ng-container>
112
- <ng-container *ngFor="let validation of field.asyncValidations;" ngProjectAs="mat-error">
113
- <mat-error *ngIf="group.get(field.name).hasError(validation.name)">{{validation.message | translate}}</mat-error>
114
- </ng-container>
118
+ @for (validation of field.validations; track validation.name) {
119
+ <ng-container ngProjectAs="mat-error">
120
+ @if (group.get(field.name).hasError(validation.name)) {
121
+ <mat-error>{{validation.message | translate}}</mat-error>
122
+ }
123
+ </ng-container>
124
+ }
125
+ @for (validation of field.asyncValidations; track validation.name) {
126
+ <ng-container ngProjectAs="mat-error">
127
+ @if (group.get(field.name).hasError(validation.name)) {
128
+ <mat-error>{{validation.message | translate}}</mat-error>
129
+ }
130
+ </ng-container>
131
+ }
115
132
  </mat-form-field>
116
- `, isInline: true, styles: ["mat-form-field{width:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i7.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i8.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple", "hideSingleSelectionIndicator"], exportAs: ["matAutocomplete"] }, { kind: "directive", type: i8.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: i9.KlesComponentDirective, selector: "[klesComponent]", inputs: ["component", "value", "field"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }] }); }
133
+ `, isInline: true, styles: ["mat-form-field{width:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "component", type: i4.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLabel, selector: "mat-label" }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i4.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i5.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i6.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "component", type: i7.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i8.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "directive", type: i8.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: i9.KlesComponentDirective, selector: "[klesComponent]", inputs: ["component", "value", "field"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }] }); }
117
134
  };
118
135
  KlesFormInputComponent = __decorate([
119
136
  FieldMapper({ type: EnumType.input })
120
137
  ], KlesFormInputComponent);
121
138
  export { KlesFormInputComponent };
122
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: KlesFormInputComponent, decorators: [{
139
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: KlesFormInputComponent, decorators: [{
123
140
  type: Component,
124
141
  args: [{ selector: 'kles-form-input', template: `
125
142
  <mat-form-field [formGroup]="group" [color]="field.color" class="form-element">
143
+ @if (field.label) {
144
+ <mat-label>{{field.label}}</mat-label>
145
+ }
126
146
 
127
- <ng-container *ngIf="field.autocomplete; else notAutoComplete">
147
+ @if (field.autocomplete) {
128
148
  <input matInput matTooltip="{{field.tooltip}}" [attr.id]="field.id" [ngClass]="field.ngClass" [formControlName]="field.name" [placeholder]="field.placeholder | translate" [type]="field.inputType"
129
149
  [maxLength]="field.maxLength" [min]="field.min" [max]="field.max" [step]="field.step"
130
150
  [matAutocomplete]="auto">
131
151
 
132
152
  <mat-autocomplete #auto="matAutocomplete" [displayWith]="displayFn.bind(this)" [panelWidth]="this.field.panelWidth">
133
- <ng-container *ngIf="!field.autocompleteComponent">
134
- <mat-option *ngFor="let option of filteredOption | async" [value]="option">
135
- {{field.property ? option[field.property] : option}}
136
- </mat-option>
137
- </ng-container>
138
-
139
- <ng-container *ngIf="field.autocompleteComponent">
140
- <mat-option *ngFor="let option of filteredOption | async" [value]="option">
141
- <ng-container klesComponent [component]="field.autocompleteComponent" [value]="option" [field]="field">
142
- </ng-container>
143
- </mat-option>
144
- </ng-container>
153
+ @if (!field.autocompleteComponent) {
154
+ @for (option of filteredOption | async; track option) {
155
+ <mat-option [value]="option">
156
+ {{field.property ? option[field.property] : option}}
157
+ </mat-option>
158
+ }
159
+ }
160
+ @else {
161
+ @for (option of filteredOption | async; track option) {
162
+ <mat-option [value]="option">
163
+ <ng-container klesComponent [component]="field.autocompleteComponent" [value]="option" [field]="field">
164
+ </ng-container>
165
+ </mat-option>
166
+ }
167
+ }
145
168
  </mat-autocomplete>
146
- </ng-container>
147
-
148
- <ng-template #notAutoComplete>
169
+ }
170
+ @else {
149
171
  <input matInput matTooltip="{{field.tooltip}}" [attr.id]="field.id" [ngClass]="field.ngClass" [formControlName]="field.name" [placeholder]="field.placeholder | translate" [type]="field.inputType"
150
172
  [maxLength]="field.maxLength" [min]="field.min" [max]="field.max" [step]="field.step">
151
- </ng-template>
173
+ }
152
174
 
153
- <mat-spinner matSuffix mode="indeterminate" *ngIf="isPending()" diameter="17"></mat-spinner>
175
+ @if (isPending()) {
176
+ <mat-spinner matSuffix mode="indeterminate" diameter="17"></mat-spinner>
177
+ }
154
178
 
155
- <div matSuffix *ngIf="field.subComponents || field.clearable">
156
- <ng-content></ng-content>
157
- </div>
179
+ @if (field.subComponents || field.clearable) {
180
+ <div matSuffix>
181
+ <ng-content></ng-content>
182
+ </div>
183
+ }
158
184
 
159
- <ng-container *ngFor="let validation of field.validations;" ngProjectAs="mat-error">
160
- <mat-error *ngIf="group.get(field.name).hasError(validation.name)">{{validation.message | translate}}</mat-error>
161
- </ng-container>
162
- <ng-container *ngFor="let validation of field.asyncValidations;" ngProjectAs="mat-error">
163
- <mat-error *ngIf="group.get(field.name).hasError(validation.name)">{{validation.message | translate}}</mat-error>
164
- </ng-container>
185
+ @for (validation of field.validations; track validation.name) {
186
+ <ng-container ngProjectAs="mat-error">
187
+ @if (group.get(field.name).hasError(validation.name)) {
188
+ <mat-error>{{validation.message | translate}}</mat-error>
189
+ }
190
+ </ng-container>
191
+ }
192
+ @for (validation of field.asyncValidations; track validation.name) {
193
+ <ng-container ngProjectAs="mat-error">
194
+ @if (group.get(field.name).hasError(validation.name)) {
195
+ <mat-error>{{validation.message | translate}}</mat-error>
196
+ }
197
+ </ng-container>
198
+ }
165
199
  </mat-form-field>
166
200
  `, styles: ["mat-form-field{width:100%}\n"] }]
167
201
  }] });
168
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { KlesFieldAbstract } from './field.abstract';\nimport { OnInit, Component, OnDestroy } from '@angular/core';\nimport { Observable, of } from 'rxjs';\nimport { startWith, map, switchMap } from 'rxjs/operators';\nimport { EnumType } from '../enums/type.enum';\nimport { FieldMapper } from '../decorators/component.decorator';\n\n@FieldMapper({ type: EnumType.input })\n@Component({\n    selector: 'kles-form-input',\n    template: `\n    <mat-form-field [formGroup]=\"group\" [color]=\"field.color\" class=\"form-element\">\n\n        <ng-container *ngIf=\"field.autocomplete; else notAutoComplete\">\n            <input matInput matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\" [ngClass]=\"field.ngClass\" [formControlName]=\"field.name\" [placeholder]=\"field.placeholder | translate\" [type]=\"field.inputType\" \n            [maxLength]=\"field.maxLength\" [min]=\"field.min\" [max]=\"field.max\" [step]=\"field.step\"\n            [matAutocomplete]=\"auto\">\n\n            <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayFn.bind(this)\" [panelWidth]=\"this.field.panelWidth\">\n                <ng-container *ngIf=\"!field.autocompleteComponent\">\n                    <mat-option *ngFor=\"let option of filteredOption | async\" [value]=\"option\">\n                        {{field.property ? option[field.property] : option}}\n                    </mat-option>\n                </ng-container>\n\n                <ng-container *ngIf=\"field.autocompleteComponent\">\n                    <mat-option *ngFor=\"let option of filteredOption | async\" [value]=\"option\">\n                        <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"option\" [field]=\"field\">\n                        </ng-container>\n                    </mat-option>\n                </ng-container>\n            </mat-autocomplete>\n        </ng-container>\n\n        <ng-template #notAutoComplete>\n            <input matInput matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\" [ngClass]=\"field.ngClass\" [formControlName]=\"field.name\" [placeholder]=\"field.placeholder | translate\" [type]=\"field.inputType\"\n            [maxLength]=\"field.maxLength\" [min]=\"field.min\" [max]=\"field.max\" [step]=\"field.step\">\n        </ng-template>\n\n        <mat-spinner matSuffix mode=\"indeterminate\" *ngIf=\"isPending()\" diameter=\"17\"></mat-spinner>\n\n        <div matSuffix *ngIf=\"field.subComponents || field.clearable\">\n            <ng-content></ng-content>\n        </div>\n\n        <ng-container *ngFor=\"let validation of field.validations;\" ngProjectAs=\"mat-error\">\n            <mat-error *ngIf=\"group.get(field.name).hasError(validation.name)\">{{validation.message | translate}}</mat-error>\n        </ng-container>\n        <ng-container *ngFor=\"let validation of field.asyncValidations;\" ngProjectAs=\"mat-error\">\n            <mat-error *ngIf=\"group.get(field.name).hasError(validation.name)\">{{validation.message | translate}}</mat-error>\n        </ng-container>\n    </mat-form-field>\n    `,\n    styles: ['mat-form-field {width: calc(100%)}']\n})\nexport class KlesFormInputComponent extends KlesFieldAbstract implements OnInit, OnDestroy {\n\n    filteredOption: Observable<any[]>;\n    options$: Observable<any[]>;\n\n    ngOnInit(): void {\n\n        if (this.field.options instanceof Observable) {\n            this.options$ = this.field.options;\n        }\n        else if (this.field.options instanceof Function) {\n            this.options$ = this.field.options();\n        }\n        else {\n            this.options$ = of(this.field.options);\n        }\n\n\n        this.filteredOption = this.group.get(this.field.name).valueChanges\n            .pipe(\n                startWith(''),\n                // map(data => data ? this.filterData(data) : this.field.options.slice())\n                switchMap(data => data ? this.filterData(data) : this.options$)\n            );\n        if (!this.field.maxLength) {\n            this.field.maxLength = 524288; // Max default input W3C\n        }\n        super.ngOnInit();\n    }\n\n    isPending() {\n        return (this.group.controls[this.field.name].pending || this.field.pending);\n    }\n\n    private filterData(value: any): Observable<any[]> {\n        let filterValue;\n\n        if (typeof value === 'string' && Object.prototype.toString.call(value) === '[object String]') {\n            filterValue = value.toLowerCase();\n        } else {\n            filterValue = value[this.field.property].toLowerCase();\n        }\n\n        if (this.field.property) {\n            return this.options$\n                .pipe(map(options => options.filter(option => option[this.field.property].toLowerCase().indexOf(filterValue) === 0)));\n            // return this.field.options\n            //     .filter(data => data[this.field.property].toLowerCase().indexOf(filterValue) === 0);\n        }\n        // return this.field.options.filter(data => data.toLowerCase().indexOf(filterValue) === 0);\n        return this.options$.pipe(map(options => options.filter(option => option.toLowerCase().indexOf(filterValue) === 0)));\n    }\n\n    displayFn(value: any) {\n        if (this.field.displayWith) {\n            return this.field.displayWith(value);\n        } else {\n            if (value && this.field && this.field.property) {\n                return value[this.field.property] ? value[this.field.property] : '';\n            }\n            return value ? value : '';\n        }\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n}\n"]}
202
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { KlesFieldAbstract } from './field.abstract';\nimport { OnInit, Component, OnDestroy } from '@angular/core';\nimport { Observable, of } from 'rxjs';\nimport { startWith, map, switchMap } from 'rxjs/operators';\nimport { EnumType } from '../enums/type.enum';\nimport { FieldMapper } from '../decorators/component.decorator';\n\n@FieldMapper({ type: EnumType.input })\n@Component({\n    selector: 'kles-form-input',\n    template: `\n    <mat-form-field [formGroup]=\"group\" [color]=\"field.color\" class=\"form-element\">\n        @if (field.label) {\n            <mat-label>{{field.label}}</mat-label>\n        }\n\n        @if (field.autocomplete) {\n            <input matInput matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\" [ngClass]=\"field.ngClass\" [formControlName]=\"field.name\" [placeholder]=\"field.placeholder | translate\" [type]=\"field.inputType\" \n            [maxLength]=\"field.maxLength\" [min]=\"field.min\" [max]=\"field.max\" [step]=\"field.step\"\n            [matAutocomplete]=\"auto\">\n\n            <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayFn.bind(this)\" [panelWidth]=\"this.field.panelWidth\">\n                @if (!field.autocompleteComponent) {\n                    @for (option of filteredOption | async; track option) {\n                        <mat-option [value]=\"option\">\n                            {{field.property ? option[field.property] : option}}\n                        </mat-option>\n                    }\n                }\n                @else {\n                    @for (option of filteredOption | async; track option) {\n                        <mat-option [value]=\"option\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"option\" [field]=\"field\">\n                            </ng-container>\n                        </mat-option>\n                    }\n                }\n            </mat-autocomplete>\n        }\n        @else {\n            <input matInput matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\" [ngClass]=\"field.ngClass\" [formControlName]=\"field.name\" [placeholder]=\"field.placeholder | translate\" [type]=\"field.inputType\"\n            [maxLength]=\"field.maxLength\" [min]=\"field.min\" [max]=\"field.max\" [step]=\"field.step\">\n        }\n\n        @if (isPending()) {\n            <mat-spinner matSuffix mode=\"indeterminate\" diameter=\"17\"></mat-spinner>\n        }\n\n        @if (field.subComponents || field.clearable) {\n            <div matSuffix>\n                <ng-content></ng-content>\n            </div>\n        }\n\n        @for (validation of field.validations; track validation.name) {\n            <ng-container ngProjectAs=\"mat-error\">\n                @if (group.get(field.name).hasError(validation.name)) {\n                    <mat-error>{{validation.message | translate}}</mat-error>\n                }\n            </ng-container>\n        }\n        @for (validation of field.asyncValidations; track validation.name) {\n            <ng-container ngProjectAs=\"mat-error\">\n                @if (group.get(field.name).hasError(validation.name)) {\n                    <mat-error>{{validation.message | translate}}</mat-error>\n                }\n            </ng-container>\n        }\n    </mat-form-field>\n    `,\n    styles: ['mat-form-field {width: calc(100%)}']\n})\nexport class KlesFormInputComponent extends KlesFieldAbstract implements OnInit, OnDestroy {\n\n    filteredOption: Observable<any[]>;\n    options$: Observable<any[]>;\n\n    ngOnInit(): void {\n\n        if (this.field.options instanceof Observable) {\n            this.options$ = this.field.options;\n        }\n        else if (this.field.options instanceof Function) {\n            this.options$ = this.field.options();\n        }\n        else {\n            this.options$ = of(this.field.options);\n        }\n\n\n        this.filteredOption = this.group.get(this.field.name).valueChanges\n            .pipe(\n                startWith(''),\n                // map(data => data ? this.filterData(data) : this.field.options.slice())\n                switchMap(data => data ? this.filterData(data) : this.options$)\n            );\n        if (!this.field.maxLength) {\n            this.field.maxLength = 524288; // Max default input W3C\n        }\n        super.ngOnInit();\n    }\n\n    isPending() {\n        return (this.group.controls[this.field.name].pending || this.field.pending);\n    }\n\n    private filterData(value: any): Observable<any[]> {\n        let filterValue;\n\n        if (typeof value === 'string' && Object.prototype.toString.call(value) === '[object String]') {\n            filterValue = value.toLowerCase();\n        } else {\n            filterValue = value[this.field.property].toLowerCase();\n        }\n\n        if (this.field.property) {\n            return this.options$\n                .pipe(map(options => options.filter(option => option[this.field.property].toLowerCase().indexOf(filterValue) === 0)));\n            // return this.field.options\n            //     .filter(data => data[this.field.property].toLowerCase().indexOf(filterValue) === 0);\n        }\n        // return this.field.options.filter(data => data.toLowerCase().indexOf(filterValue) === 0);\n        return this.options$.pipe(map(options => options.filter(option => option.toLowerCase().indexOf(filterValue) === 0)));\n    }\n\n    displayFn(value: any) {\n        if (this.field.displayWith) {\n            return this.field.displayWith(value);\n        } else {\n            if (value && this.field && this.field.property) {\n                return value[this.field.property] ? value[this.field.property] : '';\n            }\n            return value ? value : '';\n        }\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n}\n"]}
@@ -14,16 +14,16 @@ export class KlesFormLabelComponent extends KlesFieldAbstract {
14
14
  ngOnDestroy() {
15
15
  super.ngOnDestroy();
16
16
  }
17
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: KlesFormLabelComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
18
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: KlesFormLabelComponent, selector: "kles-form-label", usesInheritance: true, ngImport: i0, template: `
17
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: KlesFormLabelComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
18
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: KlesFormLabelComponent, selector: "kles-form-label", usesInheritance: true, ngImport: i0, template: `
19
19
  <div [formGroup]="group" >
20
20
  <input matInput matTooltip="{{field.tooltip}}" [attr.id]="field.id"
21
21
  [ngClass]="field.ngClass"
22
22
  [ngStyle]="{'color':'inherit'}" [formControlName]="field.name" [placeholder]="field.placeholder | translate" [type]="field.inputType">
23
23
  </div>
24
- `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }] }); }
24
+ `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i3.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i4.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }] }); }
25
25
  }
26
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: KlesFormLabelComponent, decorators: [{
26
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: KlesFormLabelComponent, decorators: [{
27
27
  type: Component,
28
28
  args: [{
29
29
  selector: "kles-form-label",
@@ -9,15 +9,15 @@ let KlesFormLineBreakComponent = class KlesFormLineBreakComponent extends KlesFi
9
9
  ngOnDestroy() {
10
10
  super.ngOnDestroy();
11
11
  }
12
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: KlesFormLineBreakComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
13
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: KlesFormLineBreakComponent, selector: "kles-form-line-break", usesInheritance: true, ngImport: i0, template: ``, isInline: true, styles: [":host{flex-basis:100%;display:flex;height:0}\n"] }); }
12
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: KlesFormLineBreakComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
13
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: KlesFormLineBreakComponent, selector: "kles-form-line-break", usesInheritance: true, ngImport: i0, template: ``, isInline: true, styles: [":host{flex-basis:100%;display:flex;height:0}\n"] }); }
14
14
  };
15
15
  KlesFormLineBreakComponent = __decorate([
16
16
  FieldMapper({ type: EnumType.lineBreak })
17
17
  ], KlesFormLineBreakComponent);
18
18
  export { KlesFormLineBreakComponent };
19
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: KlesFormLineBreakComponent, decorators: [{
19
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: KlesFormLineBreakComponent, decorators: [{
20
20
  type: Component,
21
21
  args: [{ selector: 'kles-form-line-break', template: ``, styles: [":host{flex-basis:100%;display:flex;height:0}\n"] }]
22
22
  }] });
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluZS1icmVhay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rbGVzLW1hdGVyaWFsLWR5bmFtaWNmb3Jtcy9zcmMvbGliL2ZpZWxkcy9saW5lLWJyZWFrLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDN0QsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ2hFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFjOUMsSUFBTSwwQkFBMEIsR0FBaEMsTUFBTSwwQkFBMkIsU0FBUSxpQkFBaUI7SUFDN0QsUUFBUSxLQUFLLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDaEMsV0FBVztRQUNQLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUN4QixDQUFDOzhHQUpRLDBCQUEwQjtrR0FBMUIsMEJBQTBCLG1GQVR6QixFQUFFOztBQVNILDBCQUEwQjtJQVp0QyxXQUFXLENBQUMsRUFBRSxJQUFJLEVBQUUsUUFBUSxDQUFDLFNBQVMsRUFBRSxDQUFDO0dBWTdCLDBCQUEwQixDQUt0QztTQUxZLDBCQUEwQjsyRkFBMUIsMEJBQTBCO2tCQVh0QyxTQUFTOytCQUNJLHNCQUFzQixZQUN0QixFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkRlc3Ryb3ksIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmllbGRNYXBwZXIgfSBmcm9tICcuLi9kZWNvcmF0b3JzL2NvbXBvbmVudC5kZWNvcmF0b3InO1xuaW1wb3J0IHsgRW51bVR5cGUgfSBmcm9tICcuLi9lbnVtcy90eXBlLmVudW0nO1xuaW1wb3J0IHsgS2xlc0ZpZWxkQWJzdHJhY3QgfSBmcm9tICcuL2ZpZWxkLmFic3RyYWN0JztcblxuQEZpZWxkTWFwcGVyKHsgdHlwZTogRW51bVR5cGUubGluZUJyZWFrIH0pXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2tsZXMtZm9ybS1saW5lLWJyZWFrJyxcbiAgICB0ZW1wbGF0ZTogYGAsXG4gICAgc3R5bGVzOiBbXG4gICAgICAgIGA6aG9zdHtcbiAgICAgICAgICAgICAgICAgICAgIGZsZXgtYmFzaXM6IDEwMCU7XG4gICAgICAgICAgICAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgICAgICAgICAgICAgaGVpZ2h0OjA7XG4gICAgICAgICAgICAgICAgIH1gXG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBLbGVzRm9ybUxpbmVCcmVha0NvbXBvbmVudCBleHRlbmRzIEtsZXNGaWVsZEFic3RyYWN0IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICAgIG5nT25Jbml0KCkgeyBzdXBlci5uZ09uSW5pdCgpOyB9XG4gICAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgICAgIHN1cGVyLm5nT25EZXN0cm95KCk7XG4gICAgfVxufVxuIl19
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluZS1icmVhay5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9rbGVzLW1hdGVyaWFsLWR5bmFtaWNmb3Jtcy9zcmMvbGliL2ZpZWxkcy9saW5lLWJyZWFrLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBcUIsTUFBTSxlQUFlLENBQUM7QUFDN0QsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ2hFLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7QUFjOUMsSUFBTSwwQkFBMEIsR0FBaEMsTUFBTSwwQkFBMkIsU0FBUSxpQkFBaUI7SUFDN0QsUUFBUSxLQUFLLEtBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDaEMsV0FBVztRQUNQLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUN4QixDQUFDOzhHQUpRLDBCQUEwQjtrR0FBMUIsMEJBQTBCLG1GQVR6QixFQUFFOztBQVNILDBCQUEwQjtJQVp0QyxXQUFXLENBQUMsRUFBRSxJQUFJLEVBQUUsUUFBUSxDQUFDLFNBQVMsRUFBRSxDQUFDO0dBWTdCLDBCQUEwQixDQUt0Qzs7MkZBTFksMEJBQTBCO2tCQVh0QyxTQUFTOytCQUNJLHNCQUFzQixZQUN0QixFQUFFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkRlc3Ryb3ksIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRmllbGRNYXBwZXIgfSBmcm9tICcuLi9kZWNvcmF0b3JzL2NvbXBvbmVudC5kZWNvcmF0b3InO1xuaW1wb3J0IHsgRW51bVR5cGUgfSBmcm9tICcuLi9lbnVtcy90eXBlLmVudW0nO1xuaW1wb3J0IHsgS2xlc0ZpZWxkQWJzdHJhY3QgfSBmcm9tICcuL2ZpZWxkLmFic3RyYWN0JztcblxuQEZpZWxkTWFwcGVyKHsgdHlwZTogRW51bVR5cGUubGluZUJyZWFrIH0pXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ2tsZXMtZm9ybS1saW5lLWJyZWFrJyxcbiAgICB0ZW1wbGF0ZTogYGAsXG4gICAgc3R5bGVzOiBbXG4gICAgICAgIGA6aG9zdHtcbiAgICAgICAgICAgICAgICAgICAgIGZsZXgtYmFzaXM6IDEwMCU7XG4gICAgICAgICAgICAgICAgICAgICBkaXNwbGF5OiBmbGV4O1xuICAgICAgICAgICAgICAgICAgICAgaGVpZ2h0OjA7XG4gICAgICAgICAgICAgICAgIH1gXG4gICAgXVxufSlcbmV4cG9ydCBjbGFzcyBLbGVzRm9ybUxpbmVCcmVha0NvbXBvbmVudCBleHRlbmRzIEtsZXNGaWVsZEFic3RyYWN0IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xuICAgIG5nT25Jbml0KCkgeyBzdXBlci5uZ09uSW5pdCgpOyB9XG4gICAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XG4gICAgICAgIHN1cGVyLm5nT25EZXN0cm95KCk7XG4gICAgfVxufVxuIl19
@@ -10,14 +10,14 @@ export class KlesFormLinkComponent extends KlesFieldAbstract {
10
10
  ngOnDestroy() {
11
11
  super.ngOnDestroy();
12
12
  }
13
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: KlesFormLinkComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
14
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: KlesFormLinkComponent, selector: "kles-form-link", usesInheritance: true, ngImport: i0, template: `
13
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: KlesFormLinkComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
14
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.2", type: KlesFormLinkComponent, selector: "kles-form-link", usesInheritance: true, ngImport: i0, template: `
15
15
  <a [href]="group.controls[field.name].value" matTooltip="{{field.tooltip}}" [attr.id]="field.id" [ngClass]="field.ngClass">
16
16
  {{field.label}}
17
17
  </a>
18
- `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] }); }
18
+ `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.MatTooltip, selector: "[matTooltip]", inputs: ["matTooltipPosition", "matTooltipPositionAtOrigin", "matTooltipDisabled", "matTooltipShowDelay", "matTooltipHideDelay", "matTooltipTouchGestures", "matTooltip", "matTooltipClass"], exportAs: ["matTooltip"] }] }); }
19
19
  }
20
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: KlesFormLinkComponent, decorators: [{
20
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: KlesFormLinkComponent, decorators: [{
21
21
  type: Component,
22
22
  args: [{
23
23
  selector: 'kles-form-link',
@@ -6,12 +6,11 @@ import { FieldMapper } from '../decorators/component.decorator';
6
6
  import { KlesFormArray } from '../controls/array.control';
7
7
  import * as i0 from "@angular/core";
8
8
  import * as i1 from "@angular/forms";
9
- import * as i2 from "@angular/common";
10
- import * as i3 from "@angular/material/button";
11
- import * as i4 from "@angular/material/icon";
12
- import * as i5 from "@angular/material/form-field";
13
- import * as i6 from "../directive/dynamic-field.directive";
14
- import * as i7 from "@ngx-translate/core";
9
+ import * as i2 from "@angular/material/button";
10
+ import * as i3 from "@angular/material/icon";
11
+ import * as i4 from "@angular/material/form-field";
12
+ import * as i5 from "../directive/dynamic-field.directive";
13
+ import * as i6 from "@ngx-translate/core";
15
14
  let KlesFormListFieldComponent = class KlesFormListFieldComponent extends KlesFieldAbstract {
16
15
  constructor(fb, viewRef) {
17
16
  super(viewRef);
@@ -59,8 +58,8 @@ let KlesFormListFieldComponent = class KlesFormListFieldComponent extends KlesFi
59
58
  ngOnDestroy() {
60
59
  super.ngOnDestroy();
61
60
  }
62
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: KlesFormListFieldComponent, deps: [{ token: i1.UntypedFormBuilder }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
63
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.6", type: KlesFormListFieldComponent, selector: "kles-form-listfield", usesInheritance: true, ngImport: i0, template: `
61
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: KlesFormListFieldComponent, deps: [{ token: i1.UntypedFormBuilder }, { token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); }
62
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.2", type: KlesFormListFieldComponent, selector: "kles-form-listfield", usesInheritance: true, ngImport: i0, template: `
64
63
  <div [formGroup]="group" class="form-element">
65
64
  {{field.label | translate}}
66
65
  <button mat-icon-button color="primary" (click)="addField()">
@@ -68,29 +67,40 @@ let KlesFormListFieldComponent = class KlesFormListFieldComponent extends KlesFi
68
67
  </button>
69
68
 
70
69
  <div class="dynamic-form" [formGroupName]="field.name">
71
- <div *ngFor="let subGroup of formArray.controls let index = index;" class="subfields">
72
- <ng-container *ngFor="let subfield of field.collections;"
73
- klesDynamicField [field]="subfield" [group]="subGroup">
70
+ @for (subGroup of formArray.controls; track subGroup.value._id) {
71
+ <div class="subfields">
72
+ @for (subfield of field.collections; track subfield.name) {
73
+ <ng-container klesDynamicField [field]="subfield" [group]="subGroup">
74
+ </ng-container>
75
+ }
76
+ <button mat-icon-button (click)="deleteField($index)" color="primary">
77
+ <mat-icon>delete_outlined</mat-icon>
78
+ </button>
79
+ </div>
80
+ }
81
+ @for (validation of field.validations; track validation.name) {
82
+ <ng-container ngProjectAs="mat-error">
83
+ @if (group.get(field.name).hasError(validation.name)) {
84
+ <mat-error>{{validation.message | translate}}</mat-error>
85
+ }
74
86
  </ng-container>
75
- <button mat-icon-button (click)="deleteField(index)" color="primary">
76
- <mat-icon>delete_outlined</mat-icon>
77
- </button>
78
- </div>
79
- <ng-container *ngFor="let validation of field.validations;" ngProjectAs="mat-error">
80
- <mat-error *ngIf="group.get(field.name).hasError(validation.name)">{{validation.message | translate}}</mat-error>
81
- </ng-container>
82
- <ng-container *ngFor="let validation of field.asyncValidations;" ngProjectAs="mat-error">
83
- <mat-error *ngIf="group.get(field.name).hasError(validation.name)">{{validation.message | translate}}</mat-error>
84
- </ng-container>
87
+ }
88
+ @for (validation of field.asyncValidations; track validation.name) {
89
+ <ng-container ngProjectAs="mat-error">
90
+ @if (group.get(field.name).hasError(validation.name)) {
91
+ <mat-error>{{validation.message | translate}}</mat-error>
92
+ }
93
+ </ng-container>
94
+ }
85
95
  </div>
86
96
  </div>
87
- `, isInline: true, styles: [".subfields{display:flex;flex-direction:row;gap:5px}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "component", type: i3.MatIconButton, selector: "button[mat-icon-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i6.KlesDynamicFieldDirective, selector: "[klesDynamicField]", inputs: ["field", "group", "siblingFields"] }, { kind: "pipe", type: i7.TranslatePipe, name: "translate" }] }); }
97
+ `, isInline: true, styles: [".subfields{display:flex;flex-direction:row;gap:5px}\n"], dependencies: [{ kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormGroupName, selector: "[formGroupName]", inputs: ["formGroupName"] }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i4.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i5.KlesDynamicFieldDirective, selector: "[klesDynamicField]", inputs: ["field", "group", "siblingFields"] }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }] }); }
88
98
  };
89
99
  KlesFormListFieldComponent = __decorate([
90
100
  FieldMapper({ type: 'listfield', factory: (field) => (new KlesFormArray(field).create()) })
91
101
  ], KlesFormListFieldComponent);
92
102
  export { KlesFormListFieldComponent };
93
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImport: i0, type: KlesFormListFieldComponent, decorators: [{
103
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: KlesFormListFieldComponent, decorators: [{
94
104
  type: Component,
95
105
  args: [{ selector: 'kles-form-listfield', template: `
96
106
  <div [formGroup]="group" class="form-element">
@@ -100,22 +110,33 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.6", ngImpor
100
110
  </button>
101
111
 
102
112
  <div class="dynamic-form" [formGroupName]="field.name">
103
- <div *ngFor="let subGroup of formArray.controls let index = index;" class="subfields">
104
- <ng-container *ngFor="let subfield of field.collections;"
105
- klesDynamicField [field]="subfield" [group]="subGroup">
113
+ @for (subGroup of formArray.controls; track subGroup.value._id) {
114
+ <div class="subfields">
115
+ @for (subfield of field.collections; track subfield.name) {
116
+ <ng-container klesDynamicField [field]="subfield" [group]="subGroup">
117
+ </ng-container>
118
+ }
119
+ <button mat-icon-button (click)="deleteField($index)" color="primary">
120
+ <mat-icon>delete_outlined</mat-icon>
121
+ </button>
122
+ </div>
123
+ }
124
+ @for (validation of field.validations; track validation.name) {
125
+ <ng-container ngProjectAs="mat-error">
126
+ @if (group.get(field.name).hasError(validation.name)) {
127
+ <mat-error>{{validation.message | translate}}</mat-error>
128
+ }
129
+ </ng-container>
130
+ }
131
+ @for (validation of field.asyncValidations; track validation.name) {
132
+ <ng-container ngProjectAs="mat-error">
133
+ @if (group.get(field.name).hasError(validation.name)) {
134
+ <mat-error>{{validation.message | translate}}</mat-error>
135
+ }
106
136
  </ng-container>
107
- <button mat-icon-button (click)="deleteField(index)" color="primary">
108
- <mat-icon>delete_outlined</mat-icon>
109
- </button>
110
- </div>
111
- <ng-container *ngFor="let validation of field.validations;" ngProjectAs="mat-error">
112
- <mat-error *ngIf="group.get(field.name).hasError(validation.name)">{{validation.message | translate}}</mat-error>
113
- </ng-container>
114
- <ng-container *ngFor="let validation of field.asyncValidations;" ngProjectAs="mat-error">
115
- <mat-error *ngIf="group.get(field.name).hasError(validation.name)">{{validation.message | translate}}</mat-error>
116
- </ng-container>
137
+ }
117
138
  </div>
118
139
  </div>
119
140
  `, styles: [".subfields{display:flex;flex-direction:row;gap:5px}\n"] }]
120
- }], ctorParameters: function () { return [{ type: i1.UntypedFormBuilder }, { type: i0.ViewContainerRef }]; } });
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-field.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/list-field.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';\nimport { KlesFieldAbstract } from './field.abstract';\nimport { UntypedFormGroup, UntypedFormArray, UntypedFormBuilder, ValidatorFn, Validators, AsyncValidatorFn } from '@angular/forms';\nimport { IKlesValidator } from '../interfaces/validator.interface';\nimport { FieldMapper } from '../decorators/component.decorator';\nimport { KlesFormArray } from '../controls/array.control';\n\n@FieldMapper({ type: 'listfield', factory: (field) => (new KlesFormArray(field).create()) })\n@Component({\n    selector: 'kles-form-listfield',\n    template: `\n    <div [formGroup]=\"group\" class=\"form-element\">\n        {{field.label | translate}}\n        <button mat-icon-button color=\"primary\" (click)=\"addField()\">\n            <mat-icon>add</mat-icon>\n        </button>\n\n        <div class=\"dynamic-form\" [formGroupName]=\"field.name\">\n            <div *ngFor=\"let subGroup of formArray.controls let index = index;\" class=\"subfields\">\n                <ng-container *ngFor=\"let subfield of field.collections;\"\n                    klesDynamicField [field]=\"subfield\" [group]=\"subGroup\">\n                </ng-container>\n                <button mat-icon-button (click)=\"deleteField(index)\" color=\"primary\">\n                    <mat-icon>delete_outlined</mat-icon>\n                </button>\n            </div>\n            <ng-container *ngFor=\"let validation of field.validations;\" ngProjectAs=\"mat-error\">\n                <mat-error *ngIf=\"group.get(field.name).hasError(validation.name)\">{{validation.message | translate}}</mat-error>\n            </ng-container>\n            <ng-container *ngFor=\"let validation of field.asyncValidations;\" ngProjectAs=\"mat-error\">\n                <mat-error *ngIf=\"group.get(field.name).hasError(validation.name)\">{{validation.message | translate}}</mat-error>\n            </ng-container>\n        </div>\n    </div>\n    `,\n    styles: ['.subfields {display: flex; flex-direction: row; gap:5px}',]\n})\nexport class KlesFormListFieldComponent extends KlesFieldAbstract implements OnInit, OnDestroy {\n\n    formArray: UntypedFormArray;\n\n    constructor(private fb: UntypedFormBuilder, protected viewRef: ViewContainerRef) {\n        super(viewRef);\n    }\n\n    ngOnInit(): void {\n        this.formArray = this.group.controls[this.field.name] as UntypedFormArray;\n        super.ngOnInit();\n    }\n\n    private createFormGroup(): UntypedFormGroup {\n        const group = this.fb.group({});\n        this.field.collections.forEach(item => {\n            const control = this.fb.control(\n                null,\n                this.bindValidations(item.validations || []),\n                this.bindAsyncValidations(item.asyncValidations || [])\n            );\n            group.addControl(item.name, control);\n\n        });\n\n        return group;\n\n    }\n\n    deleteField(index: number) {\n        this.formArray.removeAt(index);\n    }\n\n    addField() {\n        this.formArray.push(this.createFormGroup());\n    }\n\n\n    private bindValidations(validations: IKlesValidator<ValidatorFn>[]): ValidatorFn {\n        if (validations.length > 0) {\n            const validList = [];\n            validations.forEach(valid => {\n                validList.push(valid.validator);\n            });\n            return Validators.compose(validList);\n\n        }\n        return null;\n    }\n\n\n    private bindAsyncValidations(validations: IKlesValidator<AsyncValidatorFn>[]): AsyncValidatorFn {\n        if (validations.length > 0) {\n            const validList = [];\n            validations.forEach(valid => {\n                validList.push(valid.validator);\n            });\n            return Validators.composeAsync(validList);\n\n        }\n        return null;\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n}\n\n"]}
141
+ }], ctorParameters: () => [{ type: i1.UntypedFormBuilder }, { type: i0.ViewContainerRef }] });
142
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-field.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/list-field.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAuC,MAAM,eAAe,CAAC;AAC/E,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AACrD,OAAO,EAAuE,UAAU,EAAoB,MAAM,gBAAgB,CAAC;AAEnI,OAAO,EAAE,WAAW,EAAE,MAAM,mCAAmC,CAAC;AAChE,OAAO,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;;;;;;;;AA2CnD,IAAM,0BAA0B,GAAhC,MAAM,0BAA2B,SAAQ,iBAAiB;IAI7D,YAAoB,EAAsB,EAAY,OAAyB;QAC3E,KAAK,CAAC,OAAO,CAAC,CAAC;QADC,OAAE,GAAF,EAAE,CAAoB;QAAY,YAAO,GAAP,OAAO,CAAkB;IAE/E,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAqB,CAAC;QAC1E,KAAK,CAAC,QAAQ,EAAE,CAAC;IACrB,CAAC;IAEO,eAAe;QACnB,MAAM,KAAK,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAChC,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAClC,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAC3B,IAAI,EACJ,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,WAAW,IAAI,EAAE,CAAC,EAC5C,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,gBAAgB,IAAI,EAAE,CAAC,CACzD,CAAC;YACF,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QAEzC,CAAC,CAAC,CAAC;QAEH,OAAO,KAAK,CAAC;IAEjB,CAAC;IAED,WAAW,CAAC,KAAa;QACrB,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;IAChD,CAAC;IAGO,eAAe,CAAC,WAA0C;QAC9D,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;YACxB,MAAM,SAAS,GAAG,EAAE,CAAC;YACrB,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;gBACxB,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YACpC,CAAC,CAAC,CAAC;YACH,OAAO,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;SAExC;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAGO,oBAAoB,CAAC,WAA+C;QACxE,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE;YACxB,MAAM,SAAS,GAAG,EAAE,CAAC;YACrB,WAAW,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;gBACxB,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;YACpC,CAAC,CAAC,CAAC;YACH,OAAO,UAAU,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;SAE7C;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;IAED,WAAW;QACP,KAAK,CAAC,WAAW,EAAE,CAAC;IACxB,CAAC;8GAjEQ,0BAA0B;kGAA1B,0BAA0B,kFAtCzB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAmCT;;AAGQ,0BAA0B;IAzCtC,WAAW,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,IAAI,aAAa,CAAC,KAAK,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,CAAC;GAyC/E,0BAA0B,CAkEtC;;2FAlEY,0BAA0B;kBAxCtC,SAAS;+BACI,qBAAqB,YACrB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAmCT","sourcesContent":["import { Component, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';\nimport { KlesFieldAbstract } from './field.abstract';\nimport { UntypedFormGroup, UntypedFormArray, UntypedFormBuilder, ValidatorFn, Validators, AsyncValidatorFn } from '@angular/forms';\nimport { IKlesValidator } from '../interfaces/validator.interface';\nimport { FieldMapper } from '../decorators/component.decorator';\nimport { KlesFormArray } from '../controls/array.control';\n\n@FieldMapper({ type: 'listfield', factory: (field) => (new KlesFormArray(field).create()) })\n@Component({\n    selector: 'kles-form-listfield',\n    template: `\n    <div [formGroup]=\"group\" class=\"form-element\">\n        {{field.label | translate}}\n        <button mat-icon-button color=\"primary\" (click)=\"addField()\">\n            <mat-icon>add</mat-icon>\n        </button>\n\n        <div class=\"dynamic-form\" [formGroupName]=\"field.name\">\n            @for (subGroup of formArray.controls; track subGroup.value._id) {\n                <div class=\"subfields\">\n                    @for (subfield of field.collections; track subfield.name) {\n                        <ng-container klesDynamicField [field]=\"subfield\" [group]=\"subGroup\">\n                        </ng-container>\n                    }\n                    <button mat-icon-button (click)=\"deleteField($index)\" color=\"primary\">\n                        <mat-icon>delete_outlined</mat-icon>\n                    </button>\n                </div>\n            }\n            @for (validation of field.validations; track validation.name) {\n                <ng-container ngProjectAs=\"mat-error\">\n                    @if (group.get(field.name).hasError(validation.name)) {\n                        <mat-error>{{validation.message | translate}}</mat-error>\n                    }\n                </ng-container>\n            }\n            @for (validation of field.asyncValidations; track validation.name) {\n                <ng-container ngProjectAs=\"mat-error\">\n                    @if (group.get(field.name).hasError(validation.name)) {\n                        <mat-error>{{validation.message | translate}}</mat-error>\n                    }\n                </ng-container>\n            }\n        </div>\n    </div>\n    `,\n    styles: ['.subfields {display: flex; flex-direction: row; gap:5px}',]\n})\nexport class KlesFormListFieldComponent extends KlesFieldAbstract implements OnInit, OnDestroy {\n\n    formArray: UntypedFormArray;\n\n    constructor(private fb: UntypedFormBuilder, protected viewRef: ViewContainerRef) {\n        super(viewRef);\n    }\n\n    ngOnInit(): void {\n        this.formArray = this.group.controls[this.field.name] as UntypedFormArray;\n        super.ngOnInit();\n    }\n\n    private createFormGroup(): UntypedFormGroup {\n        const group = this.fb.group({});\n        this.field.collections.forEach(item => {\n            const control = this.fb.control(\n                null,\n                this.bindValidations(item.validations || []),\n                this.bindAsyncValidations(item.asyncValidations || [])\n            );\n            group.addControl(item.name, control);\n\n        });\n\n        return group;\n\n    }\n\n    deleteField(index: number) {\n        this.formArray.removeAt(index);\n    }\n\n    addField() {\n        this.formArray.push(this.createFormGroup());\n    }\n\n\n    private bindValidations(validations: IKlesValidator<ValidatorFn>[]): ValidatorFn {\n        if (validations.length > 0) {\n            const validList = [];\n            validations.forEach(valid => {\n                validList.push(valid.validator);\n            });\n            return Validators.compose(validList);\n\n        }\n        return null;\n    }\n\n\n    private bindAsyncValidations(validations: IKlesValidator<AsyncValidatorFn>[]): AsyncValidatorFn {\n        if (validations.length > 0) {\n            const validList = [];\n            validations.forEach(valid => {\n                validList.push(valid.validator);\n            });\n            return Validators.composeAsync(validList);\n\n        }\n        return null;\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n}\n\n"]}