@ethlete/cdk 3.3.1 → 3.4.0
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 +10 -0
- package/esm2022/lib/components/button/components/query-button/query-button.component.mjs +4 -4
- package/esm2022/lib/components/button/directives/query-button/query-button.directive.mjs +37 -7
- package/esm2022/lib/components/forms/components/select/components/combobox/components/combobox/combobox.component.mjs +33 -470
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox/combobox.directive.mjs +466 -8
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-option-template/index.mjs +2 -0
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-selected-option-template/index.mjs +2 -0
- package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-body/combobox-body.component.mjs +2 -2
- package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-option/combobox-option.component.mjs +2 -2
- package/esm2022/lib/components/forms/components/selection-list/directives/selection-list-option/selection-list-option.directive.mjs +1 -2
- package/fesm2022/ethlete-cdk.mjs +243 -197
- package/fesm2022/ethlete-cdk.mjs.map +1 -1
- package/lib/components/button/components/query-button/query-button.component.d.ts +1 -1
- package/lib/components/button/directives/query-button/query-button.directive.d.ts +13 -1
- package/lib/components/forms/components/select/components/combobox/components/combobox/combobox.component.d.ts +7 -71
- package/lib/components/forms/components/select/components/combobox/directives/combobox/combobox.directive.d.ts +76 -4
- package/lib/components/forms/components/select/components/combobox/directives/combobox-option-template/index.d.ts +1 -0
- package/lib/components/forms/components/select/components/combobox/directives/combobox-selected-option-template/index.d.ts +1 -0
- package/lib/components/forms/components/select/components/combobox/partials/combobox-body/combobox-body.component.d.ts +1 -1
- package/lib/components/forms/components/select/components/combobox/partials/combobox-option/combobox-option.component.d.ts +1 -1
- package/package.json +2 -2
|
@@ -1,14 +1,441 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { A, ENTER, ESCAPE, TAB } from '@angular/cdk/keycodes';
|
|
2
|
+
import { ContentChild, Directive, EventEmitter, InjectionToken, Input, Output, TemplateRef, booleanAttribute, inject, isDevMode, } from '@angular/core';
|
|
3
|
+
import { ActiveSelectionModel, AnimatedOverlayDirective, RuntimeError, SelectionModel, createDestroy, createReactiveBindings, } from '@ethlete/core';
|
|
4
|
+
import { BehaviorSubject, catchError, combineLatest, debounceTime, distinctUntilChanged, filter, map, skip, skipWhile, take, takeUntil, tap, throwError, } from 'rxjs';
|
|
5
|
+
import { INPUT_TOKEN } from '../../../../../../directives';
|
|
6
|
+
import { isOptionDisabled } from '../../utils';
|
|
7
|
+
import { COMBOBOX_OPTION_TEMPLATE_TOKEN } from '../combobox-option-template';
|
|
8
|
+
import { COMBOBOX_SELECTED_OPTION_TEMPLATE_TOKEN } from '../combobox-selected-option-template';
|
|
2
9
|
import * as i0 from "@angular/core";
|
|
3
|
-
export const
|
|
10
|
+
export const COMBOBOX_TOKEN = new InjectionToken('ET_COMBOBOX_INPUT_TOKEN');
|
|
11
|
+
const COMBOBOX_ERRORS = {
|
|
12
|
+
1: 'Expected options to be an array of objects. This is due to "bindLabel" and "bindValue" being set.',
|
|
13
|
+
2: 'Expected options to be an array of primitives. This is due to "bindLabel" and "bindValue" not being set or "allowCustomValues" being set to true.',
|
|
14
|
+
};
|
|
15
|
+
const comboboxError = (code, data) => {
|
|
16
|
+
const message = `<et-combobox>: ${COMBOBOX_ERRORS[code]}`;
|
|
17
|
+
throw new RuntimeError(code, message, data);
|
|
18
|
+
};
|
|
19
|
+
const isPrimitiveArray = (value) => {
|
|
20
|
+
if (!Array.isArray(value))
|
|
21
|
+
return false;
|
|
22
|
+
const first = value[0];
|
|
23
|
+
const last = value[value.length - 1];
|
|
24
|
+
if (!first || !last)
|
|
25
|
+
return false;
|
|
26
|
+
return typeof first !== 'object' && typeof last !== 'object';
|
|
27
|
+
};
|
|
28
|
+
const isObjectArray = (value) => {
|
|
29
|
+
if (!Array.isArray(value))
|
|
30
|
+
return false;
|
|
31
|
+
const first = value[0];
|
|
32
|
+
const last = value[value.length - 1];
|
|
33
|
+
if (!first || !last)
|
|
34
|
+
return false;
|
|
35
|
+
return typeof first === 'object' && typeof last === 'object';
|
|
36
|
+
};
|
|
37
|
+
const isEmptyArray = (value) => {
|
|
38
|
+
return Array.isArray(value) && value.length === 0;
|
|
39
|
+
};
|
|
40
|
+
const ComboboxOptionType = {
|
|
41
|
+
Primitive: 'primitive',
|
|
42
|
+
Object: 'object',
|
|
43
|
+
};
|
|
44
|
+
function assetComboboxBodyComponentSet(component) {
|
|
45
|
+
if (!component) {
|
|
46
|
+
throw new RuntimeError(1, 'Combobox body component is not set');
|
|
47
|
+
}
|
|
48
|
+
}
|
|
4
49
|
export class ComboboxDirective {
|
|
50
|
+
//#region Inputs
|
|
51
|
+
get options() {
|
|
52
|
+
return this._selectionModel.getFilteredOptions();
|
|
53
|
+
}
|
|
54
|
+
set options(value) {
|
|
55
|
+
this._selectionModel.setOptions(value);
|
|
56
|
+
}
|
|
57
|
+
set initialValue(value) {
|
|
58
|
+
this._selectionModel.setSelection(value);
|
|
59
|
+
}
|
|
60
|
+
get filterInternal() {
|
|
61
|
+
return this._filterInternal$.value;
|
|
62
|
+
}
|
|
63
|
+
set filterInternal(value) {
|
|
64
|
+
const val = booleanAttribute(value);
|
|
65
|
+
this._filterInternal$.next(val);
|
|
66
|
+
if (!val) {
|
|
67
|
+
this._selectionModel.setFilter('');
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
this._selectionModel.setFilter(this._currentFilter);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
get loading() {
|
|
74
|
+
return this._loading$.value;
|
|
75
|
+
}
|
|
76
|
+
set loading(value) {
|
|
77
|
+
this._loading$.next(booleanAttribute(value));
|
|
78
|
+
}
|
|
79
|
+
get error() {
|
|
80
|
+
return this._error$.value;
|
|
81
|
+
}
|
|
82
|
+
set error(value) {
|
|
83
|
+
this._error$.next(value);
|
|
84
|
+
}
|
|
85
|
+
get placeholder() {
|
|
86
|
+
return this._placeholder$.value;
|
|
87
|
+
}
|
|
88
|
+
set placeholder(value) {
|
|
89
|
+
this._placeholder$.next(value);
|
|
90
|
+
}
|
|
91
|
+
set multiple(value) {
|
|
92
|
+
this._selectionModel.setAllowMultiple(booleanAttribute(value));
|
|
93
|
+
}
|
|
94
|
+
set bindLabel(value) {
|
|
95
|
+
this._selectionModel.setLabelBinding(value);
|
|
96
|
+
}
|
|
97
|
+
set bindValue(value) {
|
|
98
|
+
this._selectionModel.setValueBinding(value);
|
|
99
|
+
}
|
|
100
|
+
get allowCustomValues() {
|
|
101
|
+
return this._allowCustomValues$.value;
|
|
102
|
+
}
|
|
103
|
+
set allowCustomValues(value) {
|
|
104
|
+
this._allowCustomValues$.next(booleanAttribute(value));
|
|
105
|
+
}
|
|
106
|
+
//#endregion
|
|
107
|
+
//#region Members
|
|
108
|
+
get _currentFilter() {
|
|
109
|
+
return this._currentFilter$.value;
|
|
110
|
+
}
|
|
111
|
+
get _isOpen() {
|
|
112
|
+
return this._animatedOverlay.isMounted;
|
|
113
|
+
}
|
|
114
|
+
set optionTemplate(value) {
|
|
115
|
+
this._optionTemplate$.next(value ?? null);
|
|
116
|
+
}
|
|
117
|
+
set selectedOptionTemplate(value) {
|
|
118
|
+
this._selectedOptionTemplate$.next(value ?? null);
|
|
119
|
+
}
|
|
120
|
+
//#endregion
|
|
121
|
+
//#region Lifecycle
|
|
122
|
+
constructor() {
|
|
123
|
+
//#region Injects
|
|
124
|
+
this._destroy$ = createDestroy();
|
|
125
|
+
this._input = inject(INPUT_TOKEN);
|
|
126
|
+
this._animatedOverlay = inject(AnimatedOverlayDirective);
|
|
127
|
+
this._filterInternal$ = new BehaviorSubject(false);
|
|
128
|
+
this._loading$ = new BehaviorSubject(false);
|
|
129
|
+
this.loading$ = this._loading$.asObservable();
|
|
130
|
+
this._error$ = new BehaviorSubject(null);
|
|
131
|
+
this.emptyText = 'No results found';
|
|
132
|
+
this._placeholder$ = new BehaviorSubject(null);
|
|
133
|
+
this._allowCustomValues$ = new BehaviorSubject(false);
|
|
134
|
+
//#endregion
|
|
135
|
+
//#region Outputs
|
|
136
|
+
this.filterChange = new EventEmitter();
|
|
137
|
+
this._currentFilter$ = new BehaviorSubject('');
|
|
138
|
+
this._isOpen$ = this._animatedOverlay.isMounted$;
|
|
139
|
+
this._selectionModel = new SelectionModel();
|
|
140
|
+
this._activeSelectionModel = new ActiveSelectionModel();
|
|
141
|
+
this.selectedOptions$ = this._selectionModel.selection$;
|
|
142
|
+
this.multiple$ = this._selectionModel.allowMultiple$;
|
|
143
|
+
this.options$ = this._selectionModel.filteredOptions$;
|
|
144
|
+
this.rawOptions$ = this._selectionModel.options$;
|
|
145
|
+
this._optionTemplate$ = new BehaviorSubject(null);
|
|
146
|
+
this._selectedOptionTemplate$ = new BehaviorSubject(null);
|
|
147
|
+
this._bindings = createReactiveBindings({
|
|
148
|
+
attribute: 'class.et-combobox--loading',
|
|
149
|
+
observable: this._loading$,
|
|
150
|
+
}, {
|
|
151
|
+
attribute: 'class.et-combobox--error',
|
|
152
|
+
observable: this._error$.pipe(map((v) => !!v)),
|
|
153
|
+
}, {
|
|
154
|
+
attribute: 'class.et-combobox--open',
|
|
155
|
+
observable: this._isOpen$,
|
|
156
|
+
}, {
|
|
157
|
+
attribute: 'class.et-select-field--multiple',
|
|
158
|
+
observable: this.multiple$,
|
|
159
|
+
}, {
|
|
160
|
+
attribute: 'class.et-select-field--open',
|
|
161
|
+
observable: this._isOpen$,
|
|
162
|
+
});
|
|
163
|
+
this._comboboxBodyComponent = null;
|
|
164
|
+
//#endregion
|
|
165
|
+
//#region Computes
|
|
166
|
+
this.customOptionTpl$ = this._optionTemplate$.asObservable();
|
|
167
|
+
this.customSelectedOptionTpl$ = this._selectedOptionTemplate$.asObservable();
|
|
168
|
+
this._activeSelectionModel.setSelectionModel(this._selectionModel);
|
|
169
|
+
this._animatedOverlay.placement = 'bottom';
|
|
170
|
+
this._animatedOverlay.fallbackPlacements = ['bottom', 'top'];
|
|
171
|
+
this._animatedOverlay.autoResize = true;
|
|
172
|
+
}
|
|
173
|
+
ngOnInit() {
|
|
174
|
+
this._initDispatchFilterChanges();
|
|
175
|
+
if (isDevMode()) {
|
|
176
|
+
this._debugValidateComboboxConfig();
|
|
177
|
+
}
|
|
178
|
+
this._selectionModel.value$
|
|
179
|
+
.pipe(takeUntil(this._destroy$), tap((value) => {
|
|
180
|
+
this._input._updateValue(value);
|
|
181
|
+
this._setFilterFromInputValue();
|
|
182
|
+
}))
|
|
183
|
+
.subscribe();
|
|
184
|
+
this._input.nativeInputRef$
|
|
185
|
+
.pipe(takeUntil(this._destroy$), debounceTime(0), filter((ref) => !!ref?.element.nativeElement), tap(() => this._updateFilter(this._currentFilter)), take(1))
|
|
186
|
+
.subscribe();
|
|
187
|
+
}
|
|
188
|
+
//#endregion
|
|
189
|
+
//#region Public Methods
|
|
190
|
+
setBodyComponent(component) {
|
|
191
|
+
this._comboboxBodyComponent = component;
|
|
192
|
+
}
|
|
193
|
+
getOptionLabel(option) {
|
|
194
|
+
return this._selectionModel.getLabel$(option);
|
|
195
|
+
}
|
|
196
|
+
getOptionValue(option) {
|
|
197
|
+
return this._selectionModel.getValue$(option);
|
|
198
|
+
}
|
|
199
|
+
removeSelectedOption(option) {
|
|
200
|
+
this._selectionModel.removeSelectedOption(option);
|
|
201
|
+
this._input._markAsTouched();
|
|
202
|
+
}
|
|
203
|
+
open() {
|
|
204
|
+
assetComboboxBodyComponentSet(this._comboboxBodyComponent);
|
|
205
|
+
if (this._isOpen || this._input.disabled || this._animatedOverlay.isMounting)
|
|
206
|
+
return;
|
|
207
|
+
this._animatedOverlay.mount({
|
|
208
|
+
component: this._comboboxBodyComponent,
|
|
209
|
+
mirrorWidth: true,
|
|
210
|
+
});
|
|
211
|
+
}
|
|
212
|
+
close() {
|
|
213
|
+
if (!this._isOpen || this._animatedOverlay.isUnmounting)
|
|
214
|
+
return;
|
|
215
|
+
this._animatedOverlay.unmount();
|
|
216
|
+
}
|
|
217
|
+
selectInputAndOpen() {
|
|
218
|
+
if (this._input.disabled)
|
|
219
|
+
return;
|
|
220
|
+
this._input.nativeInputRef?.element.nativeElement.select();
|
|
221
|
+
this.open();
|
|
222
|
+
}
|
|
223
|
+
writeValueFromOption(option) {
|
|
224
|
+
this._input._markAsTouched();
|
|
225
|
+
if (this._selectionModel.allowMultiple) {
|
|
226
|
+
this._selectionModel.toggleSelectedOption(option);
|
|
227
|
+
}
|
|
228
|
+
else {
|
|
229
|
+
this._selectionModel.addSelectedOption(option);
|
|
230
|
+
}
|
|
231
|
+
if (!this._selectionModel.allowMultiple) {
|
|
232
|
+
this.close();
|
|
233
|
+
this._setFilterFromInputValue();
|
|
234
|
+
}
|
|
235
|
+
else {
|
|
236
|
+
this._updateFilter('');
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
isOptionSelected(option) {
|
|
240
|
+
return this._selectionModel.isSelected$(option);
|
|
241
|
+
}
|
|
242
|
+
isOptionActive(option) {
|
|
243
|
+
return this._activeSelectionModel.activeOption$.pipe(map((activeOption) => activeOption === option));
|
|
244
|
+
}
|
|
245
|
+
//#endregion
|
|
246
|
+
//#region Protected Methods
|
|
247
|
+
_processKeydownEvent(event) {
|
|
248
|
+
const keyCode = event.keyCode;
|
|
249
|
+
const isOpen = this._isOpen;
|
|
250
|
+
const isMultiple = this._selectionModel.allowMultiple;
|
|
251
|
+
const canAddCustomValue = this.allowCustomValues;
|
|
252
|
+
const value = event.target.value;
|
|
253
|
+
const hasFilterValue = !!value;
|
|
254
|
+
const result = {};
|
|
255
|
+
if (keyCode === ENTER) {
|
|
256
|
+
event.preventDefault();
|
|
257
|
+
event.stopPropagation();
|
|
258
|
+
// The user typed a custom value and pressed enter. Add it to the selected options.
|
|
259
|
+
// FIXME: Currently it is impossible to select the active option with the keyboard if canAddCustomValue is true.
|
|
260
|
+
// To fix this, the active option should also include the origin it got active from (keyboard or programmatic).
|
|
261
|
+
// The "value" changing should put the combobox into a "use the custom input on enter" mode.
|
|
262
|
+
// The "active option" changing via keyboard should put the combobox into a "use the active option on enter" mode.
|
|
263
|
+
if (canAddCustomValue && hasFilterValue) {
|
|
264
|
+
result.optionAction = { type: 'add', option: value };
|
|
265
|
+
}
|
|
266
|
+
else {
|
|
267
|
+
const activeOption = this._activeSelectionModel.activeOption;
|
|
268
|
+
if (activeOption) {
|
|
269
|
+
if (isMultiple) {
|
|
270
|
+
result.optionAction = { type: 'toggle', option: activeOption };
|
|
271
|
+
}
|
|
272
|
+
else {
|
|
273
|
+
result.optionAction = { type: 'add', option: activeOption };
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
if (isMultiple) {
|
|
278
|
+
result.setFilter = '';
|
|
279
|
+
}
|
|
280
|
+
else {
|
|
281
|
+
result.overlayOperation = 'close';
|
|
282
|
+
}
|
|
283
|
+
return this._interpretKeyHandlerResult(result);
|
|
284
|
+
}
|
|
285
|
+
if (keyCode === ESCAPE) {
|
|
286
|
+
if (isOpen) {
|
|
287
|
+
result.overlayOperation = 'close';
|
|
288
|
+
}
|
|
289
|
+
else if (!isMultiple) {
|
|
290
|
+
result.setFilter = '';
|
|
291
|
+
result.optionAction = 'clear';
|
|
292
|
+
}
|
|
293
|
+
return this._interpretKeyHandlerResult(result);
|
|
294
|
+
}
|
|
295
|
+
if (keyCode === TAB) {
|
|
296
|
+
result.overlayOperation = 'close';
|
|
297
|
+
return this._interpretKeyHandlerResult(result);
|
|
298
|
+
}
|
|
299
|
+
if (!isOpen) {
|
|
300
|
+
result.overlayOperation = 'open';
|
|
301
|
+
}
|
|
302
|
+
this._activeSelectionModel.evaluateKeyboardEvent(event);
|
|
303
|
+
if (keyCode === A && event.ctrlKey && isMultiple) {
|
|
304
|
+
result.optionAction = 'toggleAll';
|
|
305
|
+
event.preventDefault();
|
|
306
|
+
}
|
|
307
|
+
return this._interpretKeyHandlerResult(result);
|
|
308
|
+
}
|
|
309
|
+
_processInputEvent(event) {
|
|
310
|
+
const value = event.target.value;
|
|
311
|
+
this._updateFilter(value);
|
|
312
|
+
}
|
|
313
|
+
_handleBlurEvent() {
|
|
314
|
+
this._input._markAsTouched();
|
|
315
|
+
this._input._setShouldDisplayError(true);
|
|
316
|
+
if (this._selectionModel.allowMultiple) {
|
|
317
|
+
this._updateFilter('');
|
|
318
|
+
return;
|
|
319
|
+
}
|
|
320
|
+
if (this._currentFilter === '') {
|
|
321
|
+
this._selectionModel.clearSelectedOptions();
|
|
322
|
+
return;
|
|
323
|
+
}
|
|
324
|
+
this._setFilterFromInputValue();
|
|
325
|
+
}
|
|
326
|
+
//#endregion
|
|
327
|
+
//#region Private Methods
|
|
328
|
+
_initDispatchFilterChanges() {
|
|
329
|
+
this._currentFilter$
|
|
330
|
+
.pipe(skipWhile(() => this.filterInternal), debounceTime(300), distinctUntilChanged(), takeUntil(this._destroy$), tap((v) => this.filterChange.emit(v)))
|
|
331
|
+
.subscribe();
|
|
332
|
+
}
|
|
333
|
+
_updateFilter(value) {
|
|
334
|
+
if (this._input.nativeInputRef && this._input.nativeInputRef.element.nativeElement.value !== value) {
|
|
335
|
+
this._input.nativeInputRef.element.nativeElement.value = value;
|
|
336
|
+
}
|
|
337
|
+
if (this._currentFilter === value)
|
|
338
|
+
return;
|
|
339
|
+
this._currentFilter$.next(value);
|
|
340
|
+
if (this.filterInternal) {
|
|
341
|
+
this._selectionModel.setFilter(value);
|
|
342
|
+
}
|
|
343
|
+
}
|
|
344
|
+
_setFilterFromInputValue() {
|
|
345
|
+
if (this._selectionModel.allowMultiple)
|
|
346
|
+
return;
|
|
347
|
+
const value = this._input.value;
|
|
348
|
+
if (!value || Array.isArray(value)) {
|
|
349
|
+
this._updateFilter('');
|
|
350
|
+
return;
|
|
351
|
+
}
|
|
352
|
+
const option = this._selectionModel.getOptionByValue(value);
|
|
353
|
+
if (!option)
|
|
354
|
+
return;
|
|
355
|
+
const label = this._selectionModel.getLabel(option);
|
|
356
|
+
if (typeof label !== 'string')
|
|
357
|
+
return;
|
|
358
|
+
this._updateFilter(label);
|
|
359
|
+
}
|
|
360
|
+
_interpretKeyHandlerResult(result) {
|
|
361
|
+
if (result.overlayOperation === 'close') {
|
|
362
|
+
this.close();
|
|
363
|
+
}
|
|
364
|
+
else if (result.overlayOperation === 'open') {
|
|
365
|
+
this.open();
|
|
366
|
+
}
|
|
367
|
+
if (result.setFilter !== undefined) {
|
|
368
|
+
this._updateFilter(result.setFilter);
|
|
369
|
+
}
|
|
370
|
+
if (result.optionAction) {
|
|
371
|
+
if (typeof result.optionAction === 'string') {
|
|
372
|
+
if (result.optionAction === 'clear') {
|
|
373
|
+
this._selectionModel.clearSelectedOptions();
|
|
374
|
+
}
|
|
375
|
+
else if (result.optionAction === 'toggleAll') {
|
|
376
|
+
this._selectionModel.toggleAllSelectedOptions();
|
|
377
|
+
}
|
|
378
|
+
}
|
|
379
|
+
else {
|
|
380
|
+
const { type, option } = result.optionAction;
|
|
381
|
+
if (isOptionDisabled(option))
|
|
382
|
+
return;
|
|
383
|
+
if (type === 'add') {
|
|
384
|
+
this._selectionModel.addSelectedOption(option);
|
|
385
|
+
}
|
|
386
|
+
if (type === 'remove') {
|
|
387
|
+
this._selectionModel.removeSelectedOption(option);
|
|
388
|
+
}
|
|
389
|
+
if (type === 'toggle') {
|
|
390
|
+
this._selectionModel.toggleSelectedOption(option);
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
//#endregion
|
|
396
|
+
//#region Dev mode
|
|
397
|
+
_debugValidateComboboxConfig(isRetry = false) {
|
|
398
|
+
combineLatest([this._selectionModel.labelBinding$, this._selectionModel.valueBinding$, this._allowCustomValues$])
|
|
399
|
+
.pipe(skip(isRetry ? 1 : 0), // Skip if retrying to avoid infinite loop
|
|
400
|
+
debounceTime(0), takeUntil(this._destroy$), map(([bindLabel, bindValue, allowCustomValues]) => {
|
|
401
|
+
const shouldBeObjects = bindLabel && bindValue && !allowCustomValues;
|
|
402
|
+
if (shouldBeObjects) {
|
|
403
|
+
return ComboboxOptionType.Object;
|
|
404
|
+
}
|
|
405
|
+
return ComboboxOptionType.Primitive;
|
|
406
|
+
}), tap((expectedOptionType) => {
|
|
407
|
+
const options = this._selectionModel.options;
|
|
408
|
+
if (isEmptyArray(options)) {
|
|
409
|
+
return;
|
|
410
|
+
}
|
|
411
|
+
if (expectedOptionType === ComboboxOptionType.Object) {
|
|
412
|
+
if (!isObjectArray(options)) {
|
|
413
|
+
throw comboboxError(1, options);
|
|
414
|
+
}
|
|
415
|
+
}
|
|
416
|
+
else if (expectedOptionType === ComboboxOptionType.Primitive) {
|
|
417
|
+
if (!isPrimitiveArray(options)) {
|
|
418
|
+
throw comboboxError(2, options);
|
|
419
|
+
}
|
|
420
|
+
}
|
|
421
|
+
}), catchError((e) => {
|
|
422
|
+
this._debugValidateComboboxConfig(true);
|
|
423
|
+
return throwError(() => e);
|
|
424
|
+
}))
|
|
425
|
+
.subscribe();
|
|
426
|
+
}
|
|
427
|
+
_assetBodyComponent() {
|
|
428
|
+
if (!this._comboboxBodyComponent) {
|
|
429
|
+
throw new RuntimeError(1, 'Combobox body component is not set');
|
|
430
|
+
}
|
|
431
|
+
}
|
|
5
432
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: ComboboxDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
6
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.0", type: ComboboxDirective, isStandalone: true, providers: [
|
|
433
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.0", type: ComboboxDirective, isStandalone: true, inputs: { options: "options", initialValue: "initialValue", filterInternal: "filterInternal", loading: "loading", error: "error", emptyText: "emptyText", placeholder: "placeholder", multiple: "multiple", bindLabel: "bindLabel", bindValue: "bindValue", allowCustomValues: "allowCustomValues" }, outputs: { filterChange: "filterChange" }, providers: [
|
|
7
434
|
{
|
|
8
|
-
provide:
|
|
435
|
+
provide: COMBOBOX_TOKEN,
|
|
9
436
|
useExisting: ComboboxDirective,
|
|
10
437
|
},
|
|
11
|
-
], ngImport: i0 }); }
|
|
438
|
+
], queries: [{ propertyName: "optionTemplate", first: true, predicate: COMBOBOX_OPTION_TEMPLATE_TOKEN, descendants: true, read: TemplateRef }, { propertyName: "selectedOptionTemplate", first: true, predicate: COMBOBOX_SELECTED_OPTION_TEMPLATE_TOKEN, descendants: true, read: TemplateRef }], ngImport: i0 }); }
|
|
12
439
|
}
|
|
13
440
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImport: i0, type: ComboboxDirective, decorators: [{
|
|
14
441
|
type: Directive,
|
|
@@ -16,10 +443,41 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
|
|
|
16
443
|
standalone: true,
|
|
17
444
|
providers: [
|
|
18
445
|
{
|
|
19
|
-
provide:
|
|
446
|
+
provide: COMBOBOX_TOKEN,
|
|
20
447
|
useExisting: ComboboxDirective,
|
|
21
448
|
},
|
|
22
449
|
],
|
|
23
450
|
}]
|
|
24
|
-
}]
|
|
25
|
-
|
|
451
|
+
}], ctorParameters: function () { return []; }, propDecorators: { options: [{
|
|
452
|
+
type: Input,
|
|
453
|
+
args: [{ required: true }]
|
|
454
|
+
}], initialValue: [{
|
|
455
|
+
type: Input
|
|
456
|
+
}], filterInternal: [{
|
|
457
|
+
type: Input
|
|
458
|
+
}], loading: [{
|
|
459
|
+
type: Input
|
|
460
|
+
}], error: [{
|
|
461
|
+
type: Input
|
|
462
|
+
}], emptyText: [{
|
|
463
|
+
type: Input
|
|
464
|
+
}], placeholder: [{
|
|
465
|
+
type: Input
|
|
466
|
+
}], multiple: [{
|
|
467
|
+
type: Input
|
|
468
|
+
}], bindLabel: [{
|
|
469
|
+
type: Input
|
|
470
|
+
}], bindValue: [{
|
|
471
|
+
type: Input
|
|
472
|
+
}], allowCustomValues: [{
|
|
473
|
+
type: Input
|
|
474
|
+
}], filterChange: [{
|
|
475
|
+
type: Output
|
|
476
|
+
}], optionTemplate: [{
|
|
477
|
+
type: ContentChild,
|
|
478
|
+
args: [COMBOBOX_OPTION_TEMPLATE_TOKEN, { read: TemplateRef }]
|
|
479
|
+
}], selectedOptionTemplate: [{
|
|
480
|
+
type: ContentChild,
|
|
481
|
+
args: [COMBOBOX_SELECTED_OPTION_TEMPLATE_TOKEN, { read: TemplateRef }]
|
|
482
|
+
}] } });
|
|
483
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"combobox.directive.js","sourceRoot":"","sources":["../../../../../../../../../../../../../libs/cdk/src/lib/components/forms/components/select/components/combobox/directives/combobox/combobox.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { A, ENTER, ESCAPE, TAB } from '@angular/cdk/keycodes';\nimport { ComponentType } from '@angular/cdk/overlay';\nimport {\n  ContentChild,\n  Directive,\n  EventEmitter,\n  InjectionToken,\n  Input,\n  OnInit,\n  Output,\n  TemplateRef,\n  booleanAttribute,\n  inject,\n  isDevMode,\n} from '@angular/core';\nimport {\n  ActiveSelectionModel,\n  AnimatedOverlayComponentBase,\n  AnimatedOverlayDirective,\n  RuntimeError,\n  SelectionModel,\n  createDestroy,\n  createReactiveBindings,\n} from '@ethlete/core';\nimport {\n  BehaviorSubject,\n  catchError,\n  combineLatest,\n  debounceTime,\n  distinctUntilChanged,\n  filter,\n  map,\n  skip,\n  skipWhile,\n  take,\n  takeUntil,\n  tap,\n  throwError,\n} from 'rxjs';\nimport { INPUT_TOKEN } from '../../../../../../directives';\nimport { isOptionDisabled } from '../../utils';\nimport { COMBOBOX_OPTION_TEMPLATE_TOKEN } from '../combobox-option-template';\nimport { COMBOBOX_SELECTED_OPTION_TEMPLATE_TOKEN } from '../combobox-selected-option-template';\n\nexport const COMBOBOX_TOKEN = new InjectionToken<ComboboxDirective>('ET_COMBOBOX_INPUT_TOKEN');\n\nconst COMBOBOX_ERRORS = {\n  1: 'Expected options to be an array of objects. This is due to \"bindLabel\" and \"bindValue\" being set.',\n  2: 'Expected options to be an array of primitives. This is due to \"bindLabel\" and \"bindValue\" not being set or \"allowCustomValues\" being set to true.',\n} as const;\n\nconst comboboxError = (code: keyof typeof COMBOBOX_ERRORS, data: unknown) => {\n  const message = `<et-combobox>: ${COMBOBOX_ERRORS[code]}`;\n\n  throw new RuntimeError(code, message, data);\n};\n\nconst isPrimitiveArray = (value: unknown): value is Array<string | number | boolean> => {\n  if (!Array.isArray(value)) return false;\n\n  const first = value[0];\n  const last = value[value.length - 1];\n\n  if (!first || !last) return false;\n\n  return typeof first !== 'object' && typeof last !== 'object';\n};\n\nconst isObjectArray = (value: unknown): value is Array<Record<string, unknown>> => {\n  if (!Array.isArray(value)) return false;\n\n  const first = value[0];\n  const last = value[value.length - 1];\n\n  if (!first || !last) return false;\n\n  return typeof first === 'object' && typeof last === 'object';\n};\n\nconst isEmptyArray = (value: unknown): value is [] => {\n  return Array.isArray(value) && value.length === 0;\n};\n\nconst ComboboxOptionType = {\n  Primitive: 'primitive',\n  Object: 'object',\n} as const;\n\ninterface KeyHandlerResult {\n  setFilter?: string;\n  overlayOperation?: 'open' | 'close';\n  optionAction?:\n    | {\n        type: 'add';\n        option: unknown;\n      }\n    | {\n        type: 'remove';\n        option: unknown;\n      }\n    | {\n        type: 'toggle';\n        option: unknown;\n      }\n    | 'clear'\n    | 'toggleAll';\n}\n\ntype TemplateRefWithOption = TemplateRef<{\n  option: unknown;\n}>;\n\nfunction assetComboboxBodyComponentSet(\n  component: ComponentType<AnimatedOverlayComponentBase> | null,\n): asserts component is ComponentType<AnimatedOverlayComponentBase> {\n  if (!component) {\n    throw new RuntimeError(1, 'Combobox body component is not set');\n  }\n}\n\n@Directive({\n  standalone: true,\n  providers: [\n    {\n      provide: COMBOBOX_TOKEN,\n      useExisting: ComboboxDirective,\n    },\n  ],\n})\nexport class ComboboxDirective implements OnInit {\n  //#region Injects\n\n  private readonly _destroy$ = createDestroy();\n  private readonly _input = inject(INPUT_TOKEN);\n  private readonly _animatedOverlay =\n    inject<AnimatedOverlayDirective<AnimatedOverlayComponentBase>>(AnimatedOverlayDirective);\n\n  //#region Inputs\n\n  @Input({ required: true })\n  get options() {\n    return this._selectionModel.getFilteredOptions();\n  }\n  set options(value: unknown[]) {\n    this._selectionModel.setOptions(value);\n  }\n\n  @Input()\n  set initialValue(value: unknown) {\n    this._selectionModel.setSelection(value);\n  }\n\n  @Input()\n  get filterInternal(): boolean {\n    return this._filterInternal$.value;\n  }\n  set filterInternal(value: unknown) {\n    const val = booleanAttribute(value);\n    this._filterInternal$.next(val);\n\n    if (!val) {\n      this._selectionModel.setFilter('');\n    } else {\n      this._selectionModel.setFilter(this._currentFilter);\n    }\n  }\n  private _filterInternal$ = new BehaviorSubject(false);\n\n  @Input()\n  get loading(): boolean {\n    return this._loading$.value;\n  }\n  set loading(value: unknown) {\n    this._loading$.next(booleanAttribute(value));\n  }\n  private _loading$ = new BehaviorSubject(false);\n  readonly loading$ = this._loading$.asObservable();\n\n  @Input()\n  get error() {\n    return this._error$.value;\n  }\n  set error(value: unknown) {\n    this._error$.next(value);\n  }\n  private _error$ = new BehaviorSubject<unknown>(null);\n\n  @Input()\n  emptyText = 'No results found';\n\n  @Input()\n  get placeholder() {\n    return this._placeholder$.value;\n  }\n  set placeholder(value: string | null) {\n    this._placeholder$.next(value);\n  }\n  private _placeholder$ = new BehaviorSubject<string | null>(null);\n\n  @Input()\n  set multiple(value: unknown) {\n    this._selectionModel.setAllowMultiple(booleanAttribute(value));\n  }\n\n  @Input()\n  set bindLabel(value: string | null) {\n    this._selectionModel.setLabelBinding(value);\n  }\n\n  @Input()\n  set bindValue(value: string | null) {\n    this._selectionModel.setValueBinding(value);\n  }\n\n  @Input()\n  get allowCustomValues(): boolean {\n    return this._allowCustomValues$.value;\n  }\n  set allowCustomValues(value: unknown) {\n    this._allowCustomValues$.next(booleanAttribute(value));\n  }\n  private _allowCustomValues$ = new BehaviorSubject(false);\n\n  //#endregion\n\n  //#region Outputs\n\n  @Output()\n  protected readonly filterChange = new EventEmitter<string>();\n\n  //#endregion\n\n  //#region Members\n\n  private get _currentFilter() {\n    return this._currentFilter$.value;\n  }\n  private readonly _currentFilter$ = new BehaviorSubject<string>('');\n\n  private get _isOpen() {\n    return this._animatedOverlay.isMounted;\n  }\n  private readonly _isOpen$ = this._animatedOverlay.isMounted$;\n\n  private readonly _selectionModel = new SelectionModel();\n  private readonly _activeSelectionModel = new ActiveSelectionModel();\n\n  readonly selectedOptions$ = this._selectionModel.selection$;\n  readonly multiple$ = this._selectionModel.allowMultiple$;\n  readonly options$ = this._selectionModel.filteredOptions$;\n  readonly rawOptions$ = this._selectionModel.options$;\n\n  @ContentChild(COMBOBOX_OPTION_TEMPLATE_TOKEN, { read: TemplateRef })\n  set optionTemplate(value: TemplateRefWithOption | undefined) {\n    this._optionTemplate$.next(value ?? null);\n  }\n  private readonly _optionTemplate$ = new BehaviorSubject<TemplateRefWithOption | null>(null);\n\n  @ContentChild(COMBOBOX_SELECTED_OPTION_TEMPLATE_TOKEN, { read: TemplateRef })\n  set selectedOptionTemplate(value: TemplateRefWithOption | undefined) {\n    this._selectedOptionTemplate$.next(value ?? null);\n  }\n  private readonly _selectedOptionTemplate$ = new BehaviorSubject<TemplateRefWithOption | null>(null);\n\n  readonly _bindings = createReactiveBindings(\n    {\n      attribute: 'class.et-combobox--loading',\n      observable: this._loading$,\n    },\n    {\n      attribute: 'class.et-combobox--error',\n      observable: this._error$.pipe(map((v) => !!v)),\n    },\n    {\n      attribute: 'class.et-combobox--open',\n      observable: this._isOpen$,\n    },\n    {\n      attribute: 'class.et-select-field--multiple',\n      observable: this.multiple$,\n    },\n    {\n      attribute: 'class.et-select-field--open',\n      observable: this._isOpen$,\n    },\n  );\n\n  private _comboboxBodyComponent: ComponentType<AnimatedOverlayComponentBase> | null = null;\n\n  //#endregion\n\n  //#region Computes\n\n  readonly customOptionTpl$ = this._optionTemplate$.asObservable();\n  readonly customSelectedOptionTpl$ = this._selectedOptionTemplate$.asObservable();\n\n  //#endregion\n\n  //#region Lifecycle\n\n  constructor() {\n    this._activeSelectionModel.setSelectionModel(this._selectionModel);\n\n    this._animatedOverlay.placement = 'bottom';\n    this._animatedOverlay.fallbackPlacements = ['bottom', 'top'];\n    this._animatedOverlay.autoResize = true;\n  }\n\n  ngOnInit(): void {\n    this._initDispatchFilterChanges();\n\n    if (isDevMode()) {\n      this._debugValidateComboboxConfig();\n    }\n\n    this._selectionModel.value$\n      .pipe(\n        takeUntil(this._destroy$),\n        tap((value) => {\n          this._input._updateValue(value);\n          this._setFilterFromInputValue();\n        }),\n      )\n      .subscribe();\n\n    this._input.nativeInputRef$\n      .pipe(\n        takeUntil(this._destroy$),\n        debounceTime(0),\n        filter((ref) => !!ref?.element.nativeElement),\n        tap(() => this._updateFilter(this._currentFilter)),\n        take(1),\n      )\n      .subscribe();\n  }\n\n  //#endregion\n\n  //#region Public Methods\n\n  setBodyComponent(component: ComponentType<AnimatedOverlayComponentBase>) {\n    this._comboboxBodyComponent = component;\n  }\n\n  getOptionLabel(option: unknown) {\n    return this._selectionModel.getLabel$(option);\n  }\n\n  getOptionValue(option: unknown) {\n    return this._selectionModel.getValue$(option);\n  }\n\n  removeSelectedOption(option: unknown) {\n    this._selectionModel.removeSelectedOption(option);\n\n    this._input._markAsTouched();\n  }\n\n  open() {\n    assetComboboxBodyComponentSet(this._comboboxBodyComponent);\n\n    if (this._isOpen || this._input.disabled || this._animatedOverlay.isMounting) return;\n\n    this._animatedOverlay.mount({\n      component: this._comboboxBodyComponent,\n      mirrorWidth: true,\n    });\n  }\n\n  close() {\n    if (!this._isOpen || this._animatedOverlay.isUnmounting) return;\n\n    this._animatedOverlay.unmount();\n  }\n\n  selectInputAndOpen() {\n    if (this._input.disabled) return;\n\n    this._input.nativeInputRef?.element.nativeElement.select();\n    this.open();\n  }\n\n  writeValueFromOption(option: unknown) {\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      this._setFilterFromInputValue();\n    } else {\n      this._updateFilter('');\n    }\n  }\n\n  isOptionSelected(option: unknown) {\n    return this._selectionModel.isSelected$(option);\n  }\n\n  isOptionActive(option: unknown) {\n    return this._activeSelectionModel.activeOption$.pipe(map((activeOption) => activeOption === option));\n  }\n\n  //#endregion\n\n  //#region Protected Methods\n\n  _processKeydownEvent(event: KeyboardEvent) {\n    const keyCode = event.keyCode;\n    const isOpen = this._isOpen;\n    const isMultiple = this._selectionModel.allowMultiple;\n    const canAddCustomValue = this.allowCustomValues;\n    const value = (event.target as HTMLInputElement).value;\n    const hasFilterValue = !!value;\n\n    const result: KeyHandlerResult = {};\n\n    if (keyCode === ENTER) {\n      event.preventDefault();\n      event.stopPropagation();\n\n      // The user typed a custom value and pressed enter. Add it to the selected options.\n      // FIXME: Currently it is impossible to select the active option with the keyboard if canAddCustomValue is true.\n      // To fix this, the active option should also include the origin it got active from (keyboard or programmatic).\n      // The \"value\" changing should put the combobox into a \"use the custom input on enter\" mode.\n      // The \"active option\" changing via keyboard should put the combobox into a \"use the active option on enter\" mode.\n      if (canAddCustomValue && hasFilterValue) {\n        result.optionAction = { type: 'add', option: value };\n      } else {\n        const activeOption = this._activeSelectionModel.activeOption;\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\n      if (isMultiple) {\n        result.setFilter = '';\n      } else {\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      } else if (!isMultiple) {\n        result.setFilter = '';\n        result.optionAction = 'clear';\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 (!isOpen) {\n      result.overlayOperation = 'open';\n    }\n\n    this._activeSelectionModel.evaluateKeyboardEvent(event);\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  _processInputEvent(event: Event) {\n    const value = (event.target as HTMLInputElement).value;\n\n    this._updateFilter(value);\n  }\n\n  _handleBlurEvent() {\n    this._input._markAsTouched();\n    this._input._setShouldDisplayError(true);\n\n    if (this._selectionModel.allowMultiple) {\n      this._updateFilter('');\n      return;\n    }\n\n    if (this._currentFilter === '') {\n      this._selectionModel.clearSelectedOptions();\n      return;\n    }\n\n    this._setFilterFromInputValue();\n  }\n\n  //#endregion\n\n  //#region Private Methods\n\n  private _initDispatchFilterChanges() {\n    this._currentFilter$\n      .pipe(\n        skipWhile(() => this.filterInternal),\n        debounceTime(300),\n        distinctUntilChanged(),\n        takeUntil(this._destroy$),\n        tap((v) => this.filterChange.emit(v)),\n      )\n      .subscribe();\n  }\n\n  private _updateFilter(value: string) {\n    if (this._input.nativeInputRef && this._input.nativeInputRef.element.nativeElement.value !== value) {\n      this._input.nativeInputRef.element.nativeElement.value = value;\n    }\n\n    if (this._currentFilter === value) return;\n\n    this._currentFilter$.next(value);\n\n    if (this.filterInternal) {\n      this._selectionModel.setFilter(value);\n    }\n  }\n\n  private _setFilterFromInputValue() {\n    if (this._selectionModel.allowMultiple) return;\n\n    const value = this._input.value;\n\n    if (!value || Array.isArray(value)) {\n      this._updateFilter('');\n      return;\n    }\n\n    const option = this._selectionModel.getOptionByValue(value);\n\n    if (!option) return;\n\n    const label = this._selectionModel.getLabel(option);\n\n    if (typeof label !== 'string') return;\n\n    this._updateFilter(label);\n  }\n\n  private _interpretKeyHandlerResult(result: KeyHandlerResult) {\n    if (result.overlayOperation === 'close') {\n      this.close();\n    } else if (result.overlayOperation === 'open') {\n      this.open();\n    }\n\n    if (result.setFilter !== undefined) {\n      this._updateFilter(result.setFilter);\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 (isOptionDisabled(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  //#endregion\n\n  //#region Dev mode\n\n  private _debugValidateComboboxConfig(isRetry = false) {\n    combineLatest([this._selectionModel.labelBinding$, this._selectionModel.valueBinding$, this._allowCustomValues$])\n      .pipe(\n        skip(isRetry ? 1 : 0), // Skip if retrying to avoid infinite loop\n        debounceTime(0),\n        takeUntil(this._destroy$),\n        map(([bindLabel, bindValue, allowCustomValues]) => {\n          const shouldBeObjects = bindLabel && bindValue && !allowCustomValues;\n\n          if (shouldBeObjects) {\n            return ComboboxOptionType.Object;\n          }\n\n          return ComboboxOptionType.Primitive;\n        }),\n        tap((expectedOptionType) => {\n          const options = this._selectionModel.options;\n\n          if (isEmptyArray(options)) {\n            return;\n          }\n\n          if (expectedOptionType === ComboboxOptionType.Object) {\n            if (!isObjectArray(options)) {\n              throw comboboxError(1, options);\n            }\n          } else if (expectedOptionType === ComboboxOptionType.Primitive) {\n            if (!isPrimitiveArray(options)) {\n              throw comboboxError(2, options);\n            }\n          }\n        }),\n        catchError((e) => {\n          this._debugValidateComboboxConfig(true);\n          return throwError(() => e);\n        }),\n      )\n      .subscribe();\n  }\n\n  private _assetBodyComponent() {\n    if (!this._comboboxBodyComponent) {\n      throw new RuntimeError(1, 'Combobox body component is not set');\n    }\n  }\n\n  //#endregion\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './public-api';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Nkay9zcmMvbGliL2NvbXBvbmVudHMvZm9ybXMvY29tcG9uZW50cy9zZWxlY3QvY29tcG9uZW50cy9jb21ib2JveC9kaXJlY3RpdmVzL2NvbWJvYm94LW9wdGlvbi10ZW1wbGF0ZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './public-api';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Nkay9zcmMvbGliL2NvbXBvbmVudHMvZm9ybXMvY29tcG9uZW50cy9zZWxlY3QvY29tcG9uZW50cy9jb21ib2JveC9kaXJlY3RpdmVzL2NvbWJvYm94LXNlbGVjdGVkLW9wdGlvbi10ZW1wbGF0ZS9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
|
|
@@ -2,7 +2,7 @@ import { AsyncPipe, NgFor, NgIf, NgTemplateOutlet } from '@angular/common';
|
|
|
2
2
|
import { ChangeDetectionStrategy, Component, InjectionToken, ViewChild, ViewEncapsulation, inject, } from '@angular/core';
|
|
3
3
|
import { ANIMATED_LIFECYCLE_TOKEN, AnimatedLifecycleDirective, ClickOutsideDirective, LetDirective, createDestroy, createReactiveBindings, } from '@ethlete/core';
|
|
4
4
|
import { takeUntil, tap } from 'rxjs';
|
|
5
|
-
import { COMBOBOX_TOKEN } from '../../
|
|
5
|
+
import { COMBOBOX_TOKEN } from '../../directives';
|
|
6
6
|
import { ComboboxOptionComponent } from '../combobox-option';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
import * as i1 from "@ethlete/core";
|
|
@@ -56,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.0", ngImpor
|
|
|
56
56
|
type: ViewChild,
|
|
57
57
|
args: [ANIMATED_LIFECYCLE_TOKEN, { static: true }]
|
|
58
58
|
}] } });
|
|
59
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
59
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tYm9ib3gtYm9keS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2Nkay9zcmMvbGliL2NvbXBvbmVudHMvZm9ybXMvY29tcG9uZW50cy9zZWxlY3QvY29tcG9uZW50cy9jb21ib2JveC9wYXJ0aWFscy9jb21ib2JveC1ib2R5L2NvbWJvYm94LWJvZHkuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jZGsvc3JjL2xpYi9jb21wb25lbnRzL2Zvcm1zL2NvbXBvbmVudHMvc2VsZWN0L2NvbXBvbmVudHMvY29tYm9ib3gvcGFydGlhbHMvY29tYm9ib3gtYm9keS9jb21ib2JveC1ib2R5LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzNFLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsU0FBUyxFQUNULGNBQWMsRUFHZCxTQUFTLEVBQ1QsaUJBQWlCLEVBQ2pCLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQ0wsd0JBQXdCLEVBQ3hCLDBCQUEwQixFQUMxQixxQkFBcUIsRUFDckIsWUFBWSxFQUNaLGFBQWEsRUFDYixzQkFBc0IsR0FDdkIsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFNBQVMsRUFBRSxHQUFHLEVBQUUsTUFBTSxNQUFNLENBQUM7QUFDdEMsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2xELE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDOzs7QUFFN0QsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsSUFBSSxjQUFjLENBQXdCLHdCQUF3QixDQUFDLENBQUM7QUE0QnZHLE1BQU0sT0FBTyxxQkFBcUI7SUExQmxDO1FBMkJtQixjQUFTLEdBQUcsYUFBYSxFQUFFLENBQUM7UUFDNUIsa0JBQWEsR0FBRyxNQUFNLENBQUMscUJBQXFCLENBQUMsQ0FBQztRQUM1QyxhQUFRLEdBQUcsTUFBTSxDQUFDLGNBQWMsQ0FBQyxDQUFDO1FBSzVDLGNBQVMsR0FBRyxzQkFBc0IsQ0FDekM7WUFDRSxTQUFTLEVBQUUsaUNBQWlDO1lBQzVDLFVBQVUsRUFBRSxJQUFJLENBQUMsUUFBUSxDQUFDLFFBQVE7U0FDbkMsRUFDRDtZQUNFLFNBQVMsRUFBRSxrQ0FBa0M7WUFDN0MsVUFBVSxFQUFFLElBQUksQ0FBQyxRQUFRLENBQUMsU0FBUztTQUNwQyxDQUNGLENBQUM7UUFFRixrQkFBYSxHQUFnQyxJQUFJLENBQUM7S0FVbkQ7SUFSQyxRQUFRO1FBQ04sSUFBSSxDQUFDLGFBQWEsQ0FBQyxjQUFjO2FBQzlCLElBQUksQ0FDSCxTQUFTLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxFQUN6QixHQUFHLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUNqQzthQUNBLFNBQVMsRUFBRSxDQUFDO0lBQ2pCLENBQUM7OEdBNUJVLHFCQUFxQjtrR0FBckIscUJBQXFCLHVJQVByQjtZQUNUO2dCQUNFLE9BQU8sRUFBRSxtQkFBbUI7Z0JBQzVCLFdBQVcsRUFBRSxxQkFBcUI7YUFDbkM7U0FDRiw4RUFPVSx3QkFBd0IseUhDeERyQyw0WkFRQSw0Q0Q0QkksS0FBSyxtSEFDTCx1QkFBdUIsbUZBQ3ZCLFlBQVksa0VBQ1osU0FBUyw4Q0FDVCwwQkFBMEIscUdBQzFCLElBQUk7OzJGQVVLLHFCQUFxQjtrQkExQmpDLFNBQVM7K0JBQ0Usa0JBQWtCLGNBRWhCLElBQUksbUJBQ0MsdUJBQXVCLENBQUMsTUFBTSxpQkFDaEMsaUJBQWlCLENBQUMsSUFBSSxRQUMvQjt3QkFDSixLQUFLLEVBQUUsNENBQTRDO3FCQUNwRCxXQUNRO3dCQUNQLGdCQUFnQjt3QkFDaEIsS0FBSzt3QkFDTCx1QkFBdUI7d0JBQ3ZCLFlBQVk7d0JBQ1osU0FBUzt3QkFDVCwwQkFBMEI7d0JBQzFCLElBQUk7cUJBQ0wsa0JBQ2UsQ0FBQyxxQkFBcUIsQ0FBQyxhQUM1Qjt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsbUJBQW1COzRCQUM1QixXQUFXLHVCQUF1Qjt5QkFDbkM7cUJBQ0Y7OEJBUVEsa0JBQWtCO3NCQUQxQixTQUFTO3VCQUFDLHdCQUF3QixFQUFFLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFzeW5jUGlwZSwgTmdGb3IsIE5nSWYsIE5nVGVtcGxhdGVPdXRsZXQgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgSW5qZWN0aW9uVG9rZW4sXG4gIE9uSW5pdCxcbiAgVGVtcGxhdGVSZWYsXG4gIFZpZXdDaGlsZCxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG4gIGluamVjdCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge1xuICBBTklNQVRFRF9MSUZFQ1lDTEVfVE9LRU4sXG4gIEFuaW1hdGVkTGlmZWN5Y2xlRGlyZWN0aXZlLFxuICBDbGlja091dHNpZGVEaXJlY3RpdmUsXG4gIExldERpcmVjdGl2ZSxcbiAgY3JlYXRlRGVzdHJveSxcbiAgY3JlYXRlUmVhY3RpdmVCaW5kaW5ncyxcbn0gZnJvbSAnQGV0aGxldGUvY29yZSc7XG5pbXBvcnQgeyB0YWtlVW50aWwsIHRhcCB9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHsgQ09NQk9CT1hfVE9LRU4gfSBmcm9tICcuLi8uLi9kaXJlY3RpdmVzJztcbmltcG9ydCB7IENvbWJvYm94T3B0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi4vY29tYm9ib3gtb3B0aW9uJztcblxuZXhwb3J0IGNvbnN0IENPTUJPQk9YX0JPRFlfVE9LRU4gPSBuZXcgSW5qZWN0aW9uVG9rZW48Q29tYm9ib3hCb2R5Q29tcG9uZW50PignRVRfQ09NQk9CT1hfQk9EWV9UT0tFTicpO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdldC1jb21ib2JveC1ib2R5JyxcbiAgdGVtcGxhdGVVcmw6ICcuL2NvbWJvYm94LWJvZHkuY29tcG9uZW50Lmh0bWwnLFxuICBzdGFuZGFsb25lOiB0cnVlLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnZXQtY29tYm9ib3gtYm9keSBldC13aXRoLWRlZmF1bHQtYW5pbWF0aW9uJyxcbiAgfSxcbiAgaW1wb3J0czogW1xuICAgIE5nVGVtcGxhdGVPdXRsZXQsXG4gICAgTmdGb3IsXG4gICAgQ29tYm9ib3hPcHRpb25Db21wb25lbnQsXG4gICAgTGV0RGlyZWN0aXZlLFxuICAgIEFzeW5jUGlwZSxcbiAgICBBbmltYXRlZExpZmVjeWNsZURpcmVjdGl2ZSxcbiAgICBOZ0lmLFxuICBdLFxuICBob3N0RGlyZWN0aXZlczogW0NsaWNrT3V0c2lkZURpcmVjdGl2ZV0sXG4gIHByb3ZpZGVyczogW1xuICAgIHtcbiAgICAgIHByb3ZpZGU6IENPTUJPQk9YX0JPRFlfVE9LRU4sXG4gICAgICB1c2VFeGlzdGluZzogQ29tYm9ib3hCb2R5Q29tcG9uZW50LFxuICAgIH0sXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIENvbWJvYm94Qm9keUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgX2Rlc3Ryb3kkID0gY3JlYXRlRGVzdHJveSgpO1xuICBwcml2YXRlIHJlYWRvbmx5IF9jbGlja091dHNpZGUgPSBpbmplY3QoQ2xpY2tPdXRzaWRlRGlyZWN0aXZlKTtcbiAgcHJvdGVjdGVkIHJlYWRvbmx5IGNvbWJvYm94ID0gaW5qZWN0KENPTUJPQk9YX1RPS0VOKTtcblxuICBAVmlld0NoaWxkKEFOSU1BVEVEX0xJRkVDWUNMRV9UT0tFTiwgeyBzdGF0aWM6IHRydWUgfSlcbiAgcmVhZG9ubHkgX2FuaW1hdGVkTGlmZWN5Y2xlPzogQW5pbWF0ZWRMaWZlY3ljbGVEaXJlY3RpdmU7XG5cbiAgcmVhZG9ubHkgX2JpbmRpbmdzID0gY3JlYXRlUmVhY3RpdmVCaW5kaW5ncyhcbiAgICB7XG4gICAgICBhdHRyaWJ1dGU6ICdjbGFzcy5ldC1jb21ib2JveC1ib2R5LS1sb2FkaW5nJyxcbiAgICAgIG9ic2VydmFibGU6IHRoaXMuY29tYm9ib3gubG9hZGluZyQsXG4gICAgfSxcbiAgICB7XG4gICAgICBhdHRyaWJ1dGU6ICdjbGFzcy5ldC1jb21ib2JveC1ib2R5LS1tdWx0aXBsZScsXG4gICAgICBvYnNlcnZhYmxlOiB0aGlzLmNvbWJvYm94Lm11bHRpcGxlJCxcbiAgICB9LFxuICApO1xuXG4gIF9ib2R5VGVtcGxhdGU6IFRlbXBsYXRlUmVmPHVua25vd24+IHwgbnVsbCA9IG51bGw7XG5cbiAgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgdGhpcy5fY2xpY2tPdXRzaWRlLmV0Q2xpY2tPdXRzaWRlXG4gICAgICAucGlwZShcbiAgICAgICAgdGFrZVVudGlsKHRoaXMuX2Rlc3Ryb3kkKSxcbiAgICAgICAgdGFwKCgpID0+IHRoaXMuY29tYm9ib3guY2xvc2UoKSksXG4gICAgICApXG4gICAgICAuc3Vic2NyaWJlKCk7XG4gIH1cbn1cbiIsIjwhLS0gZXNsaW50LWRpc2FibGUgQGFuZ3VsYXItZXNsaW50L3RlbXBsYXRlL3VzZS10cmFjay1ieS1mdW5jdGlvbiAtLT5cbjxkaXYgY2xhc3M9XCJldC1jb21ib2JveC1ib2R5LWNvbnRhaW5lclwiIGV0QW5pbWF0ZWRMaWZlY3ljbGU+XG4gIDxuZy1jb250YWluZXIgKmV0TGV0PVwiY29tYm9ib3gub3B0aW9ucyQgfCBhc3luYyBhcyBvcHRpb25zXCI+XG4gICAgPHAgKm5nSWY9XCIhb3B0aW9ucz8ubGVuZ3RoXCIgY2xhc3M9XCJldC1jb21ib2JveC1ib2R5LS1lbXB0eVwiPnt7IGNvbWJvYm94LmVtcHR5VGV4dCB9fTwvcD5cblxuICAgIDxldC1jb21ib2JveC1vcHRpb24gKm5nRm9yPVwibGV0IG9wdGlvbiBvZiBvcHRpb25zXCIgW29wdGlvbl09XCJvcHRpb25cIiAvPlxuICA8L25nLWNvbnRhaW5lcj5cbjwvZGl2PlxuIl19
|