@wlcm/angular 18.2.26 → 18.2.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/core/esm2022/lib/services/scroll-detection.api.mjs +26 -19
- package/core/fesm2022/wlcm-angular-core.mjs +24 -17
- package/core/fesm2022/wlcm-angular-core.mjs.map +1 -1
- package/core/lib/services/scroll-detection.api.d.ts +4 -1
- package/datepicker/esm2022/index.mjs +5 -2
- package/datepicker/esm2022/lib/components/range/date-range-picker-bottom-panel/date-range-picker-bottom-panel.component.mjs +5 -5
- package/datepicker/esm2022/lib/components/range/date-range-picker-input/date-range-picker-input.component.mjs +10 -8
- package/datepicker/esm2022/lib/components/range/double-calendar-range-picker/double-calendar-range-picker.component.mjs +168 -0
- package/datepicker/esm2022/lib/components/range/single-calendar-range-picker/single-calendar-range-picker.component.mjs +95 -0
- package/datepicker/esm2022/lib/constants/range/date-range-picker.constants.mjs +3 -1
- package/datepicker/esm2022/lib/directives/datepicker-trigger.base.mjs +4 -8
- package/datepicker/esm2022/lib/directives/ragne/date-range-picker-input.base.mjs +6 -4
- package/datepicker/esm2022/lib/models/range/data-range-calendar.models.mjs +1 -1
- package/datepicker/esm2022/lib/models/range/date-range-picker.models.mjs +27 -2
- package/datepicker/fesm2022/wlcm-angular-datepicker.mjs +799 -703
- package/datepicker/fesm2022/wlcm-angular-datepicker.mjs.map +1 -1
- package/datepicker/index.d.ts +4 -1
- package/datepicker/lib/components/range/date-range-picker-bottom-panel/date-range-picker-bottom-panel.component.d.ts +3 -3
- package/datepicker/lib/components/range/date-range-picker-input/date-range-picker-input.component.d.ts +5 -5
- package/datepicker/lib/components/range/{date-range-picker/date-range-picker.component.d.ts → double-calendar-range-picker/double-calendar-range-picker.component.d.ts} +12 -16
- package/datepicker/lib/components/range/single-calendar-range-picker/single-calendar-range-picker.component.d.ts +27 -0
- package/datepicker/lib/constants/range/date-range-picker.constants.d.ts +2 -1
- package/datepicker/lib/directives/datepicker-trigger.base.d.ts +1 -2
- package/datepicker/lib/models/range/date-range-picker.models.d.ts +15 -1
- package/forms/esm2022/lib/forms/components/select/select.component.mjs +11 -2
- package/forms/fesm2022/wlcm-angular-forms.mjs +10 -1
- package/forms/fesm2022/wlcm-angular-forms.mjs.map +1 -1
- package/forms/lib/forms/components/select/select.component.d.ts +1 -0
- package/package.json +1 -1
- package/styles/components/datepicker/date-range-picker/_date-range-picker-body.scss +1 -1
- package/styles/components/datepicker/date-range-picker/_date-range-picker-input.scss +1 -0
- package/datepicker/esm2022/lib/components/range/date-range-picker/date-range-picker.component.mjs +0 -174
package/datepicker/index.d.ts
CHANGED
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
export { WlcmDateRangePickerInputComponent } from './lib/components/range/date-range-picker-input/date-range-picker-input.component';
|
|
2
|
+
export { DoubleCalendarRangePickerComponent } from './lib/components/range/double-calendar-range-picker/double-calendar-range-picker.component';
|
|
3
|
+
export { SingleCalendarRangePickerComponent } from './lib/components/range/single-calendar-range-picker/single-calendar-range-picker.component';
|
|
2
4
|
export { WlcmDatepickerInputContainerComponent } from './lib/components/single/datepicker-input-container/datepicker-input-container.component';
|
|
3
5
|
export { DateRangePickerInputEndDirective } from './lib/directives/ragne/date-range-picker-input-end.directive';
|
|
4
6
|
export { DateRangePickerInputStartDirective } from './lib/directives/ragne/date-range-picker-input-start.directive';
|
|
5
7
|
export { WlcmDatepickerInputDirective } from './lib/directives/single/datepicker-input.directive';
|
|
6
|
-
export { WlcmDateRangeValidation } from './lib/models/range/date-range-validation.models';
|
|
7
8
|
export { WlcmDateRangeInputValidator } from './lib/utils/range/date-range-input.validators';
|
|
9
|
+
export { WlcmDateRangeValidation } from './lib/models/range/date-range-validation.models';
|
|
10
|
+
export { WlcmDateRangePicker } from './lib/models/range/date-range-picker.models';
|
|
8
11
|
export { WlcmDateValidation } from './lib/models/date-picker.models';
|
|
9
12
|
export { WlcmDatepickerModule } from './lib/datepicker.module';
|
|
10
13
|
export { WLCM_DATEPICKER_CONFIG } from './lib/constants/datepicker.constants';
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { WlcmDateRangePicker } from '../../../models/range/date-range-picker.models';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
3
|
export declare class WlcmDateRangePickerBottomPanelComponent {
|
|
4
|
-
protected picker:
|
|
5
|
-
constructor(picker:
|
|
4
|
+
protected picker: WlcmDateRangePicker;
|
|
5
|
+
constructor(picker: WlcmDateRangePicker);
|
|
6
6
|
static ɵfac: i0.ɵɵFactoryDeclaration<WlcmDateRangePickerBottomPanelComponent, never>;
|
|
7
7
|
static ɵcmp: i0.ɵɵComponentDeclaration<WlcmDateRangePickerBottomPanelComponent, "wlcm-date-range-picker-bottom-panel", never, {}, {}, never, never, true, never>;
|
|
8
8
|
}
|
|
@@ -2,12 +2,12 @@ import { AfterContentInit, AfterViewInit, ElementRef, Type, ViewContainerRef } f
|
|
|
2
2
|
import { DateRange, MatDateSelectionModel } from '@angular/material/datepicker';
|
|
3
3
|
import { WlcmFormField, WlcmFormFieldInput } from '@wlcm/angular/forms';
|
|
4
4
|
import { Observable } from 'rxjs';
|
|
5
|
-
import { Overlay } from '@angular/cdk/overlay';
|
|
6
|
-
import { WlcmDateRangePickerComponent } from '../date-range-picker/date-range-picker.component';
|
|
7
5
|
import { ControlContainer } from '@angular/forms';
|
|
6
|
+
import { WlcmDateRangePicker } from '../../../models/range/date-range-picker.models';
|
|
8
7
|
import { WlcmDatepickerTrigger } from '../../../directives/datepicker-trigger.base';
|
|
8
|
+
import { Overlay } from '@angular/cdk/overlay';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
|
-
export declare class WlcmDateRangePickerInputComponent extends WlcmDatepickerTrigger<
|
|
10
|
+
export declare class WlcmDateRangePickerInputComponent extends WlcmDatepickerTrigger<WlcmDateRangePicker, DateRange<Date>> implements WlcmFormFieldInput, AfterContentInit, AfterViewInit {
|
|
11
11
|
protected overlay: Overlay;
|
|
12
12
|
protected viewContainerRef: ViewContainerRef;
|
|
13
13
|
protected selectionModel: MatDateSelectionModel<DateRange<Date>>;
|
|
@@ -17,9 +17,9 @@ export declare class WlcmDateRangePickerInputComponent extends WlcmDatepickerTri
|
|
|
17
17
|
private readonly _blurStream$;
|
|
18
18
|
focus$: Observable<unknown>;
|
|
19
19
|
blur$: Observable<unknown>;
|
|
20
|
+
componentType: Type<WlcmDateRangePicker>;
|
|
20
21
|
private startInput;
|
|
21
22
|
private endInput;
|
|
22
|
-
componentType: Type<WlcmDateRangePickerComponent>;
|
|
23
23
|
protected connectedTo: ElementRef<HTMLElement>;
|
|
24
24
|
constructor(overlay: Overlay, viewContainerRef: ViewContainerRef, selectionModel: MatDateSelectionModel<DateRange<Date>>, formField: WlcmFormField, controlContainer: ControlContainer);
|
|
25
25
|
ngAfterContentInit(): void;
|
|
@@ -32,5 +32,5 @@ export declare class WlcmDateRangePickerInputComponent extends WlcmDatepickerTri
|
|
|
32
32
|
private checkInputs;
|
|
33
33
|
private attachFocusBlurListeners;
|
|
34
34
|
static ɵfac: i0.ɵɵFactoryDeclaration<WlcmDateRangePickerInputComponent, [null, null, null, { host: true; }, { host: true; }]>;
|
|
35
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<WlcmDateRangePickerInputComponent, "wlcm-date-range-picker-input", ["wlcmDateRangePickerInput"], {}, {}, ["startInput", "endInput"], ["[wlcmDateRangePickerInputStart]", "[wlcmDateRangePickerInputEnd]"], true, never>;
|
|
35
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<WlcmDateRangePickerInputComponent, "wlcm-date-range-picker-input", ["wlcmDateRangePickerInput"], { "componentType": { "alias": "componentType"; "required": false; }; }, {}, ["startInput", "endInput"], ["[wlcmDateRangePickerInputStart]", "[wlcmDateRangePickerInputEnd]"], true, never>;
|
|
36
36
|
}
|
|
@@ -1,39 +1,35 @@
|
|
|
1
|
-
import { ElementRef,
|
|
2
|
-
import {
|
|
1
|
+
import { ElementRef, Type, ViewContainerRef, WritableSignal } from '@angular/core';
|
|
2
|
+
import { WlcmDateRangePicker, WlcmDateRangePickerConfig } from '../../../models/range/date-range-picker.models';
|
|
3
3
|
import { DateAdapter } from '@angular/material/core';
|
|
4
|
-
import {
|
|
4
|
+
import { MatDateRangeSelectionStrategy, MatDateSelectionModel, DateRange, MatCalendar, MatMonthView } from '@angular/material/datepicker';
|
|
5
5
|
import { WlcmDatepickerTrigger } from '../../../directives/datepicker-trigger.base';
|
|
6
6
|
import { WlcmDatepickerConfig } from '../../../models/date-picker.models';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
|
-
export declare class
|
|
8
|
+
export declare class DoubleCalendarRangePickerComponent extends WlcmDateRangePicker {
|
|
9
9
|
private rangeConfig;
|
|
10
|
-
|
|
10
|
+
protected rangeSelectionStrategy: MatDateRangeSelectionStrategy<Date>;
|
|
11
11
|
protected localSelectionModel: MatDateSelectionModel<DateRange<Date>>;
|
|
12
12
|
protected triggerSelectionModel: MatDateSelectionModel<DateRange<Date>>;
|
|
13
|
-
protected trigger: WlcmDatepickerTrigger<
|
|
13
|
+
protected trigger: WlcmDatepickerTrigger<DoubleCalendarRangePickerComponent>;
|
|
14
14
|
protected datepickerConfig: WlcmDatepickerConfig;
|
|
15
|
+
protected pickerBottomPanel: Type<unknown>;
|
|
15
16
|
protected dateAdapter: DateAdapter<Date>;
|
|
16
17
|
protected headerComponent: Type<unknown>;
|
|
17
18
|
private _isViewInitialized;
|
|
18
|
-
|
|
19
|
-
readonly isComplete: Signal<boolean>;
|
|
20
|
-
constructor(rangeConfig: WlcmDateRangePickerConfig, rangeSelectionStrategy: MatDateRangeSelectionStrategy<Date>, localSelectionModel: MatDateSelectionModel<DateRange<Date>>, triggerSelectionModel: MatDateSelectionModel<DateRange<Date>>, trigger: WlcmDatepickerTrigger<WlcmDateRangePickerComponent>, datepickerConfig: WlcmDatepickerConfig, dateAdapter: DateAdapter<Date>);
|
|
19
|
+
constructor(rangeConfig: WlcmDateRangePickerConfig, rangeSelectionStrategy: MatDateRangeSelectionStrategy<Date>, localSelectionModel: MatDateSelectionModel<DateRange<Date>>, triggerSelectionModel: MatDateSelectionModel<DateRange<Date>>, trigger: WlcmDatepickerTrigger<DoubleCalendarRangePickerComponent>, datepickerConfig: WlcmDatepickerConfig, pickerBottomPanel: Type<unknown>, dateAdapter: DateAdapter<Date>);
|
|
21
20
|
leftCalendar: MatCalendar<Date>;
|
|
22
21
|
rightCalendar: MatCalendar<Date>;
|
|
23
22
|
leftCalendarElement: ElementRef<HTMLElement>;
|
|
24
|
-
|
|
23
|
+
bottomPanelContainer: ViewContainerRef;
|
|
24
|
+
monthView: MatMonthView<Date>;
|
|
25
25
|
startDate: WritableSignal<Date>;
|
|
26
26
|
leftCalendarYearViewActivated: WritableSignal<boolean>;
|
|
27
27
|
rightCalendarYearViewActivated: WritableSignal<boolean>;
|
|
28
28
|
ngAfterViewInit(): void;
|
|
29
|
-
calendarSelection(event: MatCalendarUserEvent<Date | null>): void;
|
|
30
|
-
calendarDragDrop(event: MatCalendarUserEvent<DateRange<Date>>): void;
|
|
31
29
|
apply(): void;
|
|
32
30
|
reset(): void;
|
|
33
|
-
get selected(): DateRange<Date>;
|
|
34
31
|
private get leftCalendarActiveCell();
|
|
35
|
-
private handleSelectionChanged;
|
|
36
32
|
private handleRightCalendarPreviewChange;
|
|
37
|
-
static ɵfac: i0.ɵɵFactoryDeclaration<
|
|
38
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<
|
|
33
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<DoubleCalendarRangePickerComponent, [{ optional: true; }, null, null, null, null, null, null, null]>;
|
|
34
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<DoubleCalendarRangePickerComponent, "wlcm-double-calendar-range-picker", never, {}, {}, never, never, true, never>;
|
|
39
35
|
}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { AfterViewInit, Type, ViewContainerRef } from '@angular/core';
|
|
2
|
+
import { DateAdapter } from '@angular/material/core';
|
|
3
|
+
import { MatDateRangeSelectionStrategy, MatDateSelectionModel, DateRange } from '@angular/material/datepicker';
|
|
4
|
+
import { WlcmCalendarHeaderComponent } from '../../calendar-header/calendar-header.component';
|
|
5
|
+
import { WlcmDateRangePicker } from '../../../models/range/date-range-picker.models';
|
|
6
|
+
import { WlcmDatepickerTrigger } from '../../../directives/datepicker-trigger.base';
|
|
7
|
+
import { WlcmDatepickerConfig } from '../../../models/date-picker.models';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
export declare class SingleCalendarRangePickerComponent extends WlcmDateRangePicker implements AfterViewInit {
|
|
10
|
+
protected rangeSelectionStrategy: MatDateRangeSelectionStrategy<Date>;
|
|
11
|
+
protected localSelectionModel: MatDateSelectionModel<DateRange<Date>>;
|
|
12
|
+
protected triggerSelectionModel: MatDateSelectionModel<DateRange<Date>>;
|
|
13
|
+
protected trigger: WlcmDatepickerTrigger<SingleCalendarRangePickerComponent>;
|
|
14
|
+
protected datepickerConfig: WlcmDatepickerConfig;
|
|
15
|
+
protected pickerBottomPanel: Type<unknown>;
|
|
16
|
+
protected dateAdapter: DateAdapter<Date>;
|
|
17
|
+
protected headerComponent: Type<WlcmCalendarHeaderComponent>;
|
|
18
|
+
bottomPanelContainer: ViewContainerRef;
|
|
19
|
+
constructor(rangeSelectionStrategy: MatDateRangeSelectionStrategy<Date>, localSelectionModel: MatDateSelectionModel<DateRange<Date>>, triggerSelectionModel: MatDateSelectionModel<DateRange<Date>>, trigger: WlcmDatepickerTrigger<SingleCalendarRangePickerComponent>, datepickerConfig: WlcmDatepickerConfig, pickerBottomPanel: Type<unknown>, dateAdapter: DateAdapter<Date>);
|
|
20
|
+
ngAfterViewInit(): void;
|
|
21
|
+
get minDate(): Date | undefined;
|
|
22
|
+
get maxDate(): Date | undefined;
|
|
23
|
+
apply(): void;
|
|
24
|
+
reset(): void;
|
|
25
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<SingleCalendarRangePickerComponent, never>;
|
|
26
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<SingleCalendarRangePickerComponent, "wlcm-single-calendar-range-picker", never, {}, {}, never, never, true, never>;
|
|
27
|
+
}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
import { InjectionToken } from '@angular/core';
|
|
1
|
+
import { InjectionToken, Type } from '@angular/core';
|
|
2
2
|
import { WlcmDateRangePickerConfig } from '../../models/range/date-range-picker.models';
|
|
3
3
|
export declare const WLCM_DATE_RANGE_PICKER_CONFIG: InjectionToken<WlcmDateRangePickerConfig>;
|
|
4
|
+
export declare const WLCM_DATE_RANGE_PICKER_BP: InjectionToken<Type<unknown>>;
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { OverlayRef, Overlay } from '@angular/cdk/overlay';
|
|
2
2
|
import { ElementRef, Type, ComponentRef, ViewContainerRef, Injector, InputSignal } from '@angular/core';
|
|
3
3
|
import { MatDateSelectionModel } from '@angular/material/datepicker';
|
|
4
|
-
import { Observable } from 'rxjs';
|
|
5
4
|
import { WlcmDatepickerConfig } from '../models/date-picker.models';
|
|
5
|
+
import { Observable } from 'rxjs';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
export declare abstract class WlcmDatepickerTrigger<T, D = Date> {
|
|
8
8
|
protected overlay: Overlay;
|
|
@@ -25,7 +25,6 @@ export declare abstract class WlcmDatepickerTrigger<T, D = Date> {
|
|
|
25
25
|
get datepickerInjector(): Injector;
|
|
26
26
|
get defaultDatepickerConfig(): WlcmDatepickerConfig;
|
|
27
27
|
get datepickerConfig(): WlcmDatepickerConfig;
|
|
28
|
-
private get overlayOrigin();
|
|
29
28
|
private handleBackdropClick;
|
|
30
29
|
private updatePositionStrategy;
|
|
31
30
|
private createOverlayConfig;
|
|
@@ -1,4 +1,18 @@
|
|
|
1
|
-
import { Type } from '@angular/core';
|
|
1
|
+
import { Signal, Type, WritableSignal } from '@angular/core';
|
|
2
|
+
import { MatDateSelectionModel, DateRange, MatCalendarUserEvent, MatDateRangeSelectionStrategy } from '@angular/material/datepicker';
|
|
3
|
+
export declare abstract class WlcmDateRangePicker {
|
|
4
|
+
protected localSelectionModel: MatDateSelectionModel<DateRange<Date>>;
|
|
5
|
+
protected rangeSelectionStrategy: MatDateRangeSelectionStrategy<Date>;
|
|
6
|
+
protected _isComplete: WritableSignal<boolean>;
|
|
7
|
+
readonly isComplete: Signal<boolean>;
|
|
8
|
+
constructor(localSelectionModel: MatDateSelectionModel<DateRange<Date>>, rangeSelectionStrategy: MatDateRangeSelectionStrategy<Date>);
|
|
9
|
+
abstract apply(): void;
|
|
10
|
+
abstract reset(): void;
|
|
11
|
+
calendarSelection(event: MatCalendarUserEvent<Date | null>): void;
|
|
12
|
+
calendarDragDrop(event: MatCalendarUserEvent<DateRange<Date>>): void;
|
|
13
|
+
get selected(): DateRange<Date>;
|
|
14
|
+
private handleSelectionChanged;
|
|
15
|
+
}
|
|
2
16
|
export interface WlcmDateRangePickerConfig {
|
|
3
17
|
headerComponent?: Type<unknown>;
|
|
4
18
|
}
|
|
@@ -73,7 +73,13 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
|
73
73
|
this.viewReady$ = new Subject();
|
|
74
74
|
this.selected$ = new Subject();
|
|
75
75
|
this.compareWith = (optionA, optionB) => {
|
|
76
|
-
|
|
76
|
+
if (this.areOptionsEqual(optionA, optionB)) {
|
|
77
|
+
if (this.selectOptionFormat() === 'CompleteOption' && typeof optionB !== 'object') {
|
|
78
|
+
this._changed?.(optionA);
|
|
79
|
+
}
|
|
80
|
+
return true;
|
|
81
|
+
}
|
|
82
|
+
return false;
|
|
77
83
|
};
|
|
78
84
|
this.focus = () => this.matSelect.open();
|
|
79
85
|
this.isFocused = () => this.isOpen;
|
|
@@ -110,6 +116,9 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
|
110
116
|
this.selectionChange.emit(event);
|
|
111
117
|
});
|
|
112
118
|
}
|
|
119
|
+
areOptionsEqual(optionA, optionB) {
|
|
120
|
+
return (optionA?.value || optionA) === (optionB?.value || optionB);
|
|
121
|
+
}
|
|
113
122
|
revertPreviousValue() {
|
|
114
123
|
this.matSelect.value = this._previousValue;
|
|
115
124
|
}
|
|
@@ -314,4 +323,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.6", ngImpor
|
|
|
314
323
|
type: HostListener,
|
|
315
324
|
args: ['click']
|
|
316
325
|
}] } });
|
|
317
|
-
//# 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 { 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() queryParams: WlcmQueryParams = { ...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  private _preferredOverlayOrigin!: CdkOverlayOrigin;\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    if (this.formField) {\n      this.matSelect._preferredOverlayOrigin = 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"]}
|
|
326
|
+
//# 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 { 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() queryParams: WlcmQueryParams = { ...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  private _preferredOverlayOrigin!: CdkOverlayOrigin;\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    if (this.formField) {\n      this.matSelect._preferredOverlayOrigin = 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    if (this.areOptionsEqual(optionA, optionB)) {\n      if (this.selectOptionFormat() === 'CompleteOption' && typeof optionB !== 'object') {\n        this._changed?.(optionA);\n      }\n\n      return true;\n    }\n\n    return false;\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 areOptionsEqual(optionA: WlcmOption | string, optionB: WlcmOption | string) {\n    return ((optionA as WlcmOption)?.value || optionA) === ((optionB as WlcmOption)?.value || optionB);\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"]}
|
|
@@ -943,7 +943,13 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
|
943
943
|
this.viewReady$ = new Subject();
|
|
944
944
|
this.selected$ = new Subject();
|
|
945
945
|
this.compareWith = (optionA, optionB) => {
|
|
946
|
-
|
|
946
|
+
if (this.areOptionsEqual(optionA, optionB)) {
|
|
947
|
+
if (this.selectOptionFormat() === 'CompleteOption' && typeof optionB !== 'object') {
|
|
948
|
+
this._changed?.(optionA);
|
|
949
|
+
}
|
|
950
|
+
return true;
|
|
951
|
+
}
|
|
952
|
+
return false;
|
|
947
953
|
};
|
|
948
954
|
this.focus = () => this.matSelect.open();
|
|
949
955
|
this.isFocused = () => this.isOpen;
|
|
@@ -980,6 +986,9 @@ let WlcmSelectComponent = class WlcmSelectComponent {
|
|
|
980
986
|
this.selectionChange.emit(event);
|
|
981
987
|
});
|
|
982
988
|
}
|
|
989
|
+
areOptionsEqual(optionA, optionB) {
|
|
990
|
+
return (optionA?.value || optionA) === (optionB?.value || optionB);
|
|
991
|
+
}
|
|
983
992
|
revertPreviousValue() {
|
|
984
993
|
this.matSelect.value = this._previousValue;
|
|
985
994
|
}
|