@3kles/kles-material-dynamicforms 14.9.1 → 14.9.3

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.
@@ -1,5 +1,6 @@
1
1
  import { Component } from '@angular/core';
2
- import { take, takeUntil } from 'rxjs/operators';
2
+ import { of } from 'rxjs';
3
+ import { switchMap, take, takeUntil } from 'rxjs/operators';
3
4
  import { KlesFormSelectSearchComponent } from './select.search.component';
4
5
  import * as i0 from "@angular/core";
5
6
  import * as i1 from "@angular/common";
@@ -25,33 +26,39 @@ export class KlesFormSelectLazySearchComponent extends KlesFormSelectSearchCompo
25
26
  }
26
27
  ngOnInit() {
27
28
  this.field.lazy = true;
29
+ this.field.debounceTime = this.field.debounceTime ? this.field.debounceTime : 500;
28
30
  super.ngOnInit();
29
- this.openChange$.pipe(takeUntil(this._onDestroy))
30
- .subscribe((open) => {
31
- if (open) {
32
- this.searchControl.reset(null);
33
- }
34
- else {
35
- this.searchControl.reset(null, { emitEvent: false });
36
- }
37
- });
38
31
  }
39
32
  ngOnDestroy() {
40
33
  super.ngOnDestroy();
41
34
  }
42
35
  onSearchChange(value) {
43
36
  if (this.field.options instanceof Function) {
44
- if (value) {
45
- return this.field.options(value).pipe(take(1));
46
- }
47
- else {
48
- return this.field.options().pipe(take(1));
37
+ if (this.openChange$.getValue() && this.field.options instanceof Function) {
38
+ if (value) {
39
+ return this.field.options(value).pipe(take(1));
40
+ }
41
+ else {
42
+ return this.field.options().pipe(take(1));
43
+ }
49
44
  }
45
+ return of(this.group.controls[this.field.name].value ? [this.group.controls[this.field.name].value] : []);
50
46
  }
51
47
  else {
52
48
  return super.onSearchChange(value);
53
49
  }
54
50
  }
51
+ openChangeEvent() {
52
+ this.openChange$
53
+ .pipe(takeUntil(this._onDestroy), switchMap((isOpen) => {
54
+ return this.onOpenChange(isOpen);
55
+ }))
56
+ .subscribe((options) => {
57
+ this.optionsFiltered$.next(options);
58
+ this.isLoading = false;
59
+ this.ref.markForCheck();
60
+ });
61
+ }
55
62
  }
56
63
  KlesFormSelectLazySearchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: KlesFormSelectLazySearchComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
57
64
  KlesFormSelectLazySearchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: KlesFormSelectLazySearchComponent, selector: "kles-form-select-lazy-search", usesInheritance: true, ngImport: i0, template: `
@@ -265,4 +272,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
265
272
  </mat-form-field>
266
273
  `, styles: ["mat-form-field{width:100%}\n", ".selectAll{padding:10px 16px}\n", "::ng-deep .hide-checkbox .mat-pseudo-checkbox{display:none!important}\n"] }]
267
274
  }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.ChangeDetectorRef }]; } });
