@3kles/kles-material-dynamicforms 17.7.6 → 17.7.7
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.
|
@@ -62,28 +62,18 @@ export class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
62
62
|
}
|
|
63
63
|
}
|
|
64
64
|
this.searchControl.valueChanges.pipe(takeUntil(this._onDestroy), debounceTime(this.field.debounceTime || 0), startWith(this.searchControl.value), switchMap(value => {
|
|
65
|
-
return concat(of({ loading: true, options: [] }), this.onSearchChange(value).pipe(map((options) => ({ loading: false, options }))));
|
|
65
|
+
return concat(of({ loading: true, options: [] }), this.onSearchChange(value).pipe(take(1), map((options) => ({ loading: false, options }))));
|
|
66
66
|
})).subscribe(({ loading, options }) => {
|
|
67
67
|
this.isLoading = loading;
|
|
68
68
|
this.optionsFiltered$.next(options);
|
|
69
69
|
this.ref.markForCheck();
|
|
70
70
|
});
|
|
71
71
|
if (this.field.multiple) {
|
|
72
|
-
this.group.controls[this.field.name]
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
}
|
|
78
|
-
if (options.length < selected.length) {
|
|
79
|
-
return options.length > 0 && options.every(o => selected.includes(o));
|
|
80
|
-
}
|
|
81
|
-
else {
|
|
82
|
-
return options.length > 0 && options.length === selected.length && selected.every(s => options.includes(s));
|
|
83
|
-
}
|
|
84
|
-
}));
|
|
85
|
-
})).subscribe(isChecked => {
|
|
86
|
-
this.selectAllControl.setValue(isChecked);
|
|
72
|
+
this.updateSelectAllControl(this.group.controls[this.field.name].value);
|
|
73
|
+
this.group.controls[this.field.name].registerOnChange((values, emitViewToModelChange) => {
|
|
74
|
+
if (emitViewToModelChange) {
|
|
75
|
+
this.updateSelectAllControl(values);
|
|
76
|
+
}
|
|
87
77
|
});
|
|
88
78
|
}
|
|
89
79
|
}
|
|
@@ -95,12 +85,12 @@ export class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
95
85
|
if (state.checked) {
|
|
96
86
|
this.optionsFiltered$.pipe(take(1), map((options) => options.filter((option) => !option?.disabled))).subscribe(options => {
|
|
97
87
|
if (options.length > 0) {
|
|
98
|
-
this.group.controls[this.field.name].patchValue(options.slice());
|
|
88
|
+
this.group.controls[this.field.name].patchValue(options.slice(), { emitModelToViewChange: false });
|
|
99
89
|
}
|
|
100
90
|
});
|
|
101
91
|
}
|
|
102
92
|
else {
|
|
103
|
-
this.group.controls[this.field.name].patchValue([]);
|
|
93
|
+
this.group.controls[this.field.name].patchValue([], { emitModelToViewChange: false });
|
|
104
94
|
}
|
|
105
95
|
}
|
|
106
96
|
openChangeEvent() {
|
|
@@ -109,8 +99,9 @@ export class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
109
99
|
return this.onOpenChange(isOpen);
|
|
110
100
|
}))
|
|
111
101
|
.subscribe((options) => {
|
|
112
|
-
this.options$.next(options);
|
|
113
102
|
this.isLoading = false;
|
|
103
|
+
this.options$.next(options);
|
|
104
|
+
this.optionsFiltered$.next(options);
|
|
114
105
|
this.ref.markForCheck();
|
|
115
106
|
});
|
|
116
107
|
}
|
|
@@ -173,6 +164,29 @@ export class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
173
164
|
}
|
|
174
165
|
}
|
|
175
166
|
}
|
|
167
|
+
selectionChange(selection) {
|
|
168
|
+
if (this.field.multiple) {
|
|
169
|
+
this.updateSelectAllControl(selection.value);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
updateSelectAllControl(values) {
|
|
173
|
+
if (values) {
|
|
174
|
+
const selected = ((this.field.property && values) ? values?.map(s => s[this.field.property]) : values);
|
|
175
|
+
this.optionsFiltered$.pipe(take(1), map((options) => options?.filter((option) => !option?.disabled).map((option) => (this.field.property ? option[this.field.property] : option))), map(options => {
|
|
176
|
+
if (!selected) {
|
|
177
|
+
return false;
|
|
178
|
+
}
|
|
179
|
+
if (options.length < selected.length) {
|
|
180
|
+
return options.length > 0 && options.every(o => selected.includes(o));
|
|
181
|
+
}
|
|
182
|
+
else {
|
|
183
|
+
return options.length > 0 && options.length === selected.length && selected.every(s => options.includes(s));
|
|
184
|
+
}
|
|
185
|
+
})).subscribe(isChecked => {
|
|
186
|
+
this.selectAllControl.setValue(isChecked, { emitEvent: false });
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
}
|
|
176
190
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: KlesFormSelectSearchComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
177
191
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: KlesFormSelectSearchComponent, selector: "kles-form-select-search", viewQueries: [{ propertyName: "cdkVirtualScrollViewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true }, { propertyName: "options", predicate: MatOption, descendants: true }], usesInheritance: true, ngImport: i0, template: `
|
|
178
192
|
<mat-form-field [subscriptSizing]="field.subscriptSizing" class="margin-top" [color]="field.color" [formGroup]="group" [appearance]="field.appearance">
|
|
@@ -182,7 +196,7 @@ export class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
182
196
|
|
|
183
197
|
<mat-select matTooltip="{{field.tooltip}}" [attr.id]="field.id" [ngClass]="field.ngClass"
|
|
184
198
|
(openedChange)="openChange($event)" [compareWith]="compareFn" [panelWidth]="field.panelWidth || 'auto'"
|
|
185
|
-
[placeholder]="field.placeholder | translate" [formControlName]="field.name" [multiple]="field.multiple">
|
|
199
|
+
[placeholder]="field.placeholder | translate" [formControlName]="field.name" [multiple]="field.multiple" (selectionChange)="selectionChange($event)">
|
|
186
200
|
@if (field.triggerComponent) {
|
|
187
201
|
<mat-select-trigger>
|
|
188
202
|
<ng-container klesComponent [component]="field.triggerComponent" [value]="group.controls[field.name].value" [field]="field"></ng-container>
|
|
@@ -310,7 +324,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
310
324
|
|
|
311
325
|
<mat-select matTooltip="{{field.tooltip}}" [attr.id]="field.id" [ngClass]="field.ngClass"
|
|
312
326
|
(openedChange)="openChange($event)" [compareWith]="compareFn" [panelWidth]="field.panelWidth || 'auto'"
|
|
313
|
-
[placeholder]="field.placeholder | translate" [formControlName]="field.name" [multiple]="field.multiple">
|
|
327
|
+
[placeholder]="field.placeholder | translate" [formControlName]="field.name" [multiple]="field.multiple" (selectionChange)="selectionChange($event)">
|
|
314
328
|
@if (field.triggerComponent) {
|
|
315
329
|
<mat-select-trigger>
|
|
316
330
|
<ng-container klesComponent [component]="field.triggerComponent" [value]="group.controls[field.name].value" [field]="field"></ng-container>
|
|
@@ -434,4 +448,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
434
448
|
type: ViewChildren,
|
|
435
449
|
args: [MatOption]
|
|
436
450
|
}] } });
|
|
437
|
-
//# 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":"AAAA,OAAO,EAAE,wBAAwB,EAAE,MAAM,wBAAwB,CAAC;AAClE,OAAO,EAAqB,SAAS,EAAgC,SAAS,EAAE,YAAY,EAAuC,MAAM,eAAe,CAAC;AACzJ,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,UAAU,EAAE,EAAE,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AAC9E,OAAO,EAAE,YAAY,EAAE,GAAG,EAAE,SAAS,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC1F,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;;;;;;;;;;;;;;;;AA0IrD,MAAM,OAAO,6BAA8B,SAAQ,iBAAiB;IAiBlE,YAAsB,OAAyB,EAAY,GAAsB;QAC/E,KAAK,CAAC,OAAO,CAAC,CAAC;QADK,YAAO,GAAP,OAAO,CAAkB;QAAY,QAAG,GAAH,GAAG,CAAmB;QAfjF,kBAAa,GAAG,IAAI,kBAAkB,EAAE,CAAC;QACzC,qBAAgB,GAAG,IAAI,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAEjD,cAAS,GAAG,KAAK,CAAC;QAGlB,qBAAgB,GAAG,IAAI,aAAa,CAAQ,CAAC,CAAC,CAAC;QAE/C,gBAAW,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QAgLlD,cAAS,GAAG,CAAC,EAAO,EAAE,EAAO,EAAE,EAAE;YAC/B,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,EAAE,IAAI,EAAE,EAAE;gBACnC,OAAO,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;aAC5D;YACD,OAAO,EAAE,KAAK,EAAE,CAAC;QACnB,CAAC,CAAA;IA5KD,CAAC;IAED,QAAQ;QACN,KAAK,CAAC,QAAQ,EAAE,CAAC;QAEjB,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE;YACnB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;YACtB,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,KAAK,SAAS,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,KAAK,IAAI,EAAE;gBACnH,IAAI,CAAC,QAAQ,GAAG,IAAI,eAAe,CAAQ,KAAK,CAAC,OAAO,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,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;gBAClM,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;aACxB;iBAAM;gBACL,IAAI,CAAC,QAAQ,GAAG,IAAI,eAAe,CAAQ,EAAE,CAAC,CAAC;aAChD;YAED,IAAI,CAAC,eAAe,EAAE,CAAC;SACxB;aAAM;YACL,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,YAAY,UAAU,EAAE;gBAC5C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC;aACpC;iBACI,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,YAAY,QAAQ,EAAE;gBAC/C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;aACtC;iBACI;gBACH,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;aACxC;SACF;QAED,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,IAAI,CAClC,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,EAC1B,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,IAAI,CAAC,CAAC,EAC1C,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,EACnC,SAAS,CAAC,KAAK,CAAC,EAAE;YAChB,OAAO,MAAM,CACX,EAAE,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC,EAClC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC,CAAC,CACjF,CAAA;QAEH,CAAC,CAAC,CACH,CAAC,SAAS,CAAC,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE;YACnC,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC;YACzB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACpC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;QAEH,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE;YACvB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC;iBACjC,YAAY,CAAC,IAAI,CAChB,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,EAC1B,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,EACrD,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,EAC9G,SAAS,CAAC,QAAQ,CAAC,EAAE;gBACnB,OAAO,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAC/B,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAC9I,GAAG,CAAC,OAAO,CAAC,EAAE;oBACZ,IAAI,CAAC,QAAQ,EAAE;wBACb,OAAO,KAAK,CAAC;qBACd;oBACD,IAAI,OAAO,CAAC,MAAM,GAAG,QAAQ,CAAC,MAAM,EAAE;wBACpC,OAAO,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;qBACvE;yBAAM;wBACL,OAAO,OAAO,CAAC,MAAM,GAAG,CAAC,IAAI,OAAO,CAAC,MAAM,KAAK,QAAQ,CAAC,MAAM,IAAI,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;qBAC7G;gBACH,CAAC,CAAC,CAAC,CAAC;YACR,CAAC,CAAC,CACH,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE;gBACtB,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;YAC5C,CAAC,CAAC,CAAC;SACN;IACH,CAAC;IAED,WAAW;QACT,0BAA0B;QAC1B,KAAK,CAAC,WAAW,EAAE,CAAC;IACtB,CAAC;IAGD,kBAAkB,CAAC,KAAK;QACtB,IAAI,KAAK,CAAC,OAAO,EAAE;YACjB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE;gBACvH,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;oBACtB,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC,CAAC;iBAClE;YACH,CAAC,CAAC,CAAC;SAEJ;aAAM;YACL,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;SACrD;IACH,CAAC;IAGS,eAAe;QACvB,IAAI,CAAC,WAAW;aACb,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,EAC1B,SAAS,CAAC,CAAC,MAAM,EAAE,EAAE;YACnB,OAAO,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QACnC,CAAC,CAAC,CACH;aACA,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE;YACpB,IAAI,CAAC,QAAmC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACxD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;IACP,CAAC;IAES,YAAY,CAAC,MAAe;QACpC,IAAI,MAAM,EAAE;YAEV,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,YAAY,UAAU,EAAE;gBAC5C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;gBACtB,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;aACzC;iBACI,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,YAAY,QAAQ,EAAE;gBAC/C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;gBACtB,OAAO,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;aAC3C;iBACI;gBACH,OAAO,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;aAC/B;SACF;aAAM;YACL,OAAO,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,KAAK,SAAS,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,KAAK,IAAI;gBACvH,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC;oBAC5D,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,CAAC,EAAE,CAAC,CAAA;SACrG;IACH,CAAC;IAES,cAAc,CAAC,KAAa;QACpC,IAAI,KAAK,EAAE;YACT,MAAM,MAAM,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;YACnC,OAAO,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE;gBACtC,OAAO,OAAO;qBACX,MAAM,CAAC,MAAM,CAAC,EAAE;oBACf,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,EAAE;wBACzD,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE;4BAC5C,IAAI,MAAM,CAAC,SAAS,CAAC,EAAE;gCACrB,OAAO,MAAM,CAAC,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;6BACzE;4BACD,OAAO,KAAK,CAAC;wBACf,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;4BAC1B,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;qBAEvF;yBAAM;wBACL,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE;4BACvB,OAAO,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;yBACnF;qBACF;oBACD,OAAO,MAAM,EAAE,QAAQ,EAAE,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC/D,CAAC,CAAC,CAAC;YACP,CAAC,CAAC,CAAC,CAAC;SACL;aAAM;YACL,OAAO,IAAI,CAAC,QAAQ,CAAC;SACtB;IACH,CAAC;IAED,UAAU,CAAC,MAAe;QACxB,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE;YACnB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC/B;QAED,IAAI,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE;YAC5B,IAAI,MAAM,EAAE;gBACV,IAAI,CAAC,wBAAwB,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC;gBAC/C,IAAI,CAAC,wBAAwB,CAAC,iBAAiB,EAAE,CAAC;aACnD;SACF;IACH,CAAC;+GAxLU,6BAA6B;mGAA7B,6BAA6B,yHAc7B,wBAAwB,6DACrB,SAAS,uEApJb;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4HX;;4FASY,6BAA6B;kBAxIzC,SAAS;+BACE,yBAAyB,YAEzB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA4HX;qHAuBsC,wBAAwB;sBAA5D,SAAS;uBAAC,wBAAwB;gBACV,OAAO;sBAA/B,YAAY;uBAAC,SAAS","sourcesContent":["import { CdkVirtualScrollViewport } from '@angular/cdk/scrolling';\nimport { ChangeDetectorRef, Component, OnDestroy, OnInit, QueryList, ViewChild, ViewChildren, ViewContainerRef, ViewEncapsulation } from '@angular/core';\nimport { UntypedFormControl } from '@angular/forms';\nimport { MatOption } from '@angular/material/core';\nimport { BehaviorSubject, concat, Observable, of, ReplaySubject } from 'rxjs';\nimport { debounceTime, map, startWith, switchMap, take, takeUntil } from 'rxjs/operators';\nimport { KlesFieldAbstract } from './field.abstract';\n\n@Component({\n  selector: 'kles-form-select-search',\n  // encapsulation: ViewEncapsulation.None,\n  template: `\n    <mat-form-field [subscriptSizing]=\"field.subscriptSizing\" class=\"margin-top\" [color]=\"field.color\" [formGroup]=\"group\" [appearance]=\"field.appearance\">\n        @if (field.label) {\n            <mat-label>{{field.label}}</mat-label>\n        }\n\n        <mat-select matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\" [ngClass]=\"field.ngClass\"\n        (openedChange)=\"openChange($event)\" [compareWith]=\"compareFn\" [panelWidth]=\"field.panelWidth || 'auto'\"\n        [placeholder]=\"field.placeholder | translate\" [formControlName]=\"field.name\" [multiple]=\"field.multiple\">\n        @if (field.triggerComponent) {\n            <mat-select-trigger>\n                <ng-container klesComponent [component]=\"field.triggerComponent\" [value]=\"group.controls[field.name].value\" [field]=\"field\"></ng-container>\n            </mat-select-trigger>\n        }\n\n        @if (field.virtualScroll) {\n            <mat-option>\n                <ngx-mat-select-search [formControl]=\"searchControl\"\n                placeholderLabel=\"\" noEntriesFoundLabel =\"\"></ngx-mat-select-search>\n            </mat-option>\n\n            <cdk-virtual-scroll-viewport [itemSize]=\"field.itemSize || 50\" [style.height.px]=4*48>\n                @if (!isLoading) {\n                    @if (field.multiple) {\n                        <mat-checkbox class=\"selectAll mat-mdc-option mdc-list-item\" [formControl]=\"selectAllControl\" (change)=\"toggleAllSelection($event)\">\n                            {{'selectAll' | translate}}\n                        </mat-checkbox>\n                    }\n\n                    @if (!field.autocompleteComponent) {\n                        <mat-option *cdkVirtualFor=\"let item of optionsFiltered$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n\n                        @if (field.multiple) {\n                            @for (item of group.controls[field.name].value | slice:0:30; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                                </mat-option>\n                            }\n                        }\n\n                        @if (!field.multiple && group.controls[field.name].value) {\n                            @for (item of [group?.controls[field.name]?.value]; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                                </mat-option>\n                            }\n                        }\n                    }\n                    @else {\n                        <mat-option *cdkVirtualFor=\"let item of optionsFiltered$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                        </mat-option>\n\n                        @if (field.multiple) {\n                            @for (item of group.controls[field.name].value | slice:0:30; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                                </mat-option>\n                            }\n                        }\n\n                        @if (!field.multiple && group.controls[field.name].value) {\n                            @for (item of [group?.controls[field.name]?.value]; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                                </mat-option>\n                            }\n                        }\n                    }\n                }\n                @else {\n                    <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                }\n            </cdk-virtual-scroll-viewport>\n        }\n        @else {\n            <mat-option>\n                <ngx-mat-select-search [formControl]=\"searchControl\"\n                placeholderLabel=\"\" noEntriesFoundLabel =\"\"></ngx-mat-select-search>\n            </mat-option>\n\n            @if (!isLoading) {\n                @if (field.multiple) {\n                    <mat-checkbox class=\"selectAll mat-mdc-option mdc-list-item\" [formControl]=\"selectAllControl\" (change)=\"toggleAllSelection($event)\">\n                        {{'selectAll' | translate}}\n                    </mat-checkbox>\n                }\n\n                @if (!field.autocompleteComponent) {\n                    @for (item of optionsFiltered$ | async; track item) {\n                        <mat-option [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n                    }\n                }\n                @else {\n                    @for (item of optionsFiltered$ | async; track item) {\n                        <mat-option [value]=\"item\" [disabled]=\"item?.disabled\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                        </mat-option>\n                    }\n                }\n            }\n            @else {\n                <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n            }\n\n            <ng-template #emptyOption>\n                <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n            </ng-template>\n        }\n\n        </mat-select>\n\n        @if (field.hint) {\n            <mat-hint>{{field.hint}}</mat-hint>\n        }\n\n        @if (field.subComponents || field.clearable) {\n            <div matSuffix>\n                <ng-content></ng-content>\n            </div>\n        }\n\n        <mat-error matErrorMessage [validations]=\"field.validations\" [asyncValidations]=\"field.asyncValidations\"></mat-error>\n    </mat-form-field>\n`,\n  styles: ['mat-form-field {width: calc(100%)}',\n    '::ng-deep .selectAll {padding: 0 16px 0 5px !important; display: flex !important;}',\n    '::ng-deep .selectAll .mdc-form-field {width: 100%;}',\n    '::ng-deep .selectAll .mdc-form-field .mdc-label {width: 100%;  min-height: 48px; align-items: center; display: flex;}',\n    '::ng-deep .selectAll .mdc-form-field .mdc-checkbox__ripple {display: none !important;}',\n    `::ng-deep .hide-checkbox .mat-pseudo-checkbox { display: none !important;  }`],\n  styleUrls: ['../styles/loading-select.style.scss']\n})\nexport class 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) ? 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"]}
|
|
451
|
+
//# 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 { ChangeDetectorRef, Component, OnDestroy, OnInit, QueryList, ViewChild, ViewChildren, ViewContainerRef, ViewEncapsulation } from '@angular/core';\nimport { FormControl, FormGroup, UntypedFormControl } from '@angular/forms';\nimport { MatOption } from '@angular/material/core';\nimport { BehaviorSubject, concat, Observable, of, ReplaySubject } from 'rxjs';\nimport { debounceTime, map, startWith, switchMap, take, takeUntil } from 'rxjs/operators';\nimport { KlesFieldAbstract } from './field.abstract';\n\n@Component({\n  selector: 'kles-form-select-search',\n  // encapsulation: ViewEncapsulation.None,\n  template: `\n    <mat-form-field [subscriptSizing]=\"field.subscriptSizing\" class=\"margin-top\" [color]=\"field.color\" [formGroup]=\"group\" [appearance]=\"field.appearance\">\n        @if (field.label) {\n            <mat-label>{{field.label}}</mat-label>\n        }\n\n        <mat-select matTooltip=\"{{field.tooltip}}\" [attr.id]=\"field.id\" [ngClass]=\"field.ngClass\"\n        (openedChange)=\"openChange($event)\" [compareWith]=\"compareFn\" [panelWidth]=\"field.panelWidth || 'auto'\"\n        [placeholder]=\"field.placeholder | translate\" [formControlName]=\"field.name\" [multiple]=\"field.multiple\"  (selectionChange)=\"selectionChange($event)\">\n        @if (field.triggerComponent) {\n            <mat-select-trigger>\n                <ng-container klesComponent [component]=\"field.triggerComponent\" [value]=\"group.controls[field.name].value\" [field]=\"field\"></ng-container>\n            </mat-select-trigger>\n        }\n\n        @if (field.virtualScroll) {\n            <mat-option>\n                <ngx-mat-select-search [formControl]=\"searchControl\"\n                placeholderLabel=\"\" noEntriesFoundLabel =\"\"></ngx-mat-select-search>\n            </mat-option>\n\n            <cdk-virtual-scroll-viewport [itemSize]=\"field.itemSize || 50\" [style.height.px]=4*48>\n                @if (!isLoading) {\n                    @if (field.multiple) {\n                        <mat-checkbox class=\"selectAll mat-mdc-option mdc-list-item\" [formControl]=\"selectAllControl\" (change)=\"toggleAllSelection($event)\">\n                            {{'selectAll' | translate}}\n                        </mat-checkbox>\n                    }\n\n                    @if (!field.autocompleteComponent) {\n                        <mat-option *cdkVirtualFor=\"let item of optionsFiltered$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n\n                        @if (field.multiple) {\n                            @for (item of group.controls[field.name].value | slice:0:30; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                                </mat-option>\n                            }\n                        }\n\n                        @if (!field.multiple && group.controls[field.name].value) {\n                            @for (item of [group?.controls[field.name]?.value]; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                                </mat-option>\n                            }\n                        }\n                    }\n                    @else {\n                        <mat-option *cdkVirtualFor=\"let item of optionsFiltered$ | async\" [value]=\"item\" [disabled]=\"item?.disabled\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                        </mat-option>\n\n                        @if (field.multiple) {\n                            @for (item of group.controls[field.name].value | slice:0:30; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                                </mat-option>\n                            }\n                        }\n\n                        @if (!field.multiple && group.controls[field.name].value) {\n                            @for (item of [group?.controls[field.name]?.value]; track item) {\n                                <mat-option [value]=\"item\" style=\"display:none\">\n                                    <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                                </mat-option>\n                            }\n                        }\n                    }\n                }\n                @else {\n                    <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n                }\n            </cdk-virtual-scroll-viewport>\n        }\n        @else {\n            <mat-option>\n                <ngx-mat-select-search [formControl]=\"searchControl\"\n                placeholderLabel=\"\" noEntriesFoundLabel =\"\"></ngx-mat-select-search>\n            </mat-option>\n\n            @if (!isLoading) {\n                @if (field.multiple) {\n                    <mat-checkbox class=\"selectAll mat-mdc-option mdc-list-item\" [formControl]=\"selectAllControl\" (change)=\"toggleAllSelection($event)\">\n                        {{'selectAll' | translate}}\n                    </mat-checkbox>\n                }\n\n                @if (!field.autocompleteComponent) {\n                    @for (item of optionsFiltered$ | async; track item) {\n                        <mat-option [value]=\"item\" [disabled]=\"item?.disabled\">{{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}</mat-option>\n                    }\n                }\n                @else {\n                    @for (item of optionsFiltered$ | async; track item) {\n                        <mat-option [value]=\"item\" [disabled]=\"item?.disabled\">\n                            <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                        </mat-option>\n                    }\n                }\n            }\n            @else {\n                <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n            }\n\n            <ng-template #emptyOption>\n                <mat-option class=\"hide-checkbox\" disabled><div class=\"loadingSelect\">{{'loading' | translate}}... <mat-spinner class=\"spinner\" diameter=\"20\"></mat-spinner></div></mat-option>\n            </ng-template>\n        }\n\n        </mat-select>\n\n        @if (field.hint) {\n            <mat-hint>{{field.hint}}</mat-hint>\n        }\n\n        @if (field.subComponents || field.clearable) {\n            <div matSuffix>\n                <ng-content></ng-content>\n            </div>\n        }\n\n        <mat-error matErrorMessage [validations]=\"field.validations\" [asyncValidations]=\"field.asyncValidations\"></mat-error>\n    </mat-form-field>\n`,\n  styles: ['mat-form-field {width: calc(100%)}',\n    '::ng-deep .selectAll {padding: 0 16px 0 5px !important; display: flex !important;}',\n    '::ng-deep .selectAll .mdc-form-field {width: 100%;}',\n    '::ng-deep .selectAll .mdc-form-field .mdc-label {width: 100%;  min-height: 48px; align-items: center; display: flex;}',\n    '::ng-deep .selectAll .mdc-form-field .mdc-checkbox__ripple {display: none !important;}',\n    `::ng-deep .hide-checkbox .mat-pseudo-checkbox { display: none !important;  }`],\n  styleUrls: ['../styles/loading-select.style.scss']\n})\nexport class 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\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(take(1), map((options) => ({ loading: false, options })))\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.updateSelectAllControl(this.group.controls[this.field.name].value);\n\n      (this.group.controls[this.field.name] as FormControl).registerOnChange((values, emitViewToModelChange) => {\n        if (emitViewToModelChange) {\n          this.updateSelectAllControl(values);\n        }\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(), { emitModelToViewChange: false });\n        }\n      });\n\n    } else {\n      this.group.controls[this.field.name].patchValue([], { emitModelToViewChange: false });\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.isLoading = false;\n        (this.options$ as BehaviorSubject<any[]>).next(options);\n        this.optionsFiltered$.next(options);\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  selectionChange(selection) {\n    if (this.field.multiple) {\n      this.updateSelectAllControl(selection.value);\n    }\n\n  }\n\n  updateSelectAllControl(values): void {\n    if (values) {\n      const selected = ((this.field.property && values) ? values?.map(s => s[this.field.property]) : values);\n      this.optionsFiltered$.pipe(\n        take(1),\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\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        })).subscribe(isChecked => {\n          this.selectAllControl.setValue(isChecked, { emitEvent: false });\n        });\n    }\n\n  }\n}\n"]}
|
|
@@ -2830,28 +2830,18 @@ class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
2830
2830
|
}
|
|
2831
2831
|
}
|
|
2832
2832
|
this.searchControl.valueChanges.pipe(takeUntil(this._onDestroy), debounceTime(this.field.debounceTime || 0), startWith(this.searchControl.value), switchMap(value => {
|
|
2833
|
-
return concat(of({ loading: true, options: [] }), this.onSearchChange(value).pipe(map((options) => ({ loading: false, options }))));
|
|
2833
|
+
return concat(of({ loading: true, options: [] }), this.onSearchChange(value).pipe(take(1), map((options) => ({ loading: false, options }))));
|
|
2834
2834
|
})).subscribe(({ loading, options }) => {
|
|
2835
2835
|
this.isLoading = loading;
|
|
2836
2836
|
this.optionsFiltered$.next(options);
|
|
2837
2837
|
this.ref.markForCheck();
|
|
2838
2838
|
});
|
|
2839
2839
|
if (this.field.multiple) {
|
|
2840
|
-
this.group.controls[this.field.name]
|
|
2841
|
-
|
|
2842
|
-
|
|
2843
|
-
|
|
2844
|
-
|
|
2845
|
-
}
|
|
2846
|
-
if (options.length < selected.length) {
|
|
2847
|
-
return options.length > 0 && options.every(o => selected.includes(o));
|
|
2848
|
-
}
|
|
2849
|
-
else {
|
|
2850
|
-
return options.length > 0 && options.length === selected.length && selected.every(s => options.includes(s));
|
|
2851
|
-
}
|
|
2852
|
-
}));
|
|
2853
|
-
})).subscribe(isChecked => {
|
|
2854
|
-
this.selectAllControl.setValue(isChecked);
|
|
2840
|
+
this.updateSelectAllControl(this.group.controls[this.field.name].value);
|
|
2841
|
+
this.group.controls[this.field.name].registerOnChange((values, emitViewToModelChange) => {
|
|
2842
|
+
if (emitViewToModelChange) {
|
|
2843
|
+
this.updateSelectAllControl(values);
|
|
2844
|
+
}
|
|
2855
2845
|
});
|
|
2856
2846
|
}
|
|
2857
2847
|
}
|
|
@@ -2863,12 +2853,12 @@ class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
2863
2853
|
if (state.checked) {
|
|
2864
2854
|
this.optionsFiltered$.pipe(take(1), map((options) => options.filter((option) => !option?.disabled))).subscribe(options => {
|
|
2865
2855
|
if (options.length > 0) {
|
|
2866
|
-
this.group.controls[this.field.name].patchValue(options.slice());
|
|
2856
|
+
this.group.controls[this.field.name].patchValue(options.slice(), { emitModelToViewChange: false });
|
|
2867
2857
|
}
|
|
2868
2858
|
});
|
|
2869
2859
|
}
|
|
2870
2860
|
else {
|
|
2871
|
-
this.group.controls[this.field.name].patchValue([]);
|
|
2861
|
+
this.group.controls[this.field.name].patchValue([], { emitModelToViewChange: false });
|
|
2872
2862
|
}
|
|
2873
2863
|
}
|
|
2874
2864
|
openChangeEvent() {
|
|
@@ -2877,8 +2867,9 @@ class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
2877
2867
|
return this.onOpenChange(isOpen);
|
|
2878
2868
|
}))
|
|
2879
2869
|
.subscribe((options) => {
|
|
2880
|
-
this.options$.next(options);
|
|
2881
2870
|
this.isLoading = false;
|
|
2871
|
+
this.options$.next(options);
|
|
2872
|
+
this.optionsFiltered$.next(options);
|
|
2882
2873
|
this.ref.markForCheck();
|
|
2883
2874
|
});
|
|
2884
2875
|
}
|
|
@@ -2941,6 +2932,29 @@ class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
2941
2932
|
}
|
|
2942
2933
|
}
|
|
2943
2934
|
}
|
|
2935
|
+
selectionChange(selection) {
|
|
2936
|
+
if (this.field.multiple) {
|
|
2937
|
+
this.updateSelectAllControl(selection.value);
|
|
2938
|
+
}
|
|
2939
|
+
}
|
|
2940
|
+
updateSelectAllControl(values) {
|
|
2941
|
+
if (values) {
|
|
2942
|
+
const selected = ((this.field.property && values) ? values?.map(s => s[this.field.property]) : values);
|
|
2943
|
+
this.optionsFiltered$.pipe(take(1), map((options) => options?.filter((option) => !option?.disabled).map((option) => (this.field.property ? option[this.field.property] : option))), map(options => {
|
|
2944
|
+
if (!selected) {
|
|
2945
|
+
return false;
|
|
2946
|
+
}
|
|
2947
|
+
if (options.length < selected.length) {
|
|
2948
|
+
return options.length > 0 && options.every(o => selected.includes(o));
|
|
2949
|
+
}
|
|
2950
|
+
else {
|
|
2951
|
+
return options.length > 0 && options.length === selected.length && selected.every(s => options.includes(s));
|
|
2952
|
+
}
|
|
2953
|
+
})).subscribe(isChecked => {
|
|
2954
|
+
this.selectAllControl.setValue(isChecked, { emitEvent: false });
|
|
2955
|
+
});
|
|
2956
|
+
}
|
|
2957
|
+
}
|
|
2944
2958
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: KlesFormSelectSearchComponent, deps: [{ token: i0.ViewContainerRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2945
2959
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.11", type: KlesFormSelectSearchComponent, selector: "kles-form-select-search", viewQueries: [{ propertyName: "cdkVirtualScrollViewport", first: true, predicate: CdkVirtualScrollViewport, descendants: true }, { propertyName: "options", predicate: MatOption, descendants: true }], usesInheritance: true, ngImport: i0, template: `
|
|
2946
2960
|
<mat-form-field [subscriptSizing]="field.subscriptSizing" class="margin-top" [color]="field.color" [formGroup]="group" [appearance]="field.appearance">
|
|
@@ -2950,7 +2964,7 @@ class KlesFormSelectSearchComponent extends KlesFieldAbstract {
|
|
|
2950
2964
|
|
|
2951
2965
|
<mat-select matTooltip="{{field.tooltip}}" [attr.id]="field.id" [ngClass]="field.ngClass"
|
|
2952
2966
|
(openedChange)="openChange($event)" [compareWith]="compareFn" [panelWidth]="field.panelWidth || 'auto'"
|
|
2953
|
-
[placeholder]="field.placeholder | translate" [formControlName]="field.name" [multiple]="field.multiple">
|
|
2967
|
+
[placeholder]="field.placeholder | translate" [formControlName]="field.name" [multiple]="field.multiple" (selectionChange)="selectionChange($event)">
|
|
2954
2968
|
@if (field.triggerComponent) {
|
|
2955
2969
|
<mat-select-trigger>
|
|
2956
2970
|
<ng-container klesComponent [component]="field.triggerComponent" [value]="group.controls[field.name].value" [field]="field"></ng-container>
|
|
@@ -3078,7 +3092,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
3078
3092
|
|
|
3079
3093
|
<mat-select matTooltip="{{field.tooltip}}" [attr.id]="field.id" [ngClass]="field.ngClass"
|
|
3080
3094
|
(openedChange)="openChange($event)" [compareWith]="compareFn" [panelWidth]="field.panelWidth || 'auto'"
|
|
3081
|
-
[placeholder]="field.placeholder | translate" [formControlName]="field.name" [multiple]="field.multiple">
|
|
3095
|
+
[placeholder]="field.placeholder | translate" [formControlName]="field.name" [multiple]="field.multiple" (selectionChange)="selectionChange($event)">
|
|
3082
3096
|
@if (field.triggerComponent) {
|
|
3083
3097
|
<mat-select-trigger>
|
|
3084
3098
|
<ng-container klesComponent [component]="field.triggerComponent" [value]="group.controls[field.name].value" [field]="field"></ng-container>
|