@alauda/ui 6.5.6 → 6.5.7-beta.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.
Files changed (31) hide show
  1. package/esm2020/autocomplete/autocomplete.component.mjs +2 -2
  2. package/esm2020/paginator/paginator.component.mjs +2 -2
  3. package/esm2020/scrolling/virtual-for-of.directive.mjs +14 -2
  4. package/esm2020/select/base-select.mjs +185 -88
  5. package/esm2020/select/index.mjs +2 -2
  6. package/esm2020/select/multi-select/multi-select.component.mjs +26 -47
  7. package/esm2020/select/option-group/option-group.component.mjs +13 -6
  8. package/esm2020/select/option-item/option-item.component.mjs +104 -0
  9. package/esm2020/select/option.component.mjs +46 -0
  10. package/esm2020/select/select.component.mjs +22 -18
  11. package/esm2020/select/select.module.mjs +14 -3
  12. package/esm2020/select/select.types.mjs +1 -1
  13. package/esm2020/select/validators.mjs +7 -4
  14. package/esm2020/tooltip/base-tooltip.mjs +5 -1
  15. package/esm2020/tree-select/tree-select.component.mjs +3 -3
  16. package/fesm2015/alauda-ui.mjs +1005 -864
  17. package/fesm2015/alauda-ui.mjs.map +1 -1
  18. package/fesm2020/alauda-ui.mjs +1003 -866
  19. package/fesm2020/alauda-ui.mjs.map +1 -1
  20. package/package.json +1 -1
  21. package/select/base-select.d.ts +55 -27
  22. package/select/index.d.ts +1 -1
  23. package/select/multi-select/multi-select.component.d.ts +3 -5
  24. package/select/option-group/option-group.component.d.ts +4 -3
  25. package/select/option-item/option-item.component.d.ts +41 -0
  26. package/select/option.component.d.ts +16 -0
  27. package/select/select.component.d.ts +6 -6
  28. package/select/select.module.d.ts +16 -13
  29. package/select/select.types.d.ts +8 -2
  30. package/esm2020/select/option/option.component.mjs +0 -112
  31. package/select/option/option.component.d.ts +0 -45
@@ -1,11 +1,20 @@
1
- import { ContentChild, ContentChildren, Directive, EventEmitter, Input, Output, ViewChild, ViewChildren, } from '@angular/core';
2
- import { BehaviorSubject, Subject, combineLatest, of, map, startWith, switchMap, takeUntil, } from 'rxjs';
1
+ import { ContentChild, ContentChildren, Directive, ElementRef, EventEmitter, Input, Output, ViewChild, ViewChildren, } from '@angular/core';
2
+ import { BehaviorSubject, Subject, combineLatest, map, switchMap, takeUntil, merge, startWith, } from 'rxjs';
3
3
  import { CommonFormControl } from '../form';
4
+ import { VirtualScrollViewportComponent } from '../scrolling/virtual-scroll-viewport.component';
4
5
  import { ComponentSize } from '../types';
5
6
  import { coerceAttrBoolean, coerceString, isTemplateRef, publishRef, scrollIntoView, } from '../utils';
6
7
  import { OptionContentDirective } from './helper-directives';
7
- import { OptionComponent } from './option/option.component';
8
+ import { OptionItemComponent } from './option-item/option-item.component';
9
+ import { OptionComponent } from './option.component';
8
10
  import * as i0 from "@angular/core";