268
- //# 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":"AAEA,OAAO,EAAqB,SAAS,EAA2E,MAAM,eAAe,CAAC;AAItI,OAAO,EAA6B,IAAI,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE5E,OAAO,EAAE,6BAA6B,EAAE,MAAM,2BAA2B,CAAC;;;;;;;;;;;;;;;;;AA+G1E,MAAM,OAAO,iCAAkC,SAAQ,6BAA6B;IAEhF,YAAsB,OAAyB,EAAY,GAAsB;QAC7E,KAAK,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QADF,YAAO,GAAP,OAAO,CAAkB;QAAY,QAAG,GAAH,GAAG,CAAmB;IAEjF,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC;QACvB,KAAK,CAAC,QAAQ,EAAE,CAAC;QAEjB,IAAI,CAAC,WAAW,CAAC,IAAI,CACjB,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAC7B;aACI,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE;YAChB,IAAI,IAAI,EAAE;gBACN,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;aAClC;iBAAM;gBACH,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;aACxD;QACL,CAAC,CAAC,CAAC;IACX,CAAC;IAED,WAAW;QACP,KAAK,CAAC,WAAW,EAAE,CAAC;IACxB,CAAC;IAES,cAAc,CAAC,KAAa;QAClC,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,YAAY,QAAQ,EAAE;YACxC,IAAI,KAAK,EAAE;gBACP,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;aAClD;iBAAM;gBACH,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;aAC7C;SAEJ;aACI;YACD,OAAO,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;SACtC;IAGL,CAAC;;8HAxCQ,iCAAiC;kHAAjC,iCAAiC,2FA3GhC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAuGb;2FAIY,iCAAiC;kBA7G7C,SAAS;+BACI,8BAA8B,YAC9B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAuGb","sourcesContent":["import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\nimport { ViewEncapsulation } from '@angular/compiler';\nimport { ChangeDetectorRef, Component, OnDestroy, OnInit, QueryList, ViewChild, ViewChildren, ViewContainerRef } from '@angular/core';\nimport { UntypedFormControl } from '@angular/forms';\nimport { MatOption } from '@angular/material/core';\nimport { BehaviorSubject, Observable, of, ReplaySubject, Subject } from 'rxjs';\nimport { map, startWith, switchMap, take, takeUntil } from 'rxjs/operators';\nimport { KlesFieldAbstract } from './field.abstract';\nimport { KlesFormSelectSearchComponent } from './select.search.component';\n\n@Component({\n    selector: 'kles-form-select-lazy-search',\n    template: `\n    <mat-form-field class=\"margin-top\" [color]=\"field.color\" [formGroup]=\"group\">\n        <mat-select matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\" [ngClass]=\"field.ngClass\"\n        (openedChange)=\"openChange($event)\" [compareWith]=\"compareFn\"\n        [placeholder]=\"field.placeholder | translate\" [formControlName]=\"field.name\" [multiple]=\"field.multiple\">\n        <mat-select-trigger *ngIf=\"field.triggerComponent\">\n            <ng-container klesComponent [component]=\"field.triggerComponent\" [value]=\"group.controls[field.name].value\" [field]=\"field\"></ng-container>\n        </mat-select-trigger>\n\n        <ng-container *ngIf=\"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                <ng-container *ngIf=\"!isLoading; else emptyOption\">\n                    <mat-checkbox *ngIf=\"field.multiple\" class=\"selectAll\" [formControl]=\"selectAllControl\"\n                    (change)=\"toggleAllSelection($event)\">\n                        {{'selectAll' | translate}}\n                    </mat-checkbox>\n                    <ng-container *ngIf=\"!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                        <ng-container *ngIf=\"field.multiple\">\n                            <mat-option *ngFor=\"let item of group.controls[field.name].value | slice:0:30\" [value]=\"item\"\n                            style=\"display:none\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-option>\n                        </ng-container>\n\n                        <ng-container *ngIf=\"!field.multiple && group.controls[field.name].value\">\n                            <mat-option *ngFor=\"let item of [group?.controls[field.name]?.value]\" [value]=\"item\" style=\"display:none\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-option>\n                        </ng-container>\n                    </ng-container>\n\n                    <ng-container *ngIf=\"field.autocompleteComponent\">\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                        <ng-container *ngIf=\"field.multiple\">\n                            <mat-option *ngFor=\"let item of group.controls[field.name].value | slice:0:30\" [value]=\"item\"\n                            style=\"display:none\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-option>\n                        </ng-container>\n\n                        <ng-container *ngIf=\"!field.multiple && group.controls[field.name].value\">\n                            <mat-option *ngFor=\"let item of [group?.controls[field.name]?.value]\" [value]=\"item\" style=\"display:none\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-option>\n                        </ng-container>\n                    </ng-container>\n                </ng-container>\n                <ng-template #emptyOption>\n                    <mat-option class=\"hide-checkbox\" disabled><div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                </ng-template>\n            </cdk-virtual-scroll-viewport>\n\n        </ng-container>\n\n        <ng-container *ngIf=\"!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            <ng-container *ngIf=\"!isLoading; else emptyOption\">\n                <mat-checkbox *ngIf=\"field.multiple\" class=\"selectAll\" [formControl]=\"selectAllControl\"\n                        (change)=\"toggleAllSelection($event)\">\n                        {{'selectAll' | translate}}\n                </mat-checkbox>\n                <ng-container *ngIf=\"!field.autocompleteComponent\">\n                    <mat-option *ngFor=\"let item of optionsFiltered$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n                </ng-container>\n\n                <ng-container *ngIf=\"field.autocompleteComponent\">\n                    <mat-option *ngFor=\"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                </ng-container>\n            </ng-container>\n\n            <ng-template #emptyOption>\n                <mat-option class=\"hide-checkbox\" disabled><div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n            </ng-template>\n        </ng-container>\n        </mat-select>\n\n        <div matSuffix>\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%)}', '.selectAll {padding: 10px 16px;}',\n        `::ng-deep .hide-checkbox .mat-pseudo-checkbox { display: none !important;  }`],\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        super.ngOnInit();\n\n        this.openChange$.pipe(\n            takeUntil(this._onDestroy),\n        )\n            .subscribe((open) => {\n                if (open) {\n                    this.searchControl.reset(null);\n                } else {\n                    this.searchControl.reset(null, { emitEvent: false });\n                }\n            });\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 (value) {\n                return this.field.options(value).pipe(take(1));\n            } else {\n                return this.field.options().pipe(take(1));\n            }\n\n        }\n        else {\n            return super.onSearchChange(value);\n        }\n\n\n    }\n}\n"]}
275
+ //# 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":"AAEA,OAAO,EAAqB,SAAS,EAA2E,MAAM,eAAe,CAAC;AAGtI,OAAO,EAA+B,EAAE,EAA0B,MAAM,MAAM,CAAC;AAC/E,OAAO,EAAkB,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE5E,OAAO,EAAE,6BAA6B,EAAE,MAAM,2BAA2B,CAAC;;;;;;;;;;;;;;;;;AA+G1E,MAAM,OAAO,iCAAkC,SAAQ,6BAA6B;IAEhF,YAAsB,OAAyB,EAAY,GAAsB;QAC7E,KAAK,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;QADF,YAAO,GAAP,OAAO,CAAkB;QAAY,QAAG,GAAH,GAAG,CAAmB;IAEjF,CAAC;IAED,QAAQ;QACJ,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC;QACvB,IAAI,CAAC,KAAK,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC;QAClF,KAAK,CAAC,QAAQ,EAAE,CAAC;IACrB,CAAC;IAED,WAAW;QACP,KAAK,CAAC,WAAW,EAAE,CAAC;IACxB,CAAC;IAES,cAAc,CAAC,KAAa;QAClC,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,YAAY,QAAQ,EAAE;YACxC,IAAI,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,YAAY,QAAQ,EAAE;gBACvE,IAAI,KAAK,EAAE;oBACP,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;iBAClD;qBAAM;oBACH,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;iBAC7C;aACJ;YACD,OAAO,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;SAC7G;aACI;YACD,OAAO,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;SACtC;IACL,CAAC;IAES,eAAe;QACrB,IAAI,CAAC,WAAW;aACX,IAAI,CACD,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,EAC1B,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACjB,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QACrC,CAAC,CAAC,CACL;aACA,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;YACnB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACpC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;IACX,CAAC;;8HA7CQ,iCAAiC;kHAAjC,iCAAiC,2FA3GhC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAuGb;2FAIY,iCAAiC;kBA7G7C,SAAS;+BACI,8BAA8B,YAC9B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAuGb","sourcesContent":["import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\nimport { ViewEncapsulation } from '@angular/compiler';\nimport { ChangeDetectorRef, Component, OnDestroy, OnInit, QueryList, ViewChild, ViewChildren, ViewContainerRef } from '@angular/core';\nimport { UntypedFormControl } from '@angular/forms';\nimport { MatOption } from '@angular/material/core';\nimport { BehaviorSubject, Observable, of, ReplaySubject, Subject } from 'rxjs';\nimport { map, startWith, switchMap, take, takeUntil } from 'rxjs/operators';\nimport { KlesFieldAbstract } from './field.abstract';\nimport { KlesFormSelectSearchComponent } from './select.search.component';\n\n@Component({\n    selector: 'kles-form-select-lazy-search',\n    template: `\n    <mat-form-field class=\"margin-top\" [color]=\"field.color\" [formGroup]=\"group\">\n        <mat-select matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\" [ngClass]=\"field.ngClass\"\n        (openedChange)=\"openChange($event)\" [compareWith]=\"compareFn\"\n        [placeholder]=\"field.placeholder | translate\" [formControlName]=\"field.name\" [multiple]=\"field.multiple\">\n        <mat-select-trigger *ngIf=\"field.triggerComponent\">\n            <ng-container klesComponent [component]=\"field.triggerComponent\" [value]=\"group.controls[field.name].value\" [field]=\"field\"></ng-container>\n        </mat-select-trigger>\n\n        <ng-container *ngIf=\"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                <ng-container *ngIf=\"!isLoading; else emptyOption\">\n                    <mat-checkbox *ngIf=\"field.multiple\" class=\"selectAll\" [formControl]=\"selectAllControl\"\n                    (change)=\"toggleAllSelection($event)\">\n                        {{'selectAll' | translate}}\n                    </mat-checkbox>\n                    <ng-container *ngIf=\"!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                        <ng-container *ngIf=\"field.multiple\">\n                            <mat-option *ngFor=\"let item of group.controls[field.name].value | slice:0:30\" [value]=\"item\"\n                            style=\"display:none\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-option>\n                        </ng-container>\n\n                        <ng-container *ngIf=\"!field.multiple && group.controls[field.name].value\">\n                            <mat-option *ngFor=\"let item of [group?.controls[field.name]?.value]\" [value]=\"item\" style=\"display:none\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-option>\n                        </ng-container>\n                    </ng-container>\n\n                    <ng-container *ngIf=\"field.autocompleteComponent\">\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                        <ng-container *ngIf=\"field.multiple\">\n                            <mat-option *ngFor=\"let item of group.controls[field.name].value | slice:0:30\" [value]=\"item\"\n                            style=\"display:none\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-option>\n                        </ng-container>\n\n                        <ng-container *ngIf=\"!field.multiple && group.controls[field.name].value\">\n                            <mat-option *ngFor=\"let item of [group?.controls[field.name]?.value]\" [value]=\"item\" style=\"display:none\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-option>\n                        </ng-container>\n                    </ng-container>\n                </ng-container>\n                <ng-template #emptyOption>\n                    <mat-option class=\"hide-checkbox\" disabled><div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                </ng-template>\n            </cdk-virtual-scroll-viewport>\n\n        </ng-container>\n\n        <ng-container *ngIf=\"!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            <ng-container *ngIf=\"!isLoading; else emptyOption\">\n                <mat-checkbox *ngIf=\"field.multiple\" class=\"selectAll\" [formControl]=\"selectAllControl\"\n                        (change)=\"toggleAllSelection($event)\">\n                        {{'selectAll' | translate}}\n                </mat-checkbox>\n                <ng-container *ngIf=\"!field.autocompleteComponent\">\n                    <mat-option *ngFor=\"let item of optionsFiltered$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n                </ng-container>\n\n                <ng-container *ngIf=\"field.autocompleteComponent\">\n                    <mat-option *ngFor=\"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                </ng-container>\n            </ng-container>\n\n            <ng-template #emptyOption>\n                <mat-option class=\"hide-checkbox\" disabled><div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n            </ng-template>\n        </ng-container>\n        </mat-select>\n\n        <div matSuffix>\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%)}', '.selectAll {padding: 10px 16px;}',\n        `::ng-deep .hide-checkbox .mat-pseudo-checkbox { display: none !important;  }`],\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);\n                })\n            )\n            .subscribe((options) => {\n                this.optionsFiltered$.next(options);\n                this.isLoading = false;\n                this.ref.markForCheck();\n            });\n    }\n}\n"]}
@@ -2,8 +2,8 @@ import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';
2
2
  import { Component, ViewChild, ViewChildren } from '@angular/core';
