@3kles/kles-material-dynamicforms 17.6.1 → 17.7.1

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 (60) hide show
  1. package/esm2022/lib/controls/default.control.mjs +3 -6
  2. package/esm2022/lib/directive/dynamic-component.directive.mjs +3 -3
  3. package/esm2022/lib/directive/dynamic-field.directive.mjs +3 -3
  4. package/esm2022/lib/directive/mat-error-message.directive.mjs +53 -0
  5. package/esm2022/lib/dynamic-form.component.mjs +3 -3
  6. package/esm2022/lib/fields/array.component.mjs +3 -3
  7. package/esm2022/lib/fields/badge.component.mjs +3 -3
  8. package/esm2022/lib/fields/button-fab.component.mjs +3 -3
  9. package/esm2022/lib/fields/button-form.component.mjs +3 -3
  10. package/esm2022/lib/fields/button-icon.component.mjs +3 -3
  11. package/esm2022/lib/fields/button-mini-fab.component.mjs +3 -3
  12. package/esm2022/lib/fields/button-toogle-group.component.mjs +3 -3
  13. package/esm2022/lib/fields/buttonchecker-form.component.mjs +3 -3
  14. package/esm2022/lib/fields/buttonfile-form.component.mjs +3 -3
  15. package/esm2022/lib/fields/checkbox.component.mjs +8 -37
  16. package/esm2022/lib/fields/chip.component.mjs +3 -3
  17. package/esm2022/lib/fields/clear.component.mjs +3 -3
  18. package/esm2022/lib/fields/color.component.mjs +9 -34
  19. package/esm2022/lib/fields/date-time.component.mjs +12 -37
  20. package/esm2022/lib/fields/date.component.mjs +13 -38
  21. package/esm2022/lib/fields/field.abstract.mjs +3 -3
  22. package/esm2022/lib/fields/group.component.mjs +3 -3
  23. package/esm2022/lib/fields/icon.component.mjs +3 -3
  24. package/esm2022/lib/fields/input.clearable.component.mjs +9 -34
  25. package/esm2022/lib/fields/input.component.mjs +11 -34
  26. package/esm2022/lib/fields/label.component.mjs +5 -5
  27. package/esm2022/lib/fields/line-break.component.mjs +3 -3
  28. package/esm2022/lib/fields/link.component.mjs +3 -3
  29. package/esm2022/lib/fields/list-field.component.mjs +3 -3
  30. package/esm2022/lib/fields/radio.component.mjs +7 -37
  31. package/esm2022/lib/fields/range.component.mjs +9 -34
  32. package/esm2022/lib/fields/select.component.mjs +10 -35
  33. package/esm2022/lib/fields/select.lazy-search.component.mjs +10 -35
  34. package/esm2022/lib/fields/select.search.component.mjs +10 -35
  35. package/esm2022/lib/fields/selection-list.component.mjs +3 -3
  36. package/esm2022/lib/fields/selection-list.search.component.mjs +3 -3
  37. package/esm2022/lib/fields/slide-toggle.component.mjs +8 -39
  38. package/esm2022/lib/fields/text.component.mjs +3 -3
  39. package/esm2022/lib/fields/textarea.component.mjs +9 -34
  40. package/esm2022/lib/forms/button-control-base.mjs +3 -3
  41. package/esm2022/lib/forms/button-control.component.mjs +3 -3
  42. package/esm2022/lib/forms/buttonchecker-control.component.mjs +3 -3
  43. package/esm2022/lib/forms/buttonfile-control.component.mjs +3 -3
  44. package/esm2022/lib/forms/fab-control.component.mjs +3 -3
  45. package/esm2022/lib/forms/icon-button-control.component.mjs +3 -3
  46. package/esm2022/lib/forms/mini-fab-control.component.mjs +3 -3
  47. package/esm2022/lib/interfaces/validator.interface.mjs +1 -1
  48. package/esm2022/lib/kles-material-dynamicforms.module.mjs +9 -8
  49. package/esm2022/lib/matcher/form-error.matcher.mjs +3 -3
  50. package/esm2022/lib/modules/material.module.mjs +4 -4
  51. package/esm2022/lib/pipe/array.pipe.mjs +3 -3
  52. package/esm2022/lib/pipe/transform.pipe.mjs +3 -3
  53. package/esm2022/public-api.mjs +2 -1
  54. package/fesm2022/3kles-kles-material-dynamicforms.mjs +267 -565
  55. package/fesm2022/3kles-kles-material-dynamicforms.mjs.map +1 -1
  56. package/lib/directive/mat-error-message.directive.d.ts +16 -0
  57. package/lib/interfaces/validator.interface.d.ts +1 -1
  58. package/lib/kles-material-dynamicforms.module.d.ts +13 -11
  59. package/package.json +1 -1
  60. package/public-api.d.ts +1 -0
@@ -17,8 +17,9 @@ import * as i6 from "@angular/material/tooltip";
17
17
  import * as i7 from "@angular/material/progress-spinner";
18
18
  import * as i8 from "@angular/cdk/scrolling";
19
19
  import * as i9 from "../directive/dynamic-component.directive";
20
- import * as i10 from "@ngx-translate/core";
21
- import * as i11 from "../pipe/transform.pipe";
20
+ import * as i10 from "../directive/mat-error-message.directive";
21
+ import * as i11 from "@ngx-translate/core";
22
+ import * as i12 from "../pipe/transform.pipe";
22
23
  let KlesFormSelectComponent = class KlesFormSelectComponent extends KlesFieldAbstract {
23
24
  constructor(viewRef, ref) {
24
25
  super(viewRef);
@@ -115,8 +116,8 @@ let KlesFormSelectComponent = class KlesFormSelectComponent extends KlesFieldAbs
115
116
  }
116
117
  }
117
118
  }
