@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.
Files changed (56) hide show
  1. package/CHANGELOG.md +22 -0
  2. package/esm2022/lib/components/forms/components/select/components/combobox/components/combobox/combobox.component.mjs +9 -5
  3. package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox/combobox.directive.mjs +33 -7
  4. package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-body/combobox-body.component.mjs +3 -3
  5. package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-option/combobox-option.component.mjs +3 -4
  6. package/esm2022/lib/components/forms/components/select/components/combobox/private/combobox.private.types.mjs +1 -1
  7. package/esm2022/lib/components/forms/components/select/components/combobox/utils/public-api.mjs +1 -2
  8. package/esm2022/lib/components/forms/components/select/components/select/components/select/select.component.mjs +3 -3
  9. package/esm2022/lib/components/forms/components/select/components/select/directives/select/select.directive.mjs +144 -312
  10. package/esm2022/lib/components/forms/components/select/components/select/directives/select-body/select-body.directive.mjs +4 -3
  11. package/esm2022/lib/components/forms/components/select/components/select/directives/select-option/select-option.directive.mjs +15 -40
  12. package/esm2022/lib/components/forms/components/select/components/select/partials/select-body/select-body.component.mjs +8 -5
  13. package/esm2022/lib/components/forms/components/select/components/{combobox/utils → select/private}/index.mjs +2 -2
  14. package/esm2022/lib/components/forms/components/select/components/select/private/select.private.types.mjs +2 -0
  15. package/esm2022/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-container-base/bottom-sheet-container-base.component.mjs +4 -4
  16. package/esm2022/lib/components/overlay/components/dialog/partials/dialog-container-base/dialog-container-base.component.mjs +4 -4
  17. package/esm2022/lib/components/overlay/components/overlay/components/overlay-container/overlay-container.component.mjs +6 -4
  18. package/esm2022/lib/components/overlay/components/overlay/services/overlay.service.mjs +10 -3
  19. package/esm2022/lib/components/overlay/components/overlay/utils/overlay-ref.mjs +35 -6
  20. package/esm2022/lib/components/overlay/components/toggletip/directives/toggletip/toggletip.directive.mjs +5 -3
  21. package/esm2022/lib/components/overlay/components/tooltip/directives/tooltip/tooltip.directive.mjs +5 -3
  22. package/esm2022/lib/components/overlay/directives/overlay-close-auto-blocker/index.mjs +2 -0
  23. package/esm2022/lib/components/overlay/directives/overlay-close-auto-blocker/overlay-close-auto-blocker.directive.mjs +51 -0
  24. package/esm2022/lib/components/overlay/directives/overlay-close-auto-blocker/public-api.mjs +2 -0
  25. package/esm2022/lib/components/overlay/directives/public-api.mjs +2 -1
  26. package/esm2022/lib/components/overlay/public-api.mjs +2 -1
  27. package/esm2022/lib/components/overlay/utils/overlay-dismiss-checker.util.mjs +79 -0
  28. package/esm2022/lib/components/overlay/utils/public-api.mjs +2 -0
  29. package/fesm2022/ethlete-cdk.mjs +397 -409
  30. package/fesm2022/ethlete-cdk.mjs.map +1 -1
  31. package/lib/components/forms/components/select/components/combobox/components/combobox/combobox.component.d.ts +4 -3
  32. package/lib/components/forms/components/select/components/combobox/directives/combobox/combobox.directive.d.ts +4 -1
  33. package/lib/components/forms/components/select/components/combobox/private/combobox.private.types.d.ts +1 -1
  34. package/lib/components/forms/components/select/components/combobox/utils/public-api.d.ts +0 -1
  35. package/lib/components/forms/components/select/components/select/directives/select/select.directive.d.ts +16 -53
  36. package/lib/components/forms/components/select/components/select/directives/select-body/select-body.directive.d.ts +2 -1
  37. package/lib/components/forms/components/select/components/select/directives/select-option/select-option.directive.d.ts +7 -9
  38. package/lib/components/forms/components/select/components/select/partials/select-body/select-body.component.d.ts +2 -1
  39. package/lib/components/forms/components/select/components/select/private/index.d.ts +1 -0
  40. package/lib/components/forms/components/select/components/select/private/select.private.types.d.ts +13 -0
  41. package/lib/components/overlay/components/bottom-sheet/partials/bottom-sheet-container-base/bottom-sheet-container-base.component.d.ts +1 -1
  42. package/lib/components/overlay/components/dialog/partials/dialog-container-base/dialog-container-base.component.d.ts +1 -1
  43. package/lib/components/overlay/components/overlay/components/overlay-container/overlay-container.component.d.ts +5 -3
  44. package/lib/components/overlay/components/overlay/utils/overlay-ref.d.ts +12 -3
  45. package/lib/components/overlay/components/toggletip/directives/toggletip/toggletip.directive.d.ts +2 -1
  46. package/lib/components/overlay/components/tooltip/directives/tooltip/tooltip.directive.d.ts +2 -1
  47. package/lib/components/overlay/directives/overlay-close-auto-blocker/overlay-close-auto-blocker.directive.d.ts +12 -0
  48. package/lib/components/overlay/directives/overlay-close-auto-blocker/public-api.d.ts +1 -0
  49. package/lib/components/overlay/directives/public-api.d.ts +1 -0
  50. package/lib/components/overlay/public-api.d.ts +1 -0
  51. package/lib/components/overlay/utils/overlay-dismiss-checker.util.d.ts +60 -0
  52. package/lib/components/overlay/utils/public-api.d.ts +1 -0
  53. package/package.json +2 -2
  54. package/esm2022/lib/components/forms/components/select/components/combobox/utils/option.utils.mjs +0 -7
  55. package/lib/components/forms/components/select/components/combobox/utils/option.utils.d.ts +0 -1
  56. /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 { LiveAnnouncer } from '@angular/cdk/a11y';
