@3kles/kles-material-dynamicforms 17.8.3 → 17.8.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.
|
@@ -40,6 +40,8 @@ export class KlesFormSelectionListComponent extends KlesFieldAbstract {
|
|
|
40
40
|
});
|
|
41
41
|
this.selection.changed.pipe(takeUntil(this._onDestroy)).subscribe(change => {
|
|
42
42
|
this.group.controls[this.field.name].patchValue(change.source.selected);
|
|
43
|
+
this.group.controls[this.field.name].markAllAsTouched();
|
|
44
|
+
this.group.controls[this.field.name].markAsDirty();
|
|
43
45
|
});
|
|
44
46
|
}
|
|
45
47
|
ngOnDestroy() {
|
|
@@ -144,4 +146,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
144
146
|
</div>
|
|
145
147
|
`, styles: ["mat-selection-list{width:100%;height:250px;overflow:auto}\n"] }]
|
|
146
148
|
}] });
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-list.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/selection-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit } from '@angular/core';\nimport { MatSelectionListChange } from '@angular/material/list';\nimport { Observable, of } from 'rxjs';\nimport { KlesFieldAbstract } from './field.abstract';\nimport { takeUntil } from 'rxjs/operators';\nimport { KlesSelectionModel } from '../selection/selection-model';\n@Component({\n    selector: 'kles-form-selection-list',\n    template: `\n    <div class=\"margin-top\" [formGroup]=\"group\">\n        <mat-selection-list [attr.id]=\"field.id\" [multiple]=\"field.multiple\" [ngClass]=\"field.ngClass\"\n        (selectionChange)=\"onSelectionChange($event)\">\n            @if(options$ | async; as options){\n                @if(field.virtualScroll){\n                    <cdk-virtual-scroll-viewport [itemSize]=\"field.itemSize || 20\" style=\"height:100%\">\n                        @if (!field.autocompleteComponent) {\n                            <mat-list-option *cdkVirtualFor=\"let item of options; templateCacheSize: 0\"\n                            [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-list-option>\n                        }\n                        @else{\n                            <mat-list-option *cdkVirtualFor=\"let item of options; templateCacheSize: 0\"\n                            [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-list-option>\n                        }\n                    </cdk-virtual-scroll-viewport>\n                }\n                @else{\n                    @if (!field.autocompleteComponent) {\n                        @for (item of options; track item) {\n                            <mat-list-option [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-list-option>\n                        }\n                    }\n                    @else {\n                        @for (item of options; track item) {\n                            <mat-list-option [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-list-option>\n                        }\n                    }\n                }   \n\n            }@else{\n                <mat-spinner></mat-spinner>\n            }\n        </mat-selection-list>\n    </div>\n`,\n    styles: [`\n        mat-selection-list {width: 100%;height: 250px; overflow:auto}`\n    ],\n})\nexport class KlesFormSelectionListComponent extends KlesFieldAbstract implements OnInit, OnDestroy {\n\n    selection: KlesSelectionModel<any>;\n    options$: Observable<any[]>;\n\n    ngOnInit() {\n        super.ngOnInit();\n\n        this.selection = new KlesSelectionModel<any>(this.field.multiple || false, [], true,\n            ((o1: any, o2: any) => {\n                if (this.field.property) {\n                    return o1?.[this.field.property] === o2?.[this.field.property];\n                } else {\n                    return o1 === o2;\n                }\n            }));\n\n        if (this.field.value) {\n            this.selection.select(Array.isArray(this.field.value) ? this.field.value : [this.field.value]);\n        }\n\n        if (this.field.options instanceof Observable) {\n            this.options$ = this.field.options;\n        }\n        else if (this.field.options instanceof Function) {\n            this.options$ = this.field.options();\n        }\n        else {\n            this.options$ = of(this.field.options);\n        }\n\n        this.group.controls[this.field.name].valueChanges\n            .pipe(\n                takeUntil(this._onDestroy),\n            ).subscribe((value) => {\n                this.selection.setSelection(Array.isArray(value) ? value : [value], { emitEvent: false });\n            });\n\n        this.selection.changed.pipe(takeUntil(this._onDestroy)).subscribe(change => {\n            this.group.controls[this.field.name].patchValue(change.source.selected);\n        });\n    }\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n\n    onSelectionChange(selection: MatSelectionListChange) {\n        selection.options.forEach(option => {\n            option.selected ? this.selection.select([option.value])\n                : this.selection.deselect([option.value])\n        });\n    }\n}\n"]}
|
|
149
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-list.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/selection-list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit } from '@angular/core';\nimport { MatSelectionListChange } from '@angular/material/list';\nimport { Observable, of } from 'rxjs';\nimport { KlesFieldAbstract } from './field.abstract';\nimport { takeUntil } from 'rxjs/operators';\nimport { KlesSelectionModel } from '../selection/selection-model';\n@Component({\n    selector: 'kles-form-selection-list',\n    template: `\n    <div class=\"margin-top\" [formGroup]=\"group\">\n        <mat-selection-list [attr.id]=\"field.id\" [multiple]=\"field.multiple\" [ngClass]=\"field.ngClass\"\n        (selectionChange)=\"onSelectionChange($event)\">\n            @if(options$ | async; as options){\n                @if(field.virtualScroll){\n                    <cdk-virtual-scroll-viewport [itemSize]=\"field.itemSize || 20\" style=\"height:100%\">\n                        @if (!field.autocompleteComponent) {\n                            <mat-list-option *cdkVirtualFor=\"let item of options; templateCacheSize: 0\"\n                            [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-list-option>\n                        }\n                        @else{\n                            <mat-list-option *cdkVirtualFor=\"let item of options; templateCacheSize: 0\"\n                            [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-list-option>\n                        }\n                    </cdk-virtual-scroll-viewport>\n                }\n                @else{\n                    @if (!field.autocompleteComponent) {\n                        @for (item of options; track item) {\n                            <mat-list-option [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-list-option>\n                        }\n                    }\n                    @else {\n                        @for (item of options; track item) {\n                            <mat-list-option [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-list-option>\n                        }\n                    }\n                }   \n\n            }@else{\n                <mat-spinner></mat-spinner>\n            }\n        </mat-selection-list>\n    </div>\n`,\n    styles: [`\n        mat-selection-list {width: 100%;height: 250px; overflow:auto}`\n    ],\n})\nexport class KlesFormSelectionListComponent extends KlesFieldAbstract implements OnInit, OnDestroy {\n\n    selection: KlesSelectionModel<any>;\n    options$: Observable<any[]>;\n\n    ngOnInit() {\n        super.ngOnInit();\n\n        this.selection = new KlesSelectionModel<any>(this.field.multiple || false, [], true,\n            ((o1: any, o2: any) => {\n                if (this.field.property) {\n                    return o1?.[this.field.property] === o2?.[this.field.property];\n                } else {\n                    return o1 === o2;\n                }\n            }));\n\n        if (this.field.value) {\n            this.selection.select(Array.isArray(this.field.value) ? this.field.value : [this.field.value]);\n        }\n\n        if (this.field.options instanceof Observable) {\n            this.options$ = this.field.options;\n        }\n        else if (this.field.options instanceof Function) {\n            this.options$ = this.field.options();\n        }\n        else {\n            this.options$ = of(this.field.options);\n        }\n\n        this.group.controls[this.field.name].valueChanges\n            .pipe(\n                takeUntil(this._onDestroy),\n            ).subscribe((value) => {\n                this.selection.setSelection(Array.isArray(value) ? value : [value], { emitEvent: false });\n            });\n\n        this.selection.changed.pipe(takeUntil(this._onDestroy)).subscribe(change => {\n            this.group.controls[this.field.name].patchValue(change.source.selected);\n            this.group.controls[this.field.name].markAllAsTouched();\n            this.group.controls[this.field.name].markAsDirty();\n        });\n    }\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n\n    onSelectionChange(selection: MatSelectionListChange) {\n        selection.options.forEach(option => {\n            option.selected ? this.selection.select([option.value])\n                : this.selection.deselect([option.value])\n        });\n    }\n}\n"]}
|
|
@@ -46,6 +46,8 @@ export class KlesFormSelectionListSearchComponent extends KlesFieldAbstract {
|
|
|
46
46
|
});
|
|
47
47
|
this.selection.changed.pipe(takeUntil(this._onDestroy)).subscribe(change => {
|
|
48
48
|
this.group.controls[this.field.name].patchValue(change.source.selected);
|
|
49
|
+
this.group.controls[this.field.name].markAllAsTouched();
|
|
50
|
+
this.group.controls[this.field.name].markAsDirty();
|
|
49
51
|
});
|
|
50
52
|
this.optionFiltered$ = this.searchControl.valueChanges
|
|
51
53
|
.pipe(takeUntil(this._onDestroy), startWith(null), debounceTime(this.field.debounceTime || 0), distinctUntilChanged(), map((value) => value?.toLowerCase()), switchMap((value) => {
|
|
@@ -188,4 +190,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
188
190
|
</div>
|
|
189
191
|
`, styles: [".selection-list{display:flex;flex-direction:column;gap:5px}\n", "mat-selection-list{width:100%;height:250px;overflow:auto;flex-grow:1}\n"] }]
|
|
190
192
|
}] });
|
|
191
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-list.search.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/selection-list.search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit } from '@angular/core';\nimport { MatSelectionListChange } from '@angular/material/list';\nimport { Observable, of } from 'rxjs';\nimport { KlesFieldAbstract } from './field.abstract';\nimport { debounceTime, distinctUntilChanged, map, shareReplay, startWith, switchMap, takeUntil } from 'rxjs/operators';\nimport { KlesSelectionModel } from '../selection/selection-model';\nimport { FormControl } from '@angular/forms';\n@Component({\n  selector: 'kles-form-selection-list-search',\n  template: `\n    <div class=\"selection-list\" [formGroup]=\"group\">\n        <mat-form-field [subscriptSizing]=\"field.subscriptSizing\" [appearance]=\"field.appearance\">\n            @if (field.label) {\n                <mat-label>{{field.label}}</mat-label>\n            }\n            <input matInput [placeholder]=\"field.placeholder\" [formControl]=\"searchControl\">\n            <button matSuffix mat-icon-button aria-label=\"Clear\" (click)=\"searchControl.reset();$event.stopPropagation();\">\n                <mat-icon>close</mat-icon>\n            </button>\n        </mat-form-field>\n\n        <mat-selection-list [attr.id]=\"field.id\" [multiple]=\"field.multiple\" [ngClass]=\"field.ngClass\"\n        (selectionChange)=\"onSelectionChange($event)\">\n            @if(optionFiltered$ | async; as options){\n                @if(field.virtualScroll){\n                    <cdk-virtual-scroll-viewport [itemSize]=\"field.itemSize || 20\" style=\"height:100%\">\n                        @if (!field.autocompleteComponent) {\n                            <mat-list-option *cdkVirtualFor=\"let item of options; templateCacheSize: 0\"\n                            [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-list-option>\n                        }\n                        @else{\n                            <mat-list-option *cdkVirtualFor=\"let item of options; templateCacheSize: 0\"\n                            [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-list-option>\n                        }\n                    </cdk-virtual-scroll-viewport>\n                }\n                @else{\n                    @if (!field.autocompleteComponent) {\n                        @for (item of options; track item) {\n                            <mat-list-option [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-list-option>\n                        }\n                    }\n                    @else {\n                        @for (item of options; track item) {\n                            <mat-list-option [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-list-option>\n                        }\n                    }\n                }\n\n            }@else{\n                <mat-spinner></mat-spinner>\n            }\n        </mat-selection-list>\n    </div>\n`,\n  styles: [\n    `.selection-list {display:flex; flex-direction:column; gap:5px}`,\n    `mat-selection-list {width: 100%;height: 250px; overflow:auto; flex-grow: 1;}`\n  ],\n})\nexport class KlesFormSelectionListSearchComponent extends KlesFieldAbstract implements OnInit, OnDestroy {\n\n  selection: KlesSelectionModel<any>;\n  options$: Observable<any[]>;\n  searchControl = new FormControl();\n\n  optionFiltered$: Observable<any[]>;\n\n  ngOnInit() {\n    if (!this.field.subscriptSizing) {\n      this.field.subscriptSizing = 'dynamic';\n    }\n    super.ngOnInit();\n\n    this.selection = new KlesSelectionModel<any>(this.field.multiple || false, [], true,\n      ((o1: any, o2: any) => {\n        if (this.field.property) {\n          return o1?.[this.field.property] === o2?.[this.field.property];\n        } else {\n          return o1 === o2;\n        }\n      }));\n\n    if (this.field.value) {\n      this.selection.select(Array.isArray(this.field.value) ? this.field.value : [this.field.value]);\n    }\n\n    if (this.field.options instanceof Observable) {\n      this.options$ = this.field.options.pipe(shareReplay(1));\n    }\n\n    this.group.controls[this.field.name].valueChanges\n      .pipe(\n        takeUntil(this._onDestroy),\n      ).subscribe((value) => {\n        this.selection.setSelection(Array.isArray(value) ? value : [value], { emitEvent: false });\n      });\n\n    this.selection.changed.pipe(takeUntil(this._onDestroy)).subscribe(change => {\n      this.group.controls[this.field.name].patchValue(change.source.selected);\n    });\n\n    this.optionFiltered$ = this.searchControl.valueChanges\n      .pipe(\n        takeUntil(this._onDestroy),\n        startWith(null as string),\n        debounceTime(this.field.debounceTime || 0),\n        distinctUntilChanged(),\n        map((value) => value?.toLowerCase()),\n        switchMap((value) => {\n          if (this.field.options instanceof Function) {\n            return this.field.options(value);\n          } else {\n            return ((this.field.options instanceof Observable) ? this.options$ : of(this.field.options)).pipe(\n              map((options) => {\n                if (!value) {\n                  return options;\n                }\n                return options.filter(option => {\n                  return (!this.field.property && option?.toString().toLowerCase().includes(value))\n                    || (this.field.property && option?.[this.field.property]?.toString().toLowerCase().includes(value))\n                    || (this.field.searchKeys && this.field.searchKeys.some(key => option?.[key].toString().toLowerCase().includes(value)));\n                });\n              })\n            );\n          }\n        })\n      )\n  }\n  ngOnDestroy(): void {\n    super.ngOnDestroy();\n  }\n\n  onSelectionChange(selection: MatSelectionListChange) {\n    selection.options.forEach(option => {\n      option.selected ? this.selection.select([option.value])\n        : this.selection.deselect([option.value])\n    });\n  }\n}\n"]}
|
|
193
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"selection-list.search.component.js","sourceRoot":"","sources":["../../../../../projects/kles-material-dynamicforms/src/lib/fields/selection-list.search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnDestroy, OnInit } from '@angular/core';\nimport { MatSelectionListChange } from '@angular/material/list';\nimport { Observable, of } from 'rxjs';\nimport { KlesFieldAbstract } from './field.abstract';\nimport { debounceTime, distinctUntilChanged, map, shareReplay, startWith, switchMap, takeUntil } from 'rxjs/operators';\nimport { KlesSelectionModel } from '../selection/selection-model';\nimport { FormControl } from '@angular/forms';\n@Component({\n  selector: 'kles-form-selection-list-search',\n  template: `\n    <div class=\"selection-list\" [formGroup]=\"group\">\n        <mat-form-field [subscriptSizing]=\"field.subscriptSizing\" [appearance]=\"field.appearance\">\n            @if (field.label) {\n                <mat-label>{{field.label}}</mat-label>\n            }\n            <input matInput [placeholder]=\"field.placeholder\" [formControl]=\"searchControl\">\n            <button matSuffix mat-icon-button aria-label=\"Clear\" (click)=\"searchControl.reset();$event.stopPropagation();\">\n                <mat-icon>close</mat-icon>\n            </button>\n        </mat-form-field>\n\n        <mat-selection-list [attr.id]=\"field.id\" [multiple]=\"field.multiple\" [ngClass]=\"field.ngClass\"\n        (selectionChange)=\"onSelectionChange($event)\">\n            @if(optionFiltered$ | async; as options){\n                @if(field.virtualScroll){\n                    <cdk-virtual-scroll-viewport [itemSize]=\"field.itemSize || 20\" style=\"height:100%\">\n                        @if (!field.autocompleteComponent) {\n                            <mat-list-option *cdkVirtualFor=\"let item of options; templateCacheSize: 0\"\n                            [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-list-option>\n                        }\n                        @else{\n                            <mat-list-option *cdkVirtualFor=\"let item of options; templateCacheSize: 0\"\n                            [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-list-option>\n                        }\n                    </cdk-virtual-scroll-viewport>\n                }\n                @else{\n                    @if (!field.autocompleteComponent) {\n                        @for (item of options; track item) {\n                            <mat-list-option [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                {{(field.property ? item[field.property] : item) | klesTransform:field.pipeTransform}}\n                            </mat-list-option>\n                        }\n                    }\n                    @else {\n                        @for (item of options; track item) {\n                            <mat-list-option [value]=\"item\" [selected]=\"selection.isSelected(item)\">\n                                <ng-container klesComponent [component]=\"field.autocompleteComponent\" [value]=\"item\" [field]=\"field\"></ng-container>\n                            </mat-list-option>\n                        }\n                    }\n                }\n\n            }@else{\n                <mat-spinner></mat-spinner>\n            }\n        </mat-selection-list>\n    </div>\n`,\n  styles: [\n    `.selection-list {display:flex; flex-direction:column; gap:5px}`,\n    `mat-selection-list {width: 100%;height: 250px; overflow:auto; flex-grow: 1;}`\n  ],\n})\nexport class KlesFormSelectionListSearchComponent extends KlesFieldAbstract implements OnInit, OnDestroy {\n\n  selection: KlesSelectionModel<any>;\n  options$: Observable<any[]>;\n  searchControl = new FormControl();\n\n  optionFiltered$: Observable<any[]>;\n\n  ngOnInit() {\n    if (!this.field.subscriptSizing) {\n      this.field.subscriptSizing = 'dynamic';\n    }\n    super.ngOnInit();\n\n    this.selection = new KlesSelectionModel<any>(this.field.multiple || false, [], true,\n      ((o1: any, o2: any) => {\n        if (this.field.property) {\n          return o1?.[this.field.property] === o2?.[this.field.property];\n        } else {\n          return o1 === o2;\n        }\n      }));\n\n    if (this.field.value) {\n      this.selection.select(Array.isArray(this.field.value) ? this.field.value : [this.field.value]);\n    }\n\n    if (this.field.options instanceof Observable) {\n      this.options$ = this.field.options.pipe(shareReplay(1));\n    }\n\n    this.group.controls[this.field.name].valueChanges\n      .pipe(\n        takeUntil(this._onDestroy),\n      ).subscribe((value) => {\n        this.selection.setSelection(Array.isArray(value) ? value : [value], { emitEvent: false });\n      });\n\n    this.selection.changed.pipe(takeUntil(this._onDestroy)).subscribe(change => {\n      this.group.controls[this.field.name].patchValue(change.source.selected);\n      this.group.controls[this.field.name].markAllAsTouched();\n      this.group.controls[this.field.name].markAsDirty();\n    });\n\n    this.optionFiltered$ = this.searchControl.valueChanges\n      .pipe(\n        takeUntil(this._onDestroy),\n        startWith(null as string),\n        debounceTime(this.field.debounceTime || 0),\n        distinctUntilChanged(),\n        map((value) => value?.toLowerCase()),\n        switchMap((value) => {\n          if (this.field.options instanceof Function) {\n            return this.field.options(value);\n          } else {\n            return ((this.field.options instanceof Observable) ? this.options$ : of(this.field.options)).pipe(\n              map((options) => {\n                if (!value) {\n                  return options;\n                }\n                return options.filter(option => {\n                  return (!this.field.property && option?.toString().toLowerCase().includes(value))\n                    || (this.field.property && option?.[this.field.property]?.toString().toLowerCase().includes(value))\n                    || (this.field.searchKeys && this.field.searchKeys.some(key => option?.[key].toString().toLowerCase().includes(value)));\n                });\n              })\n            );\n          }\n        })\n      )\n  }\n  ngOnDestroy(): void {\n    super.ngOnDestroy();\n  }\n\n  onSelectionChange(selection: MatSelectionListChange) {\n    selection.options.forEach(option => {\n      option.selected ? this.selection.select([option.value])\n        : this.selection.deselect([option.value])\n    });\n  }\n}\n"]}
|
|
@@ -3571,6 +3571,8 @@ class KlesFormSelectionListComponent extends KlesFieldAbstract {
|
|
|
3571
3571
|
});
|
|
3572
3572
|
this.selection.changed.pipe(takeUntil(this._onDestroy)).subscribe(change => {
|
|
3573
3573
|
this.group.controls[this.field.name].patchValue(change.source.selected);
|
|
3574
|
+
this.group.controls[this.field.name].markAllAsTouched();
|
|
3575
|
+
this.group.controls[this.field.name].markAsDirty();
|
|
3574
3576
|
});
|
|
3575
3577
|
}
|
|
3576
3578
|
ngOnDestroy() {
|
|
@@ -4525,6 +4527,8 @@ class KlesFormSelectionListSearchComponent extends KlesFieldAbstract {
|
|
|
4525
4527
|
});
|
|
4526
4528
|
this.selection.changed.pipe(takeUntil(this._onDestroy)).subscribe(change => {
|
|
4527
4529
|
this.group.controls[this.field.name].patchValue(change.source.selected);
|
|
4530
|
+
this.group.controls[this.field.name].markAllAsTouched();
|
|
4531
|
+
this.group.controls[this.field.name].markAsDirty();
|
|
4528
4532
|
});
|
|
4529
4533
|
this.optionFiltered$ = this.searchControl.valueChanges
|
|
4530
4534
|
.pipe(takeUntil(this._onDestroy), startWith(null), debounceTime(this.field.debounceTime || 0), distinctUntilChanged(), map((value) => value?.toLowerCase()), switchMap((value) => {
|