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