2
- import { A, DOWN_ARROW, END, ENTER, ESCAPE, HOME, LEFT_ARROW, PAGE_DOWN, PAGE_UP, RIGHT_ARROW, SPACE, UP_ARROW, hasModifierKey, } from '@angular/cdk/keycodes';
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, switchQueryListChanges, } from '@ethlete/core';
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, firstValueFrom, map, of, switchMap, takeUntil, tap } from 'rxjs';
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._multiple$.next(booleanAttribute(value));
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._multiple$.asObservable();
40
+ this.multiple$ = this._selectionModel.allowMultiple$;
74
41
  this.selectCurrentValueId = `et-select-current-value-${uniqueId++}`;
75
- this.ariaViewValue$ = this.selectedOptions$.pipe(switchMap((options) => {
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.opt.viewValue$);
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.activeDescendant$ = combineLatest([this.isOpen$, this.activeOption$]).pipe(map(([isOpen, activeOption]) => {
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.opt.id;
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._unmountSelectBodyOnDisable();
123
- this._migrateSelectValue();
124
- }
125
- ngAfterContentInit() {
126
- this._setSelectedOptionActive();
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
- mountSelectBody() {
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
- unmountSelectBody() {
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
- setValue(value) {
153
- this.input._updateValue(value);
138
+ writeValueFromOption(option) {
154
139
  this.input._markAsTouched();
155
- this.input._setShouldDisplayError(true);
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._handleKeyDownInClosedState(event);
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
- if (!this.multiple || !Array.isArray(this.input.value))
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
- _unmountSelectBodyOnDisable() {
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 isArrowKey = keyCode === DOWN_ARROW || keyCode === UP_ARROW || keyCode === LEFT_ARROW || keyCode === RIGHT_ARROW;
190
- const isOpenKey = keyCode === ENTER || keyCode === SPACE;
191
- if ((isOpenKey && !hasModifierKey(event)) || ((this.multiple || event.altKey) && isArrowKey)) {
192
- event.preventDefault();
193
- this.mountSelectBody();
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
- else if (!this.multiple) {
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.unmountSelectBody();
233
- }
234
- else if (keyCode === ENTER || keyCode === SPACE) {
235
- if (this.multiple) {
236
- this._toggleActiveOptionSelection();
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
- else {
239
- this._setActiveOptionSelected();
189
+ if (!isMultiple) {
190
+ result.overlayOperation = 'close';
240
191
  }
241
- event.preventDefault();
242
- }
243
- else if (this.multiple && keyCode === A && event.ctrlKey) {
244
- event.preventDefault();
245
- this._toggleSelectionOfAllOptions();
192
+ return this._interpretKeyHandlerResult(result);
246
193
  }
247
- else {
248
- switch (keyCode) {
249
- case DOWN_ARROW:
250
- this._activateOptionByOffset(1);
251
- break;
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
- async _setActiveOption(option) {
271
- const currentActiveOption = await firstValueFrom(this.activeOption$);
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
- this.setValue([...this.input.value, activeOption.opt.value]);
289
- }
290
- async _removeActiveOptionFromSelection() {
291
- const activeOption = await firstValueFrom(this.activeOption$);
292
- if (!activeOption || activeOption.opt.disabled || !activeOption.selected)
293
- return;
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
- this.setValue(this.input.value.filter((value) => value !== activeOption.opt.value));
299
- }
300
- async _toggleSelectionOfAllOptions() {
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
- else {
307
- this._deselectAllOptions();
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
- async _selectAllOptions() {
311
- const allOptions = await firstValueFrom(this.selectOptions$);
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
- async _setActiveOptionSelected() {
332
- const activeOption = await firstValueFrom(this.activeOption$);
333
- if (!activeOption || activeOption.opt.disabled)
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
- async _selectLastOption(announce) {
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
- async _selectOptionByOffset(offset, announce) {
381
- const options = await firstValueFrom(this.selectOptions$);
382
- if (!options)
383
- return;
384
- const selectedOption = await firstValueFrom(this.selectedOption$);
385
- const selectedOptionIndex = options.findIndex((o) => o.opt === selectedOption?.opt);
386
- const nextOptionIndex = selectedOptionIndex + offset;
387
- const nextOption = options[nextOptionIndex];
388
- if (!nextOption)
389
- return;
390
- if (nextOption.opt.disabled) {
391
- return this._selectOptionByOffset(offset + (offset < 0 ? -1 : 1), announce);
392
- }
393
- if (!this._setSelectedOption(nextOption.opt))
394
- return;
395
- if (announce) {
396
- const text = await firstValueFrom(nextOption.opt.viewValue$);
397
- this._liveAnnouncer.announce(text, 10000);
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
- async _activateFirstOption() {
401
- const options = await firstValueFrom(this.selectOptions$);
402
- if (!options)
403
- return;
404
- const firstOption = options[0]?.opt;
405
- if (!firstOption)
406
- return;
407
- await this._setActiveOption(firstOption);
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"]}