@3kles/kles-material-dynamicforms 14.9.2 → 14.9.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/fields/select.lazy-search.component.mjs +26 -16
- package/esm2020/lib/fields/select.search.component.mjs +18 -15
- package/fesm2015/3kles-kles-material-dynamicforms.mjs +39 -27
- package/fesm2015/3kles-kles-material-dynamicforms.mjs.map +1 -1
- package/fesm2020/3kles-kles-material-dynamicforms.mjs +39 -27
- package/fesm2020/3kles-kles-material-dynamicforms.mjs.map +1 -1
- package/lib/fields/select.lazy-search.component.d.ts +1 -0
- package/lib/fields/select.search.component.d.ts +3 -2
- package/package.json +1 -1
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Component } from '@angular/core';
|
|
2
|
-
import {
|
|
2
|
+
import { of } from 'rxjs';
|
|
3
|
+
import { map, 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,42 @@ 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 (
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
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).pipe(map((options) => ({ options, isOpen })));
|
|
55
|
+
}))
|
|
56
|
+
.subscribe(({ options, isOpen }) => {
|
|
57
|
+
if (!isOpen) {
|
|
58
|
+
this.searchControl.reset(null, { emitEvent: false });
|
|
59
|
+
}
|
|
60
|
+
this.optionsFiltered$.next(options);
|
|
61
|
+
this.isLoading = false;
|
|
62
|
+
this.ref.markForCheck();
|
|
63
|
+
});
|
|
64
|
+
}
|
|
55
65
|
}
|
|
56
66
|
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
67
|
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 +275,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
265
275
|
</mat-form-field>
|
|
266
276
|
`, styles: ["mat-form-field{width:100%}\n", ".selectAll{padding:10px 16px}\n", "::ng-deep .hide-checkbox .mat-pseudo-checkbox{display:none!important}\n"] }]
|
|
267
277
|
}], 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"]}
|
|
278
|
+
//# 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 { 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).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"]}
|
|
@@ -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
|
|
6
|
-
import { debounceTime,
|
|
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
|
|
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.
|
|
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,7 +62,7 @@ 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), debounceTime(
|
|
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;
|
|
@@ -112,6 +104,17 @@ export class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
112
104
|
this.group.controls[this.field.name].patchValue([]);
|
|
113
105
|
}
|
|
114
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
|
+
}
|
|
115
118
|
onOpenChange(isOpen) {
|
|
116
119
|
if (isOpen) {
|
|
117
120
|
if (this.field.options instanceof Observable) {
|
|
@@ -120,7 +123,7 @@ export class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
120
123
|
}
|
|
121
124
|
else if (this.field.options instanceof Function) {
|
|
122
125
|
this.isLoading = true;
|
|
123
|
-
return this.field.options();
|
|
126
|
+
return this.field.options().pipe(take(1));
|
|
124
127
|
}
|
|
125
128
|
else {
|
|
126
129
|
return of(this.field.options);
|
|
@@ -390,4 +393,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
390
393
|
type: ViewChildren,
|
|
391
394
|
args: [MatOption]
|
|
392
395
|
}] } });
|
|
393
|
-
//# 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 } 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            debounceTime(200),\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            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    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, debounceTime
|
|
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
|
|
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.
|
|
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,7 +2394,7 @@ class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
2402
2394
|
this.options$ = of(this.field.options);
|
|
2403
2395
|
}
|
|
2404
2396
|
}
|
|
2405
|
-
this.searchControl.valueChanges.pipe(takeUntil(this._onDestroy), debounceTime(
|
|
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;
|
|
@@ -2444,6 +2436,17 @@ class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
2444
2436
|
this.group.controls[this.field.name].patchValue([]);
|
|
2445
2437
|
}
|
|
2446
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
|
+
}
|
|
2447
2450
|
onOpenChange(isOpen) {
|
|
2448
2451
|
if (isOpen) {
|
|
2449
2452
|
if (this.field.options instanceof Observable) {
|
|
@@ -2452,7 +2455,7 @@ class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
2452
2455
|
}
|
|
2453
2456
|
else if (this.field.options instanceof Function) {
|
|
2454
2457
|
this.isLoading = true;
|
|
2455
|
-
return this.field.options();
|
|
2458
|
+
return this.field.options().pipe(take(1));
|
|
2456
2459
|
}
|
|
2457
2460
|
else {
|
|
2458
2461
|
return of(this.field.options);
|
|
@@ -3127,33 +3130,42 @@ class KlesFormSelectLazySearchComponent extends KlesFormSelectSearchComponent {
|
|
|
3127
3130
|
}
|
|
3128
3131
|
ngOnInit() {
|
|
3129
3132
|
this.field.lazy = true;
|
|
3133
|
+
this.field.debounceTime = this.field.debounceTime ? this.field.debounceTime : 500;
|
|
3130
3134
|
super.ngOnInit();
|
|
3131
|
-
this.openChange$.pipe(takeUntil(this._onDestroy))
|
|
3132
|
-
.subscribe((open) => {
|
|
3133
|
-
if (open) {
|
|
3134
|
-
this.searchControl.reset(null);
|
|
3135
|
-
}
|
|
3136
|
-
else {
|
|
3137
|
-
this.searchControl.reset(null, { emitEvent: false });
|
|
3138
|
-
}
|
|
3139
|
-
});
|
|
3140
3135
|
}
|
|
3141
3136
|
ngOnDestroy() {
|
|
3142
3137
|
super.ngOnDestroy();
|
|
3143
3138
|
}
|
|
3144
3139
|
onSearchChange(value) {
|
|
3145
3140
|
if (this.field.options instanceof Function) {
|
|
3146
|
-
if (
|
|
3147
|
-
|
|
3148
|
-
|
|
3149
|
-
|
|
3150
|
-
|
|
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
|
+
}
|
|
3151
3148
|
}
|
|
3149
|
+
return of(this.group.controls[this.field.name].value ? [this.group.controls[this.field.name].value] : []);
|
|
3152
3150
|
}
|
|
3153
3151
|
else {
|
|
3154
3152
|
return super.onSearchChange(value);
|
|
3155
3153
|
}
|
|
3156
3154
|
}
|
|
3155
|
+
openChangeEvent() {
|
|
3156
|
+
this.openChange$
|
|
3157
|
+
.pipe(takeUntil(this._onDestroy), switchMap((isOpen) => {
|
|
3158
|
+
return this.onOpenChange(isOpen).pipe(map((options) => ({ options, isOpen })));
|
|
3159
|
+
}))
|
|
3160
|
+
.subscribe(({ options, isOpen }) => {
|
|
3161
|
+
if (!isOpen) {
|
|
3162
|
+
this.searchControl.reset(null, { emitEvent: false });
|
|
3163
|
+
}
|
|
3164
|
+
this.optionsFiltered$.next(options);
|
|
3165
|
+
this.isLoading = false;
|
|
3166
|
+
this.ref.markForCheck();
|
|
3167
|
+
});
|
|
3168
|
+
}
|
|
3157
3169
|
}
|
|
3158
3170
|
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 });
|
|
3159
3171
|
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: `
|