@wlcm/angular 17.7.10 → 17.7.12
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/forms/esm2022/lib/forms/components/select/select.component.mjs +46 -18
- package/forms/esm2022/lib/forms/models/select.models.mjs +1 -1
- package/forms/fesm2022/wlcm-angular-forms.mjs +44 -15
- package/forms/fesm2022/wlcm-angular-forms.mjs.map +1 -1
- package/forms/lib/forms/components/select/select.component.d.ts +10 -6
- package/forms/lib/forms/models/select.models.d.ts +3 -0
- package/package.json +1 -1
- package/phone-input/esm2022/lib/components/country-code-select/country-code-select.component.mjs +2 -2
- package/phone-input/fesm2022/wlcm-angular-phone-input.mjs +1 -1
- package/phone-input/fesm2022/wlcm-angular-phone-input.mjs.map +1 -1
- package/table/esm2022/lib/components/table/table.component.mjs +3 -3
- package/table/fesm2022/wlcm-angular-table.mjs +2 -2
- package/table/fesm2022/wlcm-angular-table.mjs.map +1 -1
@@ -1,12 +1,12 @@
|
|
1
1
|
import { __decorate, __metadata } from "tslib";
|
2
2
|
import { CommonModule } from '@angular/common';
|
3
3
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostListener, Inject, Input, NgZone, Optional, ViewChild, computed, effect, forwardRef, inject, input, output, signal, viewChildren, } from '@angular/core';
|
4
|
-
import {
|
4
|
+
import { NG_VALIDATORS, NG_VALUE_ACCESSOR, ReactiveFormsModule, } from '@angular/forms';
|
5
5
|
import { MAT_SELECT_CONFIG, MatOption, MatSelect, MatSelectModule } from '@angular/material/select';
|
6
6
|
import { DEFAULT_QUERY_PARAMS, ScrollDetectionApi, WlcmIconDirective, WlcmIconName, } from '@wlcm/angular/core';
|
7
7
|
import { WLCM_FORM_CONTROL, WLCM_FORM_CONTROL_PROVIDER, WLCM_FORM_FIELD } from '../../constants';
|
8
8
|
import { WlcmSelectInputBinderDirective } from '../../directives/select-input-binder.directive';
|
9
|
-
import { BehaviorSubject, EMPTY, first, switchMap } from 'rxjs';
|
9
|
+
import { BehaviorSubject, EMPTY, Observable, Subject, first, of, switchMap, takeUntil } from 'rxjs';
|
10
10
|
import { WLCM_SELECT_CONFIG } from '../../constants/select.constants';
|
11
11
|
import { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';
|
12
12
|
import { CdkOverlayOrigin } from '@angular/cdk/overlay';
|
@@ -17,7 +17,6 @@ import * as i2 from "../../directives/select-input-binder.directive";
|
|
17
17
|
import * as i3 from "@angular/common";
|
18
18
|
import * as i4 from "@angular/material/select";
|
19
19
|
import * as i5 from "@angular/material/core";
|
20
|
-
import * as i6 from "@angular/forms";
|
21
20
|
const PANEL_CLASS = 'wlcm-select-panel';
|
22
21
|
const DEFAULT_CONFIG = { overlayPanelClass: [PANEL_CLASS] };
|
23
22
|
const mergeConfig = (config) => {
|
@@ -39,6 +38,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
39
38
|
this.parentFormMember = parentFormMember;
|
40
39
|
this.multiple = false;
|
41
40
|
this.placeholder = 'Not selected';
|
41
|
+
this.canSelect = (_) => true;
|
42
42
|
this.queryParams = DEFAULT_QUERY_PARAMS;
|
43
43
|
this.paginated = input(false);
|
44
44
|
this.options = input([]);
|
@@ -50,7 +50,8 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
50
50
|
this.selectionChange = output();
|
51
51
|
this.opened = output();
|
52
52
|
this.closed = output();
|
53
|
-
this.
|
53
|
+
this.value = signal(null);
|
54
|
+
this.disabled = signal(false);
|
54
55
|
this.WlcmIconName = WlcmIconName;
|
55
56
|
this._paginatedData = null;
|
56
57
|
this.computedOptions = computed(() => {
|
@@ -61,6 +62,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
61
62
|
this._blurStream$ = new BehaviorSubject(EMPTY);
|
62
63
|
this.focus$ = this._focusStream$.pipe(switchMap((stream) => stream));
|
63
64
|
this.blur$ = this._blurStream$.pipe(switchMap((stream) => stream));
|
65
|
+
this.selected$ = new Subject();
|
64
66
|
this.compareWith = (optionA, optionB) => {
|
65
67
|
return (optionA?.value || optionA) === (optionB?.value || optionB);
|
66
68
|
};
|
@@ -88,9 +90,38 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
88
90
|
this._blurStream$.next(this.matSelect._closedStream);
|
89
91
|
}
|
90
92
|
select(event) {
|
91
|
-
this.
|
92
|
-
this.
|
93
|
-
|
93
|
+
this.selected$.next();
|
94
|
+
this.validateSelectedOption(event.value)
|
95
|
+
.pipe(takeUntil(this.selected$))
|
96
|
+
.subscribe((canSelect) => {
|
97
|
+
if (!canSelect)
|
98
|
+
return this.revertPreviousValue();
|
99
|
+
this.value.set(event.value);
|
100
|
+
this._changed?.(event.value);
|
101
|
+
this._validatorChanged?.();
|
102
|
+
this.selectionChange.emit(event);
|
103
|
+
});
|
104
|
+
}
|
105
|
+
validateSelectedOption(value) {
|
106
|
+
return new Observable((observer) => {
|
107
|
+
const response = this.canSelect(value);
|
108
|
+
const source = response instanceof Observable ? response.pipe(first()) : of(response);
|
109
|
+
source.subscribe((result) => {
|
110
|
+
observer.next(result);
|
111
|
+
observer.complete();
|
112
|
+
});
|
113
|
+
});
|
114
|
+
}
|
115
|
+
revertPreviousValue() {
|
116
|
+
this.value.update((value) => {
|
117
|
+
if (this.multiple) {
|
118
|
+
if (value instanceof Array) {
|
119
|
+
return [...value];
|
120
|
+
}
|
121
|
+
return [];
|
122
|
+
}
|
123
|
+
return value;
|
124
|
+
});
|
94
125
|
}
|
95
126
|
panelOpened() {
|
96
127
|
this.opened.emit();
|
@@ -106,7 +137,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
106
137
|
});
|
107
138
|
}
|
108
139
|
writeValue(value) {
|
109
|
-
this.
|
140
|
+
this.value.set(value);
|
110
141
|
}
|
111
142
|
registerOnChange(callback) {
|
112
143
|
this._changed = callback;
|
@@ -118,12 +149,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
118
149
|
this._validatorChanged = callback;
|
119
150
|
}
|
120
151
|
setDisabledState(isDisabled) {
|
121
|
-
|
122
|
-
this.control.disable();
|
123
|
-
}
|
124
|
-
else {
|
125
|
-
this.control.enable();
|
126
|
-
}
|
152
|
+
this.disabled.set(isDisabled);
|
127
153
|
}
|
128
154
|
validate() {
|
129
155
|
return null;
|
@@ -165,7 +191,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
165
191
|
});
|
166
192
|
}
|
167
193
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmSelectComponent, deps: [{ token: i0.NgZone }, { token: i0.ChangeDetectorRef }, { token: i1.ScrollDetectionApi }, { token: WLCM_FORM_FIELD }, { token: WLCM_FORM_CONTROL, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
168
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: WlcmSelectComponent, isStandalone: true, selector: "wlcm-select", inputs: { multiple: { classPropertyName: "multiple", publicName: "multiple", isSignal: false, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: false, isRequired: false, transformFunction: null }, fetchPaginatedOptions: { classPropertyName: "fetchPaginatedOptions", publicName: "fetchPaginatedOptions", isSignal: false, isRequired: false, transformFunction: null }, queryParams: { classPropertyName: "queryParams", publicName: "queryParams", isSignal: false, isRequired: false, transformFunction: null }, paginated: { classPropertyName: "paginated", publicName: "paginated", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null }, selectOptionFormat: { classPropertyName: "selectOptionFormat", publicName: "selectOptionFormat", isSignal: true, isRequired: false, transformFunction: null }, optionTemplate: { classPropertyName: "optionTemplate", publicName: "optionTemplate", isSignal: true, isRequired: false, transformFunction: null }, triggerTemplate: { classPropertyName: "triggerTemplate", publicName: "triggerTemplate", isSignal: true, isRequired: false, transformFunction: null }, isOptionDisabled: { classPropertyName: "isOptionDisabled", publicName: "isOptionDisabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selectionChange: "selectionChange", opened: "opened", closed: "closed" }, host: { listeners: { "click": "openPanel()" } }, providers: [
|
194
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: WlcmSelectComponent, isStandalone: true, selector: "wlcm-select", inputs: { multiple: { classPropertyName: "multiple", publicName: "multiple", isSignal: false, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: false, isRequired: false, transformFunction: null }, fetchPaginatedOptions: { classPropertyName: "fetchPaginatedOptions", publicName: "fetchPaginatedOptions", isSignal: false, isRequired: false, transformFunction: null }, canSelect: { classPropertyName: "canSelect", publicName: "canSelect", isSignal: false, isRequired: false, transformFunction: null }, queryParams: { classPropertyName: "queryParams", publicName: "queryParams", isSignal: false, isRequired: false, transformFunction: null }, paginated: { classPropertyName: "paginated", publicName: "paginated", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null }, selectOptionFormat: { classPropertyName: "selectOptionFormat", publicName: "selectOptionFormat", isSignal: true, isRequired: false, transformFunction: null }, optionTemplate: { classPropertyName: "optionTemplate", publicName: "optionTemplate", isSignal: true, isRequired: false, transformFunction: null }, triggerTemplate: { classPropertyName: "triggerTemplate", publicName: "triggerTemplate", isSignal: true, isRequired: false, transformFunction: null }, isOptionDisabled: { classPropertyName: "isOptionDisabled", publicName: "isOptionDisabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selectionChange: "selectionChange", opened: "opened", closed: "closed" }, host: { listeners: { "click": "openPanel()" } }, providers: [
|
169
195
|
WLCM_FORM_CONTROL_PROVIDER,
|
170
196
|
{
|
171
197
|
provide: MAT_SELECT_CONFIG,
|
@@ -176,7 +202,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
176
202
|
},
|
177
203
|
{ provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },
|
178
204
|
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },
|
179
|
-
], viewQueries: [{ propertyName: "matOptions", predicate: MatOption, descendants: true, isSignal: true }, { propertyName: "matSelect", first: true, predicate: MatSelect, descendants: true }], hostDirectives: [{ directive: i2.WlcmSelectInputBinderDirective }], ngImport: i0, template: "<mat-select\n #selectComponent\n [
|
205
|
+
], viewQueries: [{ propertyName: "matOptions", predicate: MatOption, descendants: true, isSignal: true }, { propertyName: "matSelect", first: true, predicate: MatSelect, descendants: true }], hostDirectives: [{ directive: i2.WlcmSelectInputBinderDirective }], ngImport: i0, template: "<mat-select\n #selectComponent\n [value]=\"value()\"\n [disabled]=\"disabled()\"\n [multiple]=\"multiple\"\n [disableRipple]=\"true\"\n [placeholder]=\"placeholder\"\n [hideSingleSelectionIndicator]=\"true\"\n [ngClass]=\"{ focused: selectComponent.focused }\"\n (selectionChange)=\"select($event)\"\n [compareWith]=\"compareWith\"\n (opened)=\"panelOpened()\"\n (closed)=\"panelClosed()\"\n>\n @if (triggerTemplate()) {\n <mat-select-trigger>\n <ng-container\n *ngTemplateOutlet=\"\n triggerTemplate()!;\n context: $any({ $implicit: selectComponent.selected })\n \"\n ></ng-container>\n </mat-select-trigger>\n }\n\n <mat-option\n *ngFor=\"let option of computedOptions()\"\n [value]=\"selectOptionFormat() === 'CompleteOption' ? option : option.value\"\n >\n @if (optionTemplate()) {\n <ng-container\n *ngTemplateOutlet=\"\n optionTemplate();\n context: $any({ $implicit: option })\n \"\n ></ng-container>\n } @else {\n {{ option.viewValue }}\n }\n </mat-option>\n</mat-select>\n\n<div class=\"wlcm-select-arrow\">\n <ng-container\n [wlcmIcon]=\"WlcmIconName.CHEVRON_DOWN\"\n [wlcmIconStopPropagation]=\"false\"\n ></ng-container>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i4.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "directive", type: i4.MatSelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i5.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: WlcmIconDirective, selector: "[wlcmIcon]", inputs: ["wlcmIcon", "wlcmIconStopPropagation"], outputs: ["wlcmIconClicked"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
180
206
|
};
|
181
207
|
WlcmSelectComponent = __decorate([
|
182
208
|
UntilDestroy(),
|
@@ -198,7 +224,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
|
|
198
224
|
},
|
199
225
|
{ provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },
|
200
226
|
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },
|
201
|
-
], template: "<mat-select\n #selectComponent\n [
|
227
|
+
], template: "<mat-select\n #selectComponent\n [value]=\"value()\"\n [disabled]=\"disabled()\"\n [multiple]=\"multiple\"\n [disableRipple]=\"true\"\n [placeholder]=\"placeholder\"\n [hideSingleSelectionIndicator]=\"true\"\n [ngClass]=\"{ focused: selectComponent.focused }\"\n (selectionChange)=\"select($event)\"\n [compareWith]=\"compareWith\"\n (opened)=\"panelOpened()\"\n (closed)=\"panelClosed()\"\n>\n @if (triggerTemplate()) {\n <mat-select-trigger>\n <ng-container\n *ngTemplateOutlet=\"\n triggerTemplate()!;\n context: $any({ $implicit: selectComponent.selected })\n \"\n ></ng-container>\n </mat-select-trigger>\n }\n\n <mat-option\n *ngFor=\"let option of computedOptions()\"\n [value]=\"selectOptionFormat() === 'CompleteOption' ? option : option.value\"\n >\n @if (optionTemplate()) {\n <ng-container\n *ngTemplateOutlet=\"\n optionTemplate();\n context: $any({ $implicit: option })\n \"\n ></ng-container>\n } @else {\n {{ option.viewValue }}\n }\n </mat-option>\n</mat-select>\n\n<div class=\"wlcm-select-arrow\">\n <ng-container\n [wlcmIcon]=\"WlcmIconName.CHEVRON_DOWN\"\n [wlcmIconStopPropagation]=\"false\"\n ></ng-container>\n</div>\n" }]
|
202
228
|
}], ctorParameters: () => [{ type: i0.NgZone }, { type: i0.ChangeDetectorRef }, { type: i1.ScrollDetectionApi }, { type: undefined, decorators: [{
|
203
229
|
type: Inject,
|
204
230
|
args: [WLCM_FORM_FIELD]
|
@@ -213,6 +239,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
|
|
213
239
|
type: Input
|
214
240
|
}], fetchPaginatedOptions: [{
|
215
241
|
type: Input
|
242
|
+
}], canSelect: [{
|
243
|
+
type: Input
|
216
244
|
}], queryParams: [{
|
217
245
|
type: Input
|
218
246
|
}], matSelect: [{
|
@@ -222,4 +250,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
|
|
222
250
|
type: HostListener,
|
223
251
|
args: ['click']
|
224
252
|
}] } });
|
225
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../../modules/forms/src/lib/forms/components/select/select.component.ts","../../../../../../../../modules/forms/src/lib/forms/components/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostListener,\n  Inject,\n  Input,\n  InputSignal,\n  NgZone,\n  Optional,\n  OutputEmitterRef,\n  Signal,\n  TemplateRef,\n  ViewChild,\n  WritableSignal,\n  computed,\n  effect,\n  forwardRef,\n  inject,\n  input,\n  output,\n  signal,\n  viewChildren,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormControl,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\nimport { MAT_SELECT_CONFIG, MatOption, MatSelect, MatSelectChange, MatSelectModule } from '@angular/material/select';\nimport {\n  DEFAULT_QUERY_PARAMS,\n  PaginatedData,\n  QueryParams,\n  ScrollDetectionApi,\n  WlcmIconDirective,\n  WlcmIconName,\n  WlcmOption,\n  WlcmSelectOptionFormat,\n} from '@wlcm/angular/core';\nimport { WLCM_FORM_CONTROL, WLCM_FORM_CONTROL_PROVIDER, WLCM_FORM_FIELD } from '../../constants';\nimport { WlcmSelectInputBinderDirective } from '../../directives/select-input-binder.directive';\nimport { WlcmFormControl, WlcmFormField, WlcmFormFieldInput } from '../../models/_index';\nimport { BehaviorSubject, EMPTY, Observable, first, fromEvent, switchMap, tap } from 'rxjs';\nimport { IsOptionDisabledFn, WlcmSelectConfig } from '../../models/select.models';\nimport { WLCM_SELECT_CONFIG } from '../../constants/select.constants';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { CdkOverlayOrigin } from '@angular/cdk/overlay';\nimport { mergeWith } from 'lodash';\n\ntype SelectValue = string[] | string;\n\ntype OptionTemplateContext = TemplateRef<{ $implicit: WlcmOption }>;\n\nconst PANEL_CLASS: string = 'wlcm-select-panel';\n\nconst DEFAULT_CONFIG: WlcmSelectConfig = { overlayPanelClass: [PANEL_CLASS] };\n\nconst mergeConfig = (config: WlcmSelectConfig): WlcmSelectConfig => {\n  const customizer = (_default: WlcmSelectConfig, _new: WlcmSelectConfig): Array<unknown> | void => {\n    if (Array.isArray(_default)) return _default.concat(_new);\n  };\n\n  return mergeWith({ ...DEFAULT_CONFIG }, config, customizer);\n};\n\n@UntilDestroy()\n@Component({\n  selector: 'wlcm-select',\n  standalone: true,\n  imports: [CommonModule, MatSelectModule, ReactiveFormsModule, WlcmIconDirective, WlcmSelectInputBinderDirective],\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  hostDirectives: [WlcmSelectInputBinderDirective],\n  providers: [\n    WLCM_FORM_CONTROL_PROVIDER,\n    {\n      provide: MAT_SELECT_CONFIG,\n      useFactory: () => {\n        const wlcmConfig: WlcmSelectConfig = inject(WLCM_SELECT_CONFIG, { optional: true }) ?? {};\n\n        return mergeConfig(wlcmConfig);\n      },\n    },\n    { provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },\n    { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },\n  ],\n})\nexport class WlcmSelectComponent implements WlcmFormFieldInput, ControlValueAccessor, Validator {\n  @Input() multiple: boolean = false;\n\n  @Input() placeholder: string = 'Not selected';\n\n  @Input() fetchPaginatedOptions?: (params: QueryParams) => Observable<PaginatedData<WlcmOption>>;\n\n  @Input() queryParams: QueryParams = DEFAULT_QUERY_PARAMS;\n\n  paginated: InputSignal<boolean> = input(false);\n\n  options: InputSignal<WlcmOption[]> = input<WlcmOption[]>([]);\n\n  paginatedOptions: WritableSignal<WlcmOption[]> = signal([]);\n\n  selectOptionFormat: InputSignal<WlcmSelectOptionFormat> = input<WlcmSelectOptionFormat>('ValueOnly');\n\n  optionTemplate: InputSignal<TemplateRef<OptionTemplateContext> | null> =\n    input<TemplateRef<OptionTemplateContext> | null>(null);\n\n  triggerTemplate: InputSignal<TemplateRef<MatOption | MatOption[]> | undefined> = input();\n\n  isOptionDisabled: InputSignal<IsOptionDisabledFn> = input<IsOptionDisabledFn>(() => false);\n\n  selectionChange: OutputEmitterRef<MatSelectChange> = output();\n\n  opened: OutputEmitterRef<void> = output();\n\n  closed: OutputEmitterRef<void> = output();\n\n  readonly control: FormControl = new FormControl();\n\n  readonly WlcmIconName = WlcmIconName;\n\n  private _changed?: (value: WlcmOption) => void;\n\n  private _touched?: () => void;\n\n  private _validatorChanged?: () => void;\n\n  private _paginatedData: PaginatedData<WlcmOption> | null = null;\n\n  computedOptions: Signal<WlcmOption[]> = computed(() => {\n    return this.paginated() ? this.paginatedOptions() : this.options();\n  });\n\n  @ViewChild(MatSelect) matSelect!: MatSelect;\n\n  @HostListener('click') openPanel(): void {\n    this.matSelect.open();\n  }\n\n  protected matOptions: Signal<ReadonlyArray<MatOption>> = viewChildren(MatOption);\n\n  private readonly _focusStream$: BehaviorSubject<Observable<void>> = new BehaviorSubject(EMPTY as Observable<void>);\n\n  private readonly _blurStream$: BehaviorSubject<Observable<void>> = new BehaviorSubject(EMPTY as Observable<void>);\n\n  focus$: Observable<unknown> = this._focusStream$.pipe(switchMap((stream: Observable<unknown>) => stream));\n\n  blur$: Observable<unknown> = this._blurStream$.pipe(switchMap((stream: Observable<unknown>) => stream));\n\n  constructor(\n    private zone: NgZone,\n    private changeDetectorRef: ChangeDetectorRef,\n    private scrollDetectionApi: ScrollDetectionApi,\n    @Inject(WLCM_FORM_FIELD) private formField: WlcmFormField,\n    @Optional() @Inject(WLCM_FORM_CONTROL) private parentFormMember: WlcmFormControl,\n  ) {\n    if (this.parentFormMember) {\n      this.handleStateChange();\n    }\n\n    effect(\n      () => {\n        if (this.paginated()) this.loadPaginatedOptions();\n      },\n      { allowSignalWrites: true },\n    );\n\n    effect(() => {\n      if (this.isOptionDisabled() && this.computedOptions().length > 0) {\n        this.updateOptionsStatus();\n      }\n    });\n  }\n\n  ngAfterViewInit(): void {\n    const formField: ElementRef<HTMLElement> = this.formField.inputContainer;\n\n    if (formField) {\n      this.matSelect._preferredOverlayOrigin = new CdkOverlayOrigin(this.formField.inputContainer);\n    }\n\n    this._focusStream$.next(this.matSelect._openedStream);\n\n    this._blurStream$.next(this.matSelect._closedStream);\n  }\n\n  compareWith = (optionA: WlcmOption | string, optionB: WlcmOption | string): boolean => {\n    return ((optionA as WlcmOption)?.value || optionA) === ((optionB as WlcmOption)?.value || optionB);\n  };\n\n  focus = (): void => this.matSelect.open();\n\n  isFocused = (): boolean => this.isOpen;\n\n  select(event: MatSelectChange): void {\n    this._changed?.(event.value);\n\n    this._validatorChanged?.();\n\n    this.selectionChange.emit(event);\n  }\n\n  protected panelOpened(): void {\n    this.opened.emit();\n\n    this.handleScrollDown();\n  }\n\n  protected panelClosed(): void {\n    this.closed.emit();\n\n    this._touched?.();\n  }\n\n  updateOptionsStatus(): void {\n    this.matOptions().forEach((matOption: MatOption) => {\n      matOption.disabled = this.isOptionDisabled()(matOption.value);\n    });\n  }\n\n  writeValue(value: SelectValue): void {\n    this.control.setValue(value);\n  }\n\n  registerOnChange(callback: (value: WlcmOption) => void): void {\n    this._changed = callback;\n  }\n\n  registerOnTouched(callback: () => void): void {\n    this._touched = callback;\n  }\n\n  registerOnValidatorChange(callback: () => void): void {\n    this._validatorChanged = callback;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (isDisabled) {\n      this.control.disable();\n    } else {\n      this.control.enable();\n    }\n  }\n\n  validate(): ValidationErrors | null {\n    return null;\n  }\n\n  get isOpen(): boolean {\n    return this.matSelect?.panelOpen ?? false;\n  }\n\n  private loadPaginatedOptions(): void {\n    this.fetchPaginatedOptions!({ ...this.queryParams, page: 1 })\n      .pipe(untilDestroyed(this), first())\n      .subscribe((paginatedData: PaginatedData<WlcmOption>) => {\n        this._paginatedData = paginatedData;\n\n        this.paginatedOptions.set(paginatedData.data);\n      });\n  }\n\n  private loadMorePaginatedOptions(): void {\n    if (!this._paginatedData || this._paginatedData.currPage + 1 > this._paginatedData.totalPages) return;\n\n    this.queryParams.page++;\n\n    this.fetchPaginatedOptions!({ ...this.queryParams })\n      .pipe(untilDestroyed(this), first())\n      .subscribe((paginatedData: PaginatedData<WlcmOption>) => {\n        this._paginatedData = paginatedData;\n\n        this.paginatedOptions.update((options: WlcmOption[]) => [...options, ...paginatedData.data]);\n      });\n  }\n\n  private handleScrollDown(): void {\n    const element: HTMLElement = document.querySelector('.mat-mdc-select-panel')!;\n\n    this.zone.runOutsideAngular(() => {\n      this.scrollDetectionApi.onScrolledDown(element).subscribe(() => {\n        this.zone.run(() => this.loadMorePaginatedOptions());\n      });\n    });\n  }\n\n  private handleStateChange(): void {\n    this.parentFormMember.stateChanges$.pipe(untilDestroyed(this)).subscribe(() => {\n      this._validatorChanged?.();\n\n      this.changeDetectorRef.markForCheck();\n    });\n  }\n}\n","<mat-select\n  #selectComponent\n  [multiple]=\"multiple\"\n  [disableRipple]=\"true\"\n  [formControl]=\"control\"\n  [placeholder]=\"placeholder\"\n  [hideSingleSelectionIndicator]=\"true\"\n  [ngClass]=\"{ focused: selectComponent.focused }\"\n  (selectionChange)=\"select($event)\"\n  [compareWith]=\"compareWith\"\n  (opened)=\"panelOpened()\"\n  (closed)=\"panelClosed()\"\n>\n  @if (triggerTemplate()) {\n    <mat-select-trigger>\n      <ng-container\n        *ngTemplateOutlet=\"\n          triggerTemplate()!;\n          context: $any({ $implicit: selectComponent.selected })\n        \"\n      ></ng-container>\n    </mat-select-trigger>\n  }\n\n  <mat-option\n    *ngFor=\"let option of computedOptions()\"\n    [value]=\"selectOptionFormat() === 'CompleteOption' ? option : option.value\"\n  >\n    @if (optionTemplate()) {\n      <ng-container\n        *ngTemplateOutlet=\"\n          optionTemplate();\n          context: $any({ $implicit: option })\n        \"\n      ></ng-container>\n    } @else {\n      {{ option.viewValue }}\n    }\n  </mat-option>\n</mat-select>\n\n<div class=\"wlcm-select-arrow\">\n  <ng-container\n    [wlcmIcon]=\"WlcmIconName.CHEVRON_DOWN\"\n    [wlcmIconStopPropagation]=\"false\"\n  ></ng-container>\n</div>\n"]}
|
253
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../../modules/forms/src/lib/forms/components/select/select.component.ts","../../../../../../../../modules/forms/src/lib/forms/components/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  HostListener,\n  Inject,\n  Input,\n  InputSignal,\n  NgZone,\n  Optional,\n  OutputEmitterRef,\n  Signal,\n  TemplateRef,\n  ViewChild,\n  WritableSignal,\n  computed,\n  effect,\n  forwardRef,\n  inject,\n  input,\n  output,\n  signal,\n  viewChildren,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\nimport { MAT_SELECT_CONFIG, MatOption, MatSelect, MatSelectChange, MatSelectModule } from '@angular/material/select';\nimport {\n  DEFAULT_QUERY_PARAMS,\n  PaginatedData,\n  QueryParams,\n  ScrollDetectionApi,\n  WlcmIconDirective,\n  WlcmIconName,\n  WlcmOption,\n  WlcmSelectOptionFormat,\n} from '@wlcm/angular/core';\nimport { WLCM_FORM_CONTROL, WLCM_FORM_CONTROL_PROVIDER, WLCM_FORM_FIELD } from '../../constants';\nimport { WlcmSelectInputBinderDirective } from '../../directives/select-input-binder.directive';\nimport { WlcmFormControl, WlcmFormField, WlcmFormFieldInput } from '../../models/_index';\nimport { BehaviorSubject, EMPTY, Observable, Subject, Subscriber, first, of, switchMap, takeUntil } from 'rxjs';\nimport { IsOptionDisabledFn, WlcmCanSelectFn, WlcmSelectConfig, WlcmSelectValue } from '../../models/select.models';\nimport { WLCM_SELECT_CONFIG } from '../../constants/select.constants';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { CdkOverlayOrigin } from '@angular/cdk/overlay';\nimport { mergeWith } from 'lodash';\n\ntype OptionTemplateContext = TemplateRef<{ $implicit: WlcmOption }>;\n\nconst PANEL_CLASS: string = 'wlcm-select-panel';\n\nconst DEFAULT_CONFIG: WlcmSelectConfig = { overlayPanelClass: [PANEL_CLASS] };\n\nconst mergeConfig = (config: WlcmSelectConfig): WlcmSelectConfig => {\n  const customizer = (_default: WlcmSelectConfig, _new: WlcmSelectConfig): Array<unknown> | void => {\n    if (Array.isArray(_default)) return _default.concat(_new);\n  };\n\n  return mergeWith({ ...DEFAULT_CONFIG }, config, customizer);\n};\n\n@UntilDestroy()\n@Component({\n  selector: 'wlcm-select',\n  standalone: true,\n  imports: [CommonModule, MatSelectModule, ReactiveFormsModule, WlcmIconDirective, WlcmSelectInputBinderDirective],\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  hostDirectives: [WlcmSelectInputBinderDirective],\n  providers: [\n    WLCM_FORM_CONTROL_PROVIDER,\n    {\n      provide: MAT_SELECT_CONFIG,\n      useFactory: () => {\n        const wlcmConfig: WlcmSelectConfig = inject(WLCM_SELECT_CONFIG, { optional: true }) ?? {};\n\n        return mergeConfig(wlcmConfig);\n      },\n    },\n    { provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },\n    { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },\n  ],\n})\nexport class WlcmSelectComponent implements WlcmFormFieldInput, ControlValueAccessor, Validator {\n  @Input() multiple: boolean = false;\n\n  @Input() placeholder: string = 'Not selected';\n\n  @Input() fetchPaginatedOptions?: (params: QueryParams) => Observable<PaginatedData<WlcmOption>>;\n\n  @Input() canSelect: WlcmCanSelectFn = (_: WlcmSelectValue) => true;\n\n  @Input() queryParams: QueryParams = DEFAULT_QUERY_PARAMS;\n\n  paginated: InputSignal<boolean> = input(false);\n\n  options: InputSignal<WlcmOption[]> = input<WlcmOption[]>([]);\n\n  paginatedOptions: WritableSignal<WlcmOption[]> = signal([]);\n\n  selectOptionFormat: InputSignal<WlcmSelectOptionFormat> = input<WlcmSelectOptionFormat>('ValueOnly');\n\n  optionTemplate: InputSignal<TemplateRef<OptionTemplateContext> | null> =\n    input<TemplateRef<OptionTemplateContext> | null>(null);\n\n  triggerTemplate: InputSignal<TemplateRef<MatOption | MatOption[]> | undefined> = input();\n\n  isOptionDisabled: InputSignal<IsOptionDisabledFn> = input<IsOptionDisabledFn>(() => false);\n\n  selectionChange: OutputEmitterRef<MatSelectChange> = output();\n\n  opened: OutputEmitterRef<void> = output();\n\n  closed: OutputEmitterRef<void> = output();\n\n  readonly value: WritableSignal<WlcmSelectValue | null> = signal(null);\n\n  readonly disabled: WritableSignal<boolean> = signal(false);\n\n  readonly WlcmIconName = WlcmIconName;\n\n  private _changed?: (value: WlcmOption) => void;\n\n  private _touched?: () => void;\n\n  private _validatorChanged?: () => void;\n\n  private _paginatedData: PaginatedData<WlcmOption> | null = null;\n\n  computedOptions: Signal<WlcmOption[]> = computed(() => {\n    return this.paginated() ? this.paginatedOptions() : this.options();\n  });\n\n  @ViewChild(MatSelect) matSelect!: MatSelect;\n\n  @HostListener('click') openPanel(): void {\n    this.matSelect.open();\n  }\n\n  protected matOptions: Signal<ReadonlyArray<MatOption>> = viewChildren(MatOption);\n\n  private readonly _focusStream$: BehaviorSubject<Observable<void>> = new BehaviorSubject(EMPTY as Observable<void>);\n\n  private readonly _blurStream$: BehaviorSubject<Observable<void>> = new BehaviorSubject(EMPTY as Observable<void>);\n\n  focus$: Observable<unknown> = this._focusStream$.pipe(switchMap((stream: Observable<unknown>) => stream));\n\n  blur$: Observable<unknown> = this._blurStream$.pipe(switchMap((stream: Observable<unknown>) => stream));\n\n  private selected$: Subject<void> = new Subject();\n\n  constructor(\n    private zone: NgZone,\n    private changeDetectorRef: ChangeDetectorRef,\n    private scrollDetectionApi: ScrollDetectionApi,\n    @Inject(WLCM_FORM_FIELD) private formField: WlcmFormField,\n    @Optional() @Inject(WLCM_FORM_CONTROL) private parentFormMember: WlcmFormControl,\n  ) {\n    if (this.parentFormMember) {\n      this.handleStateChange();\n    }\n\n    effect(\n      () => {\n        if (this.paginated()) this.loadPaginatedOptions();\n      },\n      { allowSignalWrites: true },\n    );\n\n    effect(() => {\n      if (this.isOptionDisabled() && this.computedOptions().length > 0) {\n        this.updateOptionsStatus();\n      }\n    });\n  }\n\n  ngAfterViewInit(): void {\n    const formField: ElementRef<HTMLElement> = this.formField.inputContainer;\n\n    if (formField) {\n      this.matSelect._preferredOverlayOrigin = new CdkOverlayOrigin(this.formField.inputContainer);\n    }\n\n    this._focusStream$.next(this.matSelect._openedStream);\n\n    this._blurStream$.next(this.matSelect._closedStream);\n  }\n\n  compareWith = (optionA: WlcmOption | string, optionB: WlcmOption | string): boolean => {\n    return ((optionA as WlcmOption)?.value || optionA) === ((optionB as WlcmOption)?.value || optionB);\n  };\n\n  focus = (): void => this.matSelect.open();\n\n  isFocused = (): boolean => this.isOpen;\n\n  select(event: MatSelectChange): void {\n    this.selected$.next();\n\n    this.validateSelectedOption(event.value)\n      .pipe(takeUntil(this.selected$))\n      .subscribe((canSelect: boolean) => {\n        if (!canSelect) return this.revertPreviousValue();\n\n        this.value.set(event.value);\n\n        this._changed?.(event.value);\n\n        this._validatorChanged?.();\n\n        this.selectionChange.emit(event);\n      });\n  }\n\n  private validateSelectedOption(value: WlcmSelectValue): Observable<boolean> {\n    return new Observable<boolean>((observer: Subscriber<boolean>) => {\n      const response: Observable<boolean> | boolean = this.canSelect(value);\n\n      const source: Observable<boolean> = response instanceof Observable ? response.pipe(first()) : of(response);\n\n      source.subscribe((result: boolean) => {\n        observer.next(result);\n        observer.complete();\n      });\n    });\n  }\n\n  private revertPreviousValue(): void {\n    this.value.update((value: WlcmSelectValue | null) => {\n      if (this.multiple) {\n        if (value instanceof Array) {\n          return [...value] as WlcmOption[] | string[];\n        }\n\n        return [];\n      }\n\n      return value;\n    });\n  }\n\n  protected panelOpened(): void {\n    this.opened.emit();\n\n    this.handleScrollDown();\n  }\n\n  protected panelClosed(): void {\n    this.closed.emit();\n\n    this._touched?.();\n  }\n\n  updateOptionsStatus(): void {\n    this.matOptions().forEach((matOption: MatOption) => {\n      matOption.disabled = this.isOptionDisabled()(matOption.value);\n    });\n  }\n\n  writeValue(value: WlcmSelectValue): void {\n    this.value.set(value);\n  }\n\n  registerOnChange(callback: (value: WlcmOption) => void): void {\n    this._changed = callback;\n  }\n\n  registerOnTouched(callback: () => void): void {\n    this._touched = callback;\n  }\n\n  registerOnValidatorChange(callback: () => void): void {\n    this._validatorChanged = callback;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    this.disabled.set(isDisabled);\n  }\n\n  validate(): ValidationErrors | null {\n    return null;\n  }\n\n  get isOpen(): boolean {\n    return this.matSelect?.panelOpen ?? false;\n  }\n\n  private loadPaginatedOptions(): void {\n    this.fetchPaginatedOptions!({ ...this.queryParams, page: 1 })\n      .pipe(untilDestroyed(this), first())\n      .subscribe((paginatedData: PaginatedData<WlcmOption>) => {\n        this._paginatedData = paginatedData;\n\n        this.paginatedOptions.set(paginatedData.data);\n      });\n  }\n\n  private loadMorePaginatedOptions(): void {\n    if (!this._paginatedData || this._paginatedData.currPage + 1 > this._paginatedData.totalPages) return;\n\n    this.queryParams.page++;\n\n    this.fetchPaginatedOptions!({ ...this.queryParams })\n      .pipe(untilDestroyed(this), first())\n      .subscribe((paginatedData: PaginatedData<WlcmOption>) => {\n        this._paginatedData = paginatedData;\n\n        this.paginatedOptions.update((options: WlcmOption[]) => [...options, ...paginatedData.data]);\n      });\n  }\n\n  private handleScrollDown(): void {\n    const element: HTMLElement = document.querySelector('.mat-mdc-select-panel')!;\n\n    this.zone.runOutsideAngular(() => {\n      this.scrollDetectionApi.onScrolledDown(element).subscribe(() => {\n        this.zone.run(() => this.loadMorePaginatedOptions());\n      });\n    });\n  }\n\n  private handleStateChange(): void {\n    this.parentFormMember.stateChanges$.pipe(untilDestroyed(this)).subscribe(() => {\n      this._validatorChanged?.();\n\n      this.changeDetectorRef.markForCheck();\n    });\n  }\n}\n","<mat-select\n  #selectComponent\n  [value]=\"value()\"\n  [disabled]=\"disabled()\"\n  [multiple]=\"multiple\"\n  [disableRipple]=\"true\"\n  [placeholder]=\"placeholder\"\n  [hideSingleSelectionIndicator]=\"true\"\n  [ngClass]=\"{ focused: selectComponent.focused }\"\n  (selectionChange)=\"select($event)\"\n  [compareWith]=\"compareWith\"\n  (opened)=\"panelOpened()\"\n  (closed)=\"panelClosed()\"\n>\n  @if (triggerTemplate()) {\n    <mat-select-trigger>\n      <ng-container\n        *ngTemplateOutlet=\"\n          triggerTemplate()!;\n          context: $any({ $implicit: selectComponent.selected })\n        \"\n      ></ng-container>\n    </mat-select-trigger>\n  }\n\n  <mat-option\n    *ngFor=\"let option of computedOptions()\"\n    [value]=\"selectOptionFormat() === 'CompleteOption' ? option : option.value\"\n  >\n    @if (optionTemplate()) {\n      <ng-container\n        *ngTemplateOutlet=\"\n          optionTemplate();\n          context: $any({ $implicit: option })\n        \"\n      ></ng-container>\n    } @else {\n      {{ option.viewValue }}\n    }\n  </mat-option>\n</mat-select>\n\n<div class=\"wlcm-select-arrow\">\n  <ng-container\n    [wlcmIcon]=\"WlcmIconName.CHEVRON_DOWN\"\n    [wlcmIconStopPropagation]=\"false\"\n  ></ng-container>\n</div>\n"]}
|
@@ -1,2 +1,2 @@
|
|
1
1
|
export {};
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0Lm1vZGVscy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL21vZHVsZXMvZm9ybXMvc3JjL2xpYi9mb3Jtcy9tb2RlbHMvc2VsZWN0Lm1vZGVscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWF0U2VsZWN0Q29uZmlnIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvc2VsZWN0JztcbmltcG9ydCB7IFdsY21PcHRpb24gfSBmcm9tICdAd2xjbS9hbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgT2JzZXJ2YWJsZSB9IGZyb20gJ3J4anMnO1xuXG5leHBvcnQgdHlwZSBXbGNtU2VsZWN0VmFsdWUgPSBXbGNtT3B0aW9uW10gfCBXbGNtT3B0aW9uIHwgc3RyaW5nW10gfCBzdHJpbmc7XG5cbmV4cG9ydCB0eXBlIElzT3B0aW9uRGlzYWJsZWRGbiA9IChvcHRpb246IFdsY21PcHRpb24gfCBzdHJpbmcpID0+IGJvb2xlYW47XG5cbmV4cG9ydCBpbnRlcmZhY2UgV2xjbVNlbGVjdENvbmZpZyBleHRlbmRzIE1hdFNlbGVjdENvbmZpZyB7XG4gIG92ZXJsYXlQYW5lbENsYXNzPzogc3RyaW5nW107XG59XG5cbmV4cG9ydCB0eXBlIFdsY21DYW5TZWxlY3RGbiA9ICh2YWx1ZTogV2xjbVNlbGVjdFZhbHVlKSA9PiBPYnNlcnZhYmxlPGJvb2xlYW4+IHwgYm9vbGVhbjtcbiJdfQ==
|
@@ -5,7 +5,7 @@ import * as i4 from '@angular/forms';
|
|
5
5
|
import { Validators, NgControl, ControlContainer, FormControl, NG_VALUE_ACCESSOR, NG_VALIDATORS, ReactiveFormsModule } from '@angular/forms';
|
6
6
|
import * as i1 from '@angular/common';
|
7
7
|
import { CommonModule } from '@angular/common';
|
8
|
-
import { Subject, Observable, takeUntil, merge, fromEvent, observeOn, asyncScheduler, BehaviorSubject, EMPTY, switchMap, take, tap, concatMap, map, filter, timer, first } from 'rxjs';
|
8
|
+
import { Subject, Observable, takeUntil, merge, fromEvent, observeOn, asyncScheduler, BehaviorSubject, EMPTY, switchMap, take, tap, concatMap, map, filter, timer, first, of } from 'rxjs';
|
9
9
|
import * as i1$3 from '@wlcm/angular/core';
|
10
10
|
import { WlcmAutocompleteOption, DEFAULT_QUERY_PARAMS, WlcmIconName, WlcmIconDirective, WlcmLoaderComponent, ScrollDetectionApi } from '@wlcm/angular/core';
|
11
11
|
import { untilDestroyed, UntilDestroy } from '@ngneat/until-destroy';
|
@@ -884,6 +884,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
884
884
|
this.parentFormMember = parentFormMember;
|
885
885
|
this.multiple = false;
|
886
886
|
this.placeholder = 'Not selected';
|
887
|
+
this.canSelect = (_) => true;
|
887
888
|
this.queryParams = DEFAULT_QUERY_PARAMS;
|
888
889
|
this.paginated = input(false);
|
889
890
|
this.options = input([]);
|
@@ -895,7 +896,8 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
895
896
|
this.selectionChange = output();
|
896
897
|
this.opened = output();
|
897
898
|
this.closed = output();
|
898
|
-
this.
|
899
|
+
this.value = signal(null);
|
900
|
+
this.disabled = signal(false);
|
899
901
|
this.WlcmIconName = WlcmIconName;
|
900
902
|
this._paginatedData = null;
|
901
903
|
this.computedOptions = computed(() => {
|
@@ -906,6 +908,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
906
908
|
this._blurStream$ = new BehaviorSubject(EMPTY);
|
907
909
|
this.focus$ = this._focusStream$.pipe(switchMap((stream) => stream));
|
908
910
|
this.blur$ = this._blurStream$.pipe(switchMap((stream) => stream));
|
911
|
+
this.selected$ = new Subject();
|
909
912
|
this.compareWith = (optionA, optionB) => {
|
910
913
|
return (optionA?.value || optionA) === (optionB?.value || optionB);
|
911
914
|
};
|
@@ -933,9 +936,38 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
933
936
|
this._blurStream$.next(this.matSelect._closedStream);
|
934
937
|
}
|
935
938
|
select(event) {
|
936
|
-
this.
|
937
|
-
this.
|
938
|
-
|
939
|
+
this.selected$.next();
|
940
|
+
this.validateSelectedOption(event.value)
|
941
|
+
.pipe(takeUntil(this.selected$))
|
942
|
+
.subscribe((canSelect) => {
|
943
|
+
if (!canSelect)
|
944
|
+
return this.revertPreviousValue();
|
945
|
+
this.value.set(event.value);
|
946
|
+
this._changed?.(event.value);
|
947
|
+
this._validatorChanged?.();
|
948
|
+
this.selectionChange.emit(event);
|
949
|
+
});
|
950
|
+
}
|
951
|
+
validateSelectedOption(value) {
|
952
|
+
return new Observable((observer) => {
|
953
|
+
const response = this.canSelect(value);
|
954
|
+
const source = response instanceof Observable ? response.pipe(first()) : of(response);
|
955
|
+
source.subscribe((result) => {
|
956
|
+
observer.next(result);
|
957
|
+
observer.complete();
|
958
|
+
});
|
959
|
+
});
|
960
|
+
}
|
961
|
+
revertPreviousValue() {
|
962
|
+
this.value.update((value) => {
|
963
|
+
if (this.multiple) {
|
964
|
+
if (value instanceof Array) {
|
965
|
+
return [...value];
|
966
|
+
}
|
967
|
+
return [];
|
968
|
+
}
|
969
|
+
return value;
|
970
|
+
});
|
939
971
|
}
|
940
972
|
panelOpened() {
|
941
973
|
this.opened.emit();
|
@@ -951,7 +983,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
951
983
|
});
|
952
984
|
}
|
953
985
|
writeValue(value) {
|
954
|
-
this.
|
986
|
+
this.value.set(value);
|
955
987
|
}
|
956
988
|
registerOnChange(callback) {
|
957
989
|
this._changed = callback;
|
@@ -963,12 +995,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
963
995
|
this._validatorChanged = callback;
|
964
996
|
}
|
965
997
|
setDisabledState(isDisabled) {
|
966
|
-
|
967
|
-
this.control.disable();
|
968
|
-
}
|
969
|
-
else {
|
970
|
-
this.control.enable();
|
971
|
-
}
|
998
|
+
this.disabled.set(isDisabled);
|
972
999
|
}
|
973
1000
|
validate() {
|
974
1001
|
return null;
|
@@ -1010,7 +1037,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
1010
1037
|
});
|
1011
1038
|
}
|
1012
1039
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmSelectComponent, deps: [{ token: i0.NgZone }, { token: i0.ChangeDetectorRef }, { token: i1$3.ScrollDetectionApi }, { token: WLCM_FORM_FIELD }, { token: WLCM_FORM_CONTROL, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
1013
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: WlcmSelectComponent, isStandalone: true, selector: "wlcm-select", inputs: { multiple: { classPropertyName: "multiple", publicName: "multiple", isSignal: false, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: false, isRequired: false, transformFunction: null }, fetchPaginatedOptions: { classPropertyName: "fetchPaginatedOptions", publicName: "fetchPaginatedOptions", isSignal: false, isRequired: false, transformFunction: null }, queryParams: { classPropertyName: "queryParams", publicName: "queryParams", isSignal: false, isRequired: false, transformFunction: null }, paginated: { classPropertyName: "paginated", publicName: "paginated", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null }, selectOptionFormat: { classPropertyName: "selectOptionFormat", publicName: "selectOptionFormat", isSignal: true, isRequired: false, transformFunction: null }, optionTemplate: { classPropertyName: "optionTemplate", publicName: "optionTemplate", isSignal: true, isRequired: false, transformFunction: null }, triggerTemplate: { classPropertyName: "triggerTemplate", publicName: "triggerTemplate", isSignal: true, isRequired: false, transformFunction: null }, isOptionDisabled: { classPropertyName: "isOptionDisabled", publicName: "isOptionDisabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selectionChange: "selectionChange", opened: "opened", closed: "closed" }, host: { listeners: { "click": "openPanel()" } }, providers: [
|
1040
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: WlcmSelectComponent, isStandalone: true, selector: "wlcm-select", inputs: { multiple: { classPropertyName: "multiple", publicName: "multiple", isSignal: false, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: false, isRequired: false, transformFunction: null }, fetchPaginatedOptions: { classPropertyName: "fetchPaginatedOptions", publicName: "fetchPaginatedOptions", isSignal: false, isRequired: false, transformFunction: null }, canSelect: { classPropertyName: "canSelect", publicName: "canSelect", isSignal: false, isRequired: false, transformFunction: null }, queryParams: { classPropertyName: "queryParams", publicName: "queryParams", isSignal: false, isRequired: false, transformFunction: null }, paginated: { classPropertyName: "paginated", publicName: "paginated", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null }, selectOptionFormat: { classPropertyName: "selectOptionFormat", publicName: "selectOptionFormat", isSignal: true, isRequired: false, transformFunction: null }, optionTemplate: { classPropertyName: "optionTemplate", publicName: "optionTemplate", isSignal: true, isRequired: false, transformFunction: null }, triggerTemplate: { classPropertyName: "triggerTemplate", publicName: "triggerTemplate", isSignal: true, isRequired: false, transformFunction: null }, isOptionDisabled: { classPropertyName: "isOptionDisabled", publicName: "isOptionDisabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selectionChange: "selectionChange", opened: "opened", closed: "closed" }, host: { listeners: { "click": "openPanel()" } }, providers: [
|
1014
1041
|
WLCM_FORM_CONTROL_PROVIDER,
|
1015
1042
|
{
|
1016
1043
|
provide: MAT_SELECT_CONFIG,
|
@@ -1021,7 +1048,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
1021
1048
|
},
|
1022
1049
|
{ provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },
|
1023
1050
|
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },
|
1024
|
-
], viewQueries: [{ propertyName: "matOptions", predicate: MatOption, descendants: true, isSignal: true }, { propertyName: "matSelect", first: true, predicate: MatSelect, descendants: true }], hostDirectives: [{ directive: WlcmSelectInputBinderDirective }], ngImport: i0, template: "<mat-select\n #selectComponent\n [
|
1051
|
+
], viewQueries: [{ propertyName: "matOptions", predicate: MatOption, descendants: true, isSignal: true }, { propertyName: "matSelect", first: true, predicate: MatSelect, descendants: true }], hostDirectives: [{ directive: WlcmSelectInputBinderDirective }], ngImport: i0, template: "<mat-select\n #selectComponent\n [value]=\"value()\"\n [disabled]=\"disabled()\"\n [multiple]=\"multiple\"\n [disableRipple]=\"true\"\n [placeholder]=\"placeholder\"\n [hideSingleSelectionIndicator]=\"true\"\n [ngClass]=\"{ focused: selectComponent.focused }\"\n (selectionChange)=\"select($event)\"\n [compareWith]=\"compareWith\"\n (opened)=\"panelOpened()\"\n (closed)=\"panelClosed()\"\n>\n @if (triggerTemplate()) {\n <mat-select-trigger>\n <ng-container\n *ngTemplateOutlet=\"\n triggerTemplate()!;\n context: $any({ $implicit: selectComponent.selected })\n \"\n ></ng-container>\n </mat-select-trigger>\n }\n\n <mat-option\n *ngFor=\"let option of computedOptions()\"\n [value]=\"selectOptionFormat() === 'CompleteOption' ? option : option.value\"\n >\n @if (optionTemplate()) {\n <ng-container\n *ngTemplateOutlet=\"\n optionTemplate();\n context: $any({ $implicit: option })\n \"\n ></ng-container>\n } @else {\n {{ option.viewValue }}\n }\n </mat-option>\n</mat-select>\n\n<div class=\"wlcm-select-arrow\">\n <ng-container\n [wlcmIcon]=\"WlcmIconName.CHEVRON_DOWN\"\n [wlcmIconStopPropagation]=\"false\"\n ></ng-container>\n</div>\n", styles: [""], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: MatSelectModule }, { kind: "component", type: i4$1.MatSelect, selector: "mat-select", inputs: ["aria-describedby", "panelClass", "disabled", "disableRipple", "tabIndex", "hideSingleSelectionIndicator", "placeholder", "required", "multiple", "disableOptionCentering", "compareWith", "value", "aria-label", "aria-labelledby", "errorStateMatcher", "typeaheadDebounceInterval", "sortComparator", "id", "panelWidth"], outputs: ["openedChange", "opened", "closed", "selectionChange", "valueChange"], exportAs: ["matSelect"] }, { kind: "directive", type: i4$1.MatSelectTrigger, selector: "mat-select-trigger" }, { kind: "component", type: i3.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: WlcmIconDirective, selector: "[wlcmIcon]", inputs: ["wlcmIcon", "wlcmIconStopPropagation"], outputs: ["wlcmIconClicked"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
1025
1052
|
};
|
1026
1053
|
WlcmSelectComponent = __decorate([
|
1027
1054
|
UntilDestroy(),
|
@@ -1042,7 +1069,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
|
|
1042
1069
|
},
|
1043
1070
|
{ provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },
|
1044
1071
|
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmSelectComponent), multi: true },
|
1045
|
-
], template: "<mat-select\n #selectComponent\n [
|
1072
|
+
], template: "<mat-select\n #selectComponent\n [value]=\"value()\"\n [disabled]=\"disabled()\"\n [multiple]=\"multiple\"\n [disableRipple]=\"true\"\n [placeholder]=\"placeholder\"\n [hideSingleSelectionIndicator]=\"true\"\n [ngClass]=\"{ focused: selectComponent.focused }\"\n (selectionChange)=\"select($event)\"\n [compareWith]=\"compareWith\"\n (opened)=\"panelOpened()\"\n (closed)=\"panelClosed()\"\n>\n @if (triggerTemplate()) {\n <mat-select-trigger>\n <ng-container\n *ngTemplateOutlet=\"\n triggerTemplate()!;\n context: $any({ $implicit: selectComponent.selected })\n \"\n ></ng-container>\n </mat-select-trigger>\n }\n\n <mat-option\n *ngFor=\"let option of computedOptions()\"\n [value]=\"selectOptionFormat() === 'CompleteOption' ? option : option.value\"\n >\n @if (optionTemplate()) {\n <ng-container\n *ngTemplateOutlet=\"\n optionTemplate();\n context: $any({ $implicit: option })\n \"\n ></ng-container>\n } @else {\n {{ option.viewValue }}\n }\n </mat-option>\n</mat-select>\n\n<div class=\"wlcm-select-arrow\">\n <ng-container\n [wlcmIcon]=\"WlcmIconName.CHEVRON_DOWN\"\n [wlcmIconStopPropagation]=\"false\"\n ></ng-container>\n</div>\n" }]
|
1046
1073
|
}], ctorParameters: () => [{ type: i0.NgZone }, { type: i0.ChangeDetectorRef }, { type: i1$3.ScrollDetectionApi }, { type: undefined, decorators: [{
|
1047
1074
|
type: Inject,
|
1048
1075
|
args: [WLCM_FORM_FIELD]
|
@@ -1057,6 +1084,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
|
|
1057
1084
|
type: Input
|
1058
1085
|
}], fetchPaginatedOptions: [{
|
1059
1086
|
type: Input
|
1087
|
+
}], canSelect: [{
|
1088
|
+
type: Input
|
1060
1089
|
}], queryParams: [{
|
1061
1090
|
type: Input
|
1062
1091
|
}], matSelect: [{
|