11
+ export const itemSizeMap = {
12
+ [ComponentSize.Large]: 40,
13
+ [ComponentSize.Medium]: 32,
14
+ [ComponentSize.Small]: 28,
15
+ [ComponentSize.Mini]: 26,
16
+ [ComponentSize.Empty]: 32,
17
+ };
9
18
  export class BaseSelect extends CommonFormControl {
10
19
  constructor() {
11
20
  super(...arguments);
@@ -15,21 +24,34 @@ export class BaseSelect extends CommonFormControl {
15
24
  this.placeholder = '';
16
25
  this.defaultFirstOption = true;
17
26
  this.lazy = true;
27
+ this.maxItemLength = 10;
28
+ this.createFn = this._createFn;
18
29
  this.filterChange = new EventEmitter();
19
30
  this.show = new EventEmitter();
20
31
  this.hide = new EventEmitter();
21
32
  this.isTemplateRef = isTemplateRef;
22
33
  this.isMulti = false;
34
+ this.scrolledIndex = 0;
23
35
  this._size = ComponentSize.Medium;
24
36
  this._filterable = true;
25
37
  this._clearable = false;
26
38
  this._allowCreate = false;
27
39
  this._filterString = '';
40
+ this.selectableOptions = [];
28
41
  this.destroy$$ = new Subject();
29
42
  this.size$$ = new BehaviorSubject(this.size);
43
+ this.options$$ = new BehaviorSubject(null);
30
44
  this.filterString$$ = new BehaviorSubject(this.filterString);
31
45
  this.size$ = this.size$$.asObservable();
46
+ this.options$ = this.options$$.asObservable();
32
47
  this.filterString$ = this.filterString$$.asObservable();
48
+ this.allOptions$ = new BehaviorSubject([]);
49
+ this.filterOptions$ = new BehaviorSubject([]);
50
+ this.focused$ = new BehaviorSubject(null);
51
+ this.isFocus = (value, focusOption) => {
52
+ const _focusOption = focusOption || this.focused$.getValue();
53
+ return (_focusOption && this.trackFn(_focusOption.value) === this.trackFn(value));
54
+ };
33
55
  }
34
56
  get size() {
35
57
  return this._size;
@@ -41,6 +63,13 @@ export class BaseSelect extends CommonFormControl {
41
63
  this._size = val;
42
64
  this.size$$.next(val);
43
65
  }
66
+ get options() {
67
+ return this._options;
68
+ }
69
+ set options(val) {
70
+ this._options = val;
71
+ this.options$$.next(val);
72
+ }
44
73
  get filterable() {
45
74
  return this._filterable;
46
75
  }
@@ -59,18 +88,15 @@ export class BaseSelect extends CommonFormControl {
59
88
  set allowCreate(val) {
60
89
  this._allowCreate = coerceAttrBoolean(val);
61
90
  }
62
- get allOptions() {
63
- return [
64
- ...(this.customOptions ? this.customOptions.toArray() : []),
65
- ...(this.contentOptions ? this.contentOptions.toArray() : []),
66
- ];
67
- }
68
91
  get opened() {
69
92
  return this.tooltipRef.isCreated;
70
93
  }
71
94
  get inputReadonly() {
72
95
  return !(this.filterable && this.opened);
73
96
  }
97
+ get _itemSize() {
98
+ return this.itemSize || itemSizeMap[this.size];
99
+ }
74
100
  get filterString() {
75
101
  return this._filterString;
76
102
  }
@@ -82,51 +108,88 @@ export class BaseSelect extends CommonFormControl {
82
108
  }
83
109
  }
84
110
  ngAfterContentInit() {
85
- this.customCreatedOptions$ = combineLatest([
86
- this.values$,
87
- this.contentOptions.changes.pipe(startWith(this.contentOptions), switchMap((options) => options.length > 0
88
- ? combineLatest(options.map(option => option.value$))
89
- : of([]))),
90
- ]).pipe(map(([values, optionValues]) => values.reduce((acc, value) => {
91
- const included = optionValues
92
- .map(value => this.trackFn(value))
93
- .includes(this.trackFn(value));
94
- if (!included) {
95
- const label = this.labelFn?.(value) || coerceString(this.trackFn(value));
96
- if (label) {
97
- acc.push({
98
- label,
111
+ this.contentOptions$ = this.options$.pipe(switchMap(options => {
112
+ if (options?.length) {
113
+ return this.options$;
114
+ }
115
+ return combineLatest([
116
+ this.values$,
117
+ merge(...this.contentTplOptions.map(contentTpl => contentTpl.changes), this.contentTplOptions.changes).pipe(startWith(this.contentTplOptions)),
118
+ ]).pipe(map(([values]) => {
119
+ const contents = [];
120
+ let lastGroupTitle;
121
+ this.contentTplOptions.toArray().forEach(com => {
122
+ const { value, label, disabled, groupTitle, labelContext, template, } = com;
123
+ if (lastGroupTitle !== groupTitle) {
124
+ lastGroupTitle = groupTitle;
125
+ contents.push({
126
+ value,
127
+ groupTitle,
128
+ });
129
+ }
130
+ contents.push({
99
131
  value,
132
+ label,
133
+ disabled,
134
+ labelContext,
135
+ selected: this.getSelected(value, values),
136
+ contentTemplate: template,
100
137
  });
101
- }
102
- }
103
- return acc;
104
- }, [])), publishRef());
138
+ });
139
+ return contents;
140
+ }));
141
+ }), publishRef());
105
142
  }
106
143
  ngAfterViewInit() {
107
- this.allOptions$ = combineLatest([
108
- this.customOptions.changes.pipe(startWith(this.customOptions)),
109
- this.contentOptions.changes.pipe(startWith(this.contentOptions)),
110
- ]).pipe(map(([customOptions, contentOptions]) => [...customOptions.toArray(), ...contentOptions.toArray()]), publishRef());
111
- // support dynamic options loading on filtering
112
- this.allOptions$.pipe(takeUntil(this.destroy$$)).subscribe(() => {
113
- if (this.opened) {
114
- requestAnimationFrame(() => {
115
- this.autoFocusFirstOption();
116
- });
144
+ this.inputtingOption$ = this.filterString$.pipe(map(filterString => {
145
+ if (filterString && this.allowCreate) {
146
+ return this.createFn(filterString);
147
+ }
148
+ }), publishRef());
149
+ this.customOptions$ = combineLatest([
150
+ this.values$,
151
+ this.contentOptions$,
152
+ ]).pipe(map(([values, options]) => {
153
+ if (!this.allowCreate) {
154
+ return [];
117
155
  }
156
+ const optionKeys = new Set(options.map(option => this.trackFn(option.value)));
157
+ return values.reduce((acc, value) => {
158
+ if (!optionKeys.has(this.trackFn(value))) {
159
+ const label = this.labelFn?.(value) || coerceString(this.trackFn(value));
160
+ if (label) {
161
+ acc.push({
162
+ label,
163
+ value,
164
+ selected: true,
165
+ });
166
+ }
167
+ }
168
+ return acc;
169
+ }, []);
170
+ }), publishRef());
171
+ combineLatest([
172
+ this.inputtingOption$,
173
+ this.customOptions$,
174
+ this.contentOptions$,
175
+ ])
176
+ .pipe(map(([inputtingOption, customOptions, contentOptions]) => {
177
+ const arr = [...customOptions, ...contentOptions];
178
+ if (inputtingOption) {
179
+ arr.unshift(inputtingOption);
180
+ }
181
+ this.allOptions$.next(arr);
182
+ }))
183
+ .subscribe();
184
+ combineLatest([this.allOptions$, this.filterString$])
185
+ .pipe(takeUntil(this.destroy$$))
186
+ .subscribe(([options, filterString]) => {
187
+ options = options.filter(option => this.filterFn(filterString, option));
188
+ this.filterOptions$.next(options);
189
+ });
190
+ this.filterOptions$.pipe(takeUntil(this.destroy$$)).subscribe(options => {
191
+ this.selectableOptions = options.filter(option => !option.disabled);
118
192
  });
119
- this.hasMatchedOption$ = combineLatest([
120
- this.allOptions$.pipe(map(customOptions => customOptions.filter(option => option !== this.inputtingOption)),
121
- // eslint-disable-next-line sonarjs/no-identical-functions
122
- switchMap(options => options.length > 0
123
- ? combineLatest(options.map(option => option.value$))
124
- : of([]))),
125
- this.filterString$,
126
- ]).pipe(map(([values, filterString]) => values.some(value => this.trackFn(value) === filterString)), publishRef());
127
- this.hasVisibleOption$ = this.contentOptions.changes.pipe(startWith(this.contentOptions), switchMap((options) => options.length > 0
128
- ? combineLatest(options.map(option => option.visible$))
129
- : of([])), map(visible => visible.some(Boolean)), publishRef());
130
193
  }
131
194
  ngOnDestroy() {
132
195
  this.optionContent?.detach();
@@ -205,18 +268,13 @@ export class BaseSelect extends CommonFormControl {
205
268
  this.selectOption(option);
206
269
  }
207
270
  autoFocusFirstOption() {
208
- if (this.defaultFirstOption && this.allowCreate && this.filterString) {
209
- const matchedOption = this.contentOptions.find(option => this.trackFn(option.value) === this.filterString);
210
- this.resetFocusedOption(matchedOption || this.customOptions.first);
211
- return;
212
- }
213
- const selectedOption = this.allOptions.find(option => option.selected && option.visible);
271
+ const first = this.selectableOptions.find(option => option.selected) ||
272
+ this.selectableOptions[0];
214
273
  if (this.defaultFirstOption) {
215
- this.resetFocusedOption(selectedOption ||
216
- this.allOptions.find(option => option.visible && !option.disabled));
274
+ this.resetFocusedOption(first);
217
275
  }
218
- else if (selectedOption) {
219
- this.scrollToOption(selectedOption);
276
+ else {
277
+ this.scrollToOption(first);
220
278
  }
221
279
  }
222
280
  focusOptionDir(dir) {
@@ -224,37 +282,42 @@ export class BaseSelect extends CommonFormControl {
224
282
  this.openOption();
225
283
  return;
226
284
  }
227
- const visibleOptions = this.allOptions.filter(option => option.visible && !option.disabled);
228
- if (visibleOptions.length === 0) {
285
+ if (this.selectableOptions.length === 0) {
229
286
  return;
230
287
  }
231
288
  const step = dir === 'down' ? 1 : -1;
232
- let i = visibleOptions.indexOf(this.focusedOption);
289
+ let i = this.selectableOptions.findIndex(option => this.isFocus(option.value));
233
290
  i = i + step;
234
- if (i >= visibleOptions.length) {
291
+ if (i >= this.selectableOptions.length) {
235
292
  i = 0;
236
293
  }
237
294
  else if (i < 0) {
238
- i = visibleOptions.length - 1;
295
+ i = this.selectableOptions.length - 1;
239
296
  }
240
- this.resetFocusedOption(visibleOptions[i]);
297
+ this.resetFocusedOption(this.selectableOptions[i]);
241
298
  }
242
299
  resetFocusedOption(focusedOption) {
243
- if (this.focusedOption === focusedOption) {
244
- return;
245
- }
246
- if (this.focusedOption) {
247
- this.focusedOption.blur();
248
- }
249
- this.focusedOption = focusedOption;
250
- if (this.focusedOption) {
251
- this.focusedOption.focus();
252
- this.scrollToOption(this.focusedOption);
300
+ if (focusedOption?.value) {
301
+ this.focused$.next(focusedOption);
302
+ this.scrollToOption(focusedOption);
253
303
  }
254
304
  }
305
+ onScrolledIndexChange(index) {
306
+ this.scrolledIndex = index;
307
+ }
255
308
  scrollToOption(option) {
256
- if (this.optionListRef) {
257
- scrollIntoView(this.optionListRef.nativeElement, option.elRef.nativeElement);
309
+ const index = this.filterOptions$
310
+ .getValue()
311
+ .findIndex(item => this.trackFn(item.value) === this.trackFn(option.value));
312
+ if (!this.virtualScrollViewport) {
313
+ if (this.contentOptionItems.get(index)) {
314
+ scrollIntoView(this.optionListRef.nativeElement, this.contentOptionItems.get(index).nativeElement);
315
+ }
316
+ return;
317
+ }
318
+ if (index < this.scrolledIndex ||
319
+ index >= this.scrolledIndex + this.maxItemLength) {
320
+ this.virtualScrollViewport.scrollToIndex(index || 0);
258
321
  }
259
322
  }
260
323
  selectFocusedOption() {
@@ -262,16 +325,38 @@ export class BaseSelect extends CommonFormControl {
262
325
  this.openOption();
263
326
  return;
264
327
  }
265
- if (this.focusedOption && !this.focusedOption.disabled) {
266
- this.selectOption(this.focusedOption);
328
+ let focusedOption = this.focused$.getValue();
329
+ if (focusedOption) {
330
+ // 更新聚焦的option,例如:focus某一项后一直按enter键
331
+ focusedOption = this.selectableOptions.find(option => this.trackFn(option.value) === this.trackFn(focusedOption.value));
332
+ focusedOption && this.selectOption(focusedOption);
267
333
  }
268
334
  }
335
+ getSelected(value, values) {
336
+ return values.some(item => this.trackFn(item) === this.trackFn(value));
337
+ }
338
+ focus(option) {
339
+ this.focused$.next(option);
340
+ }
341
+ blur() {
342
+ this.focused$.next(null);
343
+ }
344
+ getLabelByValue(value) {
345
+ return this.labelFn?.(value) || coerceString(this.trackFn(value));
346
+ }
269
347
  escSelect() {
270
348
  this.closeOption();
271
349
  }
272
350
  _trackFn(value) {
273
351
  return value;
274
352
  }
353
+ _createFn(input) {
354
+ // @ts-ignore
355
+ const value = input;
356
+ return {
357
+ value,
358
+ };
359
+ }
275
360
  _filterFn(filterString, { label, value }) {
276
361
  return ((typeof label === 'string' && label) ||
277
362
  this.labelFn?.(value) ||
@@ -281,23 +366,25 @@ export class BaseSelect extends CommonFormControl {
281
366
  }
282
367
  }
283
368
  BaseSelect.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: BaseSelect, deps: null, target: i0.ɵɵFactoryTarget.Directive });
284
- BaseSelect.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.8", type: BaseSelect, inputs: { size: "size", filterable: "filterable", clearable: "clearable", filterFn: "filterFn", trackFn: "trackFn", labelFn: "labelFn", allowCreate: "allowCreate", loading: "loading", placeholder: "placeholder", defaultFirstOption: "defaultFirstOption", lazy: "lazy" }, outputs: { filterChange: "filterChange", show: "show", hide: "hide" }, queries: [{ propertyName: "optionContent", first: true, predicate: OptionContentDirective, descendants: true }, { propertyName: "contentOptions", predicate: OptionComponent, descendants: true }], viewQueries: [{ propertyName: "selectRef", first: true, predicate: ["selectRef"], descendants: true, static: true }, { propertyName: "tooltipRef", first: true, predicate: ["tooltipRef"], descendants: true, static: true }, { propertyName: "optionListRef", first: true, predicate: ["optionListRef"], descendants: true }, { propertyName: "inputtingOption", first: true, predicate: ["inputtingOption"], descendants: true }, { propertyName: "customOptions", predicate: OptionComponent, descendants: true }], usesInheritance: true, ngImport: i0 });
369
+ BaseSelect.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.8", type: BaseSelect, inputs: { size: "size", options: "options", filterable: "filterable", clearable: "clearable", allowCreate: "allowCreate", filterFn: "filterFn", trackFn: "trackFn", labelFn: "labelFn", loading: "loading", placeholder: "placeholder", defaultFirstOption: "defaultFirstOption", lazy: "lazy", useVirtual: "useVirtual", itemSize: "itemSize", maxItemLength: "maxItemLength", createFn: "createFn" }, outputs: { filterChange: "filterChange", show: "show", hide: "hide" }, queries: [{ propertyName: "optionContent", first: true, predicate: OptionContentDirective, descendants: true }, { propertyName: "contentTplOptions", predicate: OptionComponent, descendants: true }], viewQueries: [{ propertyName: "selectRef", first: true, predicate: ["selectRef"], descendants: true, static: true }, { propertyName: "tooltipRef", first: true, predicate: ["tooltipRef"], descendants: true, static: true }, { propertyName: "optionListRef", first: true, predicate: ["optionListRef"], descendants: true }, { propertyName: "virtualScrollViewport", first: true, predicate: VirtualScrollViewportComponent, descendants: true }, { propertyName: "contentOptionItems", predicate: OptionItemComponent, descendants: true, read: ElementRef }], usesInheritance: true, ngImport: i0 });
285
370
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: BaseSelect, decorators: [{
286
371
  type: Directive
287
372
  }], propDecorators: { size: [{
288
373
  type: Input
374
+ }], options: [{
375
+ type: Input
289
376
  }], filterable: [{
290
377
  type: Input
291
378
  }], clearable: [{
292
379
  type: Input
380
+ }], allowCreate: [{
381
+ type: Input
293
382
  }], filterFn: [{
294
383
  type: Input
295
384
  }], trackFn: [{
296
385
  type: Input
297
386
  }], labelFn: [{
298
387
  type: Input
299
- }], allowCreate: [{
300
- type: Input
301
388
  }], loading: [{
302
389
  type: Input
303
390
  }], placeholder: [{
@@ -306,6 +393,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
306
393
  type: Input
307
394
  }], lazy: [{
308
395
  type: Input
396
+ }], useVirtual: [{
397
+ type: Input
398
+ }],
399
+ // TODO 还不支持动态高度的option
400
+ itemSize: [{
401
+ type: Input
402
+ }], maxItemLength: [{
403
+ type: Input
404
+ }], createFn: [{
405
+ type: Input
309
406
  }], filterChange: [{
310
407
  type: Output
311
408
  }], show: [{
@@ -321,17 +418,17 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
321
418
  }], optionListRef: [{
322
419
  type: ViewChild,
323
420
  args: ['optionListRef', { static: false }]
324
- }], inputtingOption: [{
421
+ }], virtualScrollViewport: [{
325
422
  type: ViewChild,
326
- args: ['inputtingOption', { static: false }]
423
+ args: [VirtualScrollViewportComponent]
424
+ }], contentOptionItems: [{
425
+ type: ViewChildren,
426
+ args: [OptionItemComponent, { read: ElementRef }]
327
427
  }], optionContent: [{
328
428
  type: ContentChild,
329
429
  args: [OptionContentDirective]
330
- }], customOptions: [{
331
- type: ViewChildren,
332
- args: [OptionComponent]
333
- }], contentOptions: [{
430
+ }], contentTplOptions: [{
334
431
  type: ContentChildren,
335
432
  args: [OptionComponent, { descendants: true }]
336
433
  }] } });
337
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-select.js","sourceRoot":"","sources":["../../../src/select/base-select.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,YAAY,EACZ,eAAe,EACf,SAAS,EAET,YAAY,EACZ,KAAK,EAEL,MAAM,EAEN,SAAS,EACT,YAAY,GACb,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,eAAe,EAEf,OAAO,EACP,aAAa,EACb,EAAE,EACF,GAAG,EACH,SAAS,EACT,SAAS,EACT,SAAS,GACV,MAAM,MAAM,CAAC;AAEd,OAAO,EAAE,iBAAiB,EAAE,MAAM,SAAS,CAAC;AAE5C,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EACL,iBAAiB,EACjB,YAAY,EACZ,aAAa,EACb,UAAU,EACV,cAAc,GACf,MAAM,UAAU,CAAC;AAElB,OAAO,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAC7D,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAC;;AAI5D,MAAM,OAAgB,UACpB,SAAQ,iBAAoB;IAF9B;;QAqCE,aAAQ,GAAsB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAGxD,YAAO,GAAe,IAAI,CAAC,QAAQ,CAAC;QA0CpC,YAAO,GAAG,KAAK,CAAC;QAGhB,gBAAW,GAAG,EAAE,CAAC;QAGjB,uBAAkB,GAAG,IAAI,CAAC;QAG1B,SAAI,GAAG,IAAI,CAAC;QAGZ,iBAAY,GAAG,IAAI,YAAY,EAAU,CAAC;QAG1C,SAAI,GAAG,IAAI,YAAY,EAAQ,CAAC;QAGhC,SAAI,GAAG,IAAI,YAAY,EAAQ,CAAC;QAuBhC,kBAAa,GAAG,aAAa,CAAC;QAC9B,YAAO,GAAG,KAAK,CAAC;QAWR,UAAK,GAAkB,aAAa,CAAC,MAAM,CAAC;QAC5C,gBAAW,GAAG,IAAI,CAAC;QACnB,eAAU,GAAG,KAAK,CAAC;QACnB,iBAAY,GAAG,KAAK,CAAC;QACrB,kBAAa,GAAG,EAAE,CAAC;QAEjB,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;QAChC,WAAM,GAAG,IAAI,eAAe,CAAgB,IAAI,CAAC,IAAI,CAAC,CAAC;QAChD,mBAAc,GAAG,IAAI,eAAe,CACnD,IAAI,CAAC,YAAY,CAClB,CAAC;QAEF,UAAK,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;QACnC,kBAAa,GAAG,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;KAkSpD;IAjbC,IACI,IAAI;QACN,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IAAI,IAAI,CAAC,GAAG;QACV,IAAI,CAAC,GAAG,IAAI,IAAI,CAAC,KAAK,KAAK,GAAG,EAAE;YAC9B,OAAO;SACR;QACD,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;QACjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACxB,CAAC;IAED,IACI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,IAAI,UAAU,CAAC,GAAiB;QAC9B,IAAI,CAAC,WAAW,GAAG,iBAAiB,CAAC,GAAG,CAAC,CAAC;IAC5C,CAAC;IAED,IACI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,IAAI,SAAS,CAAC,GAAiB;QAC7B,IAAI,CAAC,UAAU,GAAG,iBAAiB,CAAC,GAAG,CAAC,CAAC;IAC3C,CAAC;IAWD,IACI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAED,IAAI,WAAW,CAAC,GAAiB;QAC/B,IAAI,CAAC,YAAY,GAAG,iBAAiB,CAAC,GAAG,CAAC,CAAC;IAC7C,CAAC;IAED,IAAI,UAAU;QACZ,OAAO;YACL,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAC3D,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAC9D,CAAC;IACJ,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC;IACnC,CAAC;IAED,IAAI,aAAa;QACf,OAAO,CAAC,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,MAAM,CAAC,CAAC;IAC3C,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,IAAI,YAAY,CAAC,GAAG;QAClB,IAAI,GAAG,KAAK,IAAI,CAAC,aAAa,EAAE;YAC9B,IAAI,CAAC,aAAa,GAAG,GAAG,CAAC;YACzB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC9B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;SAC7B;IACH,CAAC;IA2ED,kBAAkB;QAChB,IAAI,CAAC,qBAAqB,GAAG,aAAa,CAAC;YACzC,IAAI,CAAC,OAAO;YAEV,IAAI,CAAC,cAAc,CAAC,OACrB,CAAC,IAAI,CACJ,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,EAC9B,SAAS,CAAC,CAAC,OAAsC,EAAE,EAAE,CACnD,OAAO,CAAC,MAAM,GAAG,CAAC;gBAChB,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACrD,CAAC,CAAC,EAAE,CAAC,EAAS,CAAC,CAClB,CACF;SACF,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,YAAY,CAAC,EAAE,EAAE,CAC7B,MAAM,CAAC,MAAM,CAA+B,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;YACzD,MAAM,QAAQ,GAAG,YAAY;iBAC1B,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;iBACjC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;YACjC,IAAI,CAAC,QAAQ,EAAE;gBACb,MAAM,KAAK,GACT,IAAI,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,IAAI,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;gBAC7D,IAAI,KAAK,EAAE;oBACT,GAAG,CAAC,IAAI,CAAC;wBACP,KAAK;wBACL,KAAK;qBACN,CAAC,CAAC;iBACJ;aACF;YACD,OAAO,GAAG,CAAC;QACb,CAAC,EAAE,EAAE,CAAC,CACP,EACD,UAAU,EAAE,CACb,CAAC;IACJ,CAAC;IAED,eAAe;QACb,IAAI,CAAC,WAAW,GAAG,aAAa,CAAC;YAC/B,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;YAC9D,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACjE,CAAC,CAAC,IAAI,CACL,GAAG,CACD,CAAC,CAAC,aAAa,EAAE,cAAc,CAG9B,EAAE,EAAE,CAAC,CAAC,GAAG,aAAa,CAAC,OAAO,EAAE,EAAE,GAAG,cAAc,CAAC,OAAO,EAAE,CAAC,CAChE,EACD,UAAU,EAAE,CACb,CAAC;QAEF,+CAA+C;QAC/C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC9D,IAAI,IAAI,CAAC,MAAM,EAAE;gBACf,qBAAqB,CAAC,GAAG,EAAE;oBACzB,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAC9B,CAAC,CAAC,CAAC;aACJ;QACH,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,iBAAiB,GAAG,aAAa,CAAC;YACrC,IAAI,CAAC,WAAW,CAAC,IAAI,CACnB,GAAG,CAAC,aAAa,CAAC,EAAE,CAClB,aAAa,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,KAAK,IAAI,CAAC,eAAe,CAAC,CAChE;YACD,0DAA0D;YAC1D,SAAS,CAAC,OAAO,CAAC,EAAE,CAClB,OAAO,CAAC,MAAM,GAAG,CAAC;gBAChB,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;gBACrD,CAAC,CAAC,EAAE,CAAC,EAAS,CAAC,CAClB,CACF;YACD,IAAI,CAAC,aAAa;SACnB,CAAC,CAAC,IAAI,CACL,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,YAAY,CAAC,EAAE,EAAE,CAC7B,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,KAAK,YAAY,CAAC,CAC3D,EACD,UAAU,EAAE,CACb,CAAC;QAEF,IAAI,CAAC,iBAAiB,GACpB,IAAI,CAAC,cAAc,CAAC,OACrB,CAAC,IAAI,CACJ,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,EAC9B,SAAS,CAAC,CAAC,OAAsC,EAAE,EAAE,CACnD,OAAO,CAAC,MAAM,GAAG,CAAC;YAChB,CAAC,CAAC,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YACvD,CAAC,CAAC,EAAE,CAAC,EAAe,CAAC,CACxB,EACD,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EACrC,UAAU,EAAE,CACb,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC;QAC7B,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAED,UAAU;QACR,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC;IAClC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC;IACnC,CAAC;IAED,aAAa;QACX,MAAM,IAAI,GAAG,GAAG,EAAE;YAChB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,WAAW,GAAG,IAAI,CAAC;YAEtE,qBAAqB,CAAC,GAAG,EAAE;gBACzB,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC9B,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;QACnB,CAAC,CAAC;QAEF,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,qBAAqB,CAAC,GAAG,EAAE;gBACzB,IAAI,CAAC,aAAa,CAAC,MAAM,EAAE,CAAC;gBAC5B,IAAI,EAAE,CAAC;YACT,CAAC,CAAC,CAAC;SACJ;aAAM;YACL,IAAI,EAAE,CAAC;SACR;IACH,CAAC;IAED,aAAa;QACX,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;QACD,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;YACd,IAAI,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC;SAC9B;QACD,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;IACnB,CAAC;IAED,OAAO,CAAC,KAAY;QAClB,MAAM,KAAK,GAAI,KAAK,CAAC,MAA2B,CAAC,KAAK,CAAC;QACvD,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAE1B,qBAAqB,CAAC,GAAG,EAAE;YACzB,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,CAAC,CAAC,CAAC;QAEH,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,SAAS,CAAC,KAAoB;QAC5B,QAAQ,KAAK,CAAC,GAAG,EAAE;YACjB,KAAK,WAAW;gBACd,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;gBAC5B,KAAK,CAAC,eAAe,EAAE,CAAC;gBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;YACR,KAAK,SAAS;gBACZ,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;gBAC1B,KAAK,CAAC,eAAe,EAAE,CAAC;gBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;YACR,KAAK,OAAO;gBACV,IAAI,CAAC,mBAAmB,EAAE,CAAC;gBAC3B,KAAK,CAAC,eAAe,EAAE,CAAC;gBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;YACR,KAAK,QAAQ;gBACX,IAAI,CAAC,SAAS,EAAE,CAAC;gBACjB,KAAK,CAAC,eAAe,EAAE,CAAC;gBACxB,KAAK,CAAC,cAAc,EAAE,CAAC;gBACvB,MAAM;SACT;IACH,CAAC;IAED,aAAa,CAAC,MAA0B;QACtC,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;QAChC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAES,oBAAoB;QAC5B,IAAI,IAAI,CAAC,kBAAkB,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,YAAY,EAAE;YACpE,MAAM,aAAa,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAC5C,MAAM,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,IAAI,CAAC,YAAY,CAC3D,CAAC;YACF,IAAI,CAAC,kBAAkB,CAAC,aAAa,IAAI,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YACnE,OAAO;SACR;QAED,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CACzC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,OAAO,CAC5C,CAAC;QACF,IAAI,IAAI,CAAC,kBAAkB,EAAE;YAC3B,IAAI,CAAC,kBAAkB,CACrB,cAAc;gBACZ,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CACrE,CAAC;SACH;aAAM,IAAI,cAAc,EAAE;YACzB,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,CAAC;SACrC;IACH,CAAC;IAES,cAAc,CAAC,GAAkB;QACzC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,OAAO;SACR;QACD,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,MAAM,CAC3C,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,CAC7C,CAAC;QACF,IAAI,cAAc,CAAC,MAAM,KAAK,CAAC,EAAE;YAC/B,OAAO;SACR;QACD,MAAM,IAAI,GAAG,GAAG,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACrC,IAAI,CAAC,GAAG,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACnD,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;QACb,IAAI,CAAC,IAAI,cAAc,CAAC,MAAM,EAAE;YAC9B,CAAC,GAAG,CAAC,CAAC;SACP;aAAM,IAAI,CAAC,GAAG,CAAC,EAAE;YAChB,CAAC,GAAG,cAAc,CAAC,MAAM,GAAG,CAAC,CAAC;SAC/B;QACD,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAC;IAC7C,CAAC;IAES,kBAAkB,CAAC,aAAkC;QAC7D,IAAI,IAAI,CAAC,aAAa,KAAK,aAAa,EAAE;YACxC,OAAO;SACR;QAED,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;SAC3B;QAED,IAAI,CAAC,aAAa,GAAG,aAAa,CAAC;QAEnC,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YAC3B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SACzC;IACH,CAAC;IAES,cAAc,CAAC,MAA0B;QACjD,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,cAAc,CACZ,IAAI,CAAC,aAAa,CAAC,aAAa,EAChC,MAAM,CAAC,KAAK,CAAC,aAAa,CAC3B,CAAC;SACH;IACH,CAAC;IAES,mBAAmB;QAC3B,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,UAAU,EAAE,CAAC;YAClB,OAAO;SACR;QACD,IAAI,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE;YACtD,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SACvC;IACH,CAAC;IAES,SAAS;QACjB,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAEO,QAAQ,CAAI,KAAQ;QAC1B,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,SAAS,CACf,YAAoB,EACpB,EAAE,KAAK,EAAE,KAAK,EAAyB;QAEvC,OAAO,CACL,CAAC,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,CAAC;YACpC,IAAI,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC;YACrB,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAClC;YACC,EAAE,WAAW,EAAE;aACd,QAAQ,CAAC,YAAY,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAC;IACjD,CAAC;;uGAjbmB,UAAU;2FAAV,UAAU,0ZAiHhB,sBAAsB,oEAMnB,eAAe,weAHlB,eAAe;2FApHT,UAAU;kBAD/B,SAAS;8BAMJ,IAAI;sBADP,KAAK;gBAcF,UAAU;sBADb,KAAK;gBAUF,SAAS;sBADZ,KAAK;gBAUN,QAAQ;sBADP,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAIF,WAAW;sBADd,KAAK;gBAqCN,OAAO;sBADN,KAAK;gBAIN,WAAW;sBADV,KAAK;gBAIN,kBAAkB;sBADjB,KAAK;gBAIN,IAAI;sBADH,KAAK;gBAIN,YAAY;sBADX,MAAM;gBAIP,IAAI;sBADH,MAAM;gBAIP,IAAI;sBADH,MAAM;gBAIG,SAAS;sBADlB,SAAS;uBAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAI9B,UAAU;sBADnB,SAAS;uBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAI/B,aAAa;sBADtB,SAAS;uBAAC,eAAe,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAInC,eAAe;sBADxB,SAAS;uBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAIrC,aAAa;sBADtB,YAAY;uBAAC,sBAAsB;gBAIpC,aAAa;sBADZ,YAAY;uBAAC,eAAe;gBAI7B,cAAc;sBADb,eAAe;uBAAC,eAAe,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  ContentChild,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport {\n  BehaviorSubject,\n  Observable,\n  Subject,\n  combineLatest,\n  of,\n  map,\n  startWith,\n  switchMap,\n  takeUntil,\n} from 'rxjs';\n\nimport { CommonFormControl } from '../form';\nimport { TooltipDirective } from '../tooltip';\nimport { ComponentSize } from '../types';\nimport {\n  coerceAttrBoolean,\n  coerceString,\n  isTemplateRef,\n  publishRef,\n  scrollIntoView,\n} from '../utils';\n\nimport { OptionContentDirective } from './helper-directives';\nimport { OptionComponent } from './option/option.component';\nimport { OptionFilterFn, SelectFilterOption, TrackFn } from './select.types';\n\n@Directive()\nexport abstract class BaseSelect<T, V = T>\n  extends CommonFormControl<V>\n  implements AfterContentInit, AfterViewInit, OnDestroy\n{\n  @Input()\n  get size() {\n    return this._size;\n  }\n\n  set size(val) {\n    if (!val || this._size === val) {\n      return;\n    }\n    this._size = val;\n    this.size$$.next(val);\n  }\n\n  @Input()\n  get filterable() {\n    return this._filterable;\n  }\n\n  set filterable(val: boolean | '') {\n    this._filterable = coerceAttrBoolean(val);\n  }\n\n  @Input()\n  get clearable() {\n    return this._clearable;\n  }\n\n  set clearable(val: boolean | '') {\n    this._clearable = coerceAttrBoolean(val);\n  }\n\n  @Input()\n  filterFn: OptionFilterFn<T> = this._filterFn.bind(this);\n\n  @Input()\n  trackFn: TrackFn<T> = this._trackFn;\n\n  @Input()\n  labelFn?: (value: T) => string;\n\n  @Input()\n  get allowCreate() {\n    return this._allowCreate;\n  }\n\n  set allowCreate(val: boolean | '') {\n    this._allowCreate = coerceAttrBoolean(val);\n  }\n\n  get allOptions() {\n    return [\n      ...(this.customOptions ? this.customOptions.toArray() : []),\n      ...(this.contentOptions ? this.contentOptions.toArray() : []),\n    ];\n  }\n\n  get opened() {\n    return this.tooltipRef.isCreated;\n  }\n\n  get inputReadonly() {\n    return !(this.filterable && this.opened);\n  }\n\n  get filterString() {\n    return this._filterString;\n  }\n\n  set filterString(val) {\n    if (val !== this._filterString) {\n      this._filterString = val;\n      this.filterString$$.next(val);\n      this.filterChange.emit(val);\n    }\n  }\n\n  @Input()\n  loading = false;\n\n  @Input()\n  placeholder = '';\n\n  @Input()\n  defaultFirstOption = true;\n\n  @Input()\n  lazy = true;\n\n  @Output()\n  filterChange = new EventEmitter<string>();\n\n  @Output()\n  show = new EventEmitter<void>();\n\n  @Output()\n  hide = new EventEmitter<void>();\n\n  @ViewChild('selectRef', { static: true })\n  protected selectRef: ElementRef<HTMLElement>;\n\n  @ViewChild('tooltipRef', { static: true })\n  protected tooltipRef: TooltipDirective;\n\n  @ViewChild('optionListRef', { static: false })\n  protected optionListRef: ElementRef<HTMLDivElement>;\n\n  @ViewChild('inputtingOption', { static: false })\n  protected inputtingOption: OptionComponent<T>;\n\n  @ContentChild(OptionContentDirective)\n  protected optionContent?: OptionContentDirective;\n\n  @ViewChildren(OptionComponent)\n  customOptions: QueryList<OptionComponent<T>>;\n\n  @ContentChildren(OptionComponent, { descendants: true })\n  contentOptions: QueryList<OptionComponent<T>>;\n\n  isTemplateRef = isTemplateRef;\n  isMulti = false;\n\n  /**\n   * Utility field to make sure the users always see the value as type array\n   */\n  abstract readonly values$: Observable<T[]>;\n\n  allOptions$: Observable<Array<OptionComponent<T>>>;\n\n  protected focusedOption: OptionComponent<T>;\n\n  private _size: ComponentSize = ComponentSize.Medium;\n  private _filterable = true;\n  private _clearable = false;\n  private _allowCreate = false;\n  private _filterString = '';\n\n  protected destroy$$ = new Subject<void>();\n  protected size$$ = new BehaviorSubject<ComponentSize>(this.size);\n  private readonly filterString$$ = new BehaviorSubject<string>(\n    this.filterString,\n  );\n\n  size$ = this.size$$.asObservable();\n  filterString$ = this.filterString$$.asObservable();\n  hasVisibleOption$: Observable<boolean>;\n  hasMatchedOption$: Observable<boolean>;\n  customCreatedOptions$: Observable<Array<SelectFilterOption<T>>>;\n  containerWidth: string;\n\n  ngAfterContentInit() {\n    this.customCreatedOptions$ = combineLatest([\n      this.values$,\n      (\n        this.contentOptions.changes as Observable<QueryList<OptionComponent<T>>>\n      ).pipe(\n        startWith(this.contentOptions),\n        switchMap((options: QueryList<OptionComponent<T>>) =>\n          options.length > 0\n            ? combineLatest(options.map(option => option.value$))\n            : of([] as T[]),\n        ),\n      ),\n    ]).pipe(\n      map(([values, optionValues]) =>\n        values.reduce<Array<SelectFilterOption<T>>>((acc, value) => {\n          const included = optionValues\n            .map(value => this.trackFn(value))\n            .includes(this.trackFn(value));\n          if (!included) {\n            const label =\n              this.labelFn?.(value) || coerceString(this.trackFn(value));\n            if (label) {\n              acc.push({\n                label,\n                value,\n              });\n            }\n          }\n          return acc;\n        }, []),\n      ),\n      publishRef(),\n    );\n  }\n\n  ngAfterViewInit() {\n    this.allOptions$ = combineLatest([\n      this.customOptions.changes.pipe(startWith(this.customOptions)),\n      this.contentOptions.changes.pipe(startWith(this.contentOptions)),\n    ]).pipe(\n      map(\n        ([customOptions, contentOptions]: [\n          QueryList<OptionComponent<T>>,\n          QueryList<OptionComponent<T>>,\n        ]) => [...customOptions.toArray(), ...contentOptions.toArray()],\n      ),\n      publishRef(),\n    );\n\n    // support dynamic options loading on filtering\n    this.allOptions$.pipe(takeUntil(this.destroy$$)).subscribe(() => {\n      if (this.opened) {\n        requestAnimationFrame(() => {\n          this.autoFocusFirstOption();\n        });\n      }\n    });\n\n    this.hasMatchedOption$ = combineLatest([\n      this.allOptions$.pipe(\n        map(customOptions =>\n          customOptions.filter(option => option !== this.inputtingOption),\n        ),\n        // eslint-disable-next-line sonarjs/no-identical-functions\n        switchMap(options =>\n          options.length > 0\n            ? combineLatest(options.map(option => option.value$))\n            : of([] as T[]),\n        ),\n      ),\n      this.filterString$,\n    ]).pipe(\n      map(([values, filterString]) =>\n        values.some(value => this.trackFn(value) === filterString),\n      ),\n      publishRef(),\n    );\n\n    this.hasVisibleOption$ = (\n      this.contentOptions.changes as Observable<QueryList<OptionComponent<T>>>\n    ).pipe(\n      startWith(this.contentOptions),\n      switchMap((options: QueryList<OptionComponent<T>>) =>\n        options.length > 0\n          ? combineLatest(options.map(option => option.visible$))\n          : of([] as boolean[]),\n      ),\n      map(visible => visible.some(Boolean)),\n      publishRef(),\n    );\n  }\n\n  ngOnDestroy() {\n    this.optionContent?.detach();\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  openOption() {\n    this.tooltipRef.createTooltip();\n  }\n\n  closeOption() {\n    this.tooltipRef.disposeTooltip();\n  }\n\n  onShowOptions() {\n    const exec = () => {\n      this.containerWidth = this.selectRef.nativeElement.offsetWidth + 'px';\n\n      requestAnimationFrame(() => {\n        this.autoFocusFirstOption();\n      });\n\n      this.show.emit();\n    };\n\n    if (this.optionContent) {\n      requestAnimationFrame(() => {\n        this.optionContent.attach();\n        exec();\n      });\n    } else {\n      exec();\n    }\n  }\n\n  onHideOptions() {\n    if (this.onTouched) {\n      this.onTouched();\n    }\n    if (!this.lazy) {\n      this.optionContent?.detach();\n    }\n    this.resetFocusedOption();\n    this.filterString = '';\n    this.hide.emit();\n  }\n\n  onInput(event: Event) {\n    const value = (event.target as HTMLInputElement).value;\n    this.filterString = value;\n\n    requestAnimationFrame(() => {\n      this.autoFocusFirstOption();\n    });\n\n    this.cdr.markForCheck();\n  }\n\n  onKeyDown(event: KeyboardEvent) {\n    switch (event.key) {\n      case 'ArrowDown':\n        this.focusOptionDir('down');\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n      case 'ArrowUp':\n        this.focusOptionDir('up');\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n      case 'Enter':\n        this.selectFocusedOption();\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n      case 'Escape':\n        this.escSelect();\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n    }\n  }\n\n  onOptionClick(option: OptionComponent<T>) {\n    this.resetFocusedOption(option);\n    this.selectOption(option);\n  }\n\n  protected autoFocusFirstOption() {\n    if (this.defaultFirstOption && this.allowCreate && this.filterString) {\n      const matchedOption = this.contentOptions.find(\n        option => this.trackFn(option.value) === this.filterString,\n      );\n      this.resetFocusedOption(matchedOption || this.customOptions.first);\n      return;\n    }\n\n    const selectedOption = this.allOptions.find(\n      option => option.selected && option.visible,\n    );\n    if (this.defaultFirstOption) {\n      this.resetFocusedOption(\n        selectedOption ||\n          this.allOptions.find(option => option.visible && !option.disabled),\n      );\n    } else if (selectedOption) {\n      this.scrollToOption(selectedOption);\n    }\n  }\n\n  protected focusOptionDir(dir: 'down' | 'up') {\n    if (!this.opened) {\n      this.openOption();\n      return;\n    }\n    const visibleOptions = this.allOptions.filter(\n      option => option.visible && !option.disabled,\n    );\n    if (visibleOptions.length === 0) {\n      return;\n    }\n    const step = dir === 'down' ? 1 : -1;\n    let i = visibleOptions.indexOf(this.focusedOption);\n    i = i + step;\n    if (i >= visibleOptions.length) {\n      i = 0;\n    } else if (i < 0) {\n      i = visibleOptions.length - 1;\n    }\n    this.resetFocusedOption(visibleOptions[i]);\n  }\n\n  protected resetFocusedOption(focusedOption?: OptionComponent<T>) {\n    if (this.focusedOption === focusedOption) {\n      return;\n    }\n\n    if (this.focusedOption) {\n      this.focusedOption.blur();\n    }\n\n    this.focusedOption = focusedOption;\n\n    if (this.focusedOption) {\n      this.focusedOption.focus();\n      this.scrollToOption(this.focusedOption);\n    }\n  }\n\n  protected scrollToOption(option: OptionComponent<T>) {\n    if (this.optionListRef) {\n      scrollIntoView(\n        this.optionListRef.nativeElement,\n        option.elRef.nativeElement,\n      );\n    }\n  }\n\n  protected selectFocusedOption() {\n    if (!this.opened) {\n      this.openOption();\n      return;\n    }\n    if (this.focusedOption && !this.focusedOption.disabled) {\n      this.selectOption(this.focusedOption);\n    }\n  }\n\n  protected escSelect() {\n    this.closeOption();\n  }\n\n  private _trackFn<T>(value: T) {\n    return value;\n  }\n\n  private _filterFn(\n    filterString: string,\n    { label, value }: SelectFilterOption<T>,\n  ) {\n    return (\n      (typeof label === 'string' && label) ||\n      this.labelFn?.(value) ||\n      coerceString(this.trackFn(value))\n    )\n      ?.toLowerCase()\n      .includes(filterString?.toLowerCase() ?? '');\n  }\n\n  abstract selectOption(option: OptionComponent<T>): void;\n  abstract clearValue(event: Event): void;\n}\n"]}
434
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-select.js","sourceRoot":"","sources":["../../../src/select/base-select.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  ContentChild,\n  ContentChildren,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewChildren,\n} from '@angular/core';\nimport {\n  BehaviorSubject,\n  Observable,\n  Subject,\n  combineLatest,\n  map,\n  switchMap,\n  takeUntil,\n  merge,\n  startWith,\n} from 'rxjs';\n\nimport { CommonFormControl } from '../form';\nimport { VirtualScrollViewportComponent } from '../scrolling/virtual-scroll-viewport.component';\nimport { TooltipDirective } from '../tooltip';\nimport { ComponentSize } from '../types';\nimport {\n  coerceAttrBoolean,\n  coerceString,\n  isTemplateRef,\n  publishRef,\n  scrollIntoView,\n} from '../utils';\n\nimport { OptionContentDirective } from './helper-directives';\nimport { OptionItemComponent } from './option-item/option-item.component';\nimport { OptionComponent } from './option.component';\nimport {\n  CreateFn,\n  DisplayOption,\n  OptionFilterFn,\n  SelectFilterOption,\n  TrackFn,\n} from './select.types';\n\nexport const itemSizeMap = {\n  [ComponentSize.Large]: 40,\n  [ComponentSize.Medium]: 32,\n  [ComponentSize.Small]: 28,\n  [ComponentSize.Mini]: 26,\n  [ComponentSize.Empty]: 32,\n};\n\n@Directive()\nexport abstract class BaseSelect<T, V = T>\n  extends CommonFormControl<V>\n  implements AfterContentInit, AfterViewInit, OnDestroy\n{\n  @Input()\n  get size() {\n    return this._size;\n  }\n\n  set size(val) {\n    if (!val || this._size === val) {\n      return;\n    }\n    this._size = val;\n    this.size$$.next(val);\n  }\n\n  @Input()\n  get options() {\n    return this._options;\n  }\n\n  set options(val: Array<SelectFilterOption<T>>) {\n    this._options = val;\n    this.options$$.next(val);\n  }\n\n  @Input()\n  get filterable() {\n    return this._filterable;\n  }\n\n  set filterable(val: boolean | '') {\n    this._filterable = coerceAttrBoolean(val);\n  }\n\n  @Input()\n  get clearable() {\n    return this._clearable;\n  }\n\n  set clearable(val: boolean | '') {\n    this._clearable = coerceAttrBoolean(val);\n  }\n\n  @Input()\n  get allowCreate() {\n    return this._allowCreate;\n  }\n\n  set allowCreate(val: boolean | '') {\n    this._allowCreate = coerceAttrBoolean(val);\n  }\n\n  @Input()\n  filterFn: OptionFilterFn<T> = this._filterFn.bind(this);\n\n  @Input()\n  trackFn: TrackFn<T> = this._trackFn;\n\n  @Input()\n  labelFn?: (value: T) => string;\n\n  @Input()\n  loading = false;\n\n  @Input()\n  placeholder = '';\n\n  @Input()\n  defaultFirstOption = true;\n\n  @Input()\n  lazy = true;\n\n  // TODO\n  // 1. 还不完全支持多选（输入框中大量的tag）\n  // 2. 还不完全支持group（group高度和item不一致）\n  @Input()\n  useVirtual: boolean;\n\n  @Input()\n  // TODO 还不支持动态高度的option\n  itemSize: number;\n\n  @Input()\n  maxItemLength = 10;\n\n  @Input()\n  createFn: CreateFn<T> = this._createFn;\n\n  @Output()\n  filterChange = new EventEmitter<string>();\n\n  @Output()\n  show = new EventEmitter<void>();\n\n  @Output()\n  hide = new EventEmitter<void>();\n\n  @ViewChild('selectRef', { static: true })\n  protected selectRef: ElementRef<HTMLElement>;\n\n  @ViewChild('tooltipRef', { static: true })\n  protected tooltipRef: TooltipDirective;\n\n  @ViewChild('optionListRef', { static: false })\n  protected optionListRef: ElementRef<HTMLDivElement>;\n\n  @ViewChild(VirtualScrollViewportComponent)\n  virtualScrollViewport!: VirtualScrollViewportComponent;\n\n  @ViewChildren(OptionItemComponent, { read: ElementRef })\n  contentOptionItems: QueryList<ElementRef>;\n\n  // TODO 这个用法有问题\n  @ContentChild(OptionContentDirective)\n  protected optionContent?: OptionContentDirective;\n\n  @ContentChildren(OptionComponent, { descendants: true })\n  contentTplOptions: QueryList<OptionComponent<T>>;\n\n  get opened() {\n    return this.tooltipRef.isCreated;\n  }\n\n  get inputReadonly() {\n    return !(this.filterable && this.opened);\n  }\n\n  get _itemSize() {\n    return this.itemSize || itemSizeMap[this.size];\n  }\n\n  get filterString() {\n    return this._filterString;\n  }\n\n  set filterString(val) {\n    if (val !== this._filterString) {\n      this._filterString = val;\n      this.filterString$$.next(val);\n      this.filterChange.emit(val);\n    }\n  }\n\n  isTemplateRef = isTemplateRef;\n  isMulti = false;\n  protected scrolledIndex = 0;\n\n  private _size: ComponentSize = ComponentSize.Medium;\n  private _options: Array<SelectFilterOption<T>>;\n  private _filterable = true;\n  private _clearable = false;\n  private _allowCreate = false;\n  private _filterString = '';\n  selectableOptions: Array<DisplayOption<T>> = [];\n\n  /**\n   * Utility field to make sure the users always see the value as type array\n   */\n  abstract readonly values$: Observable<T[]>;\n  protected contentOptions$: Observable<Array<DisplayOption<T>>>;\n  protected customOptions$: Observable<Array<DisplayOption<T>>>;\n  protected inputtingOption$: Observable<DisplayOption<T>>;\n  containerWidth: string;\n\n  protected destroy$$ = new Subject<void>();\n  protected size$$ = new BehaviorSubject<ComponentSize>(this.size);\n  protected options$$ = new BehaviorSubject<Array<DisplayOption<T>>>(null);\n  private readonly filterString$$ = new BehaviorSubject<string>(\n    this.filterString,\n  );\n\n  size$ = this.size$$.asObservable();\n  options$ = this.options$$.asObservable();\n  filterString$ = this.filterString$$.asObservable();\n  allOptions$ = new BehaviorSubject<Array<DisplayOption<T>>>([]);\n  filterOptions$ = new BehaviorSubject<Array<DisplayOption<T>>>([]);\n  focused$ = new BehaviorSubject<DisplayOption<T>>(null);\n\n  ngAfterContentInit() {\n    this.contentOptions$ = this.options$.pipe(\n      switchMap(options => {\n        if (options?.length) {\n          return this.options$;\n        }\n        return combineLatest([\n          this.values$,\n          merge(\n            ...this.contentTplOptions.map(contentTpl => contentTpl.changes),\n            this.contentTplOptions.changes,\n          ).pipe(startWith(this.contentTplOptions)),\n        ]).pipe(\n          map(([values]) => {\n            const contents: Array<DisplayOption<T>> = [];\n            let lastGroupTitle: ElementRef;\n            this.contentTplOptions.toArray().forEach(com => {\n              const {\n                value,\n                label,\n                disabled,\n                groupTitle,\n                labelContext,\n                template,\n              } = com;\n              if (lastGroupTitle !== groupTitle) {\n                lastGroupTitle = groupTitle;\n                contents.push({\n                  value,\n                  groupTitle,\n                });\n              }\n              contents.push({\n                value,\n                label,\n                disabled,\n                labelContext,\n                selected: this.getSelected(value, values),\n                contentTemplate: template,\n              } as DisplayOption<T>);\n            });\n            return contents;\n          }),\n        );\n      }),\n      publishRef(),\n    );\n  }\n\n  ngAfterViewInit() {\n    this.inputtingOption$ = this.filterString$.pipe(\n      map(filterString => {\n        if (filterString && this.allowCreate) {\n          return this.createFn(filterString);\n        }\n      }),\n      publishRef(),\n    );\n\n    this.customOptions$ = combineLatest([\n      this.values$,\n      this.contentOptions$,\n    ]).pipe(\n      map(([values, options]) => {\n        if (!this.allowCreate) {\n          return [];\n        }\n        const optionKeys = new Set(\n          options.map(option => this.trackFn(option.value)),\n        );\n        return values.reduce<Array<DisplayOption<T>>>((acc, value) => {\n          if (!optionKeys.has(this.trackFn(value))) {\n            const label =\n              this.labelFn?.(value) || coerceString(this.trackFn(value));\n            if (label) {\n              acc.push({\n                label,\n                value,\n                selected: true,\n              });\n            }\n          }\n          return acc;\n        }, []);\n      }),\n      publishRef(),\n    );\n\n    combineLatest([\n      this.inputtingOption$,\n      this.customOptions$,\n      this.contentOptions$,\n    ])\n      .pipe(\n        map(([inputtingOption, customOptions, contentOptions]) => {\n          const arr = [...customOptions, ...contentOptions];\n          if (inputtingOption) {\n            arr.unshift(inputtingOption);\n          }\n          this.allOptions$.next(arr);\n        }),\n      )\n      .subscribe();\n\n    combineLatest([this.allOptions$, this.filterString$])\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(([options, filterString]) => {\n        options = options.filter(option => this.filterFn(filterString, option));\n        this.filterOptions$.next(options);\n      });\n\n    this.filterOptions$.pipe(takeUntil(this.destroy$$)).subscribe(options => {\n      this.selectableOptions = options.filter(option => !option.disabled);\n    });\n  }\n\n  ngOnDestroy() {\n    this.optionContent?.detach();\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  openOption() {\n    this.tooltipRef.createTooltip();\n  }\n\n  closeOption() {\n    this.tooltipRef.disposeTooltip();\n  }\n\n  onShowOptions() {\n    const exec = () => {\n      this.containerWidth = this.selectRef.nativeElement.offsetWidth + 'px';\n\n      requestAnimationFrame(() => {\n        this.autoFocusFirstOption();\n      });\n\n      this.show.emit();\n    };\n\n    if (this.optionContent) {\n      requestAnimationFrame(() => {\n        this.optionContent.attach();\n        exec();\n      });\n    } else {\n      exec();\n    }\n  }\n\n  onHideOptions() {\n    if (this.onTouched) {\n      this.onTouched();\n    }\n    if (!this.lazy) {\n      this.optionContent?.detach();\n    }\n    this.resetFocusedOption();\n    this.filterString = '';\n    this.hide.emit();\n  }\n\n  onInput(event: Event) {\n    const value = (event.target as HTMLInputElement).value;\n    this.filterString = value;\n\n    requestAnimationFrame(() => {\n      this.autoFocusFirstOption();\n    });\n\n    this.cdr.markForCheck();\n  }\n\n  onKeyDown(event: KeyboardEvent) {\n    switch (event.key) {\n      case 'ArrowDown':\n        this.focusOptionDir('down');\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n      case 'ArrowUp':\n        this.focusOptionDir('up');\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n      case 'Enter':\n        this.selectFocusedOption();\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n      case 'Escape':\n        this.escSelect();\n        event.stopPropagation();\n        event.preventDefault();\n        break;\n    }\n  }\n\n  onOptionClick(option: OptionItemComponent<T>) {\n    this.resetFocusedOption(option);\n    this.selectOption(option);\n  }\n\n  protected autoFocusFirstOption() {\n    const first =\n      this.selectableOptions.find(option => option.selected) ||\n      this.selectableOptions[0];\n    if (this.defaultFirstOption) {\n      this.resetFocusedOption(first);\n    } else {\n      this.scrollToOption(first);\n    }\n  }\n\n  protected focusOptionDir(dir: 'down' | 'up') {\n    if (!this.opened) {\n      this.openOption();\n      return;\n    }\n\n    if (this.selectableOptions.length === 0) {\n      return;\n    }\n    const step = dir === 'down' ? 1 : -1;\n    let i = this.selectableOptions.findIndex(option =>\n      this.isFocus(option.value),\n    );\n    i = i + step;\n    if (i >= this.selectableOptions.length) {\n      i = 0;\n    } else if (i < 0) {\n      i = this.selectableOptions.length - 1;\n    }\n    this.resetFocusedOption(this.selectableOptions[i]);\n  }\n\n  isFocus = (\n    value: DisplayOption<T>['value'],\n    focusOption?: DisplayOption<T>,\n  ) => {\n    const _focusOption = focusOption || this.focused$.getValue();\n    return (\n      _focusOption && this.trackFn(_focusOption.value) === this.trackFn(value)\n    );\n  };\n\n  protected resetFocusedOption(focusedOption?: DisplayOption<T>) {\n    if (focusedOption?.value) {\n      this.focused$.next(focusedOption);\n      this.scrollToOption(focusedOption);\n    }\n  }\n\n  onScrolledIndexChange(index: number) {\n    this.scrolledIndex = index;\n  }\n\n  protected scrollToOption(option: DisplayOption<T>) {\n    const index = this.filterOptions$\n      .getValue()\n      .findIndex(\n        item => this.trackFn(item.value) === this.trackFn(option.value),\n      );\n    if (!this.virtualScrollViewport) {\n      if (this.contentOptionItems.get(index)) {\n        scrollIntoView(\n          this.optionListRef.nativeElement,\n          this.contentOptionItems.get(index).nativeElement,\n        );\n      }\n      return;\n    }\n    if (\n      index < this.scrolledIndex ||\n      index >= this.scrolledIndex + this.maxItemLength\n    ) {\n      this.virtualScrollViewport.scrollToIndex(index || 0);\n    }\n  }\n\n  protected selectFocusedOption() {\n    if (!this.opened) {\n      this.openOption();\n      return;\n    }\n    let focusedOption = this.focused$.getValue();\n    if (focusedOption) {\n      // 更新聚焦的option，例如：focus某一项后一直按enter键\n      focusedOption = this.selectableOptions.find(\n        option =>\n          this.trackFn(option.value) === this.trackFn(focusedOption.value),\n      );\n      focusedOption && this.selectOption(focusedOption);\n    }\n  }\n\n  getSelected(\n    value: DisplayOption<T>['value'],\n    values: Array<DisplayOption<T>['value']>,\n  ) {\n    return values.some(item => this.trackFn(item) === this.trackFn(value));\n  }\n\n  focus(option: DisplayOption<T>) {\n    this.focused$.next(option);\n  }\n\n  blur() {\n    this.focused$.next(null);\n  }\n\n  getLabelByValue(value: T) {\n    return this.labelFn?.(value) || coerceString(this.trackFn(value));\n  }\n\n  protected escSelect() {\n    this.closeOption();\n  }\n\n  private _trackFn<T>(value: T) {\n    return value;\n  }\n\n  private _createFn<T>(input: string) {\n    // @ts-ignore\n    const value = input as T;\n    return {\n      value,\n    };\n  }\n\n  private _filterFn(\n    filterString: string,\n    { label, value }: SelectFilterOption<T>,\n  ) {\n    return (\n      (typeof label === 'string' && label) ||\n      this.labelFn?.(value) ||\n      coerceString(this.trackFn(value))\n    )\n      ?.toLowerCase()\n      .includes(filterString?.toLowerCase() ?? '');\n  }\n\n  abstract selectOption(option: DisplayOption<T>): void;\n  abstract clearValue(event: Event): void;\n}\n"]}
@@ -1,10 +1,10 @@
1
1
  export * from './helper-directives';
2
2
  export * from './multi-select/multi-select.component';
3
- export * from './option/option.component';
3
+ export * from './option.component';
4
4
  export * from './option-group/option-group.component';
5
5
  export * from './option-placeholder.component';
6
6
  export * from './select.component';
7
7
  export * from './select.module';
8
8
  export * from './select.types';
9
9
  export * from './validators';
10
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc2VsZWN0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vaGVscGVyLWRpcmVjdGl2ZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9tdWx0aS1zZWxlY3QvbXVsdGktc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL29wdGlvbi9vcHRpb24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vb3B0aW9uLWdyb3VwL29wdGlvbi1ncm91cC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9vcHRpb24tcGxhY2Vob2xkZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdC5tb2R1bGUnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWxlY3QudHlwZXMnO1xuZXhwb3J0ICogZnJvbSAnLi92YWxpZGF0b3JzJztcbiJdfQ==
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvc2VsZWN0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsdUNBQXVDLENBQUM7QUFDdEQsY0FBYyxnQ0FBZ0MsQ0FBQztBQUMvQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsaUJBQWlCLENBQUM7QUFDaEMsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vaGVscGVyLWRpcmVjdGl2ZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9tdWx0aS1zZWxlY3QvbXVsdGktc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL29wdGlvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9vcHRpb24tZ3JvdXAvb3B0aW9uLWdyb3VwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL29wdGlvbi1wbGFjZWhvbGRlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zZWxlY3QuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0Lm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3NlbGVjdC50eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL3ZhbGlkYXRvcnMnO1xuIl19