@wlcm/angular 17.7.26 → 17.7.28
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/autocomplete/autocomplete.component.mjs +19 -2
- package/forms/esm2022/lib/forms/components/select/select.component.mjs +40 -3
- package/forms/fesm2022/wlcm-angular-forms.mjs +56 -2
- package/forms/fesm2022/wlcm-angular-forms.mjs.map +1 -1
- package/forms/lib/forms/components/autocomplete/autocomplete.component.d.ts +5 -1
- package/forms/lib/forms/components/select/select.component.d.ts +7 -1
- package/package.json +1 -1
@@ -44,15 +44,19 @@ let WlcmAutocompleteComponent = class WlcmAutocompleteComponent extends WlcmAuto
|
|
44
44
|
this.focus$ = this._focusStream$.pipe(switchMap((stream) => stream));
|
45
45
|
this.blur$ = this._blurStream$.pipe(switchMap((stream) => stream));
|
46
46
|
this.loading$ = this._loading$.asObservable();
|
47
|
+
this.adjustedValue$ = new BehaviorSubject(null);
|
47
48
|
this._paginatedData = null;
|
48
49
|
this._reloadOptions$ = new Subject();
|
50
|
+
this.viewReady$ = new Subject();
|
49
51
|
this.handleLoadMoreEvent();
|
50
52
|
this.handleControlValueChanges();
|
53
|
+
this.handleAdjustedValue();
|
51
54
|
}
|
52
55
|
ngOnInit() {
|
53
56
|
this.loadOptions().pipe(first()).subscribe();
|
54
57
|
}
|
55
58
|
ngAfterViewInit() {
|
59
|
+
this.viewReady$.next();
|
56
60
|
const container = this.formField.inputContainer;
|
57
61
|
const origin = new MatAutocompleteOrigin(container);
|
58
62
|
this.autocompleteTrigger.connectedTo = origin;
|
@@ -74,7 +78,8 @@ let WlcmAutocompleteComponent = class WlcmAutocompleteComponent extends WlcmAuto
|
|
74
78
|
this._loadMore$.next();
|
75
79
|
}
|
76
80
|
writeValue(value) {
|
77
|
-
this.
|
81
|
+
const formattedValue = this.prepareValueForPatch(value);
|
82
|
+
this.control.setValue(formattedValue);
|
78
83
|
}
|
79
84
|
registerOnChange(callback) {
|
80
85
|
this._changed = callback;
|
@@ -107,6 +112,13 @@ let WlcmAutocompleteComponent = class WlcmAutocompleteComponent extends WlcmAuto
|
|
107
112
|
registerOnValidatorChange(fn) {
|
108
113
|
this._onValidatorChange = fn;
|
109
114
|
}
|
115
|
+
prepareValueForPatch(value) {
|
116
|
+
if (value instanceof Object && this.selectOptionFormat() === 'ValueOnly') {
|
117
|
+
this.adjustedValue$.next(value.value);
|
118
|
+
return value.value;
|
119
|
+
}
|
120
|
+
return value;
|
121
|
+
}
|
110
122
|
loadOptions(query = '') {
|
111
123
|
this._loading$.next(true);
|
112
124
|
this.queryParams = { ...this.queryParams, query, page: 1 };
|
@@ -155,6 +167,11 @@ let WlcmAutocompleteComponent = class WlcmAutocompleteComponent extends WlcmAuto
|
|
155
167
|
this._focusStream$.next(merge(...focusObservables).pipe(map(voidFn)));
|
156
168
|
this._blurStream$.next(merge(...blurObservables).pipe(map(() => this.control?.markAsTouched())));
|
157
169
|
}
|
170
|
+
handleAdjustedValue() {
|
171
|
+
this.viewReady$
|
172
|
+
.pipe(switchMap(() => this.adjustedValue$.pipe(filter(Boolean))))
|
173
|
+
.subscribe((value) => this._changed?.(value));
|
174
|
+
}
|
158
175
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmAutocompleteComponent, deps: [{ token: WLCM_FORM_FIELD }], target: i0.ɵɵFactoryTarget.Component }); }
|
159
176
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: WlcmAutocompleteComponent, isStandalone: true, selector: "wlcm-autocomplete", inputs: { fetchPaginatedOptions: { classPropertyName: "fetchPaginatedOptions", publicName: "fetchPaginatedOptions", isSignal: false, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: false, isRequired: false, transformFunction: null }, required: { classPropertyName: "required", publicName: "required", isSignal: false, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: false, isRequired: false, transformFunction: null }, optionTemplate: { classPropertyName: "optionTemplate", publicName: "optionTemplate", isSignal: false, isRequired: false, transformFunction: null }, queryParams: { classPropertyName: "queryParams", publicName: "queryParams", isSignal: false, isRequired: false, transformFunction: (params) => cloneDeep(params) }, selectOptionFormat: { classPropertyName: "selectOptionFormat", publicName: "selectOptionFormat", isSignal: true, isRequired: false, transformFunction: null }, noResultsTemplate: { classPropertyName: "noResultsTemplate", publicName: "noResultsTemplate", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selected: "selected" }, host: { classAttribute: "wlcm-autocomplete" }, providers: [
|
160
177
|
{ provide: MAT_AUTOCOMPLETE_DEFAULT_OPTIONS, useValue: { overlayPanelClass: PANEL_CLASS } },
|
@@ -223,4 +240,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
|
|
223
240
|
type: ViewChild,
|
224
241
|
args: [MatAutocomplete]
|
225
242
|
}] } });
|
226
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../../modules/forms/src/lib/forms/components/autocomplete/autocomplete.component.ts","../../../../../../../../modules/forms/src/lib/forms/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  InputSignal,\n  OnInit,\n  OutputEmitterRef,\n  TemplateRef,\n  ViewChild,\n  forwardRef,\n  inject,\n  input,\n  output,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { WlcmFormFieldComponent } from '../form-field/form-field.component';\nimport { WlcmLabelComponent } from '../label/label.component';\nimport { WlcmInputDirective } from '../../directives/input.directive';\nimport {\n  MAT_AUTOCOMPLETE_DEFAULT_OPTIONS,\n  MatAutocomplete,\n  MatAutocompleteModule,\n  MatAutocompleteOrigin,\n  MatAutocompleteTrigger,\n} from '@angular/material/autocomplete';\nimport {\n  BehaviorSubject,\n  EMPTY,\n  Observable,\n  Subject,\n  concatMap,\n  filter,\n  first,\n  fromEvent,\n  map,\n  merge,\n  switchMap,\n  take,\n  tap,\n  timer,\n} from 'rxjs';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { AutocompleteDirective } from '../../directives/autocomplete.directive';\nimport { DEFAULT_QUERY_PARAMS, WlcmAutocompleteOption, WlcmSelectOptionFormat } from '@wlcm/angular/core';\nimport { WLCM_FORM_FIELD, WLCM_INPUT, WLCM_INPUT_BINDER } from '../../constants';\nimport { WlcmAutocomplete, WlcmAutocompleteValue } from '../../models/autocomplete.models';\nimport { WlcmQueryParams, WlcmPaginatedData } from '@wlcm/common';\nimport { WlcmFormFieldInput } from '../../models/input.models';\nimport { WlcmFormField } from '../../models/form.models';\nimport { RxLet } from '@rx-angular/template/let';\nimport { cloneDeep } from 'lodash-es';\n\ntype Option = WlcmAutocompleteOption;\n\nconst PANEL_CLASS: string = 'wlcm-autocomplete-panel';\n\n@UntilDestroy()\n@Component({\n  selector: 'wlcm-autocomplete',\n  exportAs: 'wlcmAutocomplete',\n  host: { class: 'wlcm-autocomplete' },\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatAutocompleteModule,\n    AutocompleteDirective,\n    ReactiveFormsModule,\n    WlcmFormFieldComponent,\n    WlcmLabelComponent,\n    WlcmInputDirective,\n    RxLet,\n  ],\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['./autocomplete.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    { provide: MAT_AUTOCOMPLETE_DEFAULT_OPTIONS, useValue: { overlayPanelClass: PANEL_CLASS } },\n    { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmAutocompleteComponent), multi: true },\n    { provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmAutocompleteComponent), multi: true },\n    {\n      provide: WLCM_INPUT_BINDER,\n      useFactory: () => {\n        const autocomplete = inject(WlcmAutocompleteComponent, { self: true });\n\n        return { bind: () => autocomplete };\n      },\n    },\n  ],\n})\nexport class WlcmAutocompleteComponent\n  extends WlcmAutocomplete\n  implements OnInit, ControlValueAccessor, Validator, AfterViewInit, WlcmFormFieldInput\n{\n  @Input() fetchPaginatedOptions!: (params: WlcmQueryParams) => Observable<WlcmPaginatedData<Option>>;\n\n  @Input() label!: string;\n\n  @Input() required: boolean = false;\n\n  @Input() placeholder: string = '';\n\n  @Input() optionTemplate?: TemplateRef<{ $implicit: WlcmAutocompleteOption }>;\n\n  @Input({ transform: (params: WlcmQueryParams) => cloneDeep(params) }) queryParams: WlcmQueryParams = cloneDeep({\n    ...DEFAULT_QUERY_PARAMS,\n    limit: 15,\n  });\n\n  selectOptionFormat: InputSignal<WlcmSelectOptionFormat> = input<WlcmSelectOptionFormat>('ValueOnly');\n\n  noResultsTemplate: InputSignal<TemplateRef<{ $implicit: WlcmAutocompleteValue; loading: boolean }> | undefined> =\n    input();\n\n  selected: OutputEmitterRef<WlcmAutocompleteValue> = output();\n\n  readonly control: FormControl<WlcmAutocompleteValue> = new FormControl('');\n\n  private readonly _loadMore$: Subject<void> = new Subject();\n\n  private readonly _options$: BehaviorSubject<Option[]> = new BehaviorSubject<Option[]>([]);\n\n  protected readonly options$: Observable<Option[]> = this._options$.asObservable();\n\n  protected readonly closed$: Subject<void> = new Subject();\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  private readonly _loading$: BehaviorSubject<boolean> = new BehaviorSubject(false);\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  loading$: Observable<boolean> = this._loading$.asObservable();\n\n  private _changed?: (value: WlcmAutocompleteOption | string) => void;\n\n  private _touched?: () => void;\n\n  private _onValidatorChange?: () => void;\n\n  private _paginatedData: WlcmPaginatedData<Option> | null = null;\n\n  private _reloadOptions$: Subject<void> = new Subject();\n\n  @ViewChild(WLCM_INPUT, { read: ElementRef }) public inputElement!: ElementRef<HTMLInputElement>;\n\n  @ViewChild(MatAutocompleteTrigger) private autocompleteTrigger!: MatAutocompleteTrigger;\n\n  @ViewChild(MatAutocomplete) private autocomplete!: MatAutocomplete;\n\n  constructor(@Inject(WLCM_FORM_FIELD) private formField: WlcmFormField) {\n    super();\n\n    this.handleLoadMoreEvent();\n\n    this.handleControlValueChanges();\n  }\n\n  ngOnInit(): void {\n    this.loadOptions().pipe(first()).subscribe();\n  }\n\n  ngAfterViewInit(): void {\n    const container: ElementRef = this.formField.inputContainer;\n\n    const origin: MatAutocompleteOrigin = new MatAutocompleteOrigin(container);\n\n    this.autocompleteTrigger.connectedTo = origin;\n\n    this.attachFocusBlurListeners();\n  }\n\n  displayWith(value: Option | string): string {\n    if (value instanceof Object) {\n      return value.viewValue;\n    }\n\n    return value;\n  }\n\n  focus(): void {\n    this.inputElement.nativeElement.focus();\n  }\n\n  isFocused(): boolean {\n    return this.inputElement?.nativeElement === document.activeElement || this.autocomplete?.isOpen;\n  }\n\n  loadMore(): void {\n    this._loadMore$.next();\n  }\n\n  writeValue(value: WlcmAutocompleteValue): void {\n    this.control.setValue(value);\n  }\n\n  registerOnChange(callback: (value: WlcmAutocompleteOption | string) => void): void {\n    this._changed = callback;\n  }\n\n  registerOnTouched(callback: () => void): void {\n    this._touched = callback;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (isDisabled) {\n      return this.control.disable();\n    }\n\n    this.control.enable();\n  }\n\n  reloadOptions(): void {\n    this._reloadOptions$.next();\n  }\n\n  blured(): void {\n    if (!this.autocomplete.isOpen) this._touched?.();\n\n    this.autocomplete.closed.pipe(take(1)).subscribe(() => this._touched?.());\n  }\n\n  validate(control: AbstractControl): ValidationErrors | null {\n    if (!!this.control.value) {\n      if (this.control.value instanceof Object) return null;\n\n      return { ...control.errors, unselected: true, required: false };\n    }\n\n    return null;\n  }\n\n  registerOnValidatorChange(fn: () => void): void {\n    this._onValidatorChange = fn;\n  }\n\n  private loadOptions(query: string = ''): Observable<WlcmPaginatedData<Option>> {\n    this._loading$.next(true);\n\n    this.queryParams = { ...this.queryParams, query, page: 1 };\n\n    return this.fetchPaginatedOptions(this.queryParams).pipe(\n      tap((paginatedData: WlcmPaginatedData<Option>) => {\n        this._paginatedData = paginatedData;\n\n        this._options$.next(paginatedData.data);\n\n        this._loading$.next(false);\n      }),\n    );\n  }\n\n  private handleLoadMoreEvent(): void {\n    this._loadMore$\n      .pipe(\n        concatMap(() => {\n          if (this._paginatedData && this._paginatedData.currPage + 1 <= this._paginatedData.totalPages) {\n            this.queryParams.page++;\n\n            this._loading$.next(true);\n\n            return this.fetchPaginatedOptions(this.queryParams).pipe(\n              tap((paginatedData: WlcmPaginatedData<Option>) => {\n                this._paginatedData = paginatedData;\n\n                this._options$.next([...this._options$.value, ...paginatedData.data]);\n\n                this._loading$.next(false);\n              }),\n            );\n          }\n\n          return EMPTY;\n        }),\n      )\n      .subscribe();\n  }\n\n  private handleControlValueChanges(): void {\n    merge(this.control.valueChanges, this._reloadOptions$.pipe(map(() => this.control.value)))\n      .pipe(untilDestroyed(this))\n      .pipe(\n        filter((value: WlcmAutocompleteValue) => {\n          let _value: WlcmAutocompleteValue = value ?? '';\n\n          if (value instanceof Object && this.selectOptionFormat() === 'ValueOnly') _value = value.value;\n\n          this._changed?.(_value);\n\n          this.selected.emit(_value);\n\n          return !(value instanceof Object);\n        }),\n      )\n      .pipe(\n        switchMap((value: WlcmAutocompleteValue) =>\n          timer(200).pipe(switchMap(() => this.loadOptions(value as string))),\n        ),\n      )\n      .subscribe();\n  }\n\n  private attachFocusBlurListeners(): void {\n    const voidFn = () => {};\n\n    const inputFocus: Observable<Event> = fromEvent(this.inputElement.nativeElement, 'focus');\n\n    const inputBlur: Observable<Event> = fromEvent(this.inputElement.nativeElement, 'blur');\n\n    const focusObservables: Observable<unknown>[] = [inputFocus, this.autocomplete.opened];\n\n    const blurObservables: Observable<unknown>[] = [inputBlur, this.autocomplete.closed];\n\n    this._focusStream$.next(merge(...focusObservables).pipe(map(voidFn)));\n\n    this._blurStream$.next(merge(...blurObservables).pipe(map(() => this.control?.markAsTouched())));\n  }\n}\n","<input\n  wlcmInput\n  type=\"text\"\n  [matAutocomplete]=\"autocomplete\"\n  [placeholder]=\"placeholder\"\n  [formControl]=\"control\"\n  (blur)=\"blured()\"\n/>\n\n<mat-autocomplete\n  #autocomplete=\"matAutocomplete\"\n  wlcmAutocomplete\n  [disableRipple]=\"true\"\n  [displayWith]=\"displayWith\"\n  [hideSingleSelectionIndicator]=\"true\"\n  (panelScrolled)=\"loadMore()\"\n>\n  <ng-container *rxLet=\"$any(options$ | async); let options\">\n    <mat-option\n      *ngFor=\"let option of options\"\n      [ngClass]=\"{ 'wlcm-custom-option-content': optionTemplate }\"\n      [value]=\"option\"\n    >\n      @if (optionTemplate) {\n        <ng-container\n          *ngTemplateOutlet=\"optionTemplate; context: { $implicit: option }\"\n        ></ng-container>\n      } @else {\n        {{ option.viewValue }}\n      }\n    </mat-option>\n\n    <mat-option [disabled]=\"true\" *ngIf=\"options.length === 0\">\n      @if (noResultsTemplate()) {\n        <ng-container\n          *ngTemplateOutlet=\"\n            noResultsTemplate()!;\n            context: { $implicit: control.value, loading: loading$ | async }\n          \"\n        ></ng-container>\n      } @else {\n        <ng-container\n          *ngTemplateOutlet=\"\n            defaultNoResultsTemplate;\n            context: { $implicit: control.value, loading: loading$ | async }\n          \"\n        ></ng-container>\n      }\n    </mat-option>\n  </ng-container>\n</mat-autocomplete>\n\n<ng-template #defaultNoResultsTemplate let-loading=\"loading\">\n  @if (loading) {\n    Please wait...\n  } @else {\n    No results found\n  }\n</ng-template>\n"]}
|
243
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autocomplete.component.js","sourceRoot":"","sources":["../../../../../../../../modules/forms/src/lib/forms/components/autocomplete/autocomplete.component.ts","../../../../../../../../modules/forms/src/lib/forms/components/autocomplete/autocomplete.component.html"],"names":[],"mappings":";AAAA,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,MAAM,EACN,KAAK,EAIL,WAAW,EACX,SAAS,EACT,UAAU,EACV,MAAM,EACN,KAAK,EACL,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAGL,WAAW,EACX,aAAa,EACb,iBAAiB,EACjB,mBAAmB,GAGpB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,sBAAsB,EAAE,MAAM,oCAAoC,CAAC;AAC5E,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AACtE,OAAO,EACL,gCAAgC,EAChC,eAAe,EACf,qBAAqB,EACrB,qBAAqB,EACrB,sBAAsB,GACvB,MAAM,gCAAgC,CAAC;AACxC,OAAO,EACL,eAAe,EACf,KAAK,EAEL,OAAO,EACP,SAAS,EACT,MAAM,EACN,KAAK,EACL,SAAS,EACT,GAAG,EACH,KAAK,EACL,SAAS,EACT,IAAI,EACJ,GAAG,EACH,KAAK,GACN,MAAM,MAAM,CAAC;AACd,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACrE,OAAO,EAAE,qBAAqB,EAAE,MAAM,yCAAyC,CAAC;AAChF,OAAO,EAAE,oBAAoB,EAAkD,MAAM,oBAAoB,CAAC;AAC1G,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACjF,OAAO,EAAE,gBAAgB,EAAyB,MAAM,kCAAkC,CAAC;AAI3F,OAAO,EAAE,KAAK,EAAE,MAAM,0BAA0B,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;;;;;;AAItC,MAAM,WAAW,GAAW,yBAAyB,CAAC;AAmC/C,IAAM,yBAAyB,GAA/B,MAAM,yBACX,SAAQ,gBAAgB;IAoExB,YAA6C,SAAwB;QACnE,KAAK,EAAE,CAAC;QADmC,cAAS,GAAT,SAAS,CAAe;QA7D5D,aAAQ,GAAY,KAAK,CAAC;QAE1B,gBAAW,GAAW,EAAE,CAAC;QAIoC,gBAAW,GAAoB,SAAS,CAAC;YAC7G,GAAG,oBAAoB;YACvB,KAAK,EAAE,EAAE;SACV,CAAC,CAAC;QAEH,uBAAkB,GAAwC,KAAK,CAAyB,WAAW,CAAC,CAAC;QAErG,sBAAiB,GACf,KAAK,EAAE,CAAC;QAEV,aAAQ,GAA4C,MAAM,EAAE,CAAC;QAEpD,YAAO,GAAuC,IAAI,WAAW,CAAC,EAAE,CAAC,CAAC;QAE1D,eAAU,GAAkB,IAAI,OAAO,EAAE,CAAC;QAE1C,cAAS,GAA8B,IAAI,eAAe,CAAW,EAAE,CAAC,CAAC;QAEvE,aAAQ,GAAyB,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC;QAE/D,YAAO,GAAkB,IAAI,OAAO,EAAE,CAAC;QAEzC,kBAAa,GAAsC,IAAI,eAAe,CAAC,KAAyB,CAAC,CAAC;QAElG,iBAAY,GAAsC,IAAI,eAAe,CAAC,KAAyB,CAAC,CAAC;QAEjG,cAAS,GAA6B,IAAI,eAAe,CAAC,KAAK,CAAC,CAAC;QAElF,WAAM,GAAwB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAA2B,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;QAE1G,UAAK,GAAwB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,MAA2B,EAAE,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC;QAExG,aAAQ,GAAwB,IAAI,CAAC,SAAS,CAAC,YAAY,EAAE,CAAC;QAQtD,mBAAc,GACpB,IAAI,eAAe,CAA+B,IAAI,CAAC,CAAC;QAElD,mBAAc,GAAqC,IAAI,CAAC;QAExD,oBAAe,GAAkB,IAAI,OAAO,EAAE,CAAC;QAE/C,eAAU,GAAkB,IAAI,OAAO,EAAE,CAAC;QAWhD,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAE3B,IAAI,CAAC,yBAAyB,EAAE,CAAC;QAEjC,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC7B,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC;IAC/C,CAAC;IAED,eAAe;QACb,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QAEvB,MAAM,SAAS,GAAe,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC;QAE5D,MAAM,MAAM,GAA0B,IAAI,qBAAqB,CAAC,SAAS,CAAC,CAAC;QAE3E,IAAI,CAAC,mBAAmB,CAAC,WAAW,GAAG,MAAM,CAAC;QAE9C,IAAI,CAAC,wBAAwB,EAAE,CAAC;IAClC,CAAC;IAED,WAAW,CAAC,KAAsB;QAChC,IAAI,KAAK,YAAY,MAAM,EAAE,CAAC;YAC5B,OAAO,KAAK,CAAC,SAAS,CAAC;QACzB,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED,KAAK;QACH,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IAC1C,CAAC;IAED,SAAS;QACP,OAAO,IAAI,CAAC,YAAY,EAAE,aAAa,KAAK,QAAQ,CAAC,aAAa,IAAI,IAAI,CAAC,YAAY,EAAE,MAAM,CAAC;IAClG,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAED,UAAU,CAAC,KAA4B;QACrC,MAAM,cAAc,GAA0B,IAAI,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC;QAE/E,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;IACxC,CAAC;IAED,gBAAgB,CAAC,QAAgD;QAC/D,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAED,iBAAiB,CAAC,QAAoB;QACpC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC3B,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,UAAU,EAAE,CAAC;YACf,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;QAChC,CAAC;QAED,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;IACxB,CAAC;IAED,aAAa;QACX,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;IAC9B,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM;YAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;QAEjD,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IAC5E,CAAC;IAED,QAAQ,CAAC,OAAwB;QAC/B,IAAI,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YACzB,IAAI,IAAI,CAAC,OAAO,CAAC,KAAK,YAAY,MAAM;gBAAE,OAAO,IAAI,CAAC;YAEtD,OAAO,EAAE,GAAG,OAAO,CAAC,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;QAClE,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED,yBAAyB,CAAC,EAAc;QACtC,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;IAC/B,CAAC;IAEO,oBAAoB,CAAC,KAA4B;QACvD,IAAI,KAAK,YAAY,MAAM,IAAI,IAAI,CAAC,kBAAkB,EAAE,KAAK,WAAW,EAAE,CAAC;YACzE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YAEtC,OAAO,KAAK,CAAC,KAAK,CAAC;QACrB,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,WAAW,CAAC,QAAgB,EAAE;QACpC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAE1B,IAAI,CAAC,WAAW,GAAG,EAAE,GAAG,IAAI,CAAC,WAAW,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC;QAE3D,OAAO,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CACtD,GAAG,CAAC,CAAC,aAAwC,EAAE,EAAE;YAC/C,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC;YAEpC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;YAExC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC7B,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,UAAU;aACZ,IAAI,CACH,SAAS,CAAC,GAAG,EAAE;YACb,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,CAAC,QAAQ,GAAG,CAAC,IAAI,IAAI,CAAC,cAAc,CAAC,UAAU,EAAE,CAAC;gBAC9F,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;gBAExB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAE1B,OAAO,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC,IAAI,CACtD,GAAG,CAAC,CAAC,aAAwC,EAAE,EAAE;oBAC/C,IAAI,CAAC,cAAc,GAAG,aAAa,CAAC;oBAEpC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,GAAG,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC;oBAEtE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC7B,CAAC,CAAC,CACH,CAAC;YACJ,CAAC;YAED,OAAO,KAAK,CAAC;QACf,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;IAEO,yBAAyB;QAC/B,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;aACvF,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;aAC1B,IAAI,CACH,MAAM,CAAC,CAAC,KAA4B,EAAE,EAAE;YACtC,IAAI,MAAM,GAA0B,KAAK,IAAI,EAAE,CAAC;YAEhD,IAAI,KAAK,YAAY,MAAM,IAAI,IAAI,CAAC,kBAAkB,EAAE,KAAK,WAAW;gBAAE,MAAM,GAAG,KAAK,CAAC,KAAK,CAAC;YAE/F,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC;YAExB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAE3B,OAAO,CAAC,CAAC,KAAK,YAAY,MAAM,CAAC,CAAC;QACpC,CAAC,CAAC,CACH;aACA,IAAI,CACH,SAAS,CAAC,CAAC,KAA4B,EAAE,EAAE,CACzC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,KAAe,CAAC,CAAC,CAAC,CACpE,CACF;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;IAEO,wBAAwB;QAC9B,MAAM,MAAM,GAAG,GAAG,EAAE,GAAE,CAAC,CAAC;QAExB,MAAM,UAAU,GAAsB,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;QAE1F,MAAM,SAAS,GAAsB,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;QAExF,MAAM,gBAAgB,GAA0B,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAEvF,MAAM,eAAe,GAA0B,CAAC,SAAS,EAAE,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAErF,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,gBAAgB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QAEtE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,eAAe,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC,CAAC;IACnG,CAAC;IAEO,mBAAmB;QACzB,IAAI,CAAC,UAAU;aACZ,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;aAChE,SAAS,CAAC,CAAC,KAA4B,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IACzE,CAAC;8GAjQU,yBAAyB,kBAqEhB,eAAe;kGArExB,yBAAyB,q4BAchB,CAAC,MAAuB,EAAE,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,8ZA5BvD;YACT,EAAE,OAAO,EAAE,gCAAgC,EAAE,QAAQ,EAAE,EAAE,iBAAiB,EAAE,WAAW,EAAE,EAAE;YAC3F,EAAE,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE;YACrG,EAAE,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,yBAAyB,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE;YACjG;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,UAAU,EAAE,GAAG,EAAE;oBACf,MAAM,YAAY,GAAG,MAAM,CAAC,yBAAyB,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;oBAEvE,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,YAAY,EAAE,CAAC;gBACtC,CAAC;aACF;SACF,wEAiEU,UAAU,2BAAU,UAAU,mEAE9B,sBAAsB,+EAEtB,eAAe,uGCzK5B,olDA2DA,yDDiBI,YAAY,yjBACZ,qBAAqB,y1BACrB,qBAAqB,0FACrB,mBAAmB,0kBAGnB,kBAAkB,wDAClB,KAAK;;AAmBI,yBAAyB;IAjCrC,YAAY,EAAE;;GAiCF,yBAAyB,CAkQrC;;2FAlQY,yBAAyB;kBAhCrC,SAAS;+BACE,mBAAmB,YACnB,kBAAkB,QACtB,EAAE,KAAK,EAAE,mBAAmB,EAAE,cACxB,IAAI,WACP;wBACP,YAAY;wBACZ,qBAAqB;wBACrB,qBAAqB;wBACrB,mBAAmB;wBACnB,sBAAsB;wBACtB,kBAAkB;wBAClB,kBAAkB;wBAClB,KAAK;qBACN,mBAGgB,uBAAuB,CAAC,MAAM,aACpC;wBACT,EAAE,OAAO,EAAE,gCAAgC,EAAE,QAAQ,EAAE,EAAE,iBAAiB,EAAE,WAAW,EAAE,EAAE;wBAC3F,EAAE,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,0BAA0B,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE;wBACrG,EAAE,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,0BAA0B,CAAC,EAAE,KAAK,EAAE,IAAI,EAAE;wBACjG;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,UAAU,EAAE,GAAG,EAAE;gCACf,MAAM,YAAY,GAAG,MAAM,4BAA4B,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;gCAEvE,OAAO,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,YAAY,EAAE,CAAC;4BACtC,CAAC;yBACF;qBACF;;0BAuEY,MAAM;2BAAC,eAAe;yCAjE1B,qBAAqB;sBAA7B,KAAK;gBAEG,KAAK;sBAAb,KAAK;gBAEG,QAAQ;sBAAhB,KAAK;gBAEG,WAAW;sBAAnB,KAAK;gBAEG,cAAc;sBAAtB,KAAK;gBAEgE,WAAW;sBAAhF,KAAK;uBAAC,EAAE,SAAS,EAAE,CAAC,MAAuB,EAAE,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;gBAiDhB,YAAY;sBAA/D,SAAS;uBAAC,UAAU,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE;gBAEA,mBAAmB;sBAA7D,SAAS;uBAAC,sBAAsB;gBAEG,YAAY;sBAA/C,SAAS;uBAAC,eAAe","sourcesContent":["import {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  InputSignal,\n  OnInit,\n  OutputEmitterRef,\n  TemplateRef,\n  ViewChild,\n  forwardRef,\n  inject,\n  input,\n  output,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ReactiveFormsModule,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\nimport { CommonModule } from '@angular/common';\nimport { WlcmFormFieldComponent } from '../form-field/form-field.component';\nimport { WlcmLabelComponent } from '../label/label.component';\nimport { WlcmInputDirective } from '../../directives/input.directive';\nimport {\n  MAT_AUTOCOMPLETE_DEFAULT_OPTIONS,\n  MatAutocomplete,\n  MatAutocompleteModule,\n  MatAutocompleteOrigin,\n  MatAutocompleteTrigger,\n} from '@angular/material/autocomplete';\nimport {\n  BehaviorSubject,\n  EMPTY,\n  Observable,\n  Subject,\n  concatMap,\n  filter,\n  first,\n  fromEvent,\n  map,\n  merge,\n  switchMap,\n  take,\n  tap,\n  timer,\n} from 'rxjs';\nimport { UntilDestroy, untilDestroyed } from '@ngneat/until-destroy';\nimport { AutocompleteDirective } from '../../directives/autocomplete.directive';\nimport { DEFAULT_QUERY_PARAMS, WlcmAutocompleteOption, WlcmSelectOptionFormat } from '@wlcm/angular/core';\nimport { WLCM_FORM_FIELD, WLCM_INPUT, WLCM_INPUT_BINDER } from '../../constants';\nimport { WlcmAutocomplete, WlcmAutocompleteValue } from '../../models/autocomplete.models';\nimport { WlcmQueryParams, WlcmPaginatedData } from '@wlcm/common';\nimport { WlcmFormFieldInput } from '../../models/input.models';\nimport { WlcmFormField } from '../../models/form.models';\nimport { RxLet } from '@rx-angular/template/let';\nimport { cloneDeep } from 'lodash-es';\n\ntype Option = WlcmAutocompleteOption;\n\nconst PANEL_CLASS: string = 'wlcm-autocomplete-panel';\n\n@UntilDestroy()\n@Component({\n  selector: 'wlcm-autocomplete',\n  exportAs: 'wlcmAutocomplete',\n  host: { class: 'wlcm-autocomplete' },\n  standalone: true,\n  imports: [\n    CommonModule,\n    MatAutocompleteModule,\n    AutocompleteDirective,\n    ReactiveFormsModule,\n    WlcmFormFieldComponent,\n    WlcmLabelComponent,\n    WlcmInputDirective,\n    RxLet,\n  ],\n  templateUrl: './autocomplete.component.html',\n  styleUrls: ['./autocomplete.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    { provide: MAT_AUTOCOMPLETE_DEFAULT_OPTIONS, useValue: { overlayPanelClass: PANEL_CLASS } },\n    { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => WlcmAutocompleteComponent), multi: true },\n    { provide: NG_VALIDATORS, useExisting: forwardRef(() => WlcmAutocompleteComponent), multi: true },\n    {\n      provide: WLCM_INPUT_BINDER,\n      useFactory: () => {\n        const autocomplete = inject(WlcmAutocompleteComponent, { self: true });\n\n        return { bind: () => autocomplete };\n      },\n    },\n  ],\n})\nexport class WlcmAutocompleteComponent\n  extends WlcmAutocomplete\n  implements OnInit, ControlValueAccessor, Validator, AfterViewInit, WlcmFormFieldInput\n{\n  @Input() fetchPaginatedOptions!: (params: WlcmQueryParams) => Observable<WlcmPaginatedData<Option>>;\n\n  @Input() label!: string;\n\n  @Input() required: boolean = false;\n\n  @Input() placeholder: string = '';\n\n  @Input() optionTemplate?: TemplateRef<{ $implicit: WlcmAutocompleteOption }>;\n\n  @Input({ transform: (params: WlcmQueryParams) => cloneDeep(params) }) queryParams: WlcmQueryParams = cloneDeep({\n    ...DEFAULT_QUERY_PARAMS,\n    limit: 15,\n  });\n\n  selectOptionFormat: InputSignal<WlcmSelectOptionFormat> = input<WlcmSelectOptionFormat>('ValueOnly');\n\n  noResultsTemplate: InputSignal<TemplateRef<{ $implicit: WlcmAutocompleteValue; loading: boolean }> | undefined> =\n    input();\n\n  selected: OutputEmitterRef<WlcmAutocompleteValue> = output();\n\n  readonly control: FormControl<WlcmAutocompleteValue> = new FormControl('');\n\n  private readonly _loadMore$: Subject<void> = new Subject();\n\n  private readonly _options$: BehaviorSubject<Option[]> = new BehaviorSubject<Option[]>([]);\n\n  protected readonly options$: Observable<Option[]> = this._options$.asObservable();\n\n  protected readonly closed$: Subject<void> = new Subject();\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  private readonly _loading$: BehaviorSubject<boolean> = new BehaviorSubject(false);\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  loading$: Observable<boolean> = this._loading$.asObservable();\n\n  private _changed?: (value: WlcmAutocompleteValue) => void;\n\n  private _touched?: () => void;\n\n  private _onValidatorChange?: () => void;\n\n  private adjustedValue$: BehaviorSubject<WlcmAutocompleteValue | null> =\n    new BehaviorSubject<WlcmAutocompleteValue | null>(null);\n\n  private _paginatedData: WlcmPaginatedData<Option> | null = null;\n\n  private _reloadOptions$: Subject<void> = new Subject();\n\n  private viewReady$: Subject<void> = new Subject();\n\n  @ViewChild(WLCM_INPUT, { read: ElementRef }) public inputElement!: ElementRef<HTMLInputElement>;\n\n  @ViewChild(MatAutocompleteTrigger) private autocompleteTrigger!: MatAutocompleteTrigger;\n\n  @ViewChild(MatAutocomplete) private autocomplete!: MatAutocomplete;\n\n  constructor(@Inject(WLCM_FORM_FIELD) private formField: WlcmFormField) {\n    super();\n\n    this.handleLoadMoreEvent();\n\n    this.handleControlValueChanges();\n\n    this.handleAdjustedValue();\n  }\n\n  ngOnInit(): void {\n    this.loadOptions().pipe(first()).subscribe();\n  }\n\n  ngAfterViewInit(): void {\n    this.viewReady$.next();\n\n    const container: ElementRef = this.formField.inputContainer;\n\n    const origin: MatAutocompleteOrigin = new MatAutocompleteOrigin(container);\n\n    this.autocompleteTrigger.connectedTo = origin;\n\n    this.attachFocusBlurListeners();\n  }\n\n  displayWith(value: Option | string): string {\n    if (value instanceof Object) {\n      return value.viewValue;\n    }\n\n    return value;\n  }\n\n  focus(): void {\n    this.inputElement.nativeElement.focus();\n  }\n\n  isFocused(): boolean {\n    return this.inputElement?.nativeElement === document.activeElement || this.autocomplete?.isOpen;\n  }\n\n  loadMore(): void {\n    this._loadMore$.next();\n  }\n\n  writeValue(value: WlcmAutocompleteValue): void {\n    const formattedValue: WlcmAutocompleteValue = this.prepareValueForPatch(value);\n\n    this.control.setValue(formattedValue);\n  }\n\n  registerOnChange(callback: (value: WlcmAutocompleteValue) => void): void {\n    this._changed = callback;\n  }\n\n  registerOnTouched(callback: () => void): void {\n    this._touched = callback;\n  }\n\n  setDisabledState(isDisabled: boolean): void {\n    if (isDisabled) {\n      return this.control.disable();\n    }\n\n    this.control.enable();\n  }\n\n  reloadOptions(): void {\n    this._reloadOptions$.next();\n  }\n\n  blured(): void {\n    if (!this.autocomplete.isOpen) this._touched?.();\n\n    this.autocomplete.closed.pipe(take(1)).subscribe(() => this._touched?.());\n  }\n\n  validate(control: AbstractControl): ValidationErrors | null {\n    if (!!this.control.value) {\n      if (this.control.value instanceof Object) return null;\n\n      return { ...control.errors, unselected: true, required: false };\n    }\n\n    return null;\n  }\n\n  registerOnValidatorChange(fn: () => void): void {\n    this._onValidatorChange = fn;\n  }\n\n  private prepareValueForPatch(value: WlcmAutocompleteValue): WlcmAutocompleteValue {\n    if (value instanceof Object && this.selectOptionFormat() === 'ValueOnly') {\n      this.adjustedValue$.next(value.value);\n\n      return value.value;\n    }\n\n    return value;\n  }\n\n  private loadOptions(query: string = ''): Observable<WlcmPaginatedData<Option>> {\n    this._loading$.next(true);\n\n    this.queryParams = { ...this.queryParams, query, page: 1 };\n\n    return this.fetchPaginatedOptions(this.queryParams).pipe(\n      tap((paginatedData: WlcmPaginatedData<Option>) => {\n        this._paginatedData = paginatedData;\n\n        this._options$.next(paginatedData.data);\n\n        this._loading$.next(false);\n      }),\n    );\n  }\n\n  private handleLoadMoreEvent(): void {\n    this._loadMore$\n      .pipe(\n        concatMap(() => {\n          if (this._paginatedData && this._paginatedData.currPage + 1 <= this._paginatedData.totalPages) {\n            this.queryParams.page++;\n\n            this._loading$.next(true);\n\n            return this.fetchPaginatedOptions(this.queryParams).pipe(\n              tap((paginatedData: WlcmPaginatedData<Option>) => {\n                this._paginatedData = paginatedData;\n\n                this._options$.next([...this._options$.value, ...paginatedData.data]);\n\n                this._loading$.next(false);\n              }),\n            );\n          }\n\n          return EMPTY;\n        }),\n      )\n      .subscribe();\n  }\n\n  private handleControlValueChanges(): void {\n    merge(this.control.valueChanges, this._reloadOptions$.pipe(map(() => this.control.value)))\n      .pipe(untilDestroyed(this))\n      .pipe(\n        filter((value: WlcmAutocompleteValue) => {\n          let _value: WlcmAutocompleteValue = value ?? '';\n\n          if (value instanceof Object && this.selectOptionFormat() === 'ValueOnly') _value = value.value;\n\n          this._changed?.(_value);\n\n          this.selected.emit(_value);\n\n          return !(value instanceof Object);\n        }),\n      )\n      .pipe(\n        switchMap((value: WlcmAutocompleteValue) =>\n          timer(200).pipe(switchMap(() => this.loadOptions(value as string))),\n        ),\n      )\n      .subscribe();\n  }\n\n  private attachFocusBlurListeners(): void {\n    const voidFn = () => {};\n\n    const inputFocus: Observable<Event> = fromEvent(this.inputElement.nativeElement, 'focus');\n\n    const inputBlur: Observable<Event> = fromEvent(this.inputElement.nativeElement, 'blur');\n\n    const focusObservables: Observable<unknown>[] = [inputFocus, this.autocomplete.opened];\n\n    const blurObservables: Observable<unknown>[] = [inputBlur, this.autocomplete.closed];\n\n    this._focusStream$.next(merge(...focusObservables).pipe(map(voidFn)));\n\n    this._blurStream$.next(merge(...blurObservables).pipe(map(() => this.control?.markAsTouched())));\n  }\n\n  private handleAdjustedValue(): void {\n    this.viewReady$\n      .pipe(switchMap(() => this.adjustedValue$.pipe(filter(Boolean))))\n      .subscribe((value: WlcmAutocompleteValue) => this._changed?.(value));\n  }\n}\n","<input\n  wlcmInput\n  type=\"text\"\n  [matAutocomplete]=\"autocomplete\"\n  [placeholder]=\"placeholder\"\n  [formControl]=\"control\"\n  (blur)=\"blured()\"\n/>\n\n<mat-autocomplete\n  #autocomplete=\"matAutocomplete\"\n  wlcmAutocomplete\n  [disableRipple]=\"true\"\n  [displayWith]=\"displayWith\"\n  [hideSingleSelectionIndicator]=\"true\"\n  (panelScrolled)=\"loadMore()\"\n>\n  <ng-container *rxLet=\"$any(options$ | async); let options\">\n    <mat-option\n      *ngFor=\"let option of options\"\n      [ngClass]=\"{ 'wlcm-custom-option-content': optionTemplate }\"\n      [value]=\"option\"\n    >\n      @if (optionTemplate) {\n        <ng-container\n          *ngTemplateOutlet=\"optionTemplate; context: { $implicit: option }\"\n        ></ng-container>\n      } @else {\n        {{ option.viewValue }}\n      }\n    </mat-option>\n\n    <mat-option [disabled]=\"true\" *ngIf=\"options.length === 0\">\n      @if (noResultsTemplate()) {\n        <ng-container\n          *ngTemplateOutlet=\"\n            noResultsTemplate()!;\n            context: { $implicit: control.value, loading: loading$ | async }\n          \"\n        ></ng-container>\n      } @else {\n        <ng-container\n          *ngTemplateOutlet=\"\n            defaultNoResultsTemplate;\n            context: { $implicit: control.value, loading: loading$ | async }\n          \"\n        ></ng-container>\n      }\n    </mat-option>\n  </ng-container>\n</mat-autocomplete>\n\n<ng-template #defaultNoResultsTemplate let-loading=\"loading\">\n  @if (loading) {\n    Please wait...\n  } @else {\n    No results found\n  }\n</ng-template>\n"]}
|
@@ -6,7 +6,7 @@ import { MAT_SELECT_CONFIG, MatOption, MatSelect, MatSelectModule } from '@angul
|
|
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, Observable, Subject, first, of, switchMap, takeUntil } from 'rxjs';
|
9
|
+
import { BehaviorSubject, EMPTY, Observable, Subject, filter, 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 { toObservable } from '@angular/core/rxjs-interop';
|
@@ -70,6 +70,8 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
70
70
|
this._blurStream$ = new BehaviorSubject(EMPTY);
|
71
71
|
this.focus$ = this._focusStream$.pipe(switchMap((stream) => stream));
|
72
72
|
this.blur$ = this._blurStream$.pipe(switchMap((stream) => stream));
|
73
|
+
this.adjustedValue$ = new BehaviorSubject(null);
|
74
|
+
this.viewReady$ = new Subject();
|
73
75
|
this.selected$ = new Subject();
|
74
76
|
this.compareWith = (optionA, optionB) => {
|
75
77
|
return (optionA?.value || optionA) === (optionB?.value || optionB);
|
@@ -79,6 +81,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
79
81
|
if (this.parentFormMember) {
|
80
82
|
this.handleStateChange();
|
81
83
|
}
|
84
|
+
this.handleAdjustedValue();
|
82
85
|
toObservable(this.paginated)
|
83
86
|
.pipe(untilDestroyed(this))
|
84
87
|
.subscribe((paginated) => {
|
@@ -87,6 +90,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
87
90
|
});
|
88
91
|
}
|
89
92
|
ngAfterViewInit() {
|
93
|
+
this.viewReady$.next();
|
90
94
|
const formField = this.formField.inputContainer;
|
91
95
|
if (formField) {
|
92
96
|
this.matSelect._preferredOverlayOrigin = new CdkOverlayOrigin(this.formField.inputContainer);
|
@@ -141,7 +145,8 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
141
145
|
writeValue(value) {
|
142
146
|
if (this.paginated())
|
143
147
|
this.prefillOptions(value);
|
144
|
-
this.
|
148
|
+
const formattedValue = this.prepareValueForPatch(value);
|
149
|
+
this.updateValue(formattedValue);
|
145
150
|
}
|
146
151
|
registerOnChange(callback) {
|
147
152
|
this._changed = callback;
|
@@ -161,6 +166,33 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
161
166
|
get isOpen() {
|
162
167
|
return this.matSelect?.panelOpen ?? false;
|
163
168
|
}
|
169
|
+
prepareValueForPatch(value) {
|
170
|
+
const formatedValue = this.formatValue(value);
|
171
|
+
if (formatedValue.changed)
|
172
|
+
this.adjustedValue$.next(formatedValue.value);
|
173
|
+
return formatedValue.value;
|
174
|
+
}
|
175
|
+
formatValue(value) {
|
176
|
+
let changed = false;
|
177
|
+
const _formatOption = (value) => {
|
178
|
+
const formatedOption = this.formatOption(value);
|
179
|
+
if (formatedOption.changed)
|
180
|
+
changed = true;
|
181
|
+
return formatedOption.value;
|
182
|
+
};
|
183
|
+
if (value instanceof Array) {
|
184
|
+
const options = value.map(_formatOption);
|
185
|
+
return { changed, value: options };
|
186
|
+
}
|
187
|
+
const option = _formatOption(value);
|
188
|
+
return { changed, value: option };
|
189
|
+
}
|
190
|
+
formatOption(value) {
|
191
|
+
if (value instanceof Object && this.selectOptionFormat() === 'ValueOnly') {
|
192
|
+
return { changed: true, value: value.value };
|
193
|
+
}
|
194
|
+
return { changed: false, value };
|
195
|
+
}
|
164
196
|
loadPaginatedOptions() {
|
165
197
|
this.queryParams.page = 1;
|
166
198
|
this.fetchPaginatedOptions(this.queryParams)
|
@@ -219,6 +251,11 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
219
251
|
this.changeDetectorRef.markForCheck();
|
220
252
|
});
|
221
253
|
}
|
254
|
+
handleAdjustedValue() {
|
255
|
+
this.viewReady$
|
256
|
+
.pipe(switchMap(() => this.adjustedValue$.pipe(filter(Boolean))))
|
257
|
+
.subscribe((value) => this._changed?.(value));
|
258
|
+
}
|
222
259
|
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 }); }
|
223
260
|
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: (params) => cloneDeep(params) }, 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: [
|
224
261
|
WLCM_FORM_CONTROL_PROVIDER,
|
@@ -280,4 +317,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
|
|
280
317
|
type: HostListener,
|
281
318
|
args: ['click']
|
282
319
|
}] } });
|
283
|
-
//# 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  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 { WlcmQueryParams, WlcmPaginatedData } from '@wlcm/common';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { CdkOverlayOrigin } from '@angular/cdk/overlay';\nimport { cloneDeep, mergeWith } from 'lodash-es';\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: WlcmQueryParams) => Observable<WlcmPaginatedData<WlcmOption>>;\n\n  @Input() canSelect: WlcmCanSelectFn = (_: WlcmSelectValue) => true;\n\n  @Input({ transform: (params: WlcmQueryParams) => cloneDeep(params) }) queryParams: WlcmQueryParams =\n    cloneDeep(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: WlcmPaginatedData<WlcmOption> | null = null;\n\n  private _previousValue: WlcmSelectValue | null = null;\n\n  private _optionsCache: Set<unknown> = new Set();\n\n  computedOptions: Signal<WlcmOption[]> = computed(() => {\n    const options: WlcmOption[] = this.paginated() ? this.paginatedOptions() : this.options();\n\n    if (this.isOptionDisabled() && options.length > 0) {\n      this.updateOptionsStatus();\n    }\n\n    return options;\n  });\n\n  prefilledOptions: WritableSignal<WlcmOption[]> = signal([]);\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    toObservable(this.paginated)\n      .pipe(untilDestroyed(this))\n      .subscribe((paginated: boolean) => {\n        if (paginated) this.loadPaginatedOptions();\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.matSelect.value = event.value;\n\n    this.validateSelectedOption(event.value)\n      .pipe(takeUntil(this.selected$))\n      .subscribe((canSelect: boolean) => {\n        if (!canSelect) return this.revertPreviousValue();\n\n        this.updateValue(event.value);\n\n        this._changed?.(event.value);\n\n        this._validatorChanged?.();\n\n        this.selectionChange.emit(event);\n      });\n  }\n\n  private revertPreviousValue(): void {\n    this.matSelect.value = this._previousValue;\n  }\n\n  private updateValue(value: WlcmSelectValue): void {\n    this.value.set(value);\n\n    this._previousValue = value;\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  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    if (this.paginated()) this.prefillOptions(value);\n\n    this.updateValue(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.queryParams.page = 1;\n\n    this.fetchPaginatedOptions!(this.queryParams)\n      .pipe(untilDestroyed(this), first())\n      .subscribe((paginatedData: WlcmPaginatedData<WlcmOption>) => {\n        this._optionsCache.clear();\n\n        this.cacheOptions(paginatedData.data);\n\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: WlcmPaginatedData<WlcmOption>) => {\n        this.cacheOptions(paginatedData.data);\n\n        this._paginatedData = paginatedData;\n\n        this.paginatedOptions.update((options: WlcmOption[]) => [...options, ...paginatedData.data]);\n      });\n  }\n\n  private cacheOptions(options: WlcmOption[]): void {\n    options.forEach((option: WlcmOption) => this._optionsCache.add(option.value));\n\n    this.syncPrefilledOptions();\n  }\n\n  private syncPrefilledOptions(): void {\n    if (this.prefilledOptions().length === 0) return;\n\n    this.prefilledOptions.update((options: WlcmOption[]) => {\n      return options.filter((option: WlcmOption) => !this._optionsCache.has(option.value));\n    });\n  }\n\n  private prefillOptions(value: WlcmSelectValue): void {\n    let prefilledOptions: WlcmOption[] = [];\n\n    if (value instanceof Array) {\n      prefilledOptions = value.filter((option: WlcmOption | string) => option instanceof Object) as WlcmOption[];\n    } else if (value instanceof Object) {\n      prefilledOptions = [value];\n    }\n\n    this.prefilledOptions.set(prefilledOptions);\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 prefilledOptions()\"\n    [value]=\"selectOptionFormat() === 'CompleteOption' ? option : option.value\"\n  >\n    <ng-container\n      [ngTemplateOutlet]=\"wlcmSelectOptionContent\"\n      [ngTemplateOutletContext]=\"{ $implicit: option }\"\n    ></ng-container>\n  </mat-option>\n\n  <mat-option\n    *ngFor=\"let option of computedOptions()\"\n    [value]=\"selectOptionFormat() === 'CompleteOption' ? option : option.value\"\n  >\n    <ng-container\n      [ngTemplateOutlet]=\"wlcmSelectOptionContent\"\n      [ngTemplateOutletContext]=\"{ $implicit: option }\"\n    ></ng-container>\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\n<ng-template #wlcmSelectOptionContent let-option>\n  @if (optionTemplate()) {\n    <ng-container\n      *ngTemplateOutlet=\"optionTemplate(); context: $any({ $implicit: option })\"\n    ></ng-container>\n  } @else {\n    {{ option.viewValue }}\n  }\n</ng-template>\n"]}
|
320
|
+
//# 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  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  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, filter, 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 { WlcmQueryParams, WlcmPaginatedData } from '@wlcm/common';\nimport { toObservable } from '@angular/core/rxjs-interop';\nimport { CdkOverlayOrigin } from '@angular/cdk/overlay';\nimport { cloneDeep, mergeWith } from 'lodash-es';\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: WlcmQueryParams) => Observable<WlcmPaginatedData<WlcmOption>>;\n\n  @Input() canSelect: WlcmCanSelectFn = (_: WlcmSelectValue) => true;\n\n  @Input({ transform: (params: WlcmQueryParams) => cloneDeep(params) }) queryParams: WlcmQueryParams =\n    cloneDeep(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: WlcmSelectValue) => void;\n\n  private _touched?: () => void;\n\n  private _validatorChanged?: () => void;\n\n  private _paginatedData: WlcmPaginatedData<WlcmOption> | null = null;\n\n  private _previousValue: WlcmSelectValue | null = null;\n\n  private _optionsCache: Set<unknown> = new Set();\n\n  computedOptions: Signal<WlcmOption[]> = computed(() => {\n    const options: WlcmOption[] = this.paginated() ? this.paginatedOptions() : this.options();\n\n    if (this.isOptionDisabled() && options.length > 0) {\n      this.updateOptionsStatus();\n    }\n\n    return options;\n  });\n\n  prefilledOptions: WritableSignal<WlcmOption[]> = signal([]);\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 adjustedValue$: BehaviorSubject<WlcmSelectValue | null> = new BehaviorSubject<WlcmSelectValue | null>(null);\n\n  private viewReady$: Subject<void> = new Subject();\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    this.handleAdjustedValue();\n\n    toObservable(this.paginated)\n      .pipe(untilDestroyed(this))\n      .subscribe((paginated: boolean) => {\n        if (paginated) this.loadPaginatedOptions();\n      });\n  }\n\n  ngAfterViewInit(): void {\n    this.viewReady$.next();\n\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.matSelect.value = event.value;\n\n    this.validateSelectedOption(event.value)\n      .pipe(takeUntil(this.selected$))\n      .subscribe((canSelect: boolean) => {\n        if (!canSelect) return this.revertPreviousValue();\n\n        this.updateValue(event.value);\n\n        this._changed?.(event.value);\n\n        this._validatorChanged?.();\n\n        this.selectionChange.emit(event);\n      });\n  }\n\n  private revertPreviousValue(): void {\n    this.matSelect.value = this._previousValue;\n  }\n\n  private updateValue(value: WlcmSelectValue): void {\n    this.value.set(value);\n\n    this._previousValue = value;\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  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    if (this.paginated()) this.prefillOptions(value);\n\n    const formattedValue: WlcmSelectValue = this.prepareValueForPatch(value);\n\n    this.updateValue(formattedValue);\n  }\n\n  registerOnChange(callback: (value: WlcmSelectValue) => 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 prepareValueForPatch(value: WlcmSelectValue): WlcmSelectValue {\n    const formatedValue: { changed: boolean; value: WlcmSelectValue } = this.formatValue(value);\n\n    if (formatedValue.changed) this.adjustedValue$.next(formatedValue.value);\n\n    return formatedValue.value;\n  }\n\n  private formatValue(value: WlcmSelectValue): { changed: boolean; value: WlcmSelectValue } {\n    let changed: boolean = false;\n\n    const _formatOption = (value: WlcmOption | string): WlcmOption | string => {\n      const formatedOption: { changed: boolean; value: WlcmOption | string } = this.formatOption(value);\n\n      if (formatedOption.changed) changed = true;\n\n      return formatedOption.value;\n    };\n\n    if (value instanceof Array) {\n      const options: WlcmSelectValue = value.map(_formatOption) as WlcmSelectValue;\n\n      return { changed, value: options };\n    }\n\n    const option: WlcmSelectValue = _formatOption(value);\n\n    return { changed, value: option };\n  }\n\n  private formatOption(value: WlcmOption | string): { changed: boolean; value: WlcmOption | string } {\n    if (value instanceof Object && this.selectOptionFormat() === 'ValueOnly') {\n      return { changed: true, value: value.value as string };\n    }\n\n    return { changed: false, value };\n  }\n\n  private loadPaginatedOptions(): void {\n    this.queryParams.page = 1;\n\n    this.fetchPaginatedOptions!(this.queryParams)\n      .pipe(untilDestroyed(this), first())\n      .subscribe((paginatedData: WlcmPaginatedData<WlcmOption>) => {\n        this._optionsCache.clear();\n\n        this.cacheOptions(paginatedData.data);\n\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: WlcmPaginatedData<WlcmOption>) => {\n        this.cacheOptions(paginatedData.data);\n\n        this._paginatedData = paginatedData;\n\n        this.paginatedOptions.update((options: WlcmOption[]) => [...options, ...paginatedData.data]);\n      });\n  }\n\n  private cacheOptions(options: WlcmOption[]): void {\n    options.forEach((option: WlcmOption) => this._optionsCache.add(option.value));\n\n    this.syncPrefilledOptions();\n  }\n\n  private syncPrefilledOptions(): void {\n    if (this.prefilledOptions().length === 0) return;\n\n    this.prefilledOptions.update((options: WlcmOption[]) => {\n      return options.filter((option: WlcmOption) => !this._optionsCache.has(option.value));\n    });\n  }\n\n  private prefillOptions(value: WlcmSelectValue): void {\n    let prefilledOptions: WlcmOption[] = [];\n\n    if (value instanceof Array) {\n      prefilledOptions = value.filter((option: WlcmOption | string) => option instanceof Object) as WlcmOption[];\n    } else if (value instanceof Object) {\n      prefilledOptions = [value];\n    }\n\n    this.prefilledOptions.set(prefilledOptions);\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  private handleAdjustedValue(): void {\n    this.viewReady$\n      .pipe(switchMap(() => this.adjustedValue$.pipe(filter(Boolean))))\n      .subscribe((value: WlcmSelectValue) => this._changed?.(value));\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 prefilledOptions()\"\n    [value]=\"selectOptionFormat() === 'CompleteOption' ? option : option.value\"\n  >\n    <ng-container\n      [ngTemplateOutlet]=\"wlcmSelectOptionContent\"\n      [ngTemplateOutletContext]=\"{ $implicit: option }\"\n    ></ng-container>\n  </mat-option>\n\n  <mat-option\n    *ngFor=\"let option of computedOptions()\"\n    [value]=\"selectOptionFormat() === 'CompleteOption' ? option : option.value\"\n  >\n    <ng-container\n      [ngTemplateOutlet]=\"wlcmSelectOptionContent\"\n      [ngTemplateOutletContext]=\"{ $implicit: option }\"\n    ></ng-container>\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\n<ng-template #wlcmSelectOptionContent let-option>\n  @if (optionTemplate()) {\n    <ng-container\n      *ngTemplateOutlet=\"optionTemplate(); context: $any({ $implicit: option })\"\n    ></ng-container>\n  } @else {\n    {{ option.viewValue }}\n  }\n</ng-template>\n"]}
|
@@ -499,15 +499,19 @@ let WlcmAutocompleteComponent = class WlcmAutocompleteComponent extends WlcmAuto
|
|
499
499
|
this.focus$ = this._focusStream$.pipe(switchMap((stream) => stream));
|
500
500
|
this.blur$ = this._blurStream$.pipe(switchMap((stream) => stream));
|
501
501
|
this.loading$ = this._loading$.asObservable();
|
502
|
+
this.adjustedValue$ = new BehaviorSubject(null);
|
502
503
|
this._paginatedData = null;
|
503
504
|
this._reloadOptions$ = new Subject();
|
505
|
+
this.viewReady$ = new Subject();
|
504
506
|
this.handleLoadMoreEvent();
|
505
507
|
this.handleControlValueChanges();
|
508
|
+
this.handleAdjustedValue();
|
506
509
|
}
|
507
510
|
ngOnInit() {
|
508
511
|
this.loadOptions().pipe(first()).subscribe();
|
509
512
|
}
|
510
513
|
ngAfterViewInit() {
|
514
|
+
this.viewReady$.next();
|
511
515
|
const container = this.formField.inputContainer;
|
512
516
|
const origin = new MatAutocompleteOrigin(container);
|
513
517
|
this.autocompleteTrigger.connectedTo = origin;
|
@@ -529,7 +533,8 @@ let WlcmAutocompleteComponent = class WlcmAutocompleteComponent extends WlcmAuto
|
|
529
533
|
this._loadMore$.next();
|
530
534
|
}
|
531
535
|
writeValue(value) {
|
532
|
-
this.
|
536
|
+
const formattedValue = this.prepareValueForPatch(value);
|
537
|
+
this.control.setValue(formattedValue);
|
533
538
|
}
|
534
539
|
registerOnChange(callback) {
|
535
540
|
this._changed = callback;
|
@@ -562,6 +567,13 @@ let WlcmAutocompleteComponent = class WlcmAutocompleteComponent extends WlcmAuto
|
|
562
567
|
registerOnValidatorChange(fn) {
|
563
568
|
this._onValidatorChange = fn;
|
564
569
|
}
|
570
|
+
prepareValueForPatch(value) {
|
571
|
+
if (value instanceof Object && this.selectOptionFormat() === 'ValueOnly') {
|
572
|
+
this.adjustedValue$.next(value.value);
|
573
|
+
return value.value;
|
574
|
+
}
|
575
|
+
return value;
|
576
|
+
}
|
565
577
|
loadOptions(query = '') {
|
566
578
|
this._loading$.next(true);
|
567
579
|
this.queryParams = { ...this.queryParams, query, page: 1 };
|
@@ -610,6 +622,11 @@ let WlcmAutocompleteComponent = class WlcmAutocompleteComponent extends WlcmAuto
|
|
610
622
|
this._focusStream$.next(merge(...focusObservables).pipe(map(voidFn)));
|
611
623
|
this._blurStream$.next(merge(...blurObservables).pipe(map(() => this.control?.markAsTouched())));
|
612
624
|
}
|
625
|
+
handleAdjustedValue() {
|
626
|
+
this.viewReady$
|
627
|
+
.pipe(switchMap(() => this.adjustedValue$.pipe(filter(Boolean))))
|
628
|
+
.subscribe((value) => this._changed?.(value));
|
629
|
+
}
|
613
630
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.5", ngImport: i0, type: WlcmAutocompleteComponent, deps: [{ token: WLCM_FORM_FIELD }], target: i0.ɵɵFactoryTarget.Component }); }
|
614
631
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.5", type: WlcmAutocompleteComponent, isStandalone: true, selector: "wlcm-autocomplete", inputs: { fetchPaginatedOptions: { classPropertyName: "fetchPaginatedOptions", publicName: "fetchPaginatedOptions", isSignal: false, isRequired: false, transformFunction: null }, label: { classPropertyName: "label", publicName: "label", isSignal: false, isRequired: false, transformFunction: null }, required: { classPropertyName: "required", publicName: "required", isSignal: false, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: false, isRequired: false, transformFunction: null }, optionTemplate: { classPropertyName: "optionTemplate", publicName: "optionTemplate", isSignal: false, isRequired: false, transformFunction: null }, queryParams: { classPropertyName: "queryParams", publicName: "queryParams", isSignal: false, isRequired: false, transformFunction: (params) => cloneDeep(params) }, selectOptionFormat: { classPropertyName: "selectOptionFormat", publicName: "selectOptionFormat", isSignal: true, isRequired: false, transformFunction: null }, noResultsTemplate: { classPropertyName: "noResultsTemplate", publicName: "noResultsTemplate", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selected: "selected" }, host: { classAttribute: "wlcm-autocomplete" }, providers: [
|
615
632
|
{ provide: MAT_AUTOCOMPLETE_DEFAULT_OPTIONS, useValue: { overlayPanelClass: PANEL_CLASS$1 } },
|
@@ -924,6 +941,8 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
924
941
|
this._blurStream$ = new BehaviorSubject(EMPTY);
|
925
942
|
this.focus$ = this._focusStream$.pipe(switchMap((stream) => stream));
|
926
943
|
this.blur$ = this._blurStream$.pipe(switchMap((stream) => stream));
|
944
|
+
this.adjustedValue$ = new BehaviorSubject(null);
|
945
|
+
this.viewReady$ = new Subject();
|
927
946
|
this.selected$ = new Subject();
|
928
947
|
this.compareWith = (optionA, optionB) => {
|
929
948
|
return (optionA?.value || optionA) === (optionB?.value || optionB);
|
@@ -933,6 +952,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
933
952
|
if (this.parentFormMember) {
|
934
953
|
this.handleStateChange();
|
935
954
|
}
|
955
|
+
this.handleAdjustedValue();
|
936
956
|
toObservable(this.paginated)
|
937
957
|
.pipe(untilDestroyed(this))
|
938
958
|
.subscribe((paginated) => {
|
@@ -941,6 +961,7 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
941
961
|
});
|
942
962
|
}
|
943
963
|
ngAfterViewInit() {
|
964
|
+
this.viewReady$.next();
|
944
965
|
const formField = this.formField.inputContainer;
|
945
966
|
if (formField) {
|
946
967
|
this.matSelect._preferredOverlayOrigin = new CdkOverlayOrigin(this.formField.inputContainer);
|
@@ -995,7 +1016,8 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
995
1016
|
writeValue(value) {
|
996
1017
|
if (this.paginated())
|
997
1018
|
this.prefillOptions(value);
|
998
|
-
this.
|
1019
|
+
const formattedValue = this.prepareValueForPatch(value);
|
1020
|
+
this.updateValue(formattedValue);
|
999
1021
|
}
|
1000
1022
|
registerOnChange(callback) {
|
1001
1023
|
this._changed = callback;
|
@@ -1015,6 +1037,33 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
1015
1037
|
get isOpen() {
|
1016
1038
|
return this.matSelect?.panelOpen ?? false;
|
1017
1039
|
}
|
1040
|
+
prepareValueForPatch(value) {
|
1041
|
+
const formatedValue = this.formatValue(value);
|
1042
|
+
if (formatedValue.changed)
|
1043
|
+
this.adjustedValue$.next(formatedValue.value);
|
1044
|
+
return formatedValue.value;
|
1045
|
+
}
|
1046
|
+
formatValue(value) {
|
1047
|
+
let changed = false;
|
1048
|
+
const _formatOption = (value) => {
|
1049
|
+
const formatedOption = this.formatOption(value);
|
1050
|
+
if (formatedOption.changed)
|
1051
|
+
changed = true;
|
1052
|
+
return formatedOption.value;
|
1053
|
+
};
|
1054
|
+
if (value instanceof Array) {
|
1055
|
+
const options = value.map(_formatOption);
|
1056
|
+
return { changed, value: options };
|
1057
|
+
}
|
1058
|
+
const option = _formatOption(value);
|
1059
|
+
return { changed, value: option };
|
1060
|
+
}
|
1061
|
+
formatOption(value) {
|
1062
|
+
if (value instanceof Object && this.selectOptionFormat() === 'ValueOnly') {
|
1063
|
+
return { changed: true, value: value.value };
|
1064
|
+
}
|
1065
|
+
return { changed: false, value };
|
1066
|
+
}
|
1018
1067
|
loadPaginatedOptions() {
|
1019
1068
|
this.queryParams.page = 1;
|
1020
1069
|
this.fetchPaginatedOptions(this.queryParams)
|
@@ -1073,6 +1122,11 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
1073
1122
|
this.changeDetectorRef.markForCheck();
|
1074
1123
|
});
|
1075
1124
|
}
|
1125
|
+
handleAdjustedValue() {
|
1126
|
+
this.viewReady$
|
1127
|
+
.pipe(switchMap(() => this.adjustedValue$.pipe(filter(Boolean))))
|
1128
|
+
.subscribe((value) => this._changed?.(value));
|
1129
|
+
}
|
1076
1130
|
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 }); }
|
1077
1131
|
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: (params) => cloneDeep(params) }, 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: [
|
1078
1132
|
WLCM_FORM_CONTROL_PROVIDER,
|