118
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: KlesFormSelectComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
119
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: KlesFormSelectComponent, selector: "kles-form-select", viewQueries: [{ propertyName: "cdkVirtualScrollViewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true }, { propertyName: "options", predicate: MatOption, descendants: true }], usesInheritance: true, ngImport: i0, template: `
119
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: KlesFormSelectComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
120
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.7", type: KlesFormSelectComponent, selector: "kles-form-select", viewQueries: [{ propertyName: "cdkVirtualScrollViewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true }, { propertyName: "options", predicate: MatOption, descendants: true }], usesInheritance: true, ngImport: i0, template: `
120
121
  <mat-form-field [subscriptSizing]="field.subscriptSizing" class="margin-top" [color]="field.color" [formGroup]="group" [appearance]="field.appearance">
121
122
  @if (field.label) {
122
123
  <mat-label>{{field.label}}</mat-label>
@@ -224,28 +225,15 @@ let KlesFormSelectComponent = class KlesFormSelectComponent extends KlesFieldAbs
224
225
  </div>
225
226
  }
226
227
 
227
- @for (validation of field.validations; track validation.name) {
228
- <ng-container ngProjectAs="mat-error">
229
- @if (group.get(field.name).hasError(validation.name)) {
230
- <mat-error>{{validation.message | translate}}</mat-error>
231
- }
232
- </ng-container>
233
- }
234
- @for (validation of field.asyncValidations; track validation.name) {
235
- <ng-container ngProjectAs="mat-error">
236
- @if (group.get(field.name).hasError(validation.name)) {
237
- <mat-error>{{validation.message | translate}}</mat-error>
238
- }
239
- </ng-container>
240
- }
228
+ <mat-error matErrorMessage [validations]="field.validations" [asyncValidations]="field.asyncValidations"></mat-error>
241
229
  </mat-form-field>
242
- `, isInline: true, styles: [".loadingSelect{display:flex;flex-direction:row;justify-content:space-between;align-items:center}\n", "mat-form-field{width:100%}\n", "::ng-deep .hide-checkbox .mat-pseudo-checkbox{display:none!important}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "directive", type: i4.MatSelectTrigger, selector: "mat-select-trigger" }, { 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: "directive", type: i8.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: i8.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i8.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "directive", type: i9.KlesComponentDirective, selector: "[klesComponent]", inputs: ["component", "value", "field"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.SlicePipe, name: "slice" }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }, { kind: "pipe", type: i11.KlesTransformPipe, name: "klesTransform" }] }); }
230
+ `, isInline: true, styles: [".loadingSelect{display:flex;flex-direction:row;justify-content:space-between;align-items:center}\n", "mat-form-field{width:100%}\n", "::ng-deep .hide-checkbox .mat-pseudo-checkbox{display:none!important}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "directive", type: i4.MatSelectTrigger, selector: "mat-select-trigger" }, { 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: "directive", type: i8.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: i8.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i8.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "directive", type: i9.KlesComponentDirective, selector: "[klesComponent]", inputs: ["component", "value", "field"] }, { kind: "component", type: i10.MatErrorMessageDirective, selector: "[matErrorMessage]", inputs: ["validations", "asyncValidations"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.SlicePipe, name: "slice" }, { kind: "pipe", type: i11.TranslatePipe, name: "translate" }, { kind: "pipe", type: i12.KlesTransformPipe, name: "klesTransform" }] }); }
243
231
  };
244
232
  KlesFormSelectComponent = __decorate([
245
233
  FieldMapper({ type: EnumType.select })
246
234
  ], KlesFormSelectComponent);
247
235
  export { KlesFormSelectComponent };
248
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: KlesFormSelectComponent, decorators: [{
236
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: KlesFormSelectComponent, decorators: [{
249
237
  type: Component,
250
238
  args: [{ selector: 'kles-form-select', template: `
251
239
  <mat-form-field [subscriptSizing]="field.subscriptSizing" class="margin-top" [color]="field.color" [formGroup]="group" [appearance]="field.appearance">
@@ -355,20 +343,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
355
343
  </div>
356
344
  }
357
345
 
358
- @for (validation of field.validations; track validation.name) {
359
- <ng-container ngProjectAs="mat-error">
360
- @if (group.get(field.name).hasError(validation.name)) {
361
- <mat-error>{{validation.message | translate}}</mat-error>
362
- }
363
- </ng-container>
364
- }
365
- @for (validation of field.asyncValidations; track validation.name) {
366
- <ng-container ngProjectAs="mat-error">
367
- @if (group.get(field.name).hasError(validation.name)) {
368
- <mat-error>{{validation.message | translate}}</mat-error>
369
- }
370
- </ng-container>
371
- }
346
+ <mat-error matErrorMessage [validations]="field.validations" [asyncValidations]="field.asyncValidations"></mat-error>
372
347
  </mat-form-field>
373
348
  `, styles: [".loadingSelect{display:flex;flex-direction:row;justify-content:space-between;align-items:center}\n", "mat-form-field{width:100%}\n", "::ng-deep .hide-checkbox .mat-pseudo-checkbox{display:none!important}\n"] }]
374
349
  }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }], propDecorators: { cdkVirtualScrollViewport: [{
@@ -378,4 +353,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
378
353
  type: ViewChildren,
379
354
  args: [MatOption]
380
355
  }] } });
381
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\nimport { ChangeDetectorRef, Component, OnDestroy, OnInit, QueryList, ViewChild, ViewChildren, ViewContainerRef } from '@angular/core';\nimport { MatOption } from '@angular/material/core';\nimport { BehaviorSubject, Observable, of, Subject } from 'rxjs';\nimport { switchMap, take, takeUntil } from 'rxjs/operators';\nimport { FieldMapper } from '../decorators/component.decorator';\nimport { EnumType } from '../enums/type.enum';\nimport { KlesFieldAbstract } from './field.abstract';\n\n@FieldMapper({ type: EnumType.select })\n@Component({\n    selector: 'kles-form-select',\n    template: `\n    <mat-form-field [subscriptSizing]=\"field.subscriptSizing\" class=\"margin-top\" [color]=\"field.color\" [formGroup]=\"group\" [appearance]=\"field.appearance\">\n        @if (field.label) {\n            <mat-label>{{field.label}}</mat-label>\n        }\n        <mat-select matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\"\n        (openedChange)=\"openChange($event)\" [compareWith]=\"compareFn\" [panelWidth]=\"field.panelWidth || 'auto'\"\n        [ngClass]=\"field.ngClass\" [placeholder]=\"field.placeholder | translate\" [formControlName]=\"field.name\" [multiple]=\"field.multiple\">\n\n        @if (field.triggerComponent) {\n            <mat-select-trigger>\n                <ng-container klesComponent [component]=\"field.triggerComponent\" [value]=\"group.controls[field.name].value\" [field]=\"field\"></ng-container>\n            </mat-select-trigger>\n        }\n\n        @if (!field.virtualScroll) {\n            @if (!field.autocompleteComponent) {\n                @if (!isLoading) {\n                    @for (item of options$ | async; track item) {\n                        <mat-option [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n                    }\n                }\n                @else {\n                    <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                }\n            }\n            @else {\n                @if (!isLoading) {\n                    @for (item of options$ | async; track item) {\n                        <mat-option [value]=\"item\" [disabled]=\"item?.disabled\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                        </mat-option>\n                    }\n                }\n                @else {\n                    <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                }\n            }\n        }\n        @else {\n            <cdk-virtual-scroll-viewport [itemSize]=\"field.itemSize || 50\" [style.height.px]=5*48>\n                @if (!field.autocompleteComponent) {\n                    @if (!isLoading) {\n                        <mat-option *cdkVirtualFor=\"let item of options$ | async\" [value]=\"item\"  [disabled]=\"item?.disabled\">\n                        {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                        </mat-option>\n                    }\n                    @else {\n                        <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                    }\n\n                    @if (field.multiple) {\n                        @for (item of group.controls[field.name].value | slice:0:30; track item) {\n                            <mat-option [value]=\"item\" style=\"display:none\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-option>\n                        }\n                    }\n\n                    @if (!field.multiple && group.controls[field.name].value) {\n                        @for (item of [group?.controls[field.name]?.value]; track item) {\n                            <mat-option [value]=\"item\" style=\"display:none\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-option>\n                        }\n                    }\n                }\n                @else {\n                    @if (!isLoading) {\n                        <mat-option *cdkVirtualFor=\"let item of options$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                        </mat-option>\n                    }\n                    @else {\n                        <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                    }\n\n                    @if (field.multiple) {\n                        @for (item of group.controls[field.name].value | slice:0:30; track item) {\n                            <mat-option [value]=\"item\" style=\"display:none\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-option>\n                        }\n                    }\n\n                    @if (!field.multiple && group.controls[field.name].value) {\n                        @for (item of [group?.controls[field.name]?.value]; track item) {\n                            <mat-option [value]=\"item\" style=\"display:none\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-option>\n                        }\n                    }\n                }\n            </cdk-virtual-scroll-viewport>\n        }\n\n        </mat-select>\n\n        @if (field.hint) {\n            <mat-hint>{{field.hint}}</mat-hint>\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        `::ng-deep .hide-checkbox .mat-pseudo-checkbox { display: none !important;  }`],\n    styleUrls: ['../styles/loading-select.style.scss']\n})\nexport class KlesFormSelectComponent extends KlesFieldAbstract implements OnInit, OnDestroy {\n\n    @ViewChild(CdkVirtualScrollViewport) cdkVirtualScrollViewport: CdkVirtualScrollViewport;\n    @ViewChildren(MatOption) options: QueryList<MatOption>;\n\n    options$: Observable<any[]>;\n\n    isLoading = false;\n\n    openChange$ = new Subject<boolean>();\n\n    constructor(protected viewRef: ViewContainerRef, protected ref: ChangeDetectorRef) {\n        super(viewRef);\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n        if (this.field.lazy) {\n            this.isLoading = true;\n            if (this.group.controls[this.field.name].value !== undefined && this.group.controls[this.field.name].value !== null) {\n                this.options$ = new BehaviorSubject<any[]>(Array.isArray(this.group.controls[this.field.name].value) ? this.group.controls[this.field.name].value\n                    : [this.group.controls[this.field.name].value]);\n                this.isLoading = false;\n            } else {\n                this.options$ = new BehaviorSubject<any[]>([]);\n            }\n\n            this.openChange$\n                .pipe(\n                    takeUntil(this._onDestroy),\n                    switchMap((isOpen) => {\n                        if (isOpen) {\n                            if (this.field.options instanceof Observable) {\n                                this.isLoading = true;\n                                return this.field.options.pipe(take(1));\n                            }\n                            else if (this.field.options instanceof Function) {\n                                this.isLoading = true;\n                                return this.field.options();\n                            }\n                            else {\n                                return of(this.field.options);\n                            }\n                        } else {\n                            return of(this.group.controls[this.field.name].value !== undefined && this.group.controls[this.field.name].value !== null\n                                ? (Array.isArray(this.group.controls[this.field.name].value) ?\n                                    this.group.controls[this.field.name].value : [this.group.controls[this.field.name].value]) : [])\n                        }\n                    })\n                )\n                .subscribe((options) => {\n                    (this.options$ as BehaviorSubject<any[]>).next(options);\n                    this.isLoading = false;\n                    this.ref.markForCheck();\n                });\n\n        } else {\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\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n\n    openChange($event: boolean) {\n        if (this.field.lazy) {\n            this.openChange$.next($event);\n            // if ($event) {\n            //     if (!(this.field.options instanceof Observable)) {\n            //         (this.options$ as BehaviorSubject<any[]>).next(this.field.options);\n            //     } else {\n            //         this.isLoading = true;\n            //         this.field.options.pipe(take(1)).subscribe(options => {\n            //             (this.options$ as BehaviorSubject<any[]>).next(options);\n            //             this.isLoading = false;\n            //             this.ref.markForCheck();\n            //         });\n            //     }\n            // } else {\n            //     (this.options$ as BehaviorSubject<any[]>)\n            //         .next(this.group.controls[this.field.name].value !== undefined ? [this.group.controls[this.field.name].value] : []);\n            //     this.ref.markForCheck();\n            //     // this.isLoading = true;\n            // }\n        }\n\n        if (this.field.virtualScroll) {\n            if ($event) {\n                this.cdkVirtualScrollViewport.scrollToIndex(0);\n                this.cdkVirtualScrollViewport.checkViewportSize();\n            }\n        }\n    }\n\n    compareFn = (o1: any, o2: any) => {\n        if (this.field.property && o1 && o2) {\n            return o1[this.field.property] === o2[this.field.property];\n        }\n        return o1 === o2;\n    }\n}\n"]}
356
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\nimport { ChangeDetectorRef, Component, OnDestroy, OnInit, QueryList, ViewChild, ViewChildren, ViewContainerRef } from '@angular/core';\nimport { MatOption } from '@angular/material/core';\nimport { BehaviorSubject, Observable, of, Subject } from 'rxjs';\nimport { switchMap, take, takeUntil } from 'rxjs/operators';\nimport { FieldMapper } from '../decorators/component.decorator';\nimport { EnumType } from '../enums/type.enum';\nimport { KlesFieldAbstract } from './field.abstract';\n\n@FieldMapper({ type: EnumType.select })\n@Component({\n    selector: 'kles-form-select',\n    template: `\n    <mat-form-field [subscriptSizing]=\"field.subscriptSizing\" class=\"margin-top\" [color]=\"field.color\" [formGroup]=\"group\" [appearance]=\"field.appearance\">\n        @if (field.label) {\n            <mat-label>{{field.label}}</mat-label>\n        }\n        <mat-select matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\"\n        (openedChange)=\"openChange($event)\" [compareWith]=\"compareFn\" [panelWidth]=\"field.panelWidth || 'auto'\"\n        [ngClass]=\"field.ngClass\" [placeholder]=\"field.placeholder | translate\" [formControlName]=\"field.name\" [multiple]=\"field.multiple\">\n\n        @if (field.triggerComponent) {\n            <mat-select-trigger>\n                <ng-container klesComponent [component]=\"field.triggerComponent\" [value]=\"group.controls[field.name].value\" [field]=\"field\"></ng-container>\n            </mat-select-trigger>\n        }\n\n        @if (!field.virtualScroll) {\n            @if (!field.autocompleteComponent) {\n                @if (!isLoading) {\n                    @for (item of options$ | async; track item) {\n                        <mat-option [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n                    }\n                }\n                @else {\n                    <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                }\n            }\n            @else {\n                @if (!isLoading) {\n                    @for (item of options$ | async; track item) {\n                        <mat-option [value]=\"item\" [disabled]=\"item?.disabled\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                        </mat-option>\n                    }\n                }\n                @else {\n                    <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                }\n            }\n        }\n        @else {\n            <cdk-virtual-scroll-viewport [itemSize]=\"field.itemSize || 50\" [style.height.px]=5*48>\n                @if (!field.autocompleteComponent) {\n                    @if (!isLoading) {\n                        <mat-option *cdkVirtualFor=\"let item of options$ | async\" [value]=\"item\"  [disabled]=\"item?.disabled\">\n                        {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                        </mat-option>\n                    }\n                    @else {\n                        <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                    }\n\n                    @if (field.multiple) {\n                        @for (item of group.controls[field.name].value | slice:0:30; track item) {\n                            <mat-option [value]=\"item\" style=\"display:none\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-option>\n                        }\n                    }\n\n                    @if (!field.multiple && group.controls[field.name].value) {\n                        @for (item of [group?.controls[field.name]?.value]; track item) {\n                            <mat-option [value]=\"item\" style=\"display:none\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-option>\n                        }\n                    }\n                }\n                @else {\n                    @if (!isLoading) {\n                        <mat-option *cdkVirtualFor=\"let item of options$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                        </mat-option>\n                    }\n                    @else {\n                        <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                    }\n\n                    @if (field.multiple) {\n                        @for (item of group.controls[field.name].value | slice:0:30; track item) {\n                            <mat-option [value]=\"item\" style=\"display:none\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-option>\n                        }\n                    }\n\n                    @if (!field.multiple && group.controls[field.name].value) {\n                        @for (item of [group?.controls[field.name]?.value]; track item) {\n                            <mat-option [value]=\"item\" style=\"display:none\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-option>\n                        }\n                    }\n                }\n            </cdk-virtual-scroll-viewport>\n        }\n\n        </mat-select>\n\n        @if (field.hint) {\n            <mat-hint>{{field.hint}}</mat-hint>\n        }\n\n        @if (field.subComponents || field.clearable) {\n            <div matSuffix>\n                <ng-content></ng-content>\n            </div>\n        }\n\n        <mat-error matErrorMessage [validations]=\"field.validations\" [asyncValidations]=\"field.asyncValidations\"></mat-error>\n    </mat-form-field>\n`,\n    styles: ['mat-form-field {width: calc(100%)}',\n        `::ng-deep .hide-checkbox .mat-pseudo-checkbox { display: none !important;  }`],\n    styleUrls: ['../styles/loading-select.style.scss']\n})\nexport class KlesFormSelectComponent extends KlesFieldAbstract implements OnInit, OnDestroy {\n\n    @ViewChild(CdkVirtualScrollViewport) cdkVirtualScrollViewport: CdkVirtualScrollViewport;\n    @ViewChildren(MatOption) options: QueryList<MatOption>;\n\n    options$: Observable<any[]>;\n\n    isLoading = false;\n\n    openChange$ = new Subject<boolean>();\n\n    constructor(protected viewRef: ViewContainerRef, protected ref: ChangeDetectorRef) {\n        super(viewRef);\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n        if (this.field.lazy) {\n            this.isLoading = true;\n            if (this.group.controls[this.field.name].value !== undefined && this.group.controls[this.field.name].value !== null) {\n                this.options$ = new BehaviorSubject<any[]>(Array.isArray(this.group.controls[this.field.name].value) ? this.group.controls[this.field.name].value\n                    : [this.group.controls[this.field.name].value]);\n                this.isLoading = false;\n            } else {\n                this.options$ = new BehaviorSubject<any[]>([]);\n            }\n\n            this.openChange$\n                .pipe(\n                    takeUntil(this._onDestroy),\n                    switchMap((isOpen) => {\n                        if (isOpen) {\n                            if (this.field.options instanceof Observable) {\n                                this.isLoading = true;\n                                return this.field.options.pipe(take(1));\n                            }\n                            else if (this.field.options instanceof Function) {\n                                this.isLoading = true;\n                                return this.field.options();\n                            }\n                            else {\n                                return of(this.field.options);\n                            }\n                        } else {\n                            return of(this.group.controls[this.field.name].value !== undefined && this.group.controls[this.field.name].value !== null\n                                ? (Array.isArray(this.group.controls[this.field.name].value) ?\n                                    this.group.controls[this.field.name].value : [this.group.controls[this.field.name].value]) : [])\n                        }\n                    })\n                )\n                .subscribe((options) => {\n                    (this.options$ as BehaviorSubject<any[]>).next(options);\n                    this.isLoading = false;\n                    this.ref.markForCheck();\n                });\n\n        } else {\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\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n\n    openChange($event: boolean) {\n        if (this.field.lazy) {\n            this.openChange$.next($event);\n            // if ($event) {\n            //     if (!(this.field.options instanceof Observable)) {\n            //         (this.options$ as BehaviorSubject<any[]>).next(this.field.options);\n            //     } else {\n            //         this.isLoading = true;\n            //         this.field.options.pipe(take(1)).subscribe(options => {\n            //             (this.options$ as BehaviorSubject<any[]>).next(options);\n            //             this.isLoading = false;\n            //             this.ref.markForCheck();\n            //         });\n            //     }\n            // } else {\n            //     (this.options$ as BehaviorSubject<any[]>)\n            //         .next(this.group.controls[this.field.name].value !== undefined ? [this.group.controls[this.field.name].value] : []);\n            //     this.ref.markForCheck();\n            //     // this.isLoading = true;\n            // }\n        }\n\n        if (this.field.virtualScroll) {\n            if ($event) {\n                this.cdkVirtualScrollViewport.scrollToIndex(0);\n                this.cdkVirtualScrollViewport.checkViewportSize();\n            }\n        }\n    }\n\n    compareFn = (o1: any, o2: any) => {\n        if (this.field.property && o1 && o2) {\n            return o1[this.field.property] === o2[this.field.property];\n        }\n        return o1 === o2;\n    }\n}\n"]}
@@ -14,8 +14,9 @@ import * as i8 from "@angular/material/checkbox";
14
14
  import * as i9 from "@angular/cdk/scrolling";
15
15
  import * as i10 from "ngx-mat-select-search";
16
16
  import * as i11 from "../directive/dynamic-component.directive";
17
- import * as i12 from "@ngx-translate/core";
18
- import * as i13 from "../pipe/transform.pipe";
17
+ import * as i12 from "../directive/mat-error-message.directive";
18
+ import * as i13 from "@ngx-translate/core";
19
+ import * as i14 from "../pipe/transform.pipe";
19
20
  export class KlesFormSelectLazySearchComponent extends KlesFormSelectSearchComponent {
20
21
  constructor(viewRef, ref) {
21
22
  super(viewRef, ref);
@@ -60,8 +61,8 @@ export class KlesFormSelectLazySearchComponent extends KlesFormSelectSearchCompo
60
61
  this.ref.markForCheck();
61
62
  });
62
63
  }
63
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: KlesFormSelectLazySearchComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
64
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: KlesFormSelectLazySearchComponent, selector: "kles-form-select-lazy-search", usesInheritance: true, ngImport: i0, template: `
64
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: KlesFormSelectLazySearchComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
65
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.7", type: KlesFormSelectLazySearchComponent, selector: "kles-form-select-lazy-search", usesInheritance: true, ngImport: i0, template: `
65
66
  <mat-form-field [subscriptSizing]="field.subscriptSizing" class="margin-top" [color]="field.color" [formGroup]="group" [appearance]="field.appearance">
66
67
  @if (field.label) {
67
68
  <mat-label>{{field.label}}</mat-label>
@@ -175,24 +176,11 @@ export class KlesFormSelectLazySearchComponent extends KlesFormSelectSearchCompo
175
176
  </div>
176
177
  }
177
178
 
178
- @for (validation of field.validations; track validation.name) {
179
- <ng-container ngProjectAs="mat-error">
180
- @if (group.get(field.name).hasError(validation.name)) {
181
- <mat-error>{{validation.message | translate}}</mat-error>
182
- }
183
- </ng-container>
184
- }
185
- @for (validation of field.asyncValidations; 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
- }
179
+ <mat-error matErrorMessage [validations]="field.validations" [asyncValidations]="field.asyncValidations"></mat-error>
192
180
  </mat-form-field>
193
- `, isInline: true, styles: [".loadingSelect{display:flex;flex-direction:row;justify-content:space-between;align-items:center}\n", "mat-form-field{width:100%}\n", ".selectAll{padding:0 16px 0 5px;display:flex!important}\n", ".selectAll .mdc-form-field{width:100%}\n", ".selectAll .mdc-form-field .mdc-label{width:100%;min-height:48px;align-items:center;display:flex}\n", ".selectAll .mdc-form-field .mdc-checkbox__ripple{display:none!important}\n", "::ng-deep .hide-checkbox .mat-pseudo-checkbox{display:none!important}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["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: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "directive", type: i4.MatSelectTrigger, selector: "mat-select-trigger" }, { 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.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "directive", type: i9.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: i9.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i9.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "component", type: i10.MatSelectSearchComponent, selector: "ngx-mat-select-search", inputs: ["placeholderLabel", "type", "closeIcon", "closeSvgIcon", "noEntriesFoundLabel", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toggleAllCheckboxTooltipPosition", "hideClearSearchButton", "alwaysRestoreSelectedOptionsMulti"], outputs: ["toggleAll"] }, { kind: "directive", type: i11.KlesComponentDirective, selector: "[klesComponent]", inputs: ["component", "value", "field"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.SlicePipe, name: "slice" }, { kind: "pipe", type: i12.TranslatePipe, name: "translate" }, { kind: "pipe", type: i13.KlesTransformPipe, name: "klesTransform" }] }); }
181
+ `, isInline: true, styles: [".loadingSelect{display:flex;flex-direction:row;justify-content:space-between;align-items:center}\n", "mat-form-field{width:100%}\n", ".selectAll{padding:0 16px 0 5px;display:flex!important}\n", ".selectAll .mdc-form-field{width:100%}\n", ".selectAll .mdc-form-field .mdc-label{width:100%;min-height:48px;align-items:center;display:flex}\n", ".selectAll .mdc-form-field .mdc-checkbox__ripple{display:none!important}\n", "::ng-deep .hide-checkbox .mat-pseudo-checkbox{display:none!important}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { 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.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["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: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatError, selector: "mat-error, [matError]", inputs: ["id"] }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix], [matIconSuffix], [matTextSuffix]", inputs: ["matTextSuffix"] }, { kind: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "directive", type: i4.MatSelectTrigger, selector: "mat-select-trigger" }, { 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.MatCheckbox, selector: "mat-checkbox", inputs: ["aria-label", "aria-labelledby", "aria-describedby", "id", "required", "labelPosition", "name", "value", "disableRipple", "tabIndex", "color", "checked", "disabled", "indeterminate"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { kind: "directive", type: i9.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { kind: "directive", type: i9.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { kind: "component", type: i9.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { kind: "component", type: i10.MatSelectSearchComponent, selector: "ngx-mat-select-search", inputs: ["placeholderLabel", "type", "closeIcon", "closeSvgIcon", "noEntriesFoundLabel", "clearSearchInput", "searching", "disableInitialFocus", "enableClearOnEscapePressed", "preventHomeEndKeyPropagation", "disableScrollToActiveOnOptionsChanged", "ariaLabel", "showToggleAllCheckbox", "toggleAllCheckboxChecked", "toggleAllCheckboxIndeterminate", "toggleAllCheckboxTooltipMessage", "toggleAllCheckboxTooltipPosition", "hideClearSearchButton", "alwaysRestoreSelectedOptionsMulti"], outputs: ["toggleAll"] }, { kind: "directive", type: i11.KlesComponentDirective, selector: "[klesComponent]", inputs: ["component", "value", "field"] }, { kind: "component", type: i12.MatErrorMessageDirective, selector: "[matErrorMessage]", inputs: ["validations", "asyncValidations"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i1.SlicePipe, name: "slice" }, { kind: "pipe", type: i13.TranslatePipe, name: "translate" }, { kind: "pipe", type: i14.KlesTransformPipe, name: "klesTransform" }] }); }
194
182
  }
195
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: KlesFormSelectLazySearchComponent, decorators: [{
183
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.7", ngImport: i0, type: KlesFormSelectLazySearchComponent, decorators: [{
196
184
  type: Component,
197
185
  args: [{ selector: 'kles-form-select-lazy-search', template: `
198
186
  <mat-form-field [subscriptSizing]="field.subscriptSizing" class="margin-top" [color]="field.color" [formGroup]="group" [appearance]="field.appearance">
@@ -308,21 +296,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
308
296
  </div>
309
297
  }
310
298
 
311
- @for (validation of field.validations; track validation.name) {
312
- <ng-container ngProjectAs="mat-error">
313
- @if (group.get(field.name).hasError(validation.name)) {
314
- <mat-error>{{validation.message | translate}}</mat-error>
315
- }
316
- </ng-container>
317
- }
318
- @for (validation of field.asyncValidations; track validation.name) {
319
- <ng-container ngProjectAs="mat-error">
320
- @if (group.get(field.name).hasError(validation.name)) {
321
- <mat-error>{{validation.message | translate}}</mat-error>
322
- }
323
- </ng-container>
324
- }
299
+ <mat-error matErrorMessage [validations]="field.validations" [asyncValidations]="field.asyncValidations"></mat-error>
325
300
  </mat-form-field>
326
301
  `, styles: [".loadingSelect{display:flex;flex-direction:row;justify-content:space-between;align-items:center}\n", "mat-form-field{width:100%}\n", ".selectAll{padding:0 16px 0 5px;display:flex!important}\n", ".selectAll .mdc-form-field{width:100%}\n", ".selectAll .mdc-form-field .mdc-label{width:100%;min-height:48px;align-items:center;display:flex}\n", ".selectAll .mdc-form-field .mdc-checkbox__ripple{display:none!important}\n", "::ng-deep .hide-checkbox .mat-pseudo-checkbox{display:none!important}\n"] }]
327
302
  }], ctorParameters: () => [{ type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }] });
328
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.lazy-search.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/select.lazy-search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';\nimport { Observable, of } from 'rxjs';\nimport { map, switchMap, take, takeUntil } from 'rxjs/operators';\nimport { KlesFormSelectSearchComponent } from './select.search.component';\n\n@Component({\n    selector: 'kles-form-select-lazy-search',\n    template: `\n    <mat-form-field [subscriptSizing]=\"field.subscriptSizing\" class=\"margin-top\" [color]=\"field.color\" [formGroup]=\"group\" [appearance]=\"field.appearance\">\n        @if (field.label) {\n            <mat-label>{{field.label}}</mat-label>\n        }\n\n        <mat-select matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\" [ngClass]=\"field.ngClass\"\n        (openedChange)=\"openChange($event)\" [compareWith]=\"compareFn\" [panelWidth]=\"field.panelWidth || 'auto'\"\n        [placeholder]=\"field.placeholder | translate\" [formControlName]=\"field.name\" [multiple]=\"field.multiple\">\n        @if (field.triggerComponent) {\n            <mat-select-trigger>\n                <ng-container klesComponent [component]=\"field.triggerComponent\" [value]=\"group.controls[field.name].value\" [field]=\"field\"></ng-container>\n            </mat-select-trigger>\n        }\n\n        @if (field.virtualScroll) {\n            <mat-option>\n                <ngx-mat-select-search [formControl]=\"searchControl\" [clearSearchInput]=\"false\"\n                placeholderLabel=\"\" noEntriesFoundLabel =\"\"></ngx-mat-select-search>\n            </mat-option>\n\n            <cdk-virtual-scroll-viewport [itemSize]=\"field.itemSize || 50\" [style.height.px]=4*48>\n                @if (!isLoading) {\n                    @if (field.multiple) {\n                        <mat-checkbox class=\"selectAll mat-mdc-option mdc-list-item\" [formControl]=\"selectAllControl\" (change)=\"toggleAllSelection($event)\">\n                            {{'selectAll' | translate}}\n                        </mat-checkbox>\n                    }\n\n                    @if (!field.autocompleteComponent) {\n                        <mat-option *cdkVirtualFor=\"let item of optionsFiltered$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n\n                        @if (field.multiple) {\n                            @for (item of group.controls[field.name].value | slice:0:30; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                                </mat-option>\n                            }\n                        }\n\n                        @if (!field.multiple && group.controls[field.name].value) {\n                            @for (item of [group?.controls[field.name]?.value]; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                                </mat-option>\n                            }\n                        }\n                    }\n                    @else {\n                        <mat-option *cdkVirtualFor=\"let item of optionsFiltered$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                        </mat-option>\n\n                        @if (field.multiple) {\n                            @for (item of group.controls[field.name].value | slice:0:30; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                                </mat-option>\n                            }\n                        }\n\n                        @if (!field.multiple && group.controls[field.name].value) {\n                            @for (item of [group?.controls[field.name]?.value]; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                                </mat-option>\n                            }\n                        }\n                    }\n                }\n                @else {\n                    <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                }\n            </cdk-virtual-scroll-viewport>\n        }\n        @else {\n            <mat-option>\n                <ngx-mat-select-search [formControl]=\"searchControl\" [clearSearchInput]=\"false\"\n                placeholderLabel=\"\" noEntriesFoundLabel =\"\"></ngx-mat-select-search>\n            </mat-option>\n\n            @if (!isLoading) {\n                @if (field.multiple) {\n                    <mat-checkbox class=\"selectAll mat-mdc-option mdc-list-item\" [formControl]=\"selectAllControl\" (change)=\"toggleAllSelection($event)\">\n                        {{'selectAll' | translate}}\n                    </mat-checkbox>\n                }\n\n                @if (!field.autocompleteComponent) {\n                    @for (item of optionsFiltered$ | async; track item) {\n                        <mat-option [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n                    }\n                }\n                @else {\n                    @for (item of optionsFiltered$ | async; track item) {\n                        <mat-option [value]=\"item\" [disabled]=\"item?.disabled\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                        </mat-option>\n                    }\n                }\n            }\n            @else {\n                <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n            }\n        }\n\n        </mat-select>\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        '.selectAll {padding: 0 16px 0 5px; display: flex !important;}',\n        '.selectAll .mdc-form-field {width: 100%;}',\n        '.selectAll .mdc-form-field .mdc-label {width: 100%;  min-height: 48px; align-items: center; display: flex;}',\n        '.selectAll .mdc-form-field .mdc-checkbox__ripple {display: none !important;}',\n        `::ng-deep .hide-checkbox .mat-pseudo-checkbox { display: none !important;  }`],\n    styleUrls: ['../styles/loading-select.style.scss']\n})\nexport class KlesFormSelectLazySearchComponent extends KlesFormSelectSearchComponent implements OnInit, OnDestroy {\n\n    constructor(protected viewRef: ViewContainerRef, protected ref: ChangeDetectorRef) {\n        super(viewRef, ref);\n    }\n\n    ngOnInit() {\n        this.field.lazy = true;\n        this.field.debounceTime = this.field.debounceTime ? this.field.debounceTime : 500;\n        super.ngOnInit();\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n\n    protected onSearchChange(value: string): Observable<any[]> {\n        if (this.field.options instanceof Function) {\n            if (this.openChange$.getValue() && this.field.options instanceof Function) {\n                if (value) {\n                    return this.field.options(value).pipe(take(1));\n                } else {\n                    return this.field.options().pipe(take(1));\n                }\n            }\n            return of(this.group.controls[this.field.name].value ? [this.group.controls[this.field.name].value] : []);\n        }\n        else {\n            return super.onSearchChange(value);\n        }\n    }\n\n    protected openChangeEvent(): void {\n        this.openChange$\n            .pipe(\n                takeUntil(this._onDestroy),\n                switchMap((isOpen) => {\n                    return this.onOpenChange(isOpen).pipe(map((options) => ({ options, isOpen })));\n                })\n            )\n            .subscribe(({ options, isOpen }) => {\n                if (!isOpen) {\n                    this.searchControl.reset(null, { emitEvent: false });\n                }\n                this.optionsFiltered$.next(options);\n                this.isLoading = false;\n                this.ref.markForCheck();\n            });\n    }\n}\n"]}
303
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.lazy-search.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/select.lazy-search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, OnDestroy, OnInit, ViewContainerRef } from '@angular/core';\nimport { Observable, of } from 'rxjs';\nimport { map, switchMap, take, takeUntil } from 'rxjs/operators';\nimport { KlesFormSelectSearchComponent } from './select.search.component';\n\n@Component({\n    selector: 'kles-form-select-lazy-search',\n    template: `\n    <mat-form-field [subscriptSizing]=\"field.subscriptSizing\" class=\"margin-top\" [color]=\"field.color\" [formGroup]=\"group\" [appearance]=\"field.appearance\">\n        @if (field.label) {\n            <mat-label>{{field.label}}</mat-label>\n        }\n\n        <mat-select matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\" [ngClass]=\"field.ngClass\"\n        (openedChange)=\"openChange($event)\" [compareWith]=\"compareFn\" [panelWidth]=\"field.panelWidth || 'auto'\"\n        [placeholder]=\"field.placeholder | translate\" [formControlName]=\"field.name\" [multiple]=\"field.multiple\">\n        @if (field.triggerComponent) {\n            <mat-select-trigger>\n                <ng-container klesComponent [component]=\"field.triggerComponent\" [value]=\"group.controls[field.name].value\" [field]=\"field\"></ng-container>\n            </mat-select-trigger>\n        }\n\n        @if (field.virtualScroll) {\n            <mat-option>\n                <ngx-mat-select-search [formControl]=\"searchControl\" [clearSearchInput]=\"false\"\n                placeholderLabel=\"\" noEntriesFoundLabel =\"\"></ngx-mat-select-search>\n            </mat-option>\n\n            <cdk-virtual-scroll-viewport [itemSize]=\"field.itemSize || 50\" [style.height.px]=4*48>\n                @if (!isLoading) {\n                    @if (field.multiple) {\n                        <mat-checkbox class=\"selectAll mat-mdc-option mdc-list-item\" [formControl]=\"selectAllControl\" (change)=\"toggleAllSelection($event)\">\n                            {{'selectAll' | translate}}\n                        </mat-checkbox>\n                    }\n\n                    @if (!field.autocompleteComponent) {\n                        <mat-option *cdkVirtualFor=\"let item of optionsFiltered$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n\n                        @if (field.multiple) {\n                            @for (item of group.controls[field.name].value | slice:0:30; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                                </mat-option>\n                            }\n                        }\n\n                        @if (!field.multiple && group.controls[field.name].value) {\n                            @for (item of [group?.controls[field.name]?.value]; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                                </mat-option>\n                            }\n                        }\n                    }\n                    @else {\n                        <mat-option *cdkVirtualFor=\"let item of optionsFiltered$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                        </mat-option>\n\n                        @if (field.multiple) {\n                            @for (item of group.controls[field.name].value | slice:0:30; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                                </mat-option>\n                            }\n                        }\n\n                        @if (!field.multiple && group.controls[field.name].value) {\n                            @for (item of [group?.controls[field.name]?.value]; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                                </mat-option>\n                            }\n                        }\n                    }\n                }\n                @else {\n                    <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                }\n            </cdk-virtual-scroll-viewport>\n        }\n        @else {\n            <mat-option>\n                <ngx-mat-select-search [formControl]=\"searchControl\" [clearSearchInput]=\"false\"\n                placeholderLabel=\"\" noEntriesFoundLabel =\"\"></ngx-mat-select-search>\n            </mat-option>\n\n            @if (!isLoading) {\n                @if (field.multiple) {\n                    <mat-checkbox class=\"selectAll mat-mdc-option mdc-list-item\" [formControl]=\"selectAllControl\" (change)=\"toggleAllSelection($event)\">\n                        {{'selectAll' | translate}}\n                    </mat-checkbox>\n                }\n\n                @if (!field.autocompleteComponent) {\n                    @for (item of optionsFiltered$ | async; track item) {\n                        <mat-option [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n                    }\n                }\n                @else {\n                    @for (item of optionsFiltered$ | async; track item) {\n                        <mat-option [value]=\"item\" [disabled]=\"item?.disabled\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                        </mat-option>\n                    }\n                }\n            }\n            @else {\n                <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n            }\n        }\n\n        </mat-select>\n\n        @if (field.subComponents || field.clearable) {\n            <div matSuffix>\n                <ng-content></ng-content>\n            </div>\n        }\n\n        <mat-error matErrorMessage [validations]=\"field.validations\" [asyncValidations]=\"field.asyncValidations\"></mat-error>\n    </mat-form-field>\n`,\n    styles: ['mat-form-field {width: calc(100%)}',\n        '.selectAll {padding: 0 16px 0 5px; display: flex !important;}',\n        '.selectAll .mdc-form-field {width: 100%;}',\n        '.selectAll .mdc-form-field .mdc-label {width: 100%;  min-height: 48px; align-items: center; display: flex;}',\n        '.selectAll .mdc-form-field .mdc-checkbox__ripple {display: none !important;}',\n        `::ng-deep .hide-checkbox .mat-pseudo-checkbox { display: none !important;  }`],\n    styleUrls: ['../styles/loading-select.style.scss']\n})\nexport class KlesFormSelectLazySearchComponent extends KlesFormSelectSearchComponent implements OnInit, OnDestroy {\n\n    constructor(protected viewRef: ViewContainerRef, protected ref: ChangeDetectorRef) {\n        super(viewRef, ref);\n    }\n\n    ngOnInit() {\n        this.field.lazy = true;\n        this.field.debounceTime = this.field.debounceTime ? this.field.debounceTime : 500;\n        super.ngOnInit();\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n\n    protected onSearchChange(value: string): Observable<any[]> {\n        if (this.field.options instanceof Function) {\n            if (this.openChange$.getValue() && this.field.options instanceof Function) {\n                if (value) {\n                    return this.field.options(value).pipe(take(1));\n                } else {\n                    return this.field.options().pipe(take(1));\n                }\n            }\n            return of(this.group.controls[this.field.name].value ? [this.group.controls[this.field.name].value] : []);\n        }\n        else {\n            return super.onSearchChange(value);\n        }\n    }\n\n    protected openChangeEvent(): void {\n        this.openChange$\n            .pipe(\n                takeUntil(this._onDestroy),\n                switchMap((isOpen) => {\n                    return this.onOpenChange(isOpen).pipe(map((options) => ({ options, isOpen })));\n                })\n            )\n            .subscribe(({ options, isOpen }) => {\n                if (!isOpen) {\n                    this.searchControl.reset(null, { emitEvent: false });\n                }\n                this.optionsFiltered$.next(options);\n                this.isLoading = false;\n                this.ref.markForCheck();\n            });\n    }\n}\n"]}