3
3
  import { UntypedFormControl } from '@angular/forms';
4
4
  import { MatOption } from '@angular/material/core';
5
- import { BehaviorSubject, concat, Observable, of, ReplaySubject, Subject } from 'rxjs';
6
- import { distinctUntilChanged, map, startWith, switchMap, take, takeUntil } from 'rxjs/operators';
5
+ import { BehaviorSubject, concat, Observable, of, ReplaySubject } from 'rxjs';
6
+ import { debounceTime, map, startWith, switchMap, take, takeUntil } from 'rxjs/operators';
7
7
  import { KlesFieldAbstract } from './field.abstract';
8
8
  import * as i0 from "@angular/core";
9
9
  import * as i1 from "@angular/common";
@@ -30,7 +30,7 @@ export class KlesFormSelectSearchComponent extends KlesFieldAbstract {
30
30
  this.selectAllControl = new UntypedFormControl(false);
31
31
  this.isLoading = false;
32
32
  this.optionsFiltered$ = new ReplaySubject(1);
33
- this.openChange$ = new Subject();
33
+ this.openChange$ = new BehaviorSubject(false);
34
34
  this.compareFn = (o1, o2) => {
35
35
  if (this.field.property && o1 && o2) {
36
36
  return o1[this.field.property] === o2[this.field.property];
@@ -49,15 +49,7 @@ export class KlesFormSelectSearchComponent extends KlesFieldAbstract {
49
49
  else {
50
50
  this.options$ = new BehaviorSubject([]);
51
51
  }
52
- this.openChange$
53
- .pipe(takeUntil(this._onDestroy), switchMap((isOpen) => {
54
- return this.onOpenChange(isOpen);
55
- }))
56
- .subscribe((options) => {
57
- this.options$.next(options);
58
- this.isLoading = false;
59
- this.ref.markForCheck();
60
- });
52
+ this.openChangeEvent();
61
53
  }
62
54
  else {
63
55
  if (this.field.options instanceof Observable) {
@@ -70,11 +62,12 @@ export class KlesFormSelectSearchComponent extends KlesFieldAbstract {
70
62
  this.options$ = of(this.field.options);
71
63
  }
72
64
  }
73
- this.searchControl.valueChanges.pipe(takeUntil(this._onDestroy), startWith(this.searchControl.value), distinctUntilChanged(), switchMap(value => {
65
+ this.searchControl.valueChanges.pipe(takeUntil(this._onDestroy), debounceTime(this.field.debounceTime || 0), startWith(this.searchControl.value), switchMap(value => {
74
66
  return concat(of({ loading: true, options: [] }), this.onSearchChange(value).pipe(map((options) => ({ loading: false, options }))));
75
67
  })).subscribe(({ loading, options }) => {
76
68
  this.isLoading = loading;
77
69
  this.optionsFiltered$.next(options);
70
+ this.ref.markForCheck();
78
71
  });
79
72
  if (this.field.multiple) {
80
73
  this.group.controls[this.field.name]
@@ -111,6 +104,17 @@ export class KlesFormSelectSearchComponent extends KlesFieldAbstract {
111
104
  this.group.controls[this.field.name].patchValue([]);
112
105
  }
113
106
  }
107
+ openChangeEvent() {
108
+ this.openChange$
109
+ .pipe(takeUntil(this._onDestroy), switchMap((isOpen) => {
110
+ return this.onOpenChange(isOpen);
111
+ }))
112
+ .subscribe((options) => {
113
+ this.options$.next(options);
114
+ this.isLoading = false;
115
+ this.ref.markForCheck();
116
+ });
117
+ }
114
118
  onOpenChange(isOpen) {
115
119
  if (isOpen) {
116
120
  if (this.field.options instanceof Observable) {
@@ -119,7 +123,7 @@ export class KlesFormSelectSearchComponent extends KlesFieldAbstract {
119
123
  }
120
124
  else if (this.field.options instanceof Function) {
121
125
  this.isLoading = true;
122
- return this.field.options();
126
+ return this.field.options().pipe(take(1));
123
127
  }
124
128
  else {
125
129
  return of(this.field.options);
@@ -389,4 +393,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
389
393
  type: ViewChildren,
390
394
  args: [MatOption]
391
395
  }] } });
392
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.search.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/select.search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\nimport { ViewEncapsulation } from '@angular/compiler';\nimport { ChangeDetectorRef, Component, OnDestroy, OnInit, QueryList, ViewChild, ViewChildren, ViewContainerRef } from '@angular/core';\nimport { UntypedFormControl } from '@angular/forms';\nimport { MatOption } from '@angular/material/core';\nimport { BehaviorSubject, concat, Observable, of, ReplaySubject, Subject } from 'rxjs';\nimport { distinctUntilChanged, map, startWith, switchMap, take, takeUntil } from 'rxjs/operators';\nimport { KlesFieldAbstract } from './field.abstract';\n\n@Component({\n    selector: 'kles-form-select-search',\n    template: `\n    <mat-form-field class=\"margin-top\" [color]=\"field.color\" [formGroup]=\"group\">\n        <mat-select matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\" [ngClass]=\"field.ngClass\"\n        (openedChange)=\"openChange($event)\" [compareWith]=\"compareFn\"\n        [placeholder]=\"field.placeholder | translate\" [formControlName]=\"field.name\" [multiple]=\"field.multiple\">\n        <mat-select-trigger *ngIf=\"field.triggerComponent\">\n            <ng-container klesComponent [component]=\"field.triggerComponent\" [value]=\"group.controls[field.name].value\" [field]=\"field\"></ng-container>\n        </mat-select-trigger>\n\n        <ng-container *ngIf=\"field.virtualScroll\">\n            <mat-option>\n                <ngx-mat-select-search [formControl]=\"searchControl\"\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                <ng-container *ngIf=\"!isLoading; else emptyOption\">\n                    <mat-checkbox *ngIf=\"field.multiple\" class=\"selectAll\" [formControl]=\"selectAllControl\"\n                    (change)=\"toggleAllSelection($event)\">\n                        {{'selectAll' | translate}}\n                    </mat-checkbox>\n                    <ng-container *ngIf=\"!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                        <ng-container *ngIf=\"field.multiple\">\n                            <mat-option *ngFor=\"let item of group.controls[field.name].value | slice:0:30\" [value]=\"item\"\n                            style=\"display:none\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-option>\n                        </ng-container>\n\n                        <ng-container *ngIf=\"!field.multiple && group.controls[field.name].value\">\n                            <mat-option *ngFor=\"let item of [group?.controls[field.name]?.value]\" [value]=\"item\" style=\"display:none\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-option>\n                        </ng-container>\n                    </ng-container>\n\n                    <ng-container *ngIf=\"field.autocompleteComponent\">\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                        <ng-container *ngIf=\"field.multiple\">\n                            <mat-option *ngFor=\"let item of group.controls[field.name].value | slice:0:30\" [value]=\"item\"\n                            style=\"display:none\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-option>\n                        </ng-container>\n\n                        <ng-container *ngIf=\"!field.multiple && group.controls[field.name].value\">\n                            <mat-option *ngFor=\"let item of [group?.controls[field.name]?.value]\" [value]=\"item\" style=\"display:none\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-option>\n                        </ng-container>\n                    </ng-container>\n                </ng-container>\n                <ng-template #emptyOption>\n                    <mat-option class=\"hide-checkbox\" disabled><div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                </ng-template>\n            </cdk-virtual-scroll-viewport>\n\n        </ng-container>\n\n        <ng-container *ngIf=\"!field.virtualScroll\">\n            <mat-option>\n                <ngx-mat-select-search [formControl]=\"searchControl\"\n                placeholderLabel=\"\" noEntriesFoundLabel =\"\"></ngx-mat-select-search>\n            </mat-option>\n\n            <ng-container *ngIf=\"!isLoading; else emptyOption\">\n                <mat-checkbox *ngIf=\"field.multiple\" class=\"selectAll\" [formControl]=\"selectAllControl\"\n                        (change)=\"toggleAllSelection($event)\">\n                        {{'selectAll' | translate}}\n                </mat-checkbox>\n                <ng-container *ngIf=\"!field.autocompleteComponent\">\n                    <mat-option *ngFor=\"let item of optionsFiltered$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n                </ng-container>\n\n                <ng-container *ngIf=\"field.autocompleteComponent\">\n                    <mat-option *ngFor=\"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                </ng-container>\n            </ng-container>\n\n            <ng-template #emptyOption>\n                <mat-option class=\"hide-checkbox\" disabled><div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n            </ng-template>\n        </ng-container>\n        </mat-select>\n\n        <div matSuffix>\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%)}', '.selectAll {padding: 10px 16px;}',\n        `::ng-deep .hide-checkbox .mat-pseudo-checkbox { display: none !important;  }`],\n})\nexport class KlesFormSelectSearchComponent extends KlesFieldAbstract implements OnInit, OnDestroy {\n\n    searchControl = new UntypedFormControl();\n    selectAllControl = new UntypedFormControl(false);\n\n    isLoading = false;\n\n    options$: Observable<any[]>;\n    optionsFiltered$ = new ReplaySubject<any[]>(1);\n\n    openChange$ = new Subject<boolean>();\n\n    // private _onDestroy = new Subject<void>();\n\n    @ViewChild(CdkVirtualScrollViewport) cdkVirtualScrollViewport: CdkVirtualScrollViewport;\n    @ViewChildren(MatOption) options: QueryList<MatOption>;\n\n    constructor(protected viewRef: ViewContainerRef, protected ref: ChangeDetectorRef) {\n        super(viewRef);\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n\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 : [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                        return this.onOpenChange(isOpen);\n                    })\n                )\n                .subscribe((options) => {\n                    (this.options$ as BehaviorSubject<any[]>).next(options);\n                    this.isLoading = false;\n                    this.ref.markForCheck();\n                });\n        } else {\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.searchControl.valueChanges.pipe(\n            takeUntil(this._onDestroy),\n            startWith(this.searchControl.value),\n            distinctUntilChanged(),\n            switchMap(value => {\n                return concat(\n                    of({ loading: true, options: [] }),\n                    this.onSearchChange(value).pipe(map((options) => ({ loading: false, options })))\n                )\n\n            })\n        ).subscribe(({ loading, options }) => {\n            this.isLoading = loading;\n            this.optionsFiltered$.next(options);\n        });\n\n        if (this.field.multiple) {\n            this.group.controls[this.field.name]\n                .valueChanges.pipe(\n                    takeUntil(this._onDestroy),\n                    startWith(this.group.controls[this.field.name].value),\n                    map((selected) => (this.field.property ? selected?.map(s => s[this.field.property]) : selected)),\n                    switchMap(selected => {\n                        return this.optionsFiltered$.pipe(\n                            map((options) => options?.filter((option) => !option?.disabled).map((option) => (this.field.property ? option[this.field.property] : option))),\n                            map(options => {\n                                if (!selected) {\n                                    return false;\n                                }\n                                if (options.length < selected.length) {\n                                    return options.length > 0 && options.every(o => selected.includes(o));\n                                } else {\n                                    return options.length > 0 && options.length === selected.length && selected.every(s => options.includes(s));\n                                }\n                            }));\n                    })\n                ).subscribe(isChecked => {\n                    this.selectAllControl.setValue(isChecked);\n                });\n        }\n    }\n\n    ngOnDestroy(): void {\n        // this._onDestroy.next();\n        super.ngOnDestroy();\n    }\n\n\n    toggleAllSelection(state) {\n        if (state.checked) {\n            this.optionsFiltered$.pipe(take(1), map((options) => options.filter((option) => !option?.disabled))).subscribe(options => {\n                if (options.length > 0) {\n                    this.group.controls[this.field.name].patchValue(options.slice());\n                }\n            });\n\n        } else {\n            this.group.controls[this.field.name].patchValue([]);\n        }\n    }\n\n    protected onOpenChange(isOpen: boolean): Observable<any[]> {\n        if (isOpen) {\n\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    protected onSearchChange(value: string): Observable<any[]> {\n        if (value) {\n            const search = value.toLowerCase();\n            return this.options$.pipe(map(options => {\n                return options\n                    .filter(option => {\n                        if (this.field.searchKeys && this.field.searchKeys.length) {\n                            return this.field.searchKeys.some(searchKey => {\n                                if (option[searchKey]) {\n                                    return option[searchKey].toString().toLowerCase().indexOf(search) > -1;\n                                }\n                                return false;\n                            }) || (this.field.property ?\n                                option[this.field.property].toString().toLowerCase().indexOf(search) > -1 : false);\n\n                        } else {\n                            if (this.field.property) {\n                                return option[this.field.property].toString().toLowerCase().indexOf(search) > -1;\n                            }\n                        }\n                        return option.toString().toLowerCase().indexOf(search) > -1;\n                    });\n            }));\n        } else {\n            return this.options$;\n        }\n    }\n\n    openChange($event: boolean) {\n        if (this.field.lazy) {\n            this.openChange$.next($event);\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"]}
396
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.search.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/select.search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\nimport { ViewEncapsulation } from '@angular/compiler';\nimport { ChangeDetectorRef, Component, OnDestroy, OnInit, QueryList, ViewChild, ViewChildren, ViewContainerRef } from '@angular/core';\nimport { UntypedFormControl } from '@angular/forms';\nimport { MatOption } from '@angular/material/core';\nimport { BehaviorSubject, concat, Observable, of, ReplaySubject, Subject } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, map, startWith, switchMap, take, takeUntil, tap } from 'rxjs/operators';\nimport { KlesFieldAbstract } from './field.abstract';\n\n@Component({\n    selector: 'kles-form-select-search',\n    template: `\n    <mat-form-field class=\"margin-top\" [color]=\"field.color\" [formGroup]=\"group\">\n        <mat-select matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\" [ngClass]=\"field.ngClass\"\n        (openedChange)=\"openChange($event)\" [compareWith]=\"compareFn\"\n        [placeholder]=\"field.placeholder | translate\" [formControlName]=\"field.name\" [multiple]=\"field.multiple\">\n        <mat-select-trigger *ngIf=\"field.triggerComponent\">\n            <ng-container klesComponent [component]=\"field.triggerComponent\" [value]=\"group.controls[field.name].value\" [field]=\"field\"></ng-container>\n        </mat-select-trigger>\n\n        <ng-container *ngIf=\"field.virtualScroll\">\n            <mat-option>\n                <ngx-mat-select-search [formControl]=\"searchControl\"\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                <ng-container *ngIf=\"!isLoading; else emptyOption\">\n                    <mat-checkbox *ngIf=\"field.multiple\" class=\"selectAll\" [formControl]=\"selectAllControl\"\n                    (change)=\"toggleAllSelection($event)\">\n                        {{'selectAll' | translate}}\n                    </mat-checkbox>\n                    <ng-container *ngIf=\"!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                        <ng-container *ngIf=\"field.multiple\">\n                            <mat-option *ngFor=\"let item of group.controls[field.name].value | slice:0:30\" [value]=\"item\"\n                            style=\"display:none\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-option>\n                        </ng-container>\n\n                        <ng-container *ngIf=\"!field.multiple && group.controls[field.name].value\">\n                            <mat-option *ngFor=\"let item of [group?.controls[field.name]?.value]\" [value]=\"item\" style=\"display:none\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-option>\n                        </ng-container>\n                    </ng-container>\n\n                    <ng-container *ngIf=\"field.autocompleteComponent\">\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                        <ng-container *ngIf=\"field.multiple\">\n                            <mat-option *ngFor=\"let item of group.controls[field.name].value | slice:0:30\" [value]=\"item\"\n                            style=\"display:none\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-option>\n                        </ng-container>\n\n                        <ng-container *ngIf=\"!field.multiple && group.controls[field.name].value\">\n                            <mat-option *ngFor=\"let item of [group?.controls[field.name]?.value]\" [value]=\"item\" style=\"display:none\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-option>\n                        </ng-container>\n                    </ng-container>\n                </ng-container>\n                <ng-template #emptyOption>\n                    <mat-option class=\"hide-checkbox\" disabled><div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                </ng-template>\n            </cdk-virtual-scroll-viewport>\n\n        </ng-container>\n\n        <ng-container *ngIf=\"!field.virtualScroll\">\n            <mat-option>\n                <ngx-mat-select-search [formControl]=\"searchControl\"\n                placeholderLabel=\"\" noEntriesFoundLabel =\"\"></ngx-mat-select-search>\n            </mat-option>\n\n            <ng-container *ngIf=\"!isLoading; else emptyOption\">\n                <mat-checkbox *ngIf=\"field.multiple\" class=\"selectAll\" [formControl]=\"selectAllControl\"\n                        (change)=\"toggleAllSelection($event)\">\n                        {{'selectAll' | translate}}\n                </mat-checkbox>\n                <ng-container *ngIf=\"!field.autocompleteComponent\">\n                    <mat-option *ngFor=\"let item of optionsFiltered$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n                </ng-container>\n\n                <ng-container *ngIf=\"field.autocompleteComponent\">\n                    <mat-option *ngFor=\"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                </ng-container>\n            </ng-container>\n\n            <ng-template #emptyOption>\n                <mat-option class=\"hide-checkbox\" disabled><div fxLayout=\"row\" fxLayoutAlign=\"space-between center\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n            </ng-template>\n        </ng-container>\n        </mat-select>\n\n        <div matSuffix>\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%)}', '.selectAll {padding: 10px 16px;}',\n        `::ng-deep .hide-checkbox .mat-pseudo-checkbox { display: none !important;  }`],\n})\nexport class KlesFormSelectSearchComponent extends KlesFieldAbstract implements OnInit, OnDestroy {\n\n    searchControl = new UntypedFormControl();\n    selectAllControl = new UntypedFormControl(false);\n\n    isLoading = false;\n\n    options$: Observable<any[]>;\n    optionsFiltered$ = new ReplaySubject<any[]>(1);\n\n    openChange$ = new BehaviorSubject<boolean>(false);\n\n    // private _onDestroy = new Subject<void>();\n\n    @ViewChild(CdkVirtualScrollViewport) cdkVirtualScrollViewport: CdkVirtualScrollViewport;\n    @ViewChildren(MatOption) options: QueryList<MatOption>;\n\n    constructor(protected viewRef: ViewContainerRef, protected ref: ChangeDetectorRef) {\n        super(viewRef);\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n\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 : [this.group.controls[this.field.name].value]);\n                this.isLoading = false;\n            } else {\n                this.options$ = new BehaviorSubject<any[]>([]);\n            }\n\n            this.openChangeEvent();\n        } else {\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.searchControl.valueChanges.pipe(\n            takeUntil(this._onDestroy),\n            debounceTime(this.field.debounceTime || 0),\n            startWith(this.searchControl.value),\n            switchMap(value => {\n                return concat(\n                    of({ loading: true, options: [] }),\n                    this.onSearchChange(value).pipe(map((options) => ({ loading: false, options })))\n                )\n\n            })\n        ).subscribe(({ loading, options }) => {\n            this.isLoading = loading;\n            this.optionsFiltered$.next(options);\n            this.ref.markForCheck();\n        });\n\n        if (this.field.multiple) {\n            this.group.controls[this.field.name]\n                .valueChanges.pipe(\n                    takeUntil(this._onDestroy),\n                    startWith(this.group.controls[this.field.name].value),\n                    map((selected) => (this.field.property ? selected?.map(s => s[this.field.property]) : selected)),\n                    switchMap(selected => {\n                        return this.optionsFiltered$.pipe(\n                            map((options) => options?.filter((option) => !option?.disabled).map((option) => (this.field.property ? option[this.field.property] : option))),\n                            map(options => {\n                                if (!selected) {\n                                    return false;\n                                }\n                                if (options.length < selected.length) {\n                                    return options.length > 0 && options.every(o => selected.includes(o));\n                                } else {\n                                    return options.length > 0 && options.length === selected.length && selected.every(s => options.includes(s));\n                                }\n                            }));\n                    })\n                ).subscribe(isChecked => {\n                    this.selectAllControl.setValue(isChecked);\n                });\n        }\n    }\n\n    ngOnDestroy(): void {\n        // this._onDestroy.next();\n        super.ngOnDestroy();\n    }\n\n\n    toggleAllSelection(state) {\n        if (state.checked) {\n            this.optionsFiltered$.pipe(take(1), map((options) => options.filter((option) => !option?.disabled))).subscribe(options => {\n                if (options.length > 0) {\n                    this.group.controls[this.field.name].patchValue(options.slice());\n                }\n            });\n\n        } else {\n            this.group.controls[this.field.name].patchValue([]);\n        }\n    }\n\n\n    protected openChangeEvent(): void {\n        this.openChange$\n            .pipe(\n                takeUntil(this._onDestroy),\n                switchMap((isOpen) => {\n                    return this.onOpenChange(isOpen);\n                })\n            )\n            .subscribe((options) => {\n                (this.options$ as BehaviorSubject<any[]>).next(options);\n                this.isLoading = false;\n                this.ref.markForCheck();\n            });\n    }\n\n    protected onOpenChange(isOpen: boolean): Observable<any[]> {\n        if (isOpen) {\n\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().pipe(take(1));\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    protected onSearchChange(value: string): Observable<any[]> {\n        if (value) {\n            const search = value.toLowerCase();\n            return this.options$.pipe(map(options => {\n                return options\n                    .filter(option => {\n                        if (this.field.searchKeys && this.field.searchKeys.length) {\n                            return this.field.searchKeys.some(searchKey => {\n                                if (option[searchKey]) {\n                                    return option[searchKey].toString().toLowerCase().indexOf(search) > -1;\n                                }\n                                return false;\n                            }) || (this.field.property ?\n                                option[this.field.property].toString().toLowerCase().indexOf(search) > -1 : false);\n\n                        } else {\n                            if (this.field.property) {\n                                return option[this.field.property].toString().toLowerCase().indexOf(search) > -1;\n                            }\n                        }\n                        return option.toString().toLowerCase().indexOf(search) > -1;\n                    });\n            }));\n        } else {\n            return this.options$;\n        }\n    }\n\n    openChange($event: boolean) {\n        if (this.field.lazy) {\n            this.openChange$.next($event);\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"]}
@@ -5,7 +5,7 @@ import { CommonModule } from '@angular/common';
5
5
  import * as i2 from '@angular/forms';
6
6
  import { FormControl, Validators, FormControlDirective, FormControlName, NG_VALUE_ACCESSOR, UntypedFormGroup, UntypedFormControl, FormArray, FormGroup, ReactiveFormsModule, FormsModule } from '@angular/forms';
7
7
  import { concat, of, Subject, Observable, BehaviorSubject, ReplaySubject } from 'rxjs';
8
- import { take, catchError, map, takeUntil, startWith, switchMap, distinctUntilChanged } from 'rxjs/operators';
8
+ import { take, catchError, map, takeUntil, startWith, switchMap, debounceTime } from 'rxjs/operators';
9
9
  import * as i7$1 from '@angular/material/core';
10
10
  import { MAT_DATE_LOCALE, MAT_DATE_FORMATS, MatNativeDateModule, MatOption, ErrorStateMatcher } from '@angular/material/core';
11
11
  import * as i4 from '@angular/material/button';
@@ -2362,7 +2362,7 @@ class KlesFormSelectSearchComponent extends KlesFieldAbstract {
2362
2362
  this.selectAllControl = new UntypedFormControl(false);
2363
2363
  this.isLoading = false;
2364
2364
  this.optionsFiltered$ = new ReplaySubject(1);
2365
- this.openChange$ = new Subject();
2365
+ this.openChange$ = new BehaviorSubject(false);
2366
2366
  this.compareFn = (o1, o2) => {
2367
2367
  if (this.field.property && o1 && o2) {
2368
2368
  return o1[this.field.property] === o2[this.field.property];
@@ -2381,15 +2381,7 @@ class KlesFormSelectSearchComponent extends KlesFieldAbstract {
2381
2381
  else {
2382
2382
  this.options$ = new BehaviorSubject([]);
2383
2383
  }
2384
- this.openChange$
2385
- .pipe(takeUntil(this._onDestroy), switchMap((isOpen) => {
2386
- return this.onOpenChange(isOpen);
2387
- }))
2388
- .subscribe((options) => {
2389
- this.options$.next(options);
2390
- this.isLoading = false;
2391
- this.ref.markForCheck();
2392
- });
2384
+ this.openChangeEvent();
2393
2385
  }
2394
2386
  else {
2395
2387
  if (this.field.options instanceof Observable) {
@@ -2402,11 +2394,12 @@ class KlesFormSelectSearchComponent extends KlesFieldAbstract {
2402
2394
  this.options$ = of(this.field.options);
2403
2395
  }
2404
2396
  }
2405
- this.searchControl.valueChanges.pipe(takeUntil(this._onDestroy), startWith(this.searchControl.value), distinctUntilChanged(), switchMap(value => {
2397
+ this.searchControl.valueChanges.pipe(takeUntil(this._onDestroy), debounceTime(this.field.debounceTime || 0), startWith(this.searchControl.value), switchMap(value => {
2406
2398
  return concat(of({ loading: true, options: [] }), this.onSearchChange(value).pipe(map((options) => ({ loading: false, options }))));
2407
2399
  })).subscribe(({ loading, options }) => {
2408
2400
  this.isLoading = loading;
2409
2401
  this.optionsFiltered$.next(options);
2402
+ this.ref.markForCheck();
2410
2403
  });
2411
2404
  if (this.field.multiple) {
2412
2405
  this.group.controls[this.field.name]
@@ -2443,6 +2436,17 @@ class KlesFormSelectSearchComponent extends KlesFieldAbstract {
2443
2436
  this.group.controls[this.field.name].patchValue([]);
2444
2437
  }
2445
2438
  }
2439
+ openChangeEvent() {
2440
+ this.openChange$
2441
+ .pipe(takeUntil(this._onDestroy), switchMap((isOpen) => {
2442
+ return this.onOpenChange(isOpen);
2443
+ }))
2444
+ .subscribe((options) => {
2445
+ this.options$.next(options);
2446
+ this.isLoading = false;
2447
+ this.ref.markForCheck();
2448
+ });
2449
+ }
2446
2450
  onOpenChange(isOpen) {
2447
2451
  if (isOpen) {
2448
2452
  if (this.field.options instanceof Observable) {
@@ -2451,7 +2455,7 @@ class KlesFormSelectSearchComponent extends KlesFieldAbstract {
2451
2455
  }
2452
2456
  else if (this.field.options instanceof Function) {
2453
2457
  this.isLoading = true;
2454
- return this.field.options();
2458
+ return this.field.options().pipe(take(1));
2455
2459
  }
2456
2460
  else {
2457
2461
  return of(this.field.options);
@@ -3126,33 +3130,39 @@ class KlesFormSelectLazySearchComponent extends KlesFormSelectSearchComponent {
3126
3130
  }
3127
3131
  ngOnInit() {
3128
3132
  this.field.lazy = true;
3133
+ this.field.debounceTime = this.field.debounceTime ? this.field.debounceTime : 500;
3129
3134
  super.ngOnInit();
3130
- this.openChange$.pipe(takeUntil(this._onDestroy))
3131
- .subscribe((open) => {
3132
- if (open) {
3133
- this.searchControl.reset(null);
3134
- }
3135
- else {
3136
- this.searchControl.reset(null, { emitEvent: false });
3137
- }
3138
- });
3139
3135
  }
3140
3136
  ngOnDestroy() {
3141
3137
  super.ngOnDestroy();
3142
3138
  }
3143
3139
  onSearchChange(value) {
3144
3140
  if (this.field.options instanceof Function) {
3145
- if (value) {
3146
- return this.field.options(value).pipe(take(1));
3147
- }
3148
- else {
3149
- return this.field.options().pipe(take(1));
3141
+ if (this.openChange$.getValue() && this.field.options instanceof Function) {
3142
+ if (value) {
3143
+ return this.field.options(value).pipe(take(1));
3144
+ }
3145
+ else {
3146
+ return this.field.options().pipe(take(1));
3147
+ }
3150
3148
  }
3149
+ return of(this.group.controls[this.field.name].value ? [this.group.controls[this.field.name].value] : []);
3151
3150
  }
3152
3151
  else {
3153
3152
  return super.onSearchChange(value);
3154
3153
  }
3155
3154
  }
3155
+ openChangeEvent() {
3156
+ this.openChange$
3157
+ .pipe(takeUntil(this._onDestroy), switchMap((isOpen) => {
3158
+ return this.onOpenChange(isOpen);
3159
+ }))
3160
+ .subscribe((options) => {
3161
+ this.optionsFiltered$.next(options);
3162
+ this.isLoading = false;
3163
+ this.ref.markForCheck();
3164
+ });
3165
+ }
3156
3166
  }
3157
3167
  KlesFormSelectLazySearchComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: KlesFormSelectLazySearchComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
3158
3168
  KlesFormSelectLazySearchComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: KlesFormSelectLazySearchComponent, selector: "kles-form-select-lazy-search", usesInheritance: true, ngImport: i0, template: `