@ethlete/cdk 3.21.0 → 3.22.1
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/CHANGELOG.md +22 -0
- package/esm2022/lib/components/forms/components/select/components/combobox/components/combobox/combobox.component.mjs +9 -5
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox/combobox.directive.mjs +33 -7
- package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-body/combobox-body.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-option/combobox-option.component.mjs +3 -4
- package/esm2022/lib/components/forms/components/select/components/combobox/private/combobox.private.types.mjs +1 -1
- package/esm2022/lib/components/forms/components/select/components/combobox/utils/public-api.mjs +1 -2
- package/esm2022/lib/components/forms/components/select/components/select/components/select/select.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/select/directives/select/select.directive.mjs +144 -312
- package/esm2022/lib/components/forms/components/select/components/select/directives/select-body/select-body.directive.mjs +4 -3
- package/esm2022/lib/components/forms/components/select/components/select/directives/select-option/select-option.directive.mjs +15 -40
- package/esm2022/lib/components/forms/components/select/components/select/partials/select-body/select-body.component.mjs +8 -5
- package/esm2022/lib/components/forms/components/select/components/{combobox/utils → select/private}/index.mjs +2 -2
- package/esm2022/lib/components/forms/components/select/components/select/private/select.private.types.mjs +2 -0
- package/esm2022/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-container-base/bottom-sheet-container-base.component.mjs +4 -4
- package/esm2022/lib/components/overlay/components/dialog/partials/dialog-container-base/dialog-container-base.component.mjs +4 -4
- package/esm2022/lib/components/overlay/components/overlay/components/overlay-container/overlay-container.component.mjs +6 -4
- package/esm2022/lib/components/overlay/components/overlay/services/overlay.service.mjs +10 -3
- package/esm2022/lib/components/overlay/components/overlay/utils/overlay-ref.mjs +35 -6
- package/esm2022/lib/components/overlay/components/toggletip/directives/toggletip/toggletip.directive.mjs +5 -3
- package/esm2022/lib/components/overlay/components/tooltip/directives/tooltip/tooltip.directive.mjs +5 -3
- package/esm2022/lib/components/overlay/directives/overlay-close-auto-blocker/index.mjs +2 -0
- package/esm2022/lib/components/overlay/directives/overlay-close-auto-blocker/overlay-close-auto-blocker.directive.mjs +51 -0
- package/esm2022/lib/components/overlay/directives/overlay-close-auto-blocker/public-api.mjs +2 -0
- package/esm2022/lib/components/overlay/directives/public-api.mjs +2 -1
- package/esm2022/lib/components/overlay/public-api.mjs +2 -1
- package/esm2022/lib/components/overlay/utils/overlay-dismiss-checker.util.mjs +79 -0
- package/esm2022/lib/components/overlay/utils/public-api.mjs +2 -0
- package/fesm2022/ethlete-cdk.mjs +397 -409
- package/fesm2022/ethlete-cdk.mjs.map +1 -1
- package/lib/components/forms/components/select/components/combobox/components/combobox/combobox.component.d.ts +4 -3
- package/lib/components/forms/components/select/components/combobox/directives/combobox/combobox.directive.d.ts +4 -1
- package/lib/components/forms/components/select/components/combobox/private/combobox.private.types.d.ts +1 -1
- package/lib/components/forms/components/select/components/combobox/utils/public-api.d.ts +0 -1
- package/lib/components/forms/components/select/components/select/directives/select/select.directive.d.ts +16 -53
- package/lib/components/forms/components/select/components/select/directives/select-body/select-body.directive.d.ts +2 -1
- package/lib/components/forms/components/select/components/select/directives/select-option/select-option.directive.d.ts +7 -9
- package/lib/components/forms/components/select/components/select/partials/select-body/select-body.component.d.ts +2 -1
- package/lib/components/forms/components/select/components/select/private/index.d.ts +1 -0
- package/lib/components/forms/components/select/components/select/private/select.private.types.d.ts +13 -0
- package/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-container-base/bottom-sheet-container-base.component.d.ts +1 -1
- package/lib/components/overlay/components/dialog/partials/dialog-container-base/dialog-container-base.component.d.ts +1 -1
- package/lib/components/overlay/components/overlay/components/overlay-container/overlay-container.component.d.ts +5 -3
- package/lib/components/overlay/components/overlay/utils/overlay-ref.d.ts +12 -3
- package/lib/components/overlay/components/toggletip/directives/toggletip/toggletip.directive.d.ts +2 -1
- package/lib/components/overlay/components/tooltip/directives/tooltip/tooltip.directive.d.ts +2 -1
- package/lib/components/overlay/directives/overlay-close-auto-blocker/overlay-close-auto-blocker.directive.d.ts +12 -0
- package/lib/components/overlay/directives/overlay-close-auto-blocker/public-api.d.ts +1 -0
- package/lib/components/overlay/directives/public-api.d.ts +1 -0
- package/lib/components/overlay/public-api.d.ts +1 -0
- package/lib/components/overlay/utils/overlay-dismiss-checker.util.d.ts +60 -0
- package/lib/components/overlay/utils/public-api.d.ts +1 -0
- package/package.json +2 -2
- package/esm2022/lib/components/forms/components/select/components/combobox/utils/option.utils.mjs +0 -7
- package/lib/components/forms/components/select/components/combobox/utils/option.utils.d.ts +0 -1
- /package/lib/components/{forms/components/select/components/combobox/utils → overlay/directives/overlay-close-auto-blocker}/index.d.ts +0 -0
|
@@ -1,25 +1,22 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { ContentChildren, Directive, ElementRef, InjectionToken, Input, booleanAttribute, inject, } from '@angular/core';
|
|
1
|
+
import { A, BACKSPACE, DOWN_ARROW, ENTER, ESCAPE, SPACE, TAB, UP_ARROW, hasModifierKey } from '@angular/cdk/keycodes';
|
|
2
|
+
import { ContentChildren, Directive, ElementRef, InjectionToken, Input, ViewChild, booleanAttribute, inject, } from '@angular/core';
|
|
4
3
|
import { toSignal } from '@angular/core/rxjs-interop';
|
|
5
|
-
import { ActiveSelectionModel, AnimatedOverlayDirective, SelectionModel, TypedQueryList, createDestroy, signalClasses, signalHostClasses,
|
|
4
|
+
import { ActiveSelectionModel, AnimatedOverlayDirective, SelectionModel, TypedQueryList, createDestroy, scrollToElement, signalClasses, signalHostClasses, } from '@ethlete/core';
|
|
6
5
|
import { THEME_PROVIDER } from '@ethlete/theming';
|
|
7
|
-
import { BehaviorSubject, combineLatest,
|
|
6
|
+
import { BehaviorSubject, combineLatest, debounceTime, map, of, switchMap, takeUntil, tap } from 'rxjs';
|
|
7
|
+
import { OverlayCloseBlockerDirective } from '../../../../../../../overlay';
|
|
8
8
|
import { INPUT_TOKEN } from '../../../../../../directives';
|
|
9
9
|
import { SELECT_FIELD_TOKEN } from '../../../../directives';
|
|
10
10
|
import { SELECT_OPTION_TOKEN } from '../select-option';
|
|
11
11
|
import * as i0 from "@angular/core";
|
|
12
12
|
import * as i1 from "@ethlete/core";
|
|
13
|
+
import * as i2 from "../../../../../../../overlay/directives/overlay-close-auto-blocker/overlay-close-auto-blocker.directive";
|
|
13
14
|
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
14
15
|
export const SELECT_TOKEN = new InjectionToken('ET_SELECT_INPUT_TOKEN');
|
|
15
16
|
let uniqueId = 0;
|
|
16
17
|
export class SelectDirective {
|
|
17
|
-
get multiple() {
|
|
18
|
-
return this._multiple$.value;
|
|
19
|
-
}
|
|
20
18
|
set multiple(value) {
|
|
21
|
-
this.
|
|
22
|
-
this._migrateSelectValue();
|
|
19
|
+
this._selectionModel.setAllowMultiple(booleanAttribute(value));
|
|
23
20
|
}
|
|
24
21
|
set _selectOptionsQueryList(value) {
|
|
25
22
|
this._selectOptionsQueryList$.next(value);
|
|
@@ -28,7 +25,6 @@ export class SelectDirective {
|
|
|
28
25
|
this._selectBodyConfig = null;
|
|
29
26
|
this._animatedOverlay = inject(AnimatedOverlayDirective);
|
|
30
27
|
this._destroy$ = createDestroy();
|
|
31
|
-
this._liveAnnouncer = inject(LiveAnnouncer);
|
|
32
28
|
this._selectField = inject(SELECT_FIELD_TOKEN);
|
|
33
29
|
this._themeProvider = inject(THEME_PROVIDER, { optional: true });
|
|
34
30
|
this.input = inject(INPUT_TOKEN);
|
|
@@ -37,55 +33,27 @@ export class SelectDirective {
|
|
|
37
33
|
this.elementRef = inject(ElementRef);
|
|
38
34
|
this._selectionModel = new SelectionModel();
|
|
39
35
|
this._activeSelectionModel = new ActiveSelectionModel();
|
|
40
|
-
this._multiple$ = new BehaviorSubject(false);
|
|
41
36
|
this._selectOptionsQueryList$ = new BehaviorSubject(null);
|
|
42
|
-
this.selectOptions$ = this._selectOptionsQueryList$.pipe(switchQueryListChanges(), switchMap((queryList) => {
|
|
43
|
-
if (!queryList)
|
|
44
|
-
return of(null);
|
|
45
|
-
const items = queryList.map((opt) => combineLatest([opt.isSelected$, opt.isActive$]).pipe(map(([selected, active]) => ({ opt, selected, active }))));
|
|
46
|
-
return combineLatest(items ?? of(null));
|
|
47
|
-
}));
|
|
48
|
-
this.activeOption$ = this.selectOptions$.pipe(map((options) => {
|
|
49
|
-
if (!options)
|
|
50
|
-
return null;
|
|
51
|
-
return options.find((option) => option.active) ?? null;
|
|
52
|
-
}));
|
|
53
|
-
this.selectedOptions$ = this.selectOptions$.pipe(map((options) => {
|
|
54
|
-
if (!options)
|
|
55
|
-
return null;
|
|
56
|
-
const selectedOptions = options.filter((option) => option.selected);
|
|
57
|
-
if (!selectedOptions.length)
|
|
58
|
-
return null;
|
|
59
|
-
const inputValue = this.input.value;
|
|
60
|
-
if (this.multiple && Array.isArray(inputValue)) {
|
|
61
|
-
// sort selected options by the order of the input value
|
|
62
|
-
const selectedOptionsMap = new Map(selectedOptions.map((option) => [option.opt.value, option]));
|
|
63
|
-
return inputValue
|
|
64
|
-
.map((value) => selectedOptionsMap.get(value))
|
|
65
|
-
.filter((option) => !!option);
|
|
66
|
-
}
|
|
67
|
-
return selectedOptions;
|
|
68
|
-
}));
|
|
69
|
-
this.selectedOption$ = this.selectedOptions$.pipe(map((options) => options?.[0] ?? null));
|
|
70
37
|
this.selectBodyId$ = this._selectBodyId$.asObservable();
|
|
71
38
|
this.isOpen$ = this._isOpen$.asObservable();
|
|
72
39
|
this.isOpen = toSignal(this.isOpen$);
|
|
73
|
-
this.multiple$ = this.
|
|
40
|
+
this.multiple$ = this._selectionModel.allowMultiple$;
|
|
74
41
|
this.selectCurrentValueId = `et-select-current-value-${uniqueId++}`;
|
|
75
|
-
this.ariaViewValue$ = this.
|
|
42
|
+
this.ariaViewValue$ = this._selectionModel.selection$.pipe(switchMap((options) => {
|
|
76
43
|
if (!options?.length)
|
|
77
44
|
return of(null);
|
|
78
|
-
const viewValues = options.map((option) => option.
|
|
45
|
+
const viewValues = options.map((option) => option.viewValue$);
|
|
79
46
|
return combineLatest(viewValues);
|
|
80
47
|
}), map((viewValues) => {
|
|
81
48
|
if (!viewValues)
|
|
82
49
|
return null;
|
|
83
50
|
return viewValues.join(', ');
|
|
84
51
|
}));
|
|
85
|
-
this.
|
|
52
|
+
this.ariaViewValue = toSignal(this.ariaViewValue$);
|
|
53
|
+
this.activeDescendant$ = combineLatest([this.isOpen$, this._activeSelectionModel.activeOption$]).pipe(map(([isOpen, activeOption]) => {
|
|
86
54
|
if (!isOpen || !activeOption)
|
|
87
55
|
return null;
|
|
88
|
-
return activeOption.
|
|
56
|
+
return activeOption.id;
|
|
89
57
|
}));
|
|
90
58
|
this.owns$ = combineLatest([this.isOpen$, this.selectBodyId$]).pipe(map(([isOpen, selectBodyId]) => {
|
|
91
59
|
if (!isOpen || !selectBodyId) {
|
|
@@ -105,6 +73,7 @@ export class SelectDirective {
|
|
|
105
73
|
'et-select-field--open': this.isOpen,
|
|
106
74
|
'et-select-field--multiple': toSignal(this.multiple$),
|
|
107
75
|
});
|
|
76
|
+
this.inputElement = null;
|
|
108
77
|
this.trackByFn = (_, item) => item.id;
|
|
109
78
|
this._animatedOverlay.placement = 'bottom';
|
|
110
79
|
this._animatedOverlay.fallbackPlacements = ['bottom', 'top'];
|
|
@@ -116,21 +85,22 @@ export class SelectDirective {
|
|
|
116
85
|
.setValueBinding((v) => v.value)
|
|
117
86
|
.setDisabledBinding((v) => v.disabled);
|
|
118
87
|
this._activeSelectionModel.setSelectionModel(this._selectionModel);
|
|
119
|
-
//TODO: TO BE CONTINUED...
|
|
120
88
|
}
|
|
121
89
|
ngOnInit() {
|
|
122
|
-
this.
|
|
123
|
-
this.
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
90
|
+
this._closeBodyOnDisable();
|
|
91
|
+
this._selectionModel.setSelectionFromValue$(this.input.value);
|
|
92
|
+
this._selectionModel.value$
|
|
93
|
+
.pipe(takeUntil(this._destroy$), tap((value) => this.input._updateValue(value)))
|
|
94
|
+
.subscribe();
|
|
95
|
+
this.input.onExternalUpdate$
|
|
96
|
+
.pipe(takeUntil(this._destroy$), tap(() => this._selectionModel.setSelectionFromValue$(this.input.value)))
|
|
97
|
+
.subscribe();
|
|
127
98
|
}
|
|
128
|
-
|
|
99
|
+
open() {
|
|
129
100
|
if (!this._selectBodyConfig)
|
|
130
101
|
return;
|
|
131
102
|
if (this._animatedOverlay.isMounted || this.input.disabled)
|
|
132
103
|
return;
|
|
133
|
-
this._setSelectedOptionActive();
|
|
134
104
|
const instance = this._animatedOverlay.mount({
|
|
135
105
|
component: this._selectBodyConfig.component,
|
|
136
106
|
mirrorWidth: true,
|
|
@@ -141,300 +111,159 @@ export class SelectDirective {
|
|
|
141
111
|
return;
|
|
142
112
|
this._selectBodyId$.next(instance.selectBody.id);
|
|
143
113
|
this._isOpen$.next(true);
|
|
114
|
+
this._activeSelectionModel.activeOption$
|
|
115
|
+
.pipe(debounceTime(0), tap((activeOption) => {
|
|
116
|
+
if (!activeOption)
|
|
117
|
+
return;
|
|
118
|
+
scrollToElement({
|
|
119
|
+
container: instance._containerElementRef?.nativeElement,
|
|
120
|
+
element: activeOption._elementRef.nativeElement,
|
|
121
|
+
behavior: 'instant',
|
|
122
|
+
});
|
|
123
|
+
}), takeUntil(this._destroy$), takeUntil(this._animatedOverlay.afterClosed()))
|
|
124
|
+
.subscribe();
|
|
125
|
+
this._animatedOverlay
|
|
126
|
+
.afterClosed()
|
|
127
|
+
.pipe(takeUntil(this._destroy$), tap(() => {
|
|
128
|
+
this._selectBodyId$.next(null);
|
|
129
|
+
this._isOpen$.next(false);
|
|
130
|
+
}))
|
|
131
|
+
.subscribe();
|
|
144
132
|
}
|
|
145
|
-
|
|
133
|
+
close() {
|
|
146
134
|
if (!this._animatedOverlay.isMounted)
|
|
147
135
|
return;
|
|
148
136
|
this._animatedOverlay.unmount();
|
|
149
|
-
this._selectBodyId$.next(null);
|
|
150
|
-
this._isOpen$.next(false);
|
|
151
137
|
}
|
|
152
|
-
|
|
153
|
-
this.input._updateValue(value);
|
|
138
|
+
writeValueFromOption(option) {
|
|
154
139
|
this.input._markAsTouched();
|
|
155
|
-
this.
|
|
156
|
-
|
|
157
|
-
handleKeyDown(event) {
|
|
158
|
-
if (this._isOpen$.value) {
|
|
159
|
-
this._handleKeyDownInOpenState(event);
|
|
140
|
+
if (this._selectionModel.allowMultiple) {
|
|
141
|
+
this._selectionModel.toggleSelectedOption(option);
|
|
160
142
|
}
|
|
161
143
|
else {
|
|
162
|
-
this.
|
|
144
|
+
this._selectionModel.addSelectedOption(option);
|
|
145
|
+
}
|
|
146
|
+
if (!this._selectionModel.allowMultiple) {
|
|
147
|
+
this.close();
|
|
163
148
|
}
|
|
164
149
|
}
|
|
150
|
+
focus() {
|
|
151
|
+
this.inputElement?.nativeElement.focus();
|
|
152
|
+
}
|
|
165
153
|
setSelectBody(config) {
|
|
166
154
|
this._selectBodyConfig = config;
|
|
167
155
|
}
|
|
168
156
|
removeOptionFromSelection(option) {
|
|
169
|
-
|
|
170
|
-
return;
|
|
171
|
-
const value = this.input.value.filter((v) => v !== option.value);
|
|
172
|
-
this.setValue(value);
|
|
157
|
+
this._selectionModel.removeSelectedOption(option);
|
|
173
158
|
}
|
|
174
159
|
_controlTouched() {
|
|
175
160
|
this.input._markAsTouched();
|
|
176
161
|
this.input._setShouldDisplayError(true);
|
|
177
162
|
}
|
|
178
|
-
|
|
179
|
-
this.input.disabled$
|
|
180
|
-
.pipe(tap((disabled) => {
|
|
181
|
-
if (!disabled)
|
|
182
|
-
return;
|
|
183
|
-
this.unmountSelectBody();
|
|
184
|
-
}), takeUntil(this._destroy$))
|
|
185
|
-
.subscribe();
|
|
186
|
-
}
|
|
187
|
-
_handleKeyDownInClosedState(event) {
|
|
163
|
+
_processKeydownEvent(event) {
|
|
188
164
|
const keyCode = event.keyCode;
|
|
189
|
-
const
|
|
190
|
-
const
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
165
|
+
const isOpen = this.isOpen();
|
|
166
|
+
const isMultiple = this._selectionModel.allowMultiple;
|
|
167
|
+
const selection = this._selectionModel.selection;
|
|
168
|
+
const isArrowKey = keyCode === UP_ARROW || keyCode === DOWN_ARROW;
|
|
169
|
+
const isAltPressed = hasModifierKey(event, 'altKey');
|
|
170
|
+
const result = {};
|
|
171
|
+
if (isArrowKey && isAltPressed && !isOpen) {
|
|
172
|
+
result.overlayOperation = 'open';
|
|
173
|
+
return this._interpretKeyHandlerResult(result);
|
|
194
174
|
}
|
|
195
|
-
|
|
196
|
-
switch (keyCode) {
|
|
197
|
-
case DOWN_ARROW:
|
|
198
|
-
this._selectOptionByOffset(1, true);
|
|
199
|
-
break;
|
|
200
|
-
case UP_ARROW:
|
|
201
|
-
this._selectOptionByOffset(-1, true);
|
|
202
|
-
break;
|
|
203
|
-
case HOME:
|
|
204
|
-
this._selectFirstOption(true);
|
|
205
|
-
break;
|
|
206
|
-
case END:
|
|
207
|
-
this._selectLastOption(true);
|
|
208
|
-
break;
|
|
209
|
-
case PAGE_UP:
|
|
210
|
-
this._selectOptionByOffset(-10, true);
|
|
211
|
-
break;
|
|
212
|
-
case PAGE_DOWN:
|
|
213
|
-
this._selectOptionByOffset(10, true);
|
|
214
|
-
break;
|
|
215
|
-
}
|
|
216
|
-
}
|
|
217
|
-
else if (this.multiple && isArrowKey) {
|
|
218
|
-
event.preventDefault();
|
|
219
|
-
this.mountSelectBody();
|
|
220
|
-
}
|
|
221
|
-
}
|
|
222
|
-
async _handleKeyDownInOpenState(event) {
|
|
223
|
-
const keyCode = event.keyCode;
|
|
224
|
-
const isArrowKey = keyCode === DOWN_ARROW || keyCode === UP_ARROW;
|
|
225
|
-
if (isArrowKey && event.altKey) {
|
|
226
|
-
event.preventDefault();
|
|
227
|
-
this.unmountSelectBody();
|
|
228
|
-
}
|
|
229
|
-
else if (keyCode === ESCAPE && !hasModifierKey(event)) {
|
|
175
|
+
if (keyCode === ENTER) {
|
|
230
176
|
event.preventDefault();
|
|
231
177
|
event.stopPropagation();
|
|
232
|
-
this.
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
if (
|
|
236
|
-
|
|
178
|
+
const activeOption = this._activeSelectionModel.activeOption;
|
|
179
|
+
if (activeOption && this._selectionModel.isDisabled(activeOption))
|
|
180
|
+
return;
|
|
181
|
+
if (activeOption) {
|
|
182
|
+
if (isMultiple) {
|
|
183
|
+
result.optionAction = { type: 'toggle', option: activeOption };
|
|
184
|
+
}
|
|
185
|
+
else {
|
|
186
|
+
result.optionAction = { type: 'add', option: activeOption };
|
|
187
|
+
}
|
|
237
188
|
}
|
|
238
|
-
|
|
239
|
-
|
|
189
|
+
if (!isMultiple) {
|
|
190
|
+
result.overlayOperation = 'close';
|
|
240
191
|
}
|
|
241
|
-
|
|
242
|
-
}
|
|
243
|
-
else if (this.multiple && keyCode === A && event.ctrlKey) {
|
|
244
|
-
event.preventDefault();
|
|
245
|
-
this._toggleSelectionOfAllOptions();
|
|
192
|
+
return this._interpretKeyHandlerResult(result);
|
|
246
193
|
}
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
case UP_ARROW:
|
|
253
|
-
this._activateOptionByOffset(-1);
|
|
254
|
-
break;
|
|
255
|
-
case HOME:
|
|
256
|
-
this._activateFirstOption();
|
|
257
|
-
break;
|
|
258
|
-
case END:
|
|
259
|
-
this._activateLastOption();
|
|
260
|
-
break;
|
|
261
|
-
case PAGE_UP:
|
|
262
|
-
this._activateOptionByOffset(-10);
|
|
263
|
-
break;
|
|
264
|
-
case PAGE_DOWN:
|
|
265
|
-
this._activateOptionByOffset(10);
|
|
266
|
-
break;
|
|
194
|
+
if (keyCode === ESCAPE) {
|
|
195
|
+
if (isOpen) {
|
|
196
|
+
result.overlayOperation = 'close';
|
|
197
|
+
event.preventDefault();
|
|
198
|
+
event.stopPropagation();
|
|
267
199
|
}
|
|
200
|
+
return this._interpretKeyHandlerResult(result);
|
|
268
201
|
}
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
if (currentActiveOption?.opt === option)
|
|
273
|
-
return false;
|
|
274
|
-
currentActiveOption?.opt._setActive(false);
|
|
275
|
-
if (option) {
|
|
276
|
-
option._setActive(true);
|
|
277
|
-
}
|
|
278
|
-
return true;
|
|
279
|
-
}
|
|
280
|
-
async _addActiveOptionToSelection() {
|
|
281
|
-
const activeOption = await firstValueFrom(this.activeOption$);
|
|
282
|
-
if (!activeOption || activeOption.opt.disabled || activeOption.selected)
|
|
283
|
-
return;
|
|
284
|
-
if (!Array.isArray(this.input.value)) {
|
|
285
|
-
this.setValue([activeOption.opt.value]);
|
|
286
|
-
return;
|
|
202
|
+
if (keyCode === TAB) {
|
|
203
|
+
result.overlayOperation = 'close';
|
|
204
|
+
return this._interpretKeyHandlerResult(result);
|
|
287
205
|
}
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
if (!Array.isArray(this.input.value)) {
|
|
295
|
-
this.setValue([]);
|
|
296
|
-
return;
|
|
206
|
+
if (keyCode === BACKSPACE) {
|
|
207
|
+
const lastSelectedOption = selection[selection.length - 1];
|
|
208
|
+
if (isMultiple && lastSelectedOption) {
|
|
209
|
+
result.optionAction = { type: 'remove', option: lastSelectedOption };
|
|
210
|
+
return this._interpretKeyHandlerResult(result);
|
|
211
|
+
}
|
|
297
212
|
}
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
const allOptions = await firstValueFrom(this.selectOptions$);
|
|
302
|
-
const hasDeselectedOption = allOptions?.some((opt) => !opt.opt.disabled && !opt.selected);
|
|
303
|
-
if (hasDeselectedOption) {
|
|
304
|
-
this._selectAllOptions();
|
|
213
|
+
if (keyCode === SPACE) {
|
|
214
|
+
result.overlayOperation = 'open';
|
|
215
|
+
return this._interpretKeyHandlerResult(result);
|
|
305
216
|
}
|
|
306
|
-
|
|
307
|
-
|
|
217
|
+
const newActiveOption = this._activeSelectionModel.evaluateKeyboardEvent(event, { skipDisabled: !isOpen });
|
|
218
|
+
if (newActiveOption && !isOpen && !isMultiple) {
|
|
219
|
+
result.optionAction = { type: 'add', option: newActiveOption };
|
|
308
220
|
}
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
if (!allOptions)
|
|
313
|
-
return;
|
|
314
|
-
const selectedOptions = allOptions.filter((opt) => !opt.opt.disabled).map((opt) => opt.opt.value);
|
|
315
|
-
this.setValue(selectedOptions);
|
|
316
|
-
}
|
|
317
|
-
async _deselectAllOptions() {
|
|
318
|
-
this.setValue([]);
|
|
319
|
-
}
|
|
320
|
-
async _toggleActiveOptionSelection() {
|
|
321
|
-
const activeOption = await firstValueFrom(this.activeOption$);
|
|
322
|
-
if (!activeOption)
|
|
323
|
-
return;
|
|
324
|
-
if (activeOption.selected) {
|
|
325
|
-
this._removeActiveOptionFromSelection();
|
|
326
|
-
}
|
|
327
|
-
else {
|
|
328
|
-
this._addActiveOptionToSelection();
|
|
221
|
+
if (keyCode === A && event.ctrlKey && isMultiple) {
|
|
222
|
+
result.optionAction = 'toggleAll';
|
|
223
|
+
event.preventDefault();
|
|
329
224
|
}
|
|
225
|
+
return this._interpretKeyHandlerResult(result);
|
|
330
226
|
}
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
return;
|
|
335
|
-
this._setSelectedOption(activeOption.opt);
|
|
336
|
-
this.unmountSelectBody();
|
|
337
|
-
}
|
|
338
|
-
async _setSelectedOptionActive() {
|
|
339
|
-
const selectedOption = await firstValueFrom(this.selectedOption$);
|
|
340
|
-
if (!selectedOption)
|
|
341
|
-
return;
|
|
342
|
-
this._setActiveOption(selectedOption.opt);
|
|
343
|
-
}
|
|
344
|
-
async _setSelectedOption(option) {
|
|
345
|
-
const selectedOption = await firstValueFrom(this.selectedOption$);
|
|
346
|
-
if (selectedOption === option)
|
|
347
|
-
return false;
|
|
348
|
-
this._setActiveOption(option);
|
|
349
|
-
this.setValue(option?.value ?? null);
|
|
350
|
-
return true;
|
|
351
|
-
}
|
|
352
|
-
async _selectFirstOption(announce) {
|
|
353
|
-
const options = await firstValueFrom(this.selectOptions$);
|
|
354
|
-
if (!options)
|
|
355
|
-
return;
|
|
356
|
-
const firstOption = options[0]?.opt;
|
|
357
|
-
if (!firstOption)
|
|
358
|
-
return;
|
|
359
|
-
if (!this._setSelectedOption(firstOption))
|
|
360
|
-
return;
|
|
361
|
-
if (announce) {
|
|
362
|
-
const text = await firstValueFrom(firstOption.viewValue$);
|
|
363
|
-
this._liveAnnouncer.announce(text, 10000);
|
|
227
|
+
_interpretKeyHandlerResult(result) {
|
|
228
|
+
if (result.overlayOperation === 'close') {
|
|
229
|
+
this.close();
|
|
364
230
|
}
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
const options = await firstValueFrom(this.selectOptions$);
|
|
368
|
-
if (!options)
|
|
369
|
-
return;
|
|
370
|
-
const lastOption = options[options.length - 1]?.opt;
|
|
371
|
-
if (!lastOption)
|
|
372
|
-
return;
|
|
373
|
-
if (!this._setSelectedOption(lastOption))
|
|
374
|
-
return;
|
|
375
|
-
if (announce) {
|
|
376
|
-
const text = await firstValueFrom(lastOption.viewValue$);
|
|
377
|
-
this._liveAnnouncer.announce(text, 10000);
|
|
231
|
+
else if (result.overlayOperation === 'open') {
|
|
232
|
+
this.open();
|
|
378
233
|
}
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
234
|
+
if (result.optionAction) {
|
|
235
|
+
if (typeof result.optionAction === 'string') {
|
|
236
|
+
if (result.optionAction === 'clear') {
|
|
237
|
+
this._selectionModel.clearSelectedOptions();
|
|
238
|
+
}
|
|
239
|
+
else if (result.optionAction === 'toggleAll') {
|
|
240
|
+
this._selectionModel.toggleAllSelectedOptions();
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
else {
|
|
244
|
+
const { type, option } = result.optionAction;
|
|
245
|
+
if (this._selectionModel.isDisabled(option))
|
|
246
|
+
return;
|
|
247
|
+
if (type === 'add') {
|
|
248
|
+
this._selectionModel.addSelectedOption(option);
|
|
249
|
+
}
|
|
250
|
+
if (type === 'remove') {
|
|
251
|
+
this._selectionModel.removeSelectedOption(option);
|
|
252
|
+
}
|
|
253
|
+
if (type === 'toggle') {
|
|
254
|
+
this._selectionModel.toggleSelectedOption(option);
|
|
255
|
+
}
|
|
256
|
+
}
|
|
398
257
|
}
|
|
399
258
|
}
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
}
|
|
409
|
-
async _activateLastOption() {
|
|
410
|
-
const options = await firstValueFrom(this.selectOptions$);
|
|
411
|
-
if (!options)
|
|
412
|
-
return;
|
|
413
|
-
const lastOption = options[options.length - 1]?.opt;
|
|
414
|
-
if (!lastOption)
|
|
415
|
-
return;
|
|
416
|
-
await this._setActiveOption(lastOption);
|
|
417
|
-
}
|
|
418
|
-
async _activateOptionByOffset(offset) {
|
|
419
|
-
const options = await firstValueFrom(this.selectOptions$);
|
|
420
|
-
if (!options)
|
|
421
|
-
return;
|
|
422
|
-
const activatedOption = await firstValueFrom(this.activeOption$);
|
|
423
|
-
const activatedOptionIndex = options.findIndex((o) => o.opt === activatedOption?.opt);
|
|
424
|
-
const nextOptionIndex = activatedOptionIndex + offset;
|
|
425
|
-
const nextOption = options[nextOptionIndex];
|
|
426
|
-
if (!nextOption)
|
|
427
|
-
return;
|
|
428
|
-
await this._setActiveOption(nextOption.opt);
|
|
429
|
-
}
|
|
430
|
-
async _migrateSelectValue() {
|
|
431
|
-
if (this.multiple && !Array.isArray(this.input.value)) {
|
|
432
|
-
this.setValue([]);
|
|
433
|
-
}
|
|
434
|
-
else if (!this.multiple && Array.isArray(this.input.value)) {
|
|
435
|
-
this.setValue(null);
|
|
436
|
-
}
|
|
437
|
-
this._setActiveOption(null);
|
|
259
|
+
_closeBodyOnDisable() {
|
|
260
|
+
this.input.disabled$
|
|
261
|
+
.pipe(tap((disabled) => {
|
|
262
|
+
if (!disabled)
|
|
263
|
+
return;
|
|
264
|
+
this.close();
|
|
265
|
+
}), takeUntil(this._destroy$))
|
|
266
|
+
.subscribe();
|
|
438
267
|
}
|
|
439
268
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: SelectDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
440
269
|
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.5", type: SelectDirective, isStandalone: true, inputs: { multiple: "multiple", emptyText: "emptyText" }, providers: [
|
|
@@ -442,13 +271,13 @@ export class SelectDirective {
|
|
|
442
271
|
provide: SELECT_TOKEN,
|
|
443
272
|
useExisting: SelectDirective,
|
|
444
273
|
},
|
|
445
|
-
], queries: [{ propertyName: "_selectOptionsQueryList", predicate: SELECT_OPTION_TOKEN, descendants: true }], hostDirectives: [{ directive: i1.AnimatedOverlayDirective }], ngImport: i0 }); }
|
|
274
|
+
], queries: [{ propertyName: "_selectOptionsQueryList", predicate: SELECT_OPTION_TOKEN, descendants: true }], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["inputElement"], descendants: true }], hostDirectives: [{ directive: i1.AnimatedOverlayDirective }, { directive: i2.OverlayCloseBlockerDirective }], ngImport: i0 }); }
|
|
446
275
|
}
|
|
447
276
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: SelectDirective, decorators: [{
|
|
448
277
|
type: Directive,
|
|
449
278
|
args: [{
|
|
450
279
|
standalone: true,
|
|
451
|
-
hostDirectives: [AnimatedOverlayDirective],
|
|
280
|
+
hostDirectives: [AnimatedOverlayDirective, OverlayCloseBlockerDirective],
|
|
452
281
|
providers: [
|
|
453
282
|
{
|
|
454
283
|
provide: SELECT_TOKEN,
|
|
@@ -463,5 +292,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImpor
|
|
|
463
292
|
}], _selectOptionsQueryList: [{
|
|
464
293
|
type: ContentChildren,
|
|
465
294
|
args: [SELECT_OPTION_TOKEN, { descendants: true }]
|
|
295
|
+
}], inputElement: [{
|
|
296
|
+
type: ViewChild,
|
|
297
|
+
args: ['inputElement']
|
|
466
298
|
}] } });
|
|
467
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.directive.js","sourceRoot":"","sources":["../../../../../../../../../../../../../libs/cdk/src/lib/components/forms/components/select/components/select/directives/select/select.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { LiveAnnouncer } from '@angular/cdk/a11y';\nimport {\n  A,\n  DOWN_ARROW,\n  END,\n  ENTER,\n  ESCAPE,\n  HOME,\n  LEFT_ARROW,\n  PAGE_DOWN,\n  PAGE_UP,\n  RIGHT_ARROW,\n  SPACE,\n  UP_ARROW,\n  hasModifierKey,\n} from '@angular/cdk/keycodes';\nimport { ComponentType } from '@angular/cdk/portal';\nimport {\n  AfterContentInit,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  InjectionToken,\n  Input,\n  OnInit,\n  TemplateRef,\n  TrackByFunction,\n  booleanAttribute,\n  inject,\n} from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport {\n  ActiveSelectionModel,\n  AnimatedOverlayComponentBase,\n  AnimatedOverlayDirective,\n  SelectionModel,\n  TypedQueryList,\n  createDestroy,\n  signalClasses,\n  signalHostClasses,\n  switchQueryListChanges,\n} from '@ethlete/core';\nimport { THEME_PROVIDER } from '@ethlete/theming';\nimport { BehaviorSubject, combineLatest, firstValueFrom, map, of, switchMap, takeUntil, tap } from 'rxjs';\nimport { INPUT_TOKEN } from '../../../../../../directives';\nimport { SELECT_FIELD_TOKEN } from '../../../../directives';\nimport { SelectBodyDirective } from '../select-body';\nimport { SELECT_OPTION_TOKEN, SelectOptionDirective } from '../select-option';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const SELECT_TOKEN = new InjectionToken<SelectDirective<any>>('ET_SELECT_INPUT_TOKEN');\n\ntype SelectDirectiveBodyComponentBase = AnimatedOverlayComponentBase & {\n  _bodyTemplate: TemplateRef<unknown> | null;\n  selectBody: SelectBodyDirective;\n};\n\nlet uniqueId = 0;\n\ninterface SelectBodyConfig<T extends SelectDirectiveBodyComponentBase> {\n  component: ComponentType<T>;\n  template: TemplateRef<unknown>;\n}\n\n@Directive({\n  standalone: true,\n  hostDirectives: [AnimatedOverlayDirective],\n  providers: [\n    {\n      provide: SELECT_TOKEN,\n      useExisting: SelectDirective,\n    },\n  ],\n})\nexport class SelectDirective<T extends SelectDirectiveBodyComponentBase> implements OnInit, AfterContentInit {\n  private _selectBodyConfig: SelectBodyConfig<T> | null = null;\n\n  private readonly _animatedOverlay = inject<AnimatedOverlayDirective<T>>(AnimatedOverlayDirective);\n  private readonly _destroy$ = createDestroy();\n  private readonly _liveAnnouncer = inject(LiveAnnouncer);\n  private readonly _selectField = inject(SELECT_FIELD_TOKEN);\n  private readonly _themeProvider = inject(THEME_PROVIDER, { optional: true });\n\n  readonly input = inject(INPUT_TOKEN);\n\n  private readonly _selectBodyId$ = new BehaviorSubject<string | null>(null);\n  private readonly _isOpen$ = new BehaviorSubject(false);\n\n  readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  readonly _selectionModel = new SelectionModel<SelectOptionDirective>();\n  private readonly _activeSelectionModel = new ActiveSelectionModel<SelectOptionDirective>();\n\n  @Input()\n  get multiple(): boolean {\n    return this._multiple$.value;\n  }\n  set multiple(value: unknown) {\n    this._multiple$.next(booleanAttribute(value));\n\n    this._migrateSelectValue();\n  }\n  private _multiple$ = new BehaviorSubject(false);\n\n  @Input()\n  emptyText?: string;\n\n  @ContentChildren(SELECT_OPTION_TOKEN, { descendants: true })\n  private set _selectOptionsQueryList(value: TypedQueryList<SelectOptionDirective>) {\n    this._selectOptionsQueryList$.next(value);\n  }\n  private readonly _selectOptionsQueryList$ = new BehaviorSubject<TypedQueryList<SelectOptionDirective> | null>(null);\n\n  readonly selectOptions$ = this._selectOptionsQueryList$.pipe(\n    switchQueryListChanges(),\n    switchMap((queryList) => {\n      if (!queryList) return of(null);\n\n      const items = queryList.map((opt) =>\n        combineLatest([opt.isSelected$, opt.isActive$]).pipe(map(([selected, active]) => ({ opt, selected, active }))),\n      );\n\n      return combineLatest(items ?? of(null));\n    }),\n  );\n\n  readonly activeOption$ = this.selectOptions$.pipe(\n    map((options) => {\n      if (!options) return null;\n\n      return options.find((option) => option.active) ?? null;\n    }),\n  );\n\n  readonly selectedOptions$ = this.selectOptions$.pipe(\n    map((options) => {\n      if (!options) return null;\n\n      const selectedOptions = options.filter((option) => option.selected);\n\n      if (!selectedOptions.length) return null;\n\n      const inputValue = this.input.value;\n\n      if (this.multiple && Array.isArray(inputValue)) {\n        // sort selected options by the order of the input value\n        const selectedOptionsMap = new Map(selectedOptions.map((option) => [option.opt.value, option]));\n        return inputValue\n          .map((value) => selectedOptionsMap.get(value))\n          .filter(\n            (\n              option,\n            ): option is {\n              opt: SelectOptionDirective;\n              selected: boolean;\n              active: boolean;\n            } => !!option,\n          );\n      }\n\n      return selectedOptions;\n    }),\n  );\n\n  readonly selectedOption$ = this.selectedOptions$.pipe(map((options) => options?.[0] ?? null));\n\n  readonly selectBodyId$ = this._selectBodyId$.asObservable();\n  readonly isOpen$ = this._isOpen$.asObservable();\n  readonly isOpen = toSignal(this.isOpen$);\n  readonly multiple$ = this._multiple$.asObservable();\n\n  readonly selectCurrentValueId = `et-select-current-value-${uniqueId++}`;\n\n  readonly ariaViewValue$ = this.selectedOptions$.pipe(\n    switchMap((options) => {\n      if (!options?.length) return of(null);\n\n      const viewValues = options.map((option) => option.opt.viewValue$);\n\n      return combineLatest(viewValues);\n    }),\n    map((viewValues) => {\n      if (!viewValues) return null;\n\n      return viewValues.join(', ');\n    }),\n  );\n\n  readonly activeDescendant$ = combineLatest([this.isOpen$, this.activeOption$]).pipe(\n    map(([isOpen, activeOption]) => {\n      if (!isOpen || !activeOption) return null;\n\n      return activeOption.opt.id;\n    }),\n  );\n\n  readonly owns$ = combineLatest([this.isOpen$, this.selectBodyId$]).pipe(\n    map(([isOpen, selectBodyId]) => {\n      if (!isOpen || !selectBodyId) {\n        return null;\n      }\n\n      return selectBodyId;\n    }),\n  );\n\n  readonly labelledBy$ = this.input.labelId$.pipe(\n    map((labelId) => {\n      const ids = [labelId, this.selectCurrentValueId];\n\n      return ids.filter((id) => !!id).join(' ');\n    }),\n  );\n\n  readonly hostClassBindings = signalHostClasses({\n    'et-select--is-open': this.isOpen,\n    'et-select--disabled': toSignal(this.input.disabled$),\n  });\n\n  readonly fieldHostClassBindings = signalClasses(this._selectField.elementRef, {\n    'et-select-field--open': this.isOpen,\n    'et-select-field--multiple': toSignal(this.multiple$),\n  });\n\n  constructor() {\n    this._animatedOverlay.placement = 'bottom';\n    this._animatedOverlay.fallbackPlacements = ['bottom', 'top'];\n    this._animatedOverlay.autoResize = true;\n\n    this.input._setEmptyHelper(this.ariaViewValue$);\n\n    this._selectionModel\n      .setOptionsFromQueryList$(this._selectOptionsQueryList$)\n      .setLabelBinding((v) => v.viewValue)\n      .setValueBinding((v) => v.value)\n      .setDisabledBinding((v) => v.disabled);\n\n    this._activeSelectionModel.setSelectionModel(this._selectionModel);\n\n    //TODO: TO BE CONTINUED...\n  }\n\n  ngOnInit(): void {\n    this._unmountSelectBodyOnDisable();\n    this._migrateSelectValue();\n  }\n\n  ngAfterContentInit(): void {\n    this._setSelectedOptionActive();\n  }\n\n  trackByFn: TrackByFunction<SelectOptionDirective> = (_, item) => item.id;\n\n  mountSelectBody() {\n    if (!this._selectBodyConfig) return;\n\n    if (this._animatedOverlay.isMounted || this.input.disabled) return;\n\n    this._setSelectedOptionActive();\n\n    const instance = this._animatedOverlay.mount({\n      component: this._selectBodyConfig.component,\n      mirrorWidth: true,\n      themeProvider: this._themeProvider,\n      data: { _bodyTemplate: this._selectBodyConfig.template } as Partial<T>,\n    });\n\n    if (!instance) return;\n\n    this._selectBodyId$.next(instance.selectBody.id);\n    this._isOpen$.next(true);\n  }\n\n  unmountSelectBody() {\n    if (!this._animatedOverlay.isMounted) return;\n\n    this._animatedOverlay.unmount();\n\n    this._selectBodyId$.next(null);\n    this._isOpen$.next(false);\n  }\n\n  setValue(value: unknown) {\n    this.input._updateValue(value);\n\n    this.input._markAsTouched();\n    this.input._setShouldDisplayError(true);\n  }\n\n  handleKeyDown(event: KeyboardEvent) {\n    if (this._isOpen$.value) {\n      this._handleKeyDownInOpenState(event);\n    } else {\n      this._handleKeyDownInClosedState(event);\n    }\n  }\n\n  setSelectBody(config: SelectBodyConfig<T>) {\n    this._selectBodyConfig = config;\n  }\n\n  removeOptionFromSelection(option: SelectOptionDirective) {\n    if (!this.multiple || !Array.isArray(this.input.value)) return;\n\n    const value = this.input.value.filter((v) => v !== option.value);\n\n    this.setValue(value);\n  }\n\n  _controlTouched() {\n    this.input._markAsTouched();\n    this.input._setShouldDisplayError(true);\n  }\n\n  private _unmountSelectBodyOnDisable() {\n    this.input.disabled$\n      .pipe(\n        tap((disabled) => {\n          if (!disabled) return;\n\n          this.unmountSelectBody();\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n  }\n\n  private _handleKeyDownInClosedState(event: KeyboardEvent) {\n    const keyCode = event.keyCode;\n    const isArrowKey =\n      keyCode === DOWN_ARROW || keyCode === UP_ARROW || keyCode === LEFT_ARROW || keyCode === RIGHT_ARROW;\n\n    const isOpenKey = keyCode === ENTER || keyCode === SPACE;\n\n    if ((isOpenKey && !hasModifierKey(event)) || ((this.multiple || event.altKey) && isArrowKey)) {\n      event.preventDefault();\n      this.mountSelectBody();\n    } else if (!this.multiple) {\n      switch (keyCode) {\n        case DOWN_ARROW:\n          this._selectOptionByOffset(1, true);\n          break;\n        case UP_ARROW:\n          this._selectOptionByOffset(-1, true);\n          break;\n        case HOME:\n          this._selectFirstOption(true);\n          break;\n        case END:\n          this._selectLastOption(true);\n          break;\n        case PAGE_UP:\n          this._selectOptionByOffset(-10, true);\n          break;\n        case PAGE_DOWN:\n          this._selectOptionByOffset(10, true);\n          break;\n      }\n    } else if (this.multiple && isArrowKey) {\n      event.preventDefault();\n      this.mountSelectBody();\n    }\n  }\n\n  private async _handleKeyDownInOpenState(event: KeyboardEvent) {\n    const keyCode = event.keyCode;\n    const isArrowKey = keyCode === DOWN_ARROW || keyCode === UP_ARROW;\n\n    if (isArrowKey && event.altKey) {\n      event.preventDefault();\n      this.unmountSelectBody();\n    } else if (keyCode === ESCAPE && !hasModifierKey(event)) {\n      event.preventDefault();\n      event.stopPropagation();\n      this.unmountSelectBody();\n    } else if (keyCode === ENTER || keyCode === SPACE) {\n      if (this.multiple) {\n        this._toggleActiveOptionSelection();\n      } else {\n        this._setActiveOptionSelected();\n      }\n\n      event.preventDefault();\n    } else if (this.multiple && keyCode === A && event.ctrlKey) {\n      event.preventDefault();\n      this._toggleSelectionOfAllOptions();\n    } else {\n      switch (keyCode) {\n        case DOWN_ARROW:\n          this._activateOptionByOffset(1);\n          break;\n        case UP_ARROW:\n          this._activateOptionByOffset(-1);\n          break;\n        case HOME:\n          this._activateFirstOption();\n          break;\n        case END:\n          this._activateLastOption();\n          break;\n        case PAGE_UP:\n          this._activateOptionByOffset(-10);\n          break;\n        case PAGE_DOWN:\n          this._activateOptionByOffset(10);\n          break;\n      }\n    }\n  }\n\n  async _setActiveOption(option: SelectOptionDirective | null) {\n    const currentActiveOption = await firstValueFrom(this.activeOption$);\n\n    if (currentActiveOption?.opt === option) return false;\n\n    currentActiveOption?.opt._setActive(false);\n\n    if (option) {\n      option._setActive(true);\n    }\n\n    return true;\n  }\n\n  private async _addActiveOptionToSelection() {\n    const activeOption = await firstValueFrom(this.activeOption$);\n\n    if (!activeOption || activeOption.opt.disabled || activeOption.selected) return;\n\n    if (!Array.isArray(this.input.value)) {\n      this.setValue([activeOption.opt.value]);\n      return;\n    }\n\n    this.setValue([...this.input.value, activeOption.opt.value]);\n  }\n\n  private async _removeActiveOptionFromSelection() {\n    const activeOption = await firstValueFrom(this.activeOption$);\n\n    if (!activeOption || activeOption.opt.disabled || !activeOption.selected) return;\n\n    if (!Array.isArray(this.input.value)) {\n      this.setValue([]);\n      return;\n    }\n\n    this.setValue(this.input.value.filter((value) => value !== activeOption.opt.value));\n  }\n\n  private async _toggleSelectionOfAllOptions() {\n    const allOptions = await firstValueFrom(this.selectOptions$);\n\n    const hasDeselectedOption = allOptions?.some((opt) => !opt.opt.disabled && !opt.selected);\n\n    if (hasDeselectedOption) {\n      this._selectAllOptions();\n    } else {\n      this._deselectAllOptions();\n    }\n  }\n\n  private async _selectAllOptions() {\n    const allOptions = await firstValueFrom(this.selectOptions$);\n\n    if (!allOptions) return;\n\n    const selectedOptions = allOptions.filter((opt) => !opt.opt.disabled).map((opt) => opt.opt.value);\n\n    this.setValue(selectedOptions);\n  }\n\n  private async _deselectAllOptions() {\n    this.setValue([]);\n  }\n\n  private async _toggleActiveOptionSelection() {\n    const activeOption = await firstValueFrom(this.activeOption$);\n\n    if (!activeOption) return;\n\n    if (activeOption.selected) {\n      this._removeActiveOptionFromSelection();\n    } else {\n      this._addActiveOptionToSelection();\n    }\n  }\n\n  private async _setActiveOptionSelected() {\n    const activeOption = await firstValueFrom(this.activeOption$);\n\n    if (!activeOption || activeOption.opt.disabled) return;\n\n    this._setSelectedOption(activeOption.opt);\n\n    this.unmountSelectBody();\n  }\n\n  private async _setSelectedOptionActive() {\n    const selectedOption = await firstValueFrom(this.selectedOption$);\n\n    if (!selectedOption) return;\n\n    this._setActiveOption(selectedOption.opt);\n  }\n\n  private async _setSelectedOption(option: SelectOptionDirective | null) {\n    const selectedOption = await firstValueFrom(this.selectedOption$);\n\n    if (selectedOption === option) return false;\n\n    this._setActiveOption(option);\n\n    this.setValue(option?.value ?? null);\n\n    return true;\n  }\n\n  private async _selectFirstOption(announce: boolean) {\n    const options = await firstValueFrom(this.selectOptions$);\n\n    if (!options) return;\n\n    const firstOption = options[0]?.opt;\n\n    if (!firstOption) return;\n\n    if (!this._setSelectedOption(firstOption)) return;\n\n    if (announce) {\n      const text = await firstValueFrom(firstOption.viewValue$);\n      this._liveAnnouncer.announce(text, 10000);\n    }\n  }\n\n  private async _selectLastOption(announce: boolean) {\n    const options = await firstValueFrom(this.selectOptions$);\n\n    if (!options) return;\n\n    const lastOption = options[options.length - 1]?.opt;\n\n    if (!lastOption) return;\n\n    if (!this._setSelectedOption(lastOption)) return;\n\n    if (announce) {\n      const text = await firstValueFrom(lastOption.viewValue$);\n      this._liveAnnouncer.announce(text, 10000);\n    }\n  }\n\n  private async _selectOptionByOffset(offset: number, announce: boolean): Promise<void> {\n    const options = await firstValueFrom(this.selectOptions$);\n\n    if (!options) return;\n\n    const selectedOption = await firstValueFrom(this.selectedOption$);\n    const selectedOptionIndex = options.findIndex((o) => o.opt === selectedOption?.opt);\n    const nextOptionIndex = selectedOptionIndex + offset;\n    const nextOption = options[nextOptionIndex];\n\n    if (!nextOption) return;\n\n    if (nextOption.opt.disabled) {\n      return this._selectOptionByOffset(offset + (offset < 0 ? -1 : 1), announce);\n    }\n\n    if (!this._setSelectedOption(nextOption.opt)) return;\n\n    if (announce) {\n      const text = await firstValueFrom(nextOption.opt.viewValue$);\n      this._liveAnnouncer.announce(text, 10000);\n    }\n  }\n\n  private async _activateFirstOption() {\n    const options = await firstValueFrom(this.selectOptions$);\n\n    if (!options) return;\n\n    const firstOption = options[0]?.opt;\n\n    if (!firstOption) return;\n\n    await this._setActiveOption(firstOption);\n  }\n\n  private async _activateLastOption() {\n    const options = await firstValueFrom(this.selectOptions$);\n\n    if (!options) return;\n\n    const lastOption = options[options.length - 1]?.opt;\n\n    if (!lastOption) return;\n\n    await this._setActiveOption(lastOption);\n  }\n\n  private async _activateOptionByOffset(offset: number) {\n    const options = await firstValueFrom(this.selectOptions$);\n\n    if (!options) return;\n\n    const activatedOption = await firstValueFrom(this.activeOption$);\n    const activatedOptionIndex = options.findIndex((o) => o.opt === activatedOption?.opt);\n    const nextOptionIndex = activatedOptionIndex + offset;\n    const nextOption = options[nextOptionIndex];\n\n    if (!nextOption) return;\n\n    await this._setActiveOption(nextOption.opt);\n  }\n\n  private async _migrateSelectValue() {\n    if (this.multiple && !Array.isArray(this.input.value)) {\n      this.setValue([]);\n    } else if (!this.multiple && Array.isArray(this.input.value)) {\n      this.setValue(null);\n    }\n\n    this._setActiveOption(null);\n  }\n}\n"]}
|
|
299
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.directive.js","sourceRoot":"","sources":["../../../../../../../../../../../../../libs/cdk/src/lib/components/forms/components/select/components/select/directives/select/select.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { A, BACKSPACE, DOWN_ARROW, ENTER, ESCAPE, SPACE, TAB, UP_ARROW, hasModifierKey } from '@angular/cdk/keycodes';\nimport { ComponentType } from '@angular/cdk/portal';\nimport {\n  ContentChildren,\n  Directive,\n  ElementRef,\n  InjectionToken,\n  Input,\n  OnInit,\n  TemplateRef,\n  TrackByFunction,\n  ViewChild,\n  booleanAttribute,\n  inject,\n} from '@angular/core';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport {\n  ActiveSelectionModel,\n  AnimatedOverlayComponentBase,\n  AnimatedOverlayDirective,\n  SelectionModel,\n  TypedQueryList,\n  createDestroy,\n  scrollToElement,\n  signalClasses,\n  signalHostClasses,\n} from '@ethlete/core';\nimport { THEME_PROVIDER } from '@ethlete/theming';\nimport { BehaviorSubject, combineLatest, debounceTime, map, of, switchMap, takeUntil, tap } from 'rxjs';\nimport { OverlayCloseBlockerDirective } from '../../../../../../../overlay';\nimport { INPUT_TOKEN } from '../../../../../../directives';\nimport { SELECT_FIELD_TOKEN } from '../../../../directives';\nimport { SelectKeyHandlerResult } from '../../private';\nimport { SelectBodyDirective } from '../select-body';\nimport { SELECT_OPTION_TOKEN, SelectOptionDirective } from '../select-option';\n\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nexport const SELECT_TOKEN = new InjectionToken<SelectDirective<any>>('ET_SELECT_INPUT_TOKEN');\n\ntype SelectDirectiveBodyComponentBase = AnimatedOverlayComponentBase & {\n  _bodyTemplate: TemplateRef<unknown> | null;\n  _containerElementRef: ElementRef<HTMLElement> | null | undefined;\n  selectBody: SelectBodyDirective;\n};\n\nlet uniqueId = 0;\n\ninterface SelectBodyConfig<T extends SelectDirectiveBodyComponentBase> {\n  component: ComponentType<T>;\n  template: TemplateRef<unknown>;\n}\n\n@Directive({\n  standalone: true,\n  hostDirectives: [AnimatedOverlayDirective, OverlayCloseBlockerDirective],\n  providers: [\n    {\n      provide: SELECT_TOKEN,\n      useExisting: SelectDirective,\n    },\n  ],\n})\nexport class SelectDirective<T extends SelectDirectiveBodyComponentBase> implements OnInit {\n  private _selectBodyConfig: SelectBodyConfig<T> | null = null;\n\n  private readonly _animatedOverlay = inject<AnimatedOverlayDirective<T>>(AnimatedOverlayDirective);\n  private readonly _destroy$ = createDestroy();\n  private readonly _selectField = inject(SELECT_FIELD_TOKEN);\n  private readonly _themeProvider = inject(THEME_PROVIDER, { optional: true });\n\n  readonly input = inject(INPUT_TOKEN);\n\n  private readonly _selectBodyId$ = new BehaviorSubject<string | null>(null);\n  private readonly _isOpen$ = new BehaviorSubject(false);\n\n  readonly elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  readonly _selectionModel = new SelectionModel<SelectOptionDirective>();\n  readonly _activeSelectionModel = new ActiveSelectionModel<SelectOptionDirective>();\n\n  @Input()\n  set multiple(value: unknown) {\n    this._selectionModel.setAllowMultiple(booleanAttribute(value));\n  }\n\n  @Input()\n  emptyText?: string;\n\n  @ContentChildren(SELECT_OPTION_TOKEN, { descendants: true })\n  private set _selectOptionsQueryList(value: TypedQueryList<SelectOptionDirective>) {\n    this._selectOptionsQueryList$.next(value);\n  }\n  private readonly _selectOptionsQueryList$ = new BehaviorSubject<TypedQueryList<SelectOptionDirective> | null>(null);\n\n  readonly selectBodyId$ = this._selectBodyId$.asObservable();\n  readonly isOpen$ = this._isOpen$.asObservable();\n  readonly isOpen = toSignal(this.isOpen$);\n  readonly multiple$ = this._selectionModel.allowMultiple$;\n\n  readonly selectCurrentValueId = `et-select-current-value-${uniqueId++}`;\n\n  readonly ariaViewValue$ = this._selectionModel.selection$.pipe(\n    switchMap((options) => {\n      if (!options?.length) return of(null);\n\n      const viewValues = options.map((option) => option.viewValue$);\n\n      return combineLatest(viewValues);\n    }),\n    map((viewValues) => {\n      if (!viewValues) return null;\n\n      return viewValues.join(', ');\n    }),\n  );\n\n  readonly ariaViewValue = toSignal(this.ariaViewValue$);\n\n  readonly activeDescendant$ = combineLatest([this.isOpen$, this._activeSelectionModel.activeOption$]).pipe(\n    map(([isOpen, activeOption]) => {\n      if (!isOpen || !activeOption) return null;\n\n      return activeOption.id;\n    }),\n  );\n\n  readonly owns$ = combineLatest([this.isOpen$, this.selectBodyId$]).pipe(\n    map(([isOpen, selectBodyId]) => {\n      if (!isOpen || !selectBodyId) {\n        return null;\n      }\n\n      return selectBodyId;\n    }),\n  );\n\n  readonly labelledBy$ = this.input.labelId$.pipe(\n    map((labelId) => {\n      const ids = [labelId, this.selectCurrentValueId];\n\n      return ids.filter((id) => !!id).join(' ');\n    }),\n  );\n\n  readonly hostClassBindings = signalHostClasses({\n    'et-select--is-open': this.isOpen,\n    'et-select--disabled': toSignal(this.input.disabled$),\n  });\n\n  readonly fieldHostClassBindings = signalClasses(this._selectField.elementRef, {\n    'et-select-field--open': this.isOpen,\n    'et-select-field--multiple': toSignal(this.multiple$),\n  });\n\n  @ViewChild('inputElement')\n  inputElement: ElementRef<HTMLElement> | null = null;\n\n  constructor() {\n    this._animatedOverlay.placement = 'bottom';\n    this._animatedOverlay.fallbackPlacements = ['bottom', 'top'];\n    this._animatedOverlay.autoResize = true;\n\n    this.input._setEmptyHelper(this.ariaViewValue$);\n\n    this._selectionModel\n      .setOptionsFromQueryList$(this._selectOptionsQueryList$)\n      .setLabelBinding((v) => v.viewValue)\n      .setValueBinding((v) => v.value)\n      .setDisabledBinding((v) => v.disabled);\n\n    this._activeSelectionModel.setSelectionModel(this._selectionModel);\n  }\n\n  ngOnInit(): void {\n    this._closeBodyOnDisable();\n\n    this._selectionModel.setSelectionFromValue$(this.input.value);\n\n    this._selectionModel.value$\n      .pipe(\n        takeUntil(this._destroy$),\n        tap((value) => this.input._updateValue(value)),\n      )\n      .subscribe();\n\n    this.input.onExternalUpdate$\n      .pipe(\n        takeUntil(this._destroy$),\n        tap(() => this._selectionModel.setSelectionFromValue$(this.input.value)),\n      )\n      .subscribe();\n  }\n\n  trackByFn: TrackByFunction<SelectOptionDirective> = (_, item) => item.id;\n\n  open() {\n    if (!this._selectBodyConfig) return;\n\n    if (this._animatedOverlay.isMounted || this.input.disabled) return;\n\n    const instance = this._animatedOverlay.mount({\n      component: this._selectBodyConfig.component,\n      mirrorWidth: true,\n      themeProvider: this._themeProvider,\n      data: { _bodyTemplate: this._selectBodyConfig.template } as Partial<T>,\n    });\n\n    if (!instance) return;\n\n    this._selectBodyId$.next(instance.selectBody.id);\n    this._isOpen$.next(true);\n\n    this._activeSelectionModel.activeOption$\n      .pipe(\n        debounceTime(0),\n        tap((activeOption) => {\n          if (!activeOption) return;\n\n          scrollToElement({\n            container: instance._containerElementRef?.nativeElement,\n            element: activeOption._elementRef.nativeElement,\n            behavior: 'instant',\n          });\n        }),\n        takeUntil(this._destroy$),\n        takeUntil(this._animatedOverlay.afterClosed()),\n      )\n      .subscribe();\n\n    this._animatedOverlay\n      .afterClosed()\n      .pipe(\n        takeUntil(this._destroy$),\n        tap(() => {\n          this._selectBodyId$.next(null);\n          this._isOpen$.next(false);\n        }),\n      )\n      .subscribe();\n  }\n\n  close() {\n    if (!this._animatedOverlay.isMounted) return;\n\n    this._animatedOverlay.unmount();\n  }\n\n  writeValueFromOption(option: SelectOptionDirective) {\n    this.input._markAsTouched();\n\n    if (this._selectionModel.allowMultiple) {\n      this._selectionModel.toggleSelectedOption(option);\n    } else {\n      this._selectionModel.addSelectedOption(option);\n    }\n\n    if (!this._selectionModel.allowMultiple) {\n      this.close();\n    }\n  }\n\n  focus() {\n    this.inputElement?.nativeElement.focus();\n  }\n\n  setSelectBody(config: SelectBodyConfig<T>) {\n    this._selectBodyConfig = config;\n  }\n\n  removeOptionFromSelection(option: SelectOptionDirective) {\n    this._selectionModel.removeSelectedOption(option);\n  }\n\n  _controlTouched() {\n    this.input._markAsTouched();\n    this.input._setShouldDisplayError(true);\n  }\n\n  _processKeydownEvent(event: KeyboardEvent) {\n    const keyCode = event.keyCode;\n    const isOpen = this.isOpen();\n    const isMultiple = this._selectionModel.allowMultiple;\n    const selection = this._selectionModel.selection;\n    const isArrowKey = keyCode === UP_ARROW || keyCode === DOWN_ARROW;\n    const isAltPressed = hasModifierKey(event, 'altKey');\n\n    const result: SelectKeyHandlerResult<SelectOptionDirective> = {};\n\n    if (isArrowKey && isAltPressed && !isOpen) {\n      result.overlayOperation = 'open';\n      return this._interpretKeyHandlerResult(result);\n    }\n\n    if (keyCode === ENTER) {\n      event.preventDefault();\n      event.stopPropagation();\n\n      const activeOption = this._activeSelectionModel.activeOption;\n\n      if (activeOption && this._selectionModel.isDisabled(activeOption)) return;\n\n      if (activeOption) {\n        if (isMultiple) {\n          result.optionAction = { type: 'toggle', option: activeOption };\n        } else {\n          result.optionAction = { type: 'add', option: activeOption };\n        }\n      }\n\n      if (!isMultiple) {\n        result.overlayOperation = 'close';\n      }\n\n      return this._interpretKeyHandlerResult(result);\n    }\n\n    if (keyCode === ESCAPE) {\n      if (isOpen) {\n        result.overlayOperation = 'close';\n        event.preventDefault();\n        event.stopPropagation();\n      }\n\n      return this._interpretKeyHandlerResult(result);\n    }\n\n    if (keyCode === TAB) {\n      result.overlayOperation = 'close';\n      return this._interpretKeyHandlerResult(result);\n    }\n\n    if (keyCode === BACKSPACE) {\n      const lastSelectedOption = selection[selection.length - 1];\n\n      if (isMultiple && lastSelectedOption) {\n        result.optionAction = { type: 'remove', option: lastSelectedOption };\n        return this._interpretKeyHandlerResult(result);\n      }\n    }\n\n    if (keyCode === SPACE) {\n      result.overlayOperation = 'open';\n\n      return this._interpretKeyHandlerResult(result);\n    }\n\n    const newActiveOption = this._activeSelectionModel.evaluateKeyboardEvent(event, { skipDisabled: !isOpen });\n\n    if (newActiveOption && !isOpen && !isMultiple) {\n      result.optionAction = { type: 'add', option: newActiveOption };\n    }\n\n    if (keyCode === A && event.ctrlKey && isMultiple) {\n      result.optionAction = 'toggleAll';\n      event.preventDefault();\n    }\n\n    return this._interpretKeyHandlerResult(result);\n  }\n\n  private _interpretKeyHandlerResult(result: SelectKeyHandlerResult<SelectOptionDirective>) {\n    if (result.overlayOperation === 'close') {\n      this.close();\n    } else if (result.overlayOperation === 'open') {\n      this.open();\n    }\n\n    if (result.optionAction) {\n      if (typeof result.optionAction === 'string') {\n        if (result.optionAction === 'clear') {\n          this._selectionModel.clearSelectedOptions();\n        } else if (result.optionAction === 'toggleAll') {\n          this._selectionModel.toggleAllSelectedOptions();\n        }\n      } else {\n        const { type, option } = result.optionAction;\n\n        if (this._selectionModel.isDisabled(option)) return;\n\n        if (type === 'add') {\n          this._selectionModel.addSelectedOption(option);\n        }\n\n        if (type === 'remove') {\n          this._selectionModel.removeSelectedOption(option);\n        }\n\n        if (type === 'toggle') {\n          this._selectionModel.toggleSelectedOption(option);\n        }\n      }\n    }\n  }\n\n  private _closeBodyOnDisable() {\n    this.input.disabled$\n      .pipe(\n        tap((disabled) => {\n          if (!disabled) return;\n\n          this.close();\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n  }\n}\n"]}
|