@impartner/design-components 2.0.1 → 2.1.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +2 -1
- package/esm2022/lib/badge/badge.component.mjs +17 -1
- package/esm2022/lib/datetime-picker/components/datepicker-nav/datepicker-nav.component.mjs +105 -0
- package/esm2022/lib/datetime-picker/components/datepicker-nav/index.mjs +2 -0
- package/esm2022/lib/datetime-picker/components/datepicker-template-host/datepicker-template-host.component.mjs +30 -0
- package/esm2022/lib/datetime-picker/components/datepicker-template-host/index.mjs +2 -0
- package/esm2022/lib/datetime-picker/components/datetime-picker/datetime-picker.component.mjs +370 -0
- package/esm2022/lib/datetime-picker/components/datetime-picker/index.mjs +2 -0
- package/esm2022/lib/datetime-picker/components/datetime-picker-input/datetime-picker-input.component.mjs +367 -0
- package/esm2022/lib/datetime-picker/components/datetime-picker-input/index.mjs +2 -0
- package/esm2022/lib/datetime-picker/components/datetime-picker-input-footer/datetime-picker-input-footer.component.mjs +68 -0
- package/esm2022/lib/datetime-picker/components/datetime-picker-input-footer/index.mjs +2 -0
- package/esm2022/lib/datetime-picker/components/index.mjs +6 -0
- package/esm2022/lib/datetime-picker/constants/datetime-picker-defaults.mjs +12 -0
- package/esm2022/lib/datetime-picker/constants/index.mjs +2 -0
- package/esm2022/lib/datetime-picker/datetime-picker.module.mjs +22 -0
- package/esm2022/lib/datetime-picker/index.mjs +4 -0
- package/esm2022/lib/datetime-picker/services/datetime-formatter/datetime-formatter.service.mjs +40 -0
- package/esm2022/lib/datetime-picker/services/datetime-formatter/index.mjs +2 -0
- package/esm2022/lib/datetime-picker/services/index.mjs +2 -0
- package/esm2022/lib/datetime-picker/types/datetime-picker-value.interface.mjs +2 -0
- package/esm2022/lib/datetime-picker/types/index.mjs +2 -0
- package/esm2022/lib/design-components.module.mjs +20 -7
- package/esm2022/lib/form-field/component/directives/corner-hint.directive.mjs +15 -0
- package/esm2022/lib/form-field/component/directives/error.directive.mjs +27 -0
- package/esm2022/lib/form-field/component/directives/form-root.directive.mjs +93 -0
- package/esm2022/lib/form-field/component/directives/hint.directive.mjs +25 -0
- package/esm2022/lib/form-field/component/directives/index.mjs +25 -0
- package/esm2022/lib/form-field/component/directives/label.directive.mjs +15 -0
- package/esm2022/lib/form-field/component/directives/prefix.directive.mjs +25 -0
- package/esm2022/lib/form-field/component/directives/suffix.directive.mjs +25 -0
- package/esm2022/lib/form-field/component/form-field.component.mjs +131 -0
- package/esm2022/lib/form-field/component/form-field.module.mjs +24 -0
- package/esm2022/lib/form-field/component/index.mjs +4 -0
- package/esm2022/lib/form-field/controls/checkbox/checkbox.component.mjs +14 -6
- package/esm2022/lib/form-field/controls/checkbox/checkbox.module.mjs +4 -7
- package/esm2022/lib/form-field/controls/index.mjs +2 -1
- package/esm2022/lib/form-field/controls/input/input.directive.mjs +4 -3
- package/esm2022/lib/form-field/controls/radio/radio-button/radio-button.component.mjs +6 -4
- package/esm2022/lib/form-field/controls/radio/radio-group/radio-group.directive.mjs +4 -3
- package/esm2022/lib/form-field/controls/radio/radio.module.mjs +4 -7
- package/esm2022/lib/form-field/controls/select/index.mjs +6 -3
- package/esm2022/lib/form-field/controls/select/interfaces/index.mjs +2 -0
- package/esm2022/lib/form-field/controls/select/interfaces/select-option.interface.mjs +2 -0
- package/esm2022/lib/form-field/controls/select/option/index.mjs +2 -2
- package/esm2022/lib/form-field/controls/select/option/select-option.component.mjs +33 -128
- package/esm2022/lib/form-field/controls/select/option-display/index.mjs +2 -0
- package/esm2022/lib/form-field/controls/select/option-display/select-option-display.component.mjs +162 -0
- package/esm2022/lib/form-field/controls/select/option-group/index.mjs +2 -0
- package/esm2022/lib/form-field/controls/select/option-group/select-option-group.component.mjs +35 -0
- package/esm2022/lib/form-field/controls/select/option-parent.mjs +2 -1
- package/esm2022/lib/form-field/controls/select/select.component.mjs +348 -148
- package/esm2022/lib/form-field/controls/select/select.module.mjs +20 -13
- package/esm2022/lib/form-field/controls/select/value-tags-display/index.mjs +2 -0
- package/esm2022/lib/form-field/controls/select/value-tags-display/select-value-tags-display.component.mjs +91 -0
- package/esm2022/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.mjs +3 -3
- package/esm2022/lib/form-field/controls/shared/toggle/toggle.component.mjs +19 -3
- package/esm2022/lib/form-field/controls/shared/toggle/toggle.module.mjs +4 -6
- package/esm2022/lib/form-field/controls/tag-select/index.mjs +2 -0
- package/esm2022/lib/form-field/controls/tag-select/tag-select.component.mjs +146 -0
- package/esm2022/lib/form-field/impdc-forms.mjs +2 -3
- package/esm2022/lib/form-field/impdc-forms.module.mjs +32 -47
- package/esm2022/lib/form-field/shared/error-state.mixin.mjs +1 -1
- package/esm2022/lib/icon/icon.component.mjs +12 -5
- package/esm2022/lib/index.mjs +3 -1
- package/esm2022/lib/pagination/pagination.component.mjs +6 -6
- package/esm2022/lib/select-icon/select-icon.component.mjs +6 -6
- package/esm2022/lib/select-icon/select-icon.module.mjs +5 -1
- package/esm2022/lib/table/containers/table.component.mjs +3 -3
- package/esm2022/lib/tag/index.mjs +2 -0
- package/esm2022/lib/tag/tag.component.mjs +104 -0
- package/esm2022/lib/text-highlight/text-highlight.component.mjs +52 -37
- package/esm2022/lib/text-highlight/text-highlight.module.mjs +4 -6
- package/fesm2022/impartner-design-components.mjs +5620 -3983
- package/fesm2022/impartner-design-components.mjs.map +1 -1
- package/lib/badge/badge.component.d.ts +15 -1
- package/lib/datetime-picker/components/datepicker-nav/datepicker-nav.component.d.ts +31 -0
- package/lib/datetime-picker/components/datepicker-nav/index.d.ts +1 -0
- package/lib/datetime-picker/components/datepicker-template-host/datepicker-template-host.component.d.ts +14 -0
- package/lib/datetime-picker/components/datepicker-template-host/index.d.ts +1 -0
- package/lib/datetime-picker/components/datetime-picker/datetime-picker.component.d.ts +157 -0
- package/lib/datetime-picker/components/datetime-picker/index.d.ts +1 -0
- package/lib/datetime-picker/components/datetime-picker-input/datetime-picker-input.component.d.ts +160 -0
- package/lib/datetime-picker/components/datetime-picker-input/index.d.ts +1 -0
- package/lib/datetime-picker/components/datetime-picker-input-footer/datetime-picker-input-footer.component.d.ts +24 -0
- package/lib/datetime-picker/components/datetime-picker-input-footer/index.d.ts +1 -0
- package/lib/datetime-picker/components/index.d.ts +5 -0
- package/lib/datetime-picker/constants/datetime-picker-defaults.d.ts +4 -0
- package/lib/datetime-picker/constants/index.d.ts +1 -0
- package/lib/datetime-picker/datetime-picker.module.d.ts +8 -0
- package/lib/datetime-picker/index.d.ts +4 -0
- package/lib/datetime-picker/services/datetime-formatter/datetime-formatter.service.d.ts +20 -0
- package/lib/datetime-picker/services/datetime-formatter/index.d.ts +1 -0
- package/lib/datetime-picker/services/index.d.ts +1 -0
- package/lib/datetime-picker/types/datetime-picker-value.interface.d.ts +5 -0
- package/lib/datetime-picker/types/index.d.ts +1 -0
- package/lib/design-components.module.d.ts +14 -12
- package/lib/form-field/{directives → component/directives}/corner-hint.directive.d.ts +1 -1
- package/lib/form-field/{directives → component/directives}/error.directive.d.ts +1 -1
- package/lib/form-field/{directives → component/directives}/form-root.directive.d.ts +2 -2
- package/lib/form-field/{directives → component/directives}/hint.directive.d.ts +1 -1
- package/lib/form-field/component/directives/index.d.ts +15 -0
- package/lib/form-field/{directives → component/directives}/label.directive.d.ts +1 -1
- package/lib/form-field/{directives → component/directives}/prefix.directive.d.ts +1 -1
- package/lib/form-field/{directives → component/directives}/suffix.directive.d.ts +1 -1
- package/lib/form-field/{form-field.component.d.ts → component/form-field.component.d.ts} +3 -5
- package/lib/form-field/component/form-field.module.d.ts +14 -0
- package/lib/form-field/component/index.d.ts +3 -0
- package/lib/form-field/controls/checkbox/checkbox.component.d.ts +6 -2
- package/lib/form-field/controls/checkbox/checkbox.module.d.ts +1 -3
- package/lib/form-field/controls/index.d.ts +1 -0
- package/lib/form-field/controls/input/input.directive.d.ts +2 -2
- package/lib/form-field/controls/radio/radio-button/radio-button.component.d.ts +1 -1
- package/lib/form-field/controls/radio/radio-group/radio-group.directive.d.ts +2 -2
- package/lib/form-field/controls/radio/radio.module.d.ts +1 -3
- package/lib/form-field/controls/select/index.d.ts +6 -2
- package/lib/form-field/controls/select/interfaces/index.d.ts +1 -0
- package/lib/form-field/controls/select/interfaces/select-option.interface.d.ts +6 -0
- package/lib/form-field/controls/select/option/index.d.ts +1 -1
- package/lib/form-field/controls/select/option/select-option.component.d.ts +10 -49
- package/lib/form-field/controls/select/option-display/index.d.ts +1 -0
- package/lib/form-field/controls/select/option-display/select-option-display.component.d.ts +64 -0
- package/lib/form-field/controls/select/option-group/index.d.ts +1 -0
- package/lib/form-field/controls/select/option-group/select-option-group.component.d.ts +11 -0
- package/lib/form-field/controls/select/option-parent.d.ts +12 -1
- package/lib/form-field/controls/select/select.component.d.ts +113 -51
- package/lib/form-field/controls/select/select.module.d.ts +5 -6
- package/lib/form-field/controls/select/value-tags-display/index.d.ts +1 -0
- package/lib/form-field/controls/select/value-tags-display/select-value-tags-display.component.d.ts +46 -0
- package/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.d.ts +1 -1
- package/lib/form-field/controls/shared/toggle/toggle.component.d.ts +4 -1
- package/lib/form-field/controls/shared/toggle/toggle.module.d.ts +1 -2
- package/lib/form-field/controls/tag-select/index.d.ts +1 -0
- package/lib/form-field/controls/tag-select/tag-select.component.d.ts +43 -0
- package/lib/form-field/impdc-forms.d.ts +1 -2
- package/lib/form-field/impdc-forms.module.d.ts +8 -14
- package/lib/form-field/shared/error-state.mixin.d.ts +4 -4
- package/lib/icon/icon.component.d.ts +5 -3
- package/lib/index.d.ts +2 -0
- package/lib/select-icon/select-icon.module.d.ts +4 -3
- package/lib/tag/index.d.ts +1 -0
- package/lib/tag/tag.component.d.ts +54 -0
- package/lib/text-highlight/text-highlight.component.d.ts +12 -6
- package/lib/text-highlight/text-highlight.module.d.ts +1 -2
- package/package.json +2 -2
- package/esm2022/lib/form-field/directives/corner-hint.directive.mjs +0 -14
- package/esm2022/lib/form-field/directives/error.directive.mjs +0 -26
- package/esm2022/lib/form-field/directives/form-root.directive.mjs +0 -91
- package/esm2022/lib/form-field/directives/hint.directive.mjs +0 -24
- package/esm2022/lib/form-field/directives/index.mjs +0 -8
- package/esm2022/lib/form-field/directives/label.directive.mjs +0 -14
- package/esm2022/lib/form-field/directives/prefix.directive.mjs +0 -24
- package/esm2022/lib/form-field/directives/suffix.directive.mjs +0 -24
- package/esm2022/lib/form-field/form-field.component.mjs +0 -132
- package/lib/form-field/directives/index.d.ts +0 -7
|
@@ -1,20 +1,33 @@
|
|
|
1
1
|
/* eslint-disable @angular-eslint/no-conflicting-lifecycle */
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
2
|
+
import { AsyncPipe, CommonModule } from '@angular/common';
|
|
3
|
+
import { Attribute, ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, Directive, ElementRef, EventEmitter, Input, NgZone, Output, ViewChild, ViewChildren, booleanAttribute, inject, numberAttribute } from '@angular/core';
|
|
4
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
5
|
+
import { FormControl, FormGroupDirective, NgControl, NgForm, ReactiveFormsModule, Validators } from '@angular/forms';
|
|
6
|
+
import { NgbDropdown, NgbDropdownModule } from '@ng-bootstrap/ng-bootstrap';
|
|
5
7
|
import { nanoid } from 'nanoid';
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
8
|
+
import { BehaviorSubject, combineLatest, debounceTime, defer, distinctUntilChanged, map, merge, startWith, Subject, switchMap, take, takeUntil, tap } from 'rxjs';
|
|
9
|
+
import { ComponentTheme } from '../../../../types';
|
|
10
|
+
import { lc } from '../../../../utilities';
|
|
11
|
+
import { BadgeModule } from '../../../badge';
|
|
12
|
+
import { IconModule } from '../../../icon';
|
|
13
|
+
import { ErrorStateMatcher } from '../../services';
|
|
14
|
+
import { IMPDC_FORM_ROOT, FormFieldModule } from '../../component';
|
|
9
15
|
import { ImpdcFormFieldControl, mixinDisabled, mixinErrorState, mixinTabIndex } from '../../shared';
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
16
|
+
import { InputDirective } from '../input';
|
|
17
|
+
import { IMPDC_SELECT_OPTION_PARENT_COMPONENT, IMPDC_SELECT_VALUE_BADGES_PARENT_COMPONENT } from './option-parent';
|
|
18
|
+
import { SelectOptionDisplayComponent } from './option-display';
|
|
12
19
|
import { SelectModel } from './select-model';
|
|
20
|
+
import { SelectOptionComponent } from './option';
|
|
21
|
+
import { SelectValueTagsDisplayComponent } from './value-tags-display';
|
|
13
22
|
import * as i0 from "@angular/core";
|
|
14
|
-
import * as i1 from "
|
|
23
|
+
import * as i1 from "@angular/common";
|
|
15
24
|
import * as i2 from "@angular/forms";
|
|
16
|
-
import * as i3 from "@
|
|
17
|
-
import * as i4 from "
|
|
25
|
+
import * as i3 from "@ng-bootstrap/ng-bootstrap";
|
|
26
|
+
import * as i4 from "../../../icon/icon.component";
|
|
27
|
+
import * as i5 from "../../component/form-field.component";
|
|
28
|
+
import * as i6 from "../../component/directives/prefix.directive";
|
|
29
|
+
import * as i7 from "../../component/directives/suffix.directive";
|
|
30
|
+
export const ON_OPEN_AUTO_SCROLL_TIMEOUT_MS = 50;
|
|
18
31
|
export class SelectChangeEvent {
|
|
19
32
|
constructor(
|
|
20
33
|
/** The specific SelectComponent that changed. */
|
|
@@ -50,7 +63,8 @@ export function getImpdcSelectNonFunctionValueError() {
|
|
|
50
63
|
export function getImpdcSelectDynamicMultipleError() {
|
|
51
64
|
return Error('Cannot change `multiple` mode of select after initialization.');
|
|
52
65
|
}
|
|
53
|
-
const
|
|
66
|
+
const DEFAULT_ACTIVE_INDEX = -1;
|
|
67
|
+
const __SelectComponentBase = mixinTabIndex(mixinDisabled(mixinErrorState(class {
|
|
54
68
|
constructor(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl) {
|
|
55
69
|
this._defaultErrorStateMatcher = _defaultErrorStateMatcher;
|
|
56
70
|
this._formRoot = _formRoot;
|
|
@@ -60,12 +74,22 @@ const _SelectComponentBase = mixinTabIndex(mixinDisabled(mixinErrorState(class {
|
|
|
60
74
|
this.stateChanges = new Subject();
|
|
61
75
|
}
|
|
62
76
|
})));
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
77
|
+
export class _SelectComponentBase extends __SelectComponentBase {
|
|
78
|
+
/**
|
|
79
|
+
* Set whether or not an input field will appear for searching and
|
|
80
|
+
* filtering visible options.
|
|
81
|
+
*
|
|
82
|
+
* - `'none'`: No search control will be displayed, and all select options are provided via projected `<impdc-select-option>` elements.
|
|
83
|
+
* - `'static'`: A search control will be displayed, select options are provided via projected `<impdc-select-option>` elements, and
|
|
84
|
+
* filtering is performed against the `[label]` attribute value.
|
|
85
|
+
* @default 'none'
|
|
86
|
+
*/
|
|
87
|
+
get search() {
|
|
88
|
+
return this._searchSubject.value;
|
|
89
|
+
}
|
|
90
|
+
set search(value) {
|
|
91
|
+
this._searchSubject.next(value);
|
|
92
|
+
}
|
|
69
93
|
/**
|
|
70
94
|
* The placeholder text that will be displayed when no selection has been made.
|
|
71
95
|
*
|
|
@@ -88,24 +112,18 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
88
112
|
false);
|
|
89
113
|
}
|
|
90
114
|
set required(value) {
|
|
91
|
-
this._required =
|
|
115
|
+
this._required = value;
|
|
92
116
|
this.stateChanges.next();
|
|
93
117
|
}
|
|
94
118
|
/**
|
|
95
|
-
*
|
|
119
|
+
* Whether the control is a single-select or multiple-select. Cannot be changed after component initialization.
|
|
96
120
|
*/
|
|
97
121
|
get multiple() {
|
|
98
122
|
return this._multiple;
|
|
99
123
|
}
|
|
100
|
-
set multiple(value) {
|
|
101
|
-
if (this._selectionModel) {
|
|
102
|
-
throw getImpdcSelectDynamicMultipleError();
|
|
103
|
-
}
|
|
104
|
-
this._multiple = coerceBooleanPropertyValue(value);
|
|
105
|
-
}
|
|
106
124
|
/**
|
|
107
125
|
* Function used to compare option values with selected values. The first arg is a
|
|
108
|
-
* value from an option, and the second arg is a value from the selection.
|
|
126
|
+
* `value` from an option, and the second arg is a `value` from the selection or another option.
|
|
109
127
|
*
|
|
110
128
|
* @returns Boolean indicating if the values are equivalent.
|
|
111
129
|
*/
|
|
@@ -117,33 +135,91 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
117
135
|
throw getImpdcSelectNonFunctionValueError();
|
|
118
136
|
}
|
|
119
137
|
this._compareWith = fn;
|
|
120
|
-
if (this.
|
|
138
|
+
if (this.selectionModel) {
|
|
121
139
|
// Changing the comparator function means the visual selection may have changed.
|
|
122
140
|
this._initializeSelection();
|
|
123
141
|
}
|
|
124
142
|
}
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
this.
|
|
131
|
-
this.
|
|
143
|
+
constructor(uid, tabIndex) {
|
|
144
|
+
super(inject(ErrorStateMatcher), inject(IMPDC_FORM_ROOT, { optional: true }), inject(NgForm, { optional: true }), inject(FormGroupDirective, { optional: true }), inject(NgControl, { optional: true, self: true }));
|
|
145
|
+
this._ngDestroy = new Subject();
|
|
146
|
+
this._searchSubject = new BehaviorSubject('none');
|
|
147
|
+
this._compareWith = (o1, o2) => o1 === o2;
|
|
148
|
+
this._cvaOnChange = () => { };
|
|
149
|
+
this._cvaOnTouched = () => { };
|
|
150
|
+
this.changeDetector = inject(ChangeDetectorRef);
|
|
151
|
+
this.ngZone = inject(NgZone);
|
|
152
|
+
this.searchControl = new FormControl(null);
|
|
153
|
+
this.BadgeTheme = ComponentTheme;
|
|
154
|
+
this.filteredOptions$ = this._searchSubject.pipe(switchMap(searchMode => {
|
|
155
|
+
switch (searchMode) {
|
|
156
|
+
case 'none':
|
|
157
|
+
return this.staticOptions.changes.pipe(startWith(this.staticOptions.toArray()), map(options => options.map(opt => ({
|
|
158
|
+
groupLabel: opt.groupLabel,
|
|
159
|
+
get label() {
|
|
160
|
+
return opt.label;
|
|
161
|
+
},
|
|
162
|
+
value: opt.value,
|
|
163
|
+
get disabled() {
|
|
164
|
+
return opt.disabled;
|
|
165
|
+
},
|
|
166
|
+
selected: this.selectionModel.isSelected(opt)
|
|
167
|
+
}))));
|
|
168
|
+
case 'static':
|
|
169
|
+
return combineLatest([
|
|
170
|
+
this.staticOptions.changes.pipe(startWith(this.staticOptions.toArray())),
|
|
171
|
+
this.searchTextChanges.pipe(startWith(''))
|
|
172
|
+
]).pipe(tap(([, searchText]) => {
|
|
173
|
+
this.activeIndex = !!searchText ? 0 : DEFAULT_ACTIVE_INDEX;
|
|
174
|
+
}), map(([options, searchText]) => {
|
|
175
|
+
const renderedOptions = options.map(opt => ({
|
|
176
|
+
groupLabel: opt.groupLabel,
|
|
177
|
+
get label() {
|
|
178
|
+
return opt.label;
|
|
179
|
+
},
|
|
180
|
+
value: opt.value,
|
|
181
|
+
get disabled() {
|
|
182
|
+
return opt.disabled;
|
|
183
|
+
},
|
|
184
|
+
selected: this.selectionModel.isSelected(opt)
|
|
185
|
+
}));
|
|
186
|
+
return !!searchText
|
|
187
|
+
? renderedOptions.filter(opt => lc(opt.label).indexOf(lc(searchText)) !== -1)
|
|
188
|
+
: renderedOptions;
|
|
189
|
+
}));
|
|
190
|
+
}
|
|
191
|
+
}), map(options => Object.entries(options.reduce((result, opt) => {
|
|
192
|
+
const resolvedGroupLabel = opt.groupLabel?.trim() || '';
|
|
193
|
+
let showGroupLabel = false;
|
|
194
|
+
if (!(resolvedGroupLabel in result)) {
|
|
195
|
+
result[resolvedGroupLabel] = [];
|
|
196
|
+
showGroupLabel = true;
|
|
197
|
+
}
|
|
198
|
+
result[resolvedGroupLabel].push({
|
|
199
|
+
...opt,
|
|
200
|
+
showGroupLabel
|
|
201
|
+
});
|
|
202
|
+
return result;
|
|
203
|
+
}, {})).flatMap(([, groupOptions]) => groupOptions)));
|
|
204
|
+
this.activeIndex = DEFAULT_ACTIVE_INDEX;
|
|
132
205
|
/** @ignore */
|
|
133
206
|
this.optionSelectionChanges = defer(() => {
|
|
134
207
|
const options = this.options;
|
|
135
208
|
if (options) {
|
|
136
209
|
return options.changes.pipe(startWith(options), switchMap(() => merge(...options.map(option => option.onSelectionChange))));
|
|
137
210
|
}
|
|
138
|
-
return this.
|
|
211
|
+
return this.ngZone.onStable.pipe(take(1), switchMap(() => this.optionSelectionChanges));
|
|
139
212
|
});
|
|
140
|
-
this._uid = `impdc-select-${nanoid()}`;
|
|
141
|
-
this._ngDestroy = new Subject();
|
|
142
|
-
this._compareWith = (o1, o2) => o1 === o2;
|
|
143
|
-
this._cvaOnChange = () => { };
|
|
144
|
-
this._cvaOnTouched = () => { };
|
|
145
213
|
this._placeholder = '- Select -';
|
|
146
214
|
this._multiple = false;
|
|
215
|
+
/**
|
|
216
|
+
* Document element that the select dropdown will be attached to in the DOM - either the
|
|
217
|
+
* document's `<body>` tag, or as a child of the component tag.
|
|
218
|
+
*
|
|
219
|
+
* The default value (`'body'`) is generally the correct choice, and should only be
|
|
220
|
+
* overridden when absolutely certain that the result behavior is what's desired.
|
|
221
|
+
*/
|
|
222
|
+
this.dropdownContainer = 'body';
|
|
147
223
|
/** Events fire when selection has been changed by the user. */
|
|
148
224
|
this.selectionChange = new EventEmitter();
|
|
149
225
|
/**
|
|
@@ -152,59 +228,71 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
152
228
|
* @ignore
|
|
153
229
|
*/
|
|
154
230
|
this.valueChange = new EventEmitter();
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
231
|
+
/**
|
|
232
|
+
* Events fire when the text value of the option search input control has changed.
|
|
233
|
+
*/
|
|
234
|
+
this.searchTextChanges = this.searchControl.valueChanges.pipe(takeUntilDestroyed(), startWith(''), debounceTime(200), distinctUntilChanged());
|
|
158
235
|
this._focused = false;
|
|
236
|
+
this.uid = uid;
|
|
159
237
|
if (this.ngControl) {
|
|
160
238
|
this.ngControl.valueAccessor = this;
|
|
161
239
|
}
|
|
162
240
|
this.id = this.id;
|
|
163
|
-
this.tabIndex = parseInt(tabIndex) || 0;
|
|
241
|
+
this.tabIndex = parseInt(tabIndex ?? '') || 0;
|
|
164
242
|
}
|
|
165
|
-
get
|
|
166
|
-
return
|
|
243
|
+
get dropdownOpen() {
|
|
244
|
+
return this.ngbDropdown?.isOpen() ?? false;
|
|
167
245
|
}
|
|
168
|
-
get
|
|
169
|
-
|
|
170
|
-
return '';
|
|
171
|
-
}
|
|
172
|
-
if (!this._multiple) {
|
|
173
|
-
return this._selectionModel.selected[0].label;
|
|
174
|
-
}
|
|
175
|
-
return this._selectionModel.selected.map(opt => opt.label).join(', ');
|
|
246
|
+
get empty() {
|
|
247
|
+
return !this.selectionModel || this.selectionModel.isEmpty();
|
|
176
248
|
}
|
|
177
249
|
get selected() {
|
|
178
|
-
return this.
|
|
179
|
-
? this.
|
|
180
|
-
: this.
|
|
250
|
+
return this._multiple
|
|
251
|
+
? this.selectionModel?.selected || []
|
|
252
|
+
: this.selectionModel?.selected[0];
|
|
181
253
|
}
|
|
182
254
|
/** @ignore */
|
|
183
255
|
focus(options) {
|
|
184
|
-
this.
|
|
256
|
+
this.toggleButtonRef?.nativeElement.focus(options);
|
|
185
257
|
}
|
|
186
|
-
|
|
258
|
+
handleOpenChange(isOpen) {
|
|
187
259
|
if (isOpen) {
|
|
188
|
-
this.
|
|
260
|
+
this.onFocus();
|
|
261
|
+
if (this.search !== 'none' && !!this.searchInputRef) {
|
|
262
|
+
setTimeout(() => {
|
|
263
|
+
this.searchInputRef?.nativeElement.focus();
|
|
264
|
+
}, ON_OPEN_AUTO_SCROLL_TIMEOUT_MS);
|
|
265
|
+
}
|
|
266
|
+
if (!this._multiple && !!this.value) {
|
|
267
|
+
this._scrollToSelectedOption();
|
|
268
|
+
}
|
|
189
269
|
}
|
|
190
270
|
else {
|
|
191
|
-
this.
|
|
271
|
+
this.onBlur();
|
|
192
272
|
}
|
|
273
|
+
this.activeIndex = DEFAULT_ACTIVE_INDEX;
|
|
274
|
+
this.searchControl.reset();
|
|
193
275
|
this.stateChanges.next();
|
|
194
276
|
}
|
|
195
277
|
/* Angular lifecycle hooks */
|
|
196
278
|
/** @ignore */
|
|
197
279
|
ngOnInit() {
|
|
198
|
-
this.
|
|
280
|
+
this.selectionModel = new SelectModel(this._multiple, undefined, undefined, (a, b) => {
|
|
281
|
+
return this.compareWith(a.value, b.value);
|
|
282
|
+
});
|
|
199
283
|
this.stateChanges.next();
|
|
200
284
|
}
|
|
201
285
|
/** @ignore */
|
|
202
|
-
|
|
203
|
-
this.
|
|
286
|
+
ngAfterViewInit() {
|
|
287
|
+
this.selectionModel.changed$
|
|
204
288
|
.pipe(takeUntil(this._ngDestroy))
|
|
205
289
|
.subscribe(changeEvent => {
|
|
206
|
-
changeEvent.added.forEach(option =>
|
|
207
|
-
|
|
290
|
+
changeEvent.added.forEach(option => this.options
|
|
291
|
+
.find(o => this.compareWith(o.value, option.value))
|
|
292
|
+
?.select());
|
|
293
|
+
changeEvent.removed.forEach(option => this.options
|
|
294
|
+
.find(o => this.compareWith(o.value, option.value))
|
|
295
|
+
?.deselect());
|
|
208
296
|
});
|
|
209
297
|
this.options.changes
|
|
210
298
|
.pipe(startWith(null), takeUntil(this._ngDestroy))
|
|
@@ -214,10 +302,6 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
214
302
|
});
|
|
215
303
|
}
|
|
216
304
|
/** @ignore */
|
|
217
|
-
ngAfterViewInit() {
|
|
218
|
-
this._ngbDropdownMenu.menuItems = this.options;
|
|
219
|
-
}
|
|
220
|
-
/** @ignore */
|
|
221
305
|
ngDoCheck() {
|
|
222
306
|
const ngControl = this.ngControl;
|
|
223
307
|
if (!ngControl) {
|
|
@@ -260,7 +344,7 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
260
344
|
return this._id;
|
|
261
345
|
}
|
|
262
346
|
set id(value) {
|
|
263
|
-
this._id = value || this.
|
|
347
|
+
this._id = value || this.uid;
|
|
264
348
|
this.stateChanges.next();
|
|
265
349
|
}
|
|
266
350
|
get focused() {
|
|
@@ -282,11 +366,11 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
282
366
|
/** @ignore */
|
|
283
367
|
setDisabledState(isDisabled) {
|
|
284
368
|
this.disabled = isDisabled;
|
|
285
|
-
this.
|
|
369
|
+
this.changeDetector.markForCheck();
|
|
286
370
|
this.stateChanges.next();
|
|
287
371
|
}
|
|
288
372
|
/* Internals */
|
|
289
|
-
|
|
373
|
+
onFocus() {
|
|
290
374
|
if (!this.disabled) {
|
|
291
375
|
this._focused = true;
|
|
292
376
|
this.stateChanges.next();
|
|
@@ -295,14 +379,52 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
295
379
|
/**
|
|
296
380
|
* Calls the CVA touched callback only if the dropdown is closed.
|
|
297
381
|
*/
|
|
298
|
-
|
|
382
|
+
onBlur() {
|
|
299
383
|
this._focused = false;
|
|
300
384
|
if (!this.disabled && !this.dropdownOpen) {
|
|
301
385
|
this._cvaOnTouched();
|
|
302
|
-
this.
|
|
386
|
+
this.changeDetector.markForCheck();
|
|
303
387
|
this.stateChanges.next();
|
|
304
388
|
}
|
|
305
389
|
}
|
|
390
|
+
clearSelection() {
|
|
391
|
+
this.value = null;
|
|
392
|
+
this.focus();
|
|
393
|
+
}
|
|
394
|
+
handleSearchSubmit(evt) {
|
|
395
|
+
evt.preventDefault();
|
|
396
|
+
evt.stopPropagation();
|
|
397
|
+
if (this.activeIndex < 0 || this.activeIndex >= this.options.length)
|
|
398
|
+
return;
|
|
399
|
+
this.options.get(this.activeIndex)?.nativeElement.click();
|
|
400
|
+
}
|
|
401
|
+
handleSearchUpDown(evt, direction) {
|
|
402
|
+
evt.preventDefault();
|
|
403
|
+
if (direction === 'up') {
|
|
404
|
+
if (this.activeIndex === this.options.length - 1) {
|
|
405
|
+
this.activeIndex = (this.activeIndex + 1) % this.options.length;
|
|
406
|
+
}
|
|
407
|
+
else {
|
|
408
|
+
this.activeIndex++;
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
else {
|
|
412
|
+
if (this.activeIndex <= 0) {
|
|
413
|
+
this.activeIndex = this.options.length - 1;
|
|
414
|
+
}
|
|
415
|
+
else {
|
|
416
|
+
this.activeIndex--;
|
|
417
|
+
}
|
|
418
|
+
}
|
|
419
|
+
this.changeDetector.markForCheck();
|
|
420
|
+
}
|
|
421
|
+
markActive(index) {
|
|
422
|
+
this.activeIndex = index;
|
|
423
|
+
this.changeDetector.markForCheck();
|
|
424
|
+
}
|
|
425
|
+
selectedIsSingle(selected) {
|
|
426
|
+
return !Array.isArray(selected);
|
|
427
|
+
}
|
|
306
428
|
_initializeSelection() {
|
|
307
429
|
// We defer this work into a promise in order to avoid tripping Angular's
|
|
308
430
|
// "Expression has changed after it was checked" error.
|
|
@@ -315,8 +437,10 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
315
437
|
});
|
|
316
438
|
}
|
|
317
439
|
_setSelectionByValue(value) {
|
|
318
|
-
this.
|
|
319
|
-
|
|
440
|
+
if (this.search === 'none') {
|
|
441
|
+
this.selectionModel.clear();
|
|
442
|
+
}
|
|
443
|
+
if (this._multiple && value) {
|
|
320
444
|
if (!Array.isArray(value)) {
|
|
321
445
|
throw getImpdcSelectNonArrayValueError();
|
|
322
446
|
}
|
|
@@ -326,11 +450,11 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
326
450
|
else {
|
|
327
451
|
this._selectOptionByValue(value);
|
|
328
452
|
}
|
|
329
|
-
this.
|
|
453
|
+
this.changeDetector.detectChanges();
|
|
330
454
|
}
|
|
331
455
|
_selectOptionByValue(value) {
|
|
332
456
|
const correspondingOption = this.options.find((option) => {
|
|
333
|
-
if (this.
|
|
457
|
+
if (this.selectionModel.isSelected(option)) {
|
|
334
458
|
return false;
|
|
335
459
|
}
|
|
336
460
|
try {
|
|
@@ -342,7 +466,7 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
342
466
|
}
|
|
343
467
|
});
|
|
344
468
|
if (correspondingOption) {
|
|
345
|
-
this.
|
|
469
|
+
this.selectionModel.select(correspondingOption);
|
|
346
470
|
}
|
|
347
471
|
return correspondingOption;
|
|
348
472
|
}
|
|
@@ -353,6 +477,7 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
353
477
|
if (newValue !== this._value ||
|
|
354
478
|
(this._multiple && Array.isArray(newValue))) {
|
|
355
479
|
if (this.options) {
|
|
480
|
+
this.selectionModel.clear();
|
|
356
481
|
this._setSelectionByValue(newValue);
|
|
357
482
|
}
|
|
358
483
|
this._value = newValue;
|
|
@@ -366,23 +491,23 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
366
491
|
.pipe(takeUntil(changedOrDestroyed))
|
|
367
492
|
.subscribe(event => {
|
|
368
493
|
this._onSelect(event.source, event.isUserInput);
|
|
369
|
-
if (event.isUserInput && !this.
|
|
370
|
-
this.
|
|
494
|
+
if (event.isUserInput && !this._multiple && this.dropdownOpen) {
|
|
495
|
+
this.ngbDropdown.close();
|
|
371
496
|
this.focus();
|
|
372
497
|
}
|
|
373
498
|
});
|
|
374
499
|
merge(...this.options.map(option => option.stateChanges))
|
|
375
500
|
.pipe(takeUntil(changedOrDestroyed))
|
|
376
501
|
.subscribe(() => {
|
|
377
|
-
this.
|
|
502
|
+
this.changeDetector.detectChanges();
|
|
378
503
|
this.stateChanges.next();
|
|
379
504
|
});
|
|
380
505
|
}
|
|
381
506
|
_onSelect(option, isUserInput) {
|
|
382
|
-
const wasSelected = this.
|
|
507
|
+
const wasSelected = this.selectionModel.isSelected(option);
|
|
383
508
|
if (option.value == null && !this._multiple) {
|
|
384
509
|
option.deselect();
|
|
385
|
-
this.
|
|
510
|
+
this.selectionModel.clear();
|
|
386
511
|
if (this.value != null) {
|
|
387
512
|
this._propagateChanges(option.value);
|
|
388
513
|
}
|
|
@@ -390,34 +515,33 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
390
515
|
else {
|
|
391
516
|
if (wasSelected !== option.selected) {
|
|
392
517
|
option.selected
|
|
393
|
-
? this.
|
|
394
|
-
: this.
|
|
518
|
+
? this.selectionModel.select(option)
|
|
519
|
+
: this.selectionModel.deselect(option);
|
|
395
520
|
}
|
|
396
|
-
if (this.
|
|
521
|
+
if (this._multiple) {
|
|
397
522
|
this._sortValues();
|
|
398
|
-
if (isUserInput) {
|
|
399
|
-
this.focus();
|
|
400
|
-
}
|
|
401
523
|
}
|
|
402
524
|
}
|
|
403
|
-
if (wasSelected !== this.
|
|
525
|
+
if (wasSelected !== this.selectionModel.isSelected(option)) {
|
|
404
526
|
this._propagateChanges();
|
|
405
527
|
}
|
|
406
|
-
this.
|
|
528
|
+
this.changeDetector.markForCheck();
|
|
407
529
|
this.stateChanges.next();
|
|
408
530
|
}
|
|
409
531
|
_sortValues() {
|
|
410
|
-
if (this.
|
|
411
|
-
|
|
412
|
-
this.
|
|
413
|
-
|
|
532
|
+
if (this._multiple &&
|
|
533
|
+
(this.search === 'none' || this.search === 'static')) {
|
|
534
|
+
const options = this.staticOptions.toArray();
|
|
535
|
+
this.selectionModel.sort((a, b) => {
|
|
536
|
+
return (options.findIndex(o => this.compareWith(o.value, a.value)) -
|
|
537
|
+
options.findIndex(o => this.compareWith(o.value, b.value)));
|
|
414
538
|
});
|
|
415
539
|
this.stateChanges.next();
|
|
416
540
|
}
|
|
417
541
|
}
|
|
418
542
|
_propagateChanges(fallbackValue) {
|
|
419
543
|
let valToEmit = null;
|
|
420
|
-
if (this.
|
|
544
|
+
if (this._multiple) {
|
|
421
545
|
valToEmit = this.selected.map(option => option.value);
|
|
422
546
|
}
|
|
423
547
|
else {
|
|
@@ -433,8 +557,91 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
433
557
|
_buildChangeEvent(value) {
|
|
434
558
|
return new SelectChangeEvent(this, value);
|
|
435
559
|
}
|
|
436
|
-
|
|
437
|
-
|
|
560
|
+
/** @ignore */
|
|
561
|
+
_deselectOption(option, markTouched = true) {
|
|
562
|
+
if (this._multiple && this.selectionModel.isSelected(option)) {
|
|
563
|
+
this.selectionModel.deselect(option);
|
|
564
|
+
this._propagateChanges();
|
|
565
|
+
if (markTouched) {
|
|
566
|
+
this._cvaOnTouched();
|
|
567
|
+
}
|
|
568
|
+
this.changeDetector.markForCheck();
|
|
569
|
+
this.stateChanges.next();
|
|
570
|
+
}
|
|
571
|
+
}
|
|
572
|
+
_scrollToSelectedOption() {
|
|
573
|
+
setTimeout(() => {
|
|
574
|
+
if (this.dropdownOpen && this.selected && !Array.isArray(this.selected)) {
|
|
575
|
+
const selectedOptionElement = this.options.find(o => !Array.isArray(this.selected) &&
|
|
576
|
+
this.compareWith(o.value, this.selected.value));
|
|
577
|
+
selectedOptionElement?.nativeElement.scrollIntoView({
|
|
578
|
+
block: 'nearest',
|
|
579
|
+
inline: 'nearest',
|
|
580
|
+
behavior: 'instant'
|
|
581
|
+
});
|
|
582
|
+
}
|
|
583
|
+
}, ON_OPEN_AUTO_SCROLL_TIMEOUT_MS);
|
|
584
|
+
}
|
|
585
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: _SelectComponentBase, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive }); }
|
|
586
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.1", type: _SelectComponentBase, inputs: { value: "value", id: "id" }, outputs: { searchTextChanges: "searchTextChanges" }, queries: [{ propertyName: "staticOptions", predicate: SelectOptionComponent, descendants: true }], viewQueries: [{ propertyName: "ngbDropdown", first: true, predicate: NgbDropdown, descendants: true }, { propertyName: "toggleButtonRef", first: true, predicate: ["toggleButton"], descendants: true, read: ElementRef }, { propertyName: "searchInputRef", first: true, predicate: ["searchInput"], descendants: true, read: (ElementRef) }, { propertyName: "options", predicate: SelectOptionDisplayComponent, descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0 }); }
|
|
587
|
+
}
|
|
588
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: _SelectComponentBase, decorators: [{
|
|
589
|
+
type: Directive
|
|
590
|
+
}], ctorParameters: () => [{ type: undefined }, { type: undefined }], propDecorators: { staticOptions: [{
|
|
591
|
+
type: ContentChildren,
|
|
592
|
+
args: [SelectOptionComponent, { descendants: true }]
|
|
593
|
+
}], options: [{
|
|
594
|
+
type: ViewChildren,
|
|
595
|
+
args: [SelectOptionDisplayComponent]
|
|
596
|
+
}], ngbDropdown: [{
|
|
597
|
+
type: ViewChild,
|
|
598
|
+
args: [NgbDropdown]
|
|
599
|
+
}], toggleButtonRef: [{
|
|
600
|
+
type: ViewChild,
|
|
601
|
+
args: ['toggleButton', { read: ElementRef }]
|
|
602
|
+
}], searchInputRef: [{
|
|
603
|
+
type: ViewChild,
|
|
604
|
+
args: ['searchInput', { read: (ElementRef) }]
|
|
605
|
+
}], searchTextChanges: [{
|
|
606
|
+
type: Output
|
|
607
|
+
}], value: [{
|
|
608
|
+
type: Input
|
|
609
|
+
}], id: [{
|
|
610
|
+
type: Input
|
|
611
|
+
}] } });
|
|
612
|
+
/**
|
|
613
|
+
* The `SelectComponent` (`<impdc-select`) is a select-style dropdown input where an item (or multiple items) can be picked
|
|
614
|
+
* from a list of *unique* available options. This component can be used within a `FormFieldComponent` (`<impdc-form-field`).
|
|
615
|
+
* To use, add `SelectModule` to the `imports` array of the relevant `NgModule` or standalone component.
|
|
616
|
+
*/
|
|
617
|
+
export class SelectComponent extends _SelectComponentBase {
|
|
618
|
+
constructor(tabIndex) {
|
|
619
|
+
super(`impdc-select-${nanoid()}`, tabIndex);
|
|
620
|
+
this.controlType = 'impdc-select';
|
|
621
|
+
this.supportsAffixes = true;
|
|
622
|
+
/**
|
|
623
|
+
* Allow the user to click a button inside of the select control and clear their selection(s);
|
|
624
|
+
*
|
|
625
|
+
* @default true
|
|
626
|
+
*/
|
|
627
|
+
this.allowClear = true;
|
|
628
|
+
this.multipleDisplay = 'inside';
|
|
629
|
+
}
|
|
630
|
+
get multiple() {
|
|
631
|
+
return this._multiple;
|
|
632
|
+
}
|
|
633
|
+
set multiple(value) {
|
|
634
|
+
if (this.selectionModel) {
|
|
635
|
+
throw getImpdcSelectDynamicMultipleError();
|
|
636
|
+
}
|
|
637
|
+
this._multiple = value;
|
|
638
|
+
}
|
|
639
|
+
/** @ignore */
|
|
640
|
+
deselectOption(option) {
|
|
641
|
+
this._deselectOption(option);
|
|
642
|
+
}
|
|
643
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: SelectComponent, deps: [{ token: 'tabindex', attribute: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
644
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.1", type: SelectComponent, isStandalone: true, selector: "impdc-select", inputs: { disabled: "disabled", tabIndex: ["tabIndex", "tabIndex", numberAttribute], search: "search", placeholder: "placeholder", required: ["required", "required", booleanAttribute], compareWith: "compareWith", dropdownContainer: "dropdownContainer", errorStateMatcher: "errorStateMatcher", allowClear: ["allowClear", "allowClear", booleanAttribute], multiple: ["multiple", "multiple", booleanAttribute], multipleDisplay: "multipleDisplay" }, outputs: { selectionChange: "selectionChange", valueChange: "valueChange", searchTextChanges: "searchTextChanges" }, host: { listeners: { "focus": "onFocus(); focus()" }, properties: { "attr.id": "id", "attr.tabindex": "tabIndex", "attr.aria-required": "required.toString()", "attr.aria-disabled": "disabled.toString()", "attr.aria-invalid": "errorState", "class.form-select": "true", "class.is-invalid": "errorState", "class.impdc-form-field-control": "true", "class.impdc-select--required": "required", "class.impdc-select--disabled": "disabled", "class.impdc-select--invalid": "errorState", "class.impdc-select--empty": "empty", "class.impdc-select--multiple": "multiple" } }, providers: [
|
|
438
645
|
{
|
|
439
646
|
provide: ImpdcFormFieldControl,
|
|
440
647
|
useExisting: SelectComponent
|
|
@@ -442,12 +649,36 @@ export class SelectComponent extends _SelectComponentBase {
|
|
|
442
649
|
{
|
|
443
650
|
provide: IMPDC_SELECT_OPTION_PARENT_COMPONENT,
|
|
444
651
|
useExisting: SelectComponent
|
|
652
|
+
},
|
|
653
|
+
{
|
|
654
|
+
provide: IMPDC_SELECT_VALUE_BADGES_PARENT_COMPONENT,
|
|
655
|
+
useExisting: SelectComponent
|
|
445
656
|
}
|
|
446
|
-
],
|
|
657
|
+
], exportAs: ["impdcSelect"], usesInheritance: true, ngImport: i0, template: "<div\n ngbDropdown\n #dropdown=\"ngbDropdown\"\n [autoClose]=\"multiple ? 'outside' : true\"\n [container]=\"dropdownContainer\"\n [dropdownClass]=\"dropdownContainer === 'body' ? 'impartner-hex' : ''\"\n (openChange)=\"handleOpenChange($event)\"\n class=\"h-100 w-100\">\n <button\n #toggleButton\n class=\"impdc-select--toggle btn border-0 h-100 text-start\"\n type=\"button\"\n role=\"combobox\"\n [disabled]=\"disabled\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n ngbDropdownToggle>\n @if (empty) {\n <span class=\"impdc-select--text impdc-select--placeholder\">{{\n placeholder\n }}</span>\n } @else { @if (selectedIsSingle(selected)) {\n <span class=\"impdc-select--text impdc-select--value-text\">\n {{ selected.label }}\n </span>\n } @else if (multipleDisplay === 'inside') {\n <impdc-select-value-tags-display />\n } @else {\n <span class=\"impdc-select--text impdc-select--placeholder\">{{\n placeholder\n }}</span>\n } @if (!disabled && allowClear) {\n <button\n type=\"button\"\n class=\"impdc-select--clear-btn btn btn-xs btn-link text-gray-400 ms-auto\"\n (click)=\"$event.stopPropagation(); dropdown.close(); clearSelection()\">\n <impdc-icon name=\"times\" [size]=\"16\"></impdc-icon>\n </button>\n } }\n </button>\n <div\n ngbDropdownMenu\n class=\"impdc-select--dropdown-menu bg-white text-gray-600\"\n role=\"listbox\"\n tabindex=\"-1\">\n <div *ngIf=\"search !== 'none'\" class=\"impdc-select--search\">\n <impdc-form-field>\n <span impdcTextPrefix (click)=\"searchInput.focus()\">\n <impdc-icon name=\"search\"></impdc-icon>\n </span>\n <input\n #searchInput\n impdcInput\n [formControl]=\"searchControl\"\n class=\"impdc-select--search-input\"\n type=\"search\"\n (keydown.enter)=\"handleSearchSubmit($event)\"\n (keydown.arrowdown)=\"handleSearchUpDown($event, 'up')\"\n (keydown.arrowup)=\"handleSearchUpDown($event, 'down')\" />\n <span impdcTextSuffix>\n <button\n *ngIf=\"searchControl.value\"\n type=\"button\"\n class=\"impdc-select--clear-btn btn btn-xs btn-link text-gray-400 ms-auto\"\n (click)=\"searchControl.reset(); searchInput.focus()\">\n <impdc-icon name=\"times\" [size]=\"16\"></impdc-icon>\n </button>\n </span>\n </impdc-form-field>\n </div>\n <div class=\"impdc-select--options\">\n @for (option of filteredOptions$ | async; track option.value; let idx =\n $index; let first = $first) { @if (option.groupLabel &&\n option.showGroupLabel) {\n <div class=\"impdc-select--option-group-label\">\n {{ option.groupLabel }}\n </div>\n }\n <impdc-select-option-display\n [class.impdc-select-option--active]=\"idx === activeIndex\"\n [class.impdc-select-option--grouped]=\"!!option.groupLabel\"\n [groupLabel]=\"option.groupLabel\"\n [label]=\"option.label\"\n [value]=\"option.value\"\n [disabled]=\"!!option.disabled\"\n [selected]=\"option.selected\"\n [highlightText]=\"searchControl.value\"\n (mouseenter)=\"markActive(idx)\"\n (focus)=\"markActive(idx)\" />\n }\n </div>\n </div>\n</div>\n", styles: [".impdc-select--clear-btn{align-items:center;color:var(--impd-color-gray-400);display:inline-flex;justify-content:center;padding:0;height:2rem;width:2rem;box-shadow:none!important}.impdc-select--clear-btn:focus-visible{box-shadow:var(--impartner-hex-btn-box-shadow),var(--impartner-hex-btn-focus-box-shadow)!important}.impdc-select--clear-btn impdc-icon{line-height:1}.impdc-select--dropdown-menu{overflow:hidden}.impdc-select--search{padding-left:var(--impd-size-2);padding-right:var(--impd-size-2)}.impdc-select--search [impdcTextSuffix]{min-width:3.4rem;width:3.4rem}.impdc-select--options{overflow-y:auto;overflow-x:hidden;max-height:var(--impd-size-72)}.impdc-select--option-group-label{color:var(--impd-color-gray-600);font-size:var(--impd-size-2_5);font-weight:var(--impd-font-weight-semibold);line-height:var(--impd-size-4);padding:var(--impd-size-1) var(--impd-size-4);text-transform:uppercase;white-space:nowrap}.impdc-select--option-group-label:not(:first-child){margin-top:var(--impd-size-2)}button[ngbDropdownToggle].dropdown-toggle:after{display:none}:host{padding:0!important;position:relative}:host.impdc-select--disabled{background-color:var(--impd-color-gray-100)}:host.no-caret{--impartner-hex-form-select-bg-img: none}:host:not(.no-caret) .impdc-select--toggle{padding-right:3.6rem}:host:not(.no-caret).is-invalid .impdc-select--toggle{padding-right:6.6rem}.impdc-select--toggle{font-weight:inherit;cursor:pointer;-webkit-user-select:none;user-select:none;width:100%;gap:var(--impd-size-1)}.impdc-select--toggle:disabled{cursor:default}.impdc-select--text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.impdc-select--value-badges{display:flex;flex-wrap:wrap;gap:var(--impd-size-1);width:100%}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: NgbDropdownModule }, { kind: "directive", type: i3.NgbDropdown, selector: "[ngbDropdown]", inputs: ["autoClose", "dropdownClass", "open", "placement", "popperOptions", "container", "display"], outputs: ["openChange"], exportAs: ["ngbDropdown"] }, { kind: "directive", type: i3.NgbDropdownToggle, selector: "[ngbDropdownToggle]" }, { kind: "directive", type: i3.NgbDropdownMenu, selector: "[ngbDropdownMenu]" }, { kind: "ngmodule", type: IconModule }, { kind: "component", type: i4.IconComponent, selector: "impdc-icon, [impdc-icon]", inputs: ["name", "theme", "size"] }, { kind: "component", type: SelectOptionDisplayComponent, selector: "impdc-select-option-display", inputs: ["selected", "value", "label", "groupLabel", "highlightText", "id", "disabled"], outputs: ["onSelectionChange"] }, { kind: "component", type: SelectValueTagsDisplayComponent, selector: "impdc-select-value-tags-display", inputs: ["rounded", "select", "readonly", "truncateThreshold", "showMoreLabel", "showLessLabel"] }, { kind: "ngmodule", type: FormFieldModule }, { kind: "component", type: i5.FormFieldComponent, selector: "impdc-form-field", exportAs: ["impdcFormField"] }, { kind: "directive", type: i6.PrefixDirective, selector: "[impdcPrefix], [impdcTextPrefix]", inputs: ["impdcTextPrefix"] }, { kind: "directive", type: i7.SuffixDirective, selector: "[impdcSuffix], [impdcTextSuffix]", inputs: ["impdcTextSuffix"] }, { kind: "directive", type: InputDirective, selector: "input[impdcInput], textarea[impdcInput], select[impdcNativeSelect]", inputs: ["disabled", "id", "type", "required", "readonly", "errorStateMatcher", "value"], exportAs: ["impdcInput"] }, { kind: "ngmodule", type: BadgeModule }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
447
658
|
}
|
|
448
659
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImport: i0, type: SelectComponent, decorators: [{
|
|
449
660
|
type: Component,
|
|
450
|
-
args: [{ selector: 'impdc-select', exportAs: 'impdcSelect',
|
|
661
|
+
args: [{ selector: 'impdc-select', exportAs: 'impdcSelect', standalone: true, imports: [
|
|
662
|
+
CommonModule,
|
|
663
|
+
AsyncPipe,
|
|
664
|
+
ReactiveFormsModule,
|
|
665
|
+
NgbDropdownModule,
|
|
666
|
+
IconModule,
|
|
667
|
+
SelectOptionDisplayComponent,
|
|
668
|
+
SelectValueTagsDisplayComponent,
|
|
669
|
+
FormFieldModule,
|
|
670
|
+
InputDirective,
|
|
671
|
+
BadgeModule
|
|
672
|
+
], inputs: [
|
|
673
|
+
'disabled',
|
|
674
|
+
{ name: 'tabIndex', transform: numberAttribute },
|
|
675
|
+
'search',
|
|
676
|
+
'placeholder',
|
|
677
|
+
{ name: 'required', transform: booleanAttribute },
|
|
678
|
+
'compareWith',
|
|
679
|
+
'dropdownContainer',
|
|
680
|
+
'errorStateMatcher'
|
|
681
|
+
], outputs: ['selectionChange', 'valueChange', 'searchTextChanges'], changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
451
682
|
'[attr.id]': 'id',
|
|
452
683
|
'[attr.tabindex]': 'tabIndex',
|
|
453
684
|
'[attr.aria-required]': 'required.toString()',
|
|
@@ -461,7 +692,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImpor
|
|
|
461
692
|
'[class.impdc-select--invalid]': 'errorState',
|
|
462
693
|
'[class.impdc-select--empty]': 'empty',
|
|
463
694
|
'[class.impdc-select--multiple]': 'multiple',
|
|
464
|
-
'(focus)': '
|
|
695
|
+
'(focus)': 'onFocus(); focus()'
|
|
465
696
|
}, providers: [
|
|
466
697
|
{
|
|
467
698
|
provide: ImpdcFormFieldControl,
|
|
@@ -470,53 +701,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.1", ngImpor
|
|
|
470
701
|
{
|
|
471
702
|
provide: IMPDC_SELECT_OPTION_PARENT_COMPONENT,
|
|
472
703
|
useExisting: SelectComponent
|
|
704
|
+
},
|
|
705
|
+
{
|
|
706
|
+
provide: IMPDC_SELECT_VALUE_BADGES_PARENT_COMPONENT,
|
|
707
|
+
useExisting: SelectComponent
|
|
473
708
|
}
|
|
474
|
-
], template: "<div\n ngbDropdown\n [autoClose]=\"multiple ? 'outside' : true\"\n container=\"
|
|
475
|
-
}], ctorParameters: () => [{ type:
|
|
709
|
+
], template: "<div\n ngbDropdown\n #dropdown=\"ngbDropdown\"\n [autoClose]=\"multiple ? 'outside' : true\"\n [container]=\"dropdownContainer\"\n [dropdownClass]=\"dropdownContainer === 'body' ? 'impartner-hex' : ''\"\n (openChange)=\"handleOpenChange($event)\"\n class=\"h-100 w-100\">\n <button\n #toggleButton\n class=\"impdc-select--toggle btn border-0 h-100 text-start\"\n type=\"button\"\n role=\"combobox\"\n [disabled]=\"disabled\"\n (focus)=\"onFocus()\"\n (blur)=\"onBlur()\"\n ngbDropdownToggle>\n @if (empty) {\n <span class=\"impdc-select--text impdc-select--placeholder\">{{\n placeholder\n }}</span>\n } @else { @if (selectedIsSingle(selected)) {\n <span class=\"impdc-select--text impdc-select--value-text\">\n {{ selected.label }}\n </span>\n } @else if (multipleDisplay === 'inside') {\n <impdc-select-value-tags-display />\n } @else {\n <span class=\"impdc-select--text impdc-select--placeholder\">{{\n placeholder\n }}</span>\n } @if (!disabled && allowClear) {\n <button\n type=\"button\"\n class=\"impdc-select--clear-btn btn btn-xs btn-link text-gray-400 ms-auto\"\n (click)=\"$event.stopPropagation(); dropdown.close(); clearSelection()\">\n <impdc-icon name=\"times\" [size]=\"16\"></impdc-icon>\n </button>\n } }\n </button>\n <div\n ngbDropdownMenu\n class=\"impdc-select--dropdown-menu bg-white text-gray-600\"\n role=\"listbox\"\n tabindex=\"-1\">\n <div *ngIf=\"search !== 'none'\" class=\"impdc-select--search\">\n <impdc-form-field>\n <span impdcTextPrefix (click)=\"searchInput.focus()\">\n <impdc-icon name=\"search\"></impdc-icon>\n </span>\n <input\n #searchInput\n impdcInput\n [formControl]=\"searchControl\"\n class=\"impdc-select--search-input\"\n type=\"search\"\n (keydown.enter)=\"handleSearchSubmit($event)\"\n (keydown.arrowdown)=\"handleSearchUpDown($event, 'up')\"\n (keydown.arrowup)=\"handleSearchUpDown($event, 'down')\" />\n <span impdcTextSuffix>\n <button\n *ngIf=\"searchControl.value\"\n type=\"button\"\n class=\"impdc-select--clear-btn btn btn-xs btn-link text-gray-400 ms-auto\"\n (click)=\"searchControl.reset(); searchInput.focus()\">\n <impdc-icon name=\"times\" [size]=\"16\"></impdc-icon>\n </button>\n </span>\n </impdc-form-field>\n </div>\n <div class=\"impdc-select--options\">\n @for (option of filteredOptions$ | async; track option.value; let idx =\n $index; let first = $first) { @if (option.groupLabel &&\n option.showGroupLabel) {\n <div class=\"impdc-select--option-group-label\">\n {{ option.groupLabel }}\n </div>\n }\n <impdc-select-option-display\n [class.impdc-select-option--active]=\"idx === activeIndex\"\n [class.impdc-select-option--grouped]=\"!!option.groupLabel\"\n [groupLabel]=\"option.groupLabel\"\n [label]=\"option.label\"\n [value]=\"option.value\"\n [disabled]=\"!!option.disabled\"\n [selected]=\"option.selected\"\n [highlightText]=\"searchControl.value\"\n (mouseenter)=\"markActive(idx)\"\n (focus)=\"markActive(idx)\" />\n }\n </div>\n </div>\n</div>\n", styles: [".impdc-select--clear-btn{align-items:center;color:var(--impd-color-gray-400);display:inline-flex;justify-content:center;padding:0;height:2rem;width:2rem;box-shadow:none!important}.impdc-select--clear-btn:focus-visible{box-shadow:var(--impartner-hex-btn-box-shadow),var(--impartner-hex-btn-focus-box-shadow)!important}.impdc-select--clear-btn impdc-icon{line-height:1}.impdc-select--dropdown-menu{overflow:hidden}.impdc-select--search{padding-left:var(--impd-size-2);padding-right:var(--impd-size-2)}.impdc-select--search [impdcTextSuffix]{min-width:3.4rem;width:3.4rem}.impdc-select--options{overflow-y:auto;overflow-x:hidden;max-height:var(--impd-size-72)}.impdc-select--option-group-label{color:var(--impd-color-gray-600);font-size:var(--impd-size-2_5);font-weight:var(--impd-font-weight-semibold);line-height:var(--impd-size-4);padding:var(--impd-size-1) var(--impd-size-4);text-transform:uppercase;white-space:nowrap}.impdc-select--option-group-label:not(:first-child){margin-top:var(--impd-size-2)}button[ngbDropdownToggle].dropdown-toggle:after{display:none}:host{padding:0!important;position:relative}:host.impdc-select--disabled{background-color:var(--impd-color-gray-100)}:host.no-caret{--impartner-hex-form-select-bg-img: none}:host:not(.no-caret) .impdc-select--toggle{padding-right:3.6rem}:host:not(.no-caret).is-invalid .impdc-select--toggle{padding-right:6.6rem}.impdc-select--toggle{font-weight:inherit;cursor:pointer;-webkit-user-select:none;user-select:none;width:100%;gap:var(--impd-size-1)}.impdc-select--toggle:disabled{cursor:default}.impdc-select--text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.impdc-select--value-badges{display:flex;flex-wrap:wrap;gap:var(--impd-size-1);width:100%}\n"] }]
|
|
710
|
+
}], ctorParameters: () => [{ type: undefined, decorators: [{
|
|
476
711
|
type: Attribute,
|
|
477
712
|
args: ['tabindex']
|
|
478
|
-
}] },
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
type: Inject,
|
|
482
|
-
args: [IMPDC_FORM_ROOT]
|
|
483
|
-
}] }, { type: i2.NgForm, decorators: [{
|
|
484
|
-
type: Optional
|
|
485
|
-
}] }, { type: i2.FormGroupDirective, decorators: [{
|
|
486
|
-
type: Optional
|
|
487
|
-
}] }, { type: i2.NgControl, decorators: [{
|
|
488
|
-
type: Self
|
|
489
|
-
}, {
|
|
490
|
-
type: Optional
|
|
491
|
-
}] }], propDecorators: { options: [{
|
|
492
|
-
type: ContentChildren,
|
|
493
|
-
args: [SelectOptionComponent, { descendants: true }]
|
|
494
|
-
}], _ngbDropdown: [{
|
|
495
|
-
type: ViewChild,
|
|
496
|
-
args: [NgbDropdown]
|
|
497
|
-
}], _ngbDropdownMenu: [{
|
|
498
|
-
type: ViewChild,
|
|
499
|
-
args: [NgbDropdownMenu]
|
|
500
|
-
}], _toggleButtonRef: [{
|
|
501
|
-
type: ViewChild,
|
|
502
|
-
args: ['toggleButton', { static: true, read: ElementRef }]
|
|
503
|
-
}], placeholder: [{
|
|
504
|
-
type: Input
|
|
505
|
-
}], required: [{
|
|
506
|
-
type: Input
|
|
713
|
+
}] }], propDecorators: { allowClear: [{
|
|
714
|
+
type: Input,
|
|
715
|
+
args: [{ transform: booleanAttribute }]
|
|
507
716
|
}], multiple: [{
|
|
508
|
-
type: Input
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
}], errorStateMatcher: [{
|
|
512
|
-
type: Input
|
|
513
|
-
}], selectionChange: [{
|
|
514
|
-
type: Output
|
|
515
|
-
}], valueChange: [{
|
|
516
|
-
type: Output
|
|
517
|
-
}], value: [{
|
|
518
|
-
type: Input
|
|
519
|
-
}], id: [{
|
|
717
|
+
type: Input,
|
|
718
|
+
args: [{ transform: booleanAttribute }]
|
|
719
|
+
}], multipleDisplay: [{
|
|
520
720
|
type: Input
|
|
521
721
|
}] } });
|
|
522
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../../projects/design-components/src/lib/form-field/controls/select/select.component.ts","../../../../../../../../projects/design-components/src/lib/form-field/controls/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/no-conflicting-lifecycle */\nimport {\n  AfterContentInit,\n  AfterViewInit,\n  Attribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  Self,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormGroupDirective,\n  NgControl,\n  NgForm,\n  Validators\n} from '@angular/forms';\nimport { NgbDropdown, NgbDropdownMenu } from '@ng-bootstrap/ng-bootstrap';\nimport { nanoid } from 'nanoid';\nimport {\n  BooleanInput,\n  coerceBooleanPropertyValue\n} from '../../../../utilities';\nimport {\n  defer,\n  merge,\n  Observable,\n  startWith,\n  Subject,\n  switchMap,\n  take,\n  takeUntil\n} from 'rxjs';\nimport { ErrorStateMatcher } from '../../services';\nimport { ImpdcFormRoot, IMPDC_FORM_ROOT } from '../../directives';\nimport {\n  CanDisable,\n  HasTabIndex,\n  ICanUpdateErrorState,\n  IHasErrorState,\n  ImpdcFormFieldControl,\n  mixinDisabled,\n  mixinErrorState,\n  mixinTabIndex\n} from '../../shared';\nimport { IMPDC_SELECT_OPTION_PARENT_COMPONENT } from './option-parent';\nimport {\n  SelectOptionSelectionChangeEvent,\n  SelectOptionComponent\n} from './option/select-option.component';\nimport { SelectModel } from './select-model';\n\nexport class SelectChangeEvent {\n  constructor(\n    /** The specific SelectComponent that changed. */\n    public readonly source: SelectComponent,\n    /** The selected value(s) */\n    public readonly value: any\n  ) {}\n}\n\n/**\n * Returns an exception to be thrown when attempting to assign a non-array value to a select\n * in `multiple` mode. Note that `undefined` and `null` are still valid values to allow for\n * resetting the value.\n * @ignore\n */\nexport function getImpdcSelectNonArrayValueError(): Error {\n  return Error('Value must be an array in multiple-selection mode.');\n}\n\n/**\n * Returns an exception to be thrown when assigning a non-function value to the comparator\n * used to determine if a value corresponds to an option. Note that whether the function\n * actually takes two values and returns a boolean is not checked.\n */\nexport function getImpdcSelectNonFunctionValueError(): Error {\n  return Error('`compareWith` must be a function.');\n}\n\n/**\n * Returns an exception to be thrown when attempting to change a select's `multiple` option\n * after initialization.\n * @ignore\n */\nexport function getImpdcSelectDynamicMultipleError(): Error {\n  return Error('Cannot change `multiple` mode of select after initialization.');\n}\n\nconst _SelectComponentBase = mixinTabIndex(\n  mixinDisabled(\n    mixinErrorState(\n      class {\n        public readonly stateChanges = new Subject<void>();\n\n        constructor(\n          public _defaultErrorStateMatcher: ErrorStateMatcher,\n          public _formRoot: ImpdcFormRoot,\n          public _parentForm: NgForm,\n          public _parentFormGroup: FormGroupDirective,\n          public ngControl: NgControl | null\n        ) {}\n      }\n    )\n  )\n);\n\n/**\n * The `SelectComponent` (`<impdc-select`) is a select-style dropdown input where an item (or multiple items) can be picked\n * from a list of available options. This component can be used within a `FormFieldComponent` (`<impdc-form-field`).\n * To use, import `SelectModule` or another module that imports and exports that module from `@impartner/design-components`.\n */\n@Component({\n  selector: 'impdc-select',\n  exportAs: 'impdcSelect',\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property\n  inputs: ['disabled', 'tabIndex'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    '[attr.id]': 'id',\n    '[attr.tabindex]': 'tabIndex',\n    '[attr.aria-required]': 'required.toString()',\n    '[attr.aria-disabled]': 'disabled.toString()',\n    '[attr.aria-invalid]': 'errorState',\n    '[class.form-select]': 'true',\n    '[class.is-invalid]': 'errorState',\n    '[class.impdc-form-field-control]': 'true',\n    '[class.impdc-select--required]': 'required',\n    '[class.impdc-select--disabled]': 'disabled',\n    '[class.impdc-select--invalid]': 'errorState',\n    '[class.impdc-select--empty]': 'empty',\n    '[class.impdc-select--multiple]': 'multiple',\n    '(focus)': '_onFocus(); focus()'\n  },\n  providers: [\n    {\n      provide: ImpdcFormFieldControl,\n      useExisting: SelectComponent\n    },\n    {\n      provide: IMPDC_SELECT_OPTION_PARENT_COMPONENT,\n      useExisting: SelectComponent\n    }\n  ]\n})\nexport class SelectComponent\n  extends _SelectComponentBase\n  implements\n    OnInit,\n    AfterContentInit,\n    AfterViewInit,\n    OnChanges,\n    DoCheck,\n    OnDestroy,\n    ControlValueAccessor,\n    HasTabIndex,\n    ImpdcFormFieldControl<any>,\n    CanDisable,\n    ICanUpdateErrorState,\n    IHasErrorState\n{\n  /** @ignore */\n  @ContentChildren(SelectOptionComponent, { descendants: true })\n  public options!: QueryList<SelectOptionComponent>;\n\n  @ViewChild(NgbDropdown)\n  protected _ngbDropdown!: NgbDropdown;\n\n  @ViewChild(NgbDropdownMenu)\n  protected _ngbDropdownMenu!: NgbDropdownMenu;\n\n  @ViewChild('toggleButton', { static: true, read: ElementRef })\n  protected _toggleButtonRef!: ElementRef<HTMLButtonElement>;\n\n  /** @ignore */\n  public readonly optionSelectionChanges: Observable<SelectOptionSelectionChangeEvent> =\n    defer(() => {\n      const options = this.options;\n\n      if (options) {\n        return options.changes.pipe(\n          startWith(options),\n          switchMap(() =>\n            merge(...options.map(option => option.onSelectionChange))\n          )\n        );\n      }\n\n      return this._ngZone.onStable.pipe(\n        take(1),\n        switchMap(() => this.optionSelectionChanges)\n      );\n    });\n\n  protected readonly _uid = `impdc-select-${nanoid()}`;\n  protected _selectionModel!: SelectModel<SelectOptionComponent>;\n\n  private readonly _ngDestroy = new Subject<void>();\n  private _previousControl?: AbstractControl | null;\n  private _compareWith = (o1: any, o2: any) => o1 === o2;\n  private _cvaOnChange: (value: any) => void = () => {};\n  private _cvaOnTouched = () => {};\n\n  /**\n   * The placeholder text that will be displayed when no selection has been made.\n   *\n   * @default \\- Select -\n   */\n  @Input()\n  public get placeholder(): string {\n    return this._placeholder;\n  }\n  public set placeholder(value: string) {\n    this._placeholder = value;\n    this.stateChanges.next();\n  }\n  private _placeholder = '- Select -';\n\n  /**\n   * Used to set requiredness of control in a template-based manner;\n   * not necessary when using the Angular reactive forms API and `required` validator.\n   */\n  @Input()\n  public get required(): boolean {\n    return (\n      this._required ??\n      this.ngControl?.control?.hasValidator(Validators.required) ??\n      false\n    );\n  }\n  public set required(value: BooleanInput) {\n    this._required = coerceBooleanPropertyValue(value);\n    this.stateChanges.next();\n  }\n  private _required: boolean | undefined;\n\n  /**\n   * Sets whether the control is a single-select or multiple-select. Cannot be changed after component initialization.\n   */\n  @Input()\n  public get multiple(): boolean {\n    return this._multiple;\n  }\n  public set multiple(value: BooleanInput) {\n    if (this._selectionModel) {\n      throw getImpdcSelectDynamicMultipleError();\n    }\n\n    this._multiple = coerceBooleanPropertyValue(value);\n  }\n  protected _multiple = false;\n\n  /**\n   * Function used to compare option values with selected values. The first arg is a\n   * value from an option, and the second arg is a value from the selection.\n   *\n   * @returns Boolean indicating if the values are equivalent.\n   */\n  @Input()\n  public get compareWith() {\n    return this._compareWith;\n  }\n  public set compareWith(fn: (a: any, b: any) => boolean) {\n    if (typeof fn !== 'function') {\n      throw getImpdcSelectNonFunctionValueError();\n    }\n\n    this._compareWith = fn;\n\n    if (this._selectionModel) {\n      // Changing the comparator function means the visual selection may have changed.\n      this._initializeSelection();\n    }\n  }\n\n  @Input()\n  public override errorStateMatcher!: ErrorStateMatcher;\n\n  /** Events fire when selection has been changed by the user. */\n  @Output()\n  public readonly selectionChange: EventEmitter<SelectChangeEvent> =\n    new EventEmitter<SelectChangeEvent>();\n\n  /**\n   * Events fire when raw value of select changes. Mainly exists to handle\n   * two-way binding of `value` input property.\n   * @ignore\n   */\n  @Output()\n  public readonly valueChange: EventEmitter<any> = new EventEmitter<any>();\n\n  public get dropdownOpen(): boolean {\n    return this._ngbDropdown?.isOpen() ?? false;\n  }\n\n  constructor(\n    private readonly _changeDetector: ChangeDetectorRef,\n    protected readonly _ngZone: NgZone,\n    @Attribute('tabindex') tabIndex: string,\n    _defaultErrorStateMatcher: ErrorStateMatcher,\n    @Optional() @Inject(IMPDC_FORM_ROOT) _formRoot: ImpdcFormRoot,\n    @Optional() _parentForm: NgForm,\n    @Optional() _parentFormGroup: FormGroupDirective,\n    @Self() @Optional() ngControl: NgControl\n  ) {\n    super(\n      _defaultErrorStateMatcher,\n      _formRoot,\n      _parentForm,\n      _parentFormGroup,\n      ngControl\n    );\n\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    this.id = this.id;\n    this.tabIndex = parseInt(tabIndex) || 0;\n  }\n\n  public get empty(): boolean {\n    return !this._selectionModel || this._selectionModel.isEmpty();\n  }\n\n  public get displayedValue(): string {\n    if (this.empty) {\n      return '';\n    }\n\n    if (!this._multiple) {\n      return this._selectionModel.selected[0].label;\n    }\n\n    return this._selectionModel.selected.map(opt => opt.label).join(', ');\n  }\n\n  public get selected(): SelectOptionComponent | SelectOptionComponent[] {\n    return this.multiple\n      ? this._selectionModel?.selected || []\n      : this._selectionModel?.selected[0];\n  }\n\n  /** @ignore */\n  public focus(options?: FocusOptions): void {\n    this._toggleButtonRef.nativeElement.focus(options);\n  }\n\n  protected _handleOpenChange(isOpen: boolean): void {\n    if (isOpen) {\n      this._onFocus();\n    } else {\n      this._onBlur();\n    }\n\n    this.stateChanges.next();\n  }\n\n  /* Angular lifecycle hooks */\n\n  /** @ignore */\n  public ngOnInit(): void {\n    this._selectionModel = new SelectModel<SelectOptionComponent>(\n      this.multiple\n    );\n    this.stateChanges.next();\n  }\n\n  /** @ignore */\n  public ngAfterContentInit(): void {\n    this._selectionModel.changed$\n      .pipe(takeUntil(this._ngDestroy))\n      .subscribe(changeEvent => {\n        changeEvent.added.forEach(option => option.select());\n        changeEvent.removed.forEach(option => option.deselect());\n      });\n\n    this.options.changes\n      .pipe(startWith(null), takeUntil(this._ngDestroy))\n      .subscribe(() => {\n        this._resetOptions();\n        this._initializeSelection();\n      });\n  }\n\n  /** @ignore */\n  public ngAfterViewInit(): void {\n    this._ngbDropdownMenu.menuItems = this.options;\n  }\n\n  /** @ignore */\n  public ngDoCheck(): void {\n    const ngControl = this.ngControl;\n\n    if (!ngControl) {\n      return;\n    }\n\n    if (this._previousControl !== ngControl.control) {\n      if (\n        this._previousControl !== undefined &&\n        ngControl.disabled !== null &&\n        ngControl.disabled !== this.disabled\n      ) {\n        this.disabled = ngControl?.disabled;\n      }\n\n      this._previousControl = ngControl.control;\n    }\n\n    this.updateErrorState();\n  }\n\n  /** @ignore */\n  public ngOnChanges(changes: SimpleChanges): void {\n    // Managing disabled state is handled via the `mixinDisabled` mixin/generator, but we still need to signal\n    // to the parent form field so it can run change detection when disabled state is changed.\n    if (changes['disabled']) {\n      this.stateChanges.next();\n    }\n  }\n\n  /** @ignore */\n  public ngOnDestroy(): void {\n    this._ngDestroy.next();\n    this._ngDestroy.complete();\n    this.stateChanges.complete();\n  }\n\n  /* ImpdcFormFieldControl */\n  public readonly controlType: string = 'impdc-select';\n\n  public readonly supportsAffixes: boolean = true;\n\n  @Input()\n  public get value(): any {\n    return this._value;\n  }\n  public set value(value: any) {\n    const hasAssigned = this._assignValue(value);\n\n    if (hasAssigned) {\n      this._cvaOnChange(value);\n    }\n  }\n  protected _value: any;\n\n  @Input()\n  public get id(): string {\n    return this._id;\n  }\n  public set id(value: string) {\n    this._id = value || this._uid;\n    this.stateChanges.next();\n  }\n  protected _id!: string;\n\n  public get focused(): boolean {\n    return this._focused || this.dropdownOpen;\n  }\n  protected _focused = false;\n\n  /* ControlValueAccessor */\n  /** @ignore */\n  public writeValue(value: any): void {\n    this._assignValue(value);\n  }\n\n  /** @ignore */\n  public registerOnChange(fn: (value: any) => void): void {\n    this._cvaOnChange = fn;\n  }\n\n  /** @ignore */\n  public registerOnTouched(fn: () => {}): void {\n    this._cvaOnTouched = fn;\n  }\n\n  /** @ignore */\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this._changeDetector.markForCheck();\n    this.stateChanges.next();\n  }\n\n  /* Internals */\n\n  protected _onFocus(): void {\n    if (!this.disabled) {\n      this._focused = true;\n      this.stateChanges.next();\n    }\n  }\n\n  /**\n   * Calls the CVA touched callback only if the dropdown is closed.\n   */\n  protected _onBlur(): void {\n    this._focused = false;\n\n    if (!this.disabled && !this.dropdownOpen) {\n      this._cvaOnTouched();\n      this._changeDetector.markForCheck();\n      this.stateChanges.next();\n    }\n  }\n\n  private _initializeSelection(): void {\n    // We defer this work into a promise in order to avoid tripping Angular's\n    // \"Expression has changed after it was checked\" error.\n    Promise.resolve().then(() => {\n      if (this.ngControl) {\n        this._value = this.ngControl.value;\n      }\n\n      this._setSelectionByValue(this._value);\n      this.stateChanges.next();\n    });\n  }\n\n  private _setSelectionByValue(value: any | any[]): void {\n    this._selectionModel.clear();\n\n    if (this.multiple && value) {\n      if (!Array.isArray(value)) {\n        throw getImpdcSelectNonArrayValueError();\n      }\n\n      value.forEach(currentValue => this._selectOptionByValue(currentValue));\n      this._sortValues();\n    } else {\n      this._selectOptionByValue(value);\n    }\n\n    this._changeDetector.detectChanges();\n  }\n\n  private _selectOptionByValue(value: any): SelectOptionComponent | undefined {\n    const correspondingOption = this.options.find(\n      (option: SelectOptionComponent) => {\n        if (this._selectionModel.isSelected(option)) {\n          return false;\n        }\n\n        try {\n          return option.value != null && this._compareWith(option.value, value);\n        } catch (error) {\n          console.warn(error);\n          return false;\n        }\n      }\n    );\n\n    if (correspondingOption) {\n      this._selectionModel.select(correspondingOption);\n    }\n\n    return correspondingOption;\n  }\n\n  /** Assigns a value to the select control. Returns a boolean indicating whether or not\n   * the value has changed.\n   */\n  private _assignValue(newValue: any | any[]): boolean {\n    if (\n      newValue !== this._value ||\n      (this._multiple && Array.isArray(newValue))\n    ) {\n      if (this.options) {\n        this._setSelectionByValue(newValue);\n      }\n\n      this._value = newValue;\n      return true;\n    }\n\n    return false;\n  }\n\n  private _resetOptions(): void {\n    const changedOrDestroyed = merge(this.options.changes, this._ngDestroy);\n\n    this.optionSelectionChanges\n      .pipe(takeUntil(changedOrDestroyed))\n      .subscribe(event => {\n        this._onSelect(event.source, event.isUserInput);\n\n        if (event.isUserInput && !this.multiple && this.dropdownOpen) {\n          this._ngbDropdown.close();\n          this.focus();\n        }\n      });\n\n    merge(...this.options.map(option => option.stateChanges))\n      .pipe(takeUntil(changedOrDestroyed))\n      .subscribe(() => {\n        this._changeDetector.detectChanges();\n        this.stateChanges.next();\n      });\n  }\n\n  private _onSelect(option: SelectOptionComponent, isUserInput: boolean): void {\n    const wasSelected = this._selectionModel.isSelected(option);\n\n    if (option.value == null && !this._multiple) {\n      option.deselect();\n      this._selectionModel.clear();\n\n      if (this.value != null) {\n        this._propagateChanges(option.value);\n      }\n    } else {\n      if (wasSelected !== option.selected) {\n        option.selected\n          ? this._selectionModel.select(option)\n          : this._selectionModel.deselect(option);\n      }\n\n      if (this.multiple) {\n        this._sortValues();\n\n        if (isUserInput) {\n          this.focus();\n        }\n      }\n    }\n\n    if (wasSelected !== this._selectionModel.isSelected(option)) {\n      this._propagateChanges();\n    }\n\n    this._changeDetector.markForCheck();\n    this.stateChanges.next();\n  }\n\n  private _sortValues(): void {\n    if (this.multiple) {\n      const options = this.options.toArray();\n\n      this._selectionModel.sort((a, b) => {\n        return options.indexOf(a) - options.indexOf(b);\n      });\n\n      this.stateChanges.next();\n    }\n  }\n\n  private _propagateChanges(fallbackValue?: any): void {\n    let valToEmit: any = null;\n\n    if (this.multiple) {\n      valToEmit = (this.selected as SelectOptionComponent[]).map(\n        option => option.value\n      );\n    } else {\n      valToEmit = this.selected\n        ? (this.selected as SelectOptionComponent).value\n        : fallbackValue;\n    }\n\n    this._value = valToEmit;\n    this.valueChange.emit(valToEmit);\n    this._cvaOnChange(valToEmit);\n    this.selectionChange.emit(this._buildChangeEvent(valToEmit));\n  }\n\n  private _buildChangeEvent(value: any): SelectChangeEvent {\n    return new SelectChangeEvent(this, value);\n  }\n}\n","<div\n  ngbDropdown\n  [autoClose]=\"multiple ? 'outside' : true\"\n  container=\"body\"\n  dropdownClass=\"impartner-hex\"\n  (openChange)=\"_handleOpenChange($event)\"\n  class=\"w-100\">\n  <button\n    #toggleButton\n    class=\"impdc-select--toggle btn border-0 text-start\"\n    type=\"button\"\n    role=\"combobox\"\n    [disabled]=\"disabled\"\n    (focus)=\"_onFocus()\"\n    (blur)=\"_onBlur()\"\n    ngbDropdownToggle>\n    <ng-container [ngSwitch]=\"empty\">\n      <span\n        class=\"impdc-select--text impdc-select--placeholder\"\n        *ngSwitchCase=\"true\"\n        >{{ placeholder }}</span\n      >\n      <span\n        class=\"impdc-select--text impdc-select--value-text\"\n        *ngSwitchCase=\"false\"\n        >{{ displayedValue }}</span\n      >\n    </ng-container>\n  </button>\n  <div\n    ngbDropdownMenu\n    class=\"w-100 bg-white text-gray-600\"\n    role=\"listbox\"\n    tabindex=\"-1\">\n    <ng-content></ng-content>\n  </div>\n</div>\n"]}
|
|
722
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../../projects/design-components/src/lib/form-field/controls/select/select.component.ts","../../../../../../../../projects/design-components/src/lib/form-field/controls/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/no-conflicting-lifecycle */\nimport { AsyncPipe, CommonModule } from '@angular/common';\nimport {\n  AfterViewInit,\n  Attribute,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Directive,\n  DoCheck,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Output,\n  QueryList,\n  SimpleChanges,\n  ViewChild,\n  ViewChildren,\n  booleanAttribute,\n  inject,\n  numberAttribute\n} from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormControl,\n  FormGroupDirective,\n  NgControl,\n  NgForm,\n  ReactiveFormsModule,\n  Validators\n} from '@angular/forms';\nimport { NgbDropdown, NgbDropdownModule } from '@ng-bootstrap/ng-bootstrap';\nimport { nanoid } from 'nanoid';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  debounceTime,\n  defer,\n  distinctUntilChanged,\n  map,\n  merge,\n  Observable,\n  startWith,\n  Subject,\n  switchMap,\n  take,\n  takeUntil,\n  tap\n} from 'rxjs';\n\nimport { ComponentTheme } from '../../../../types';\nimport { lc } from '../../../../utilities';\nimport { BadgeModule } from '../../../badge';\nimport { IconModule } from '../../../icon';\nimport { ErrorStateMatcher } from '../../services';\nimport {\n  ImpdcFormRoot,\n  IMPDC_FORM_ROOT,\n  FormFieldModule\n} from '../../component';\nimport {\n  CanDisable,\n  HasTabIndex,\n  ICanUpdateErrorState,\n  IHasErrorState,\n  ImpdcFormFieldControl,\n  mixinDisabled,\n  mixinErrorState,\n  mixinTabIndex\n} from '../../shared';\nimport { InputDirective } from '../input';\nimport {\n  IMPDC_SELECT_OPTION_PARENT_COMPONENT,\n  IMPDC_SELECT_VALUE_BADGES_PARENT_COMPONENT,\n  ISelectOptionParentComponent,\n  ISelectValueBadgesParentComponent\n} from './option-parent';\nimport {\n  SelectOptionSelectionChangeEvent,\n  SelectOptionDisplayComponent\n} from './option-display';\nimport { SelectModel } from './select-model';\nimport { SelectOptionComponent } from './option';\nimport { ISelectOption } from './interfaces';\nimport { SelectValueTagsDisplayComponent } from './value-tags-display';\n\nexport const ON_OPEN_AUTO_SCROLL_TIMEOUT_MS = 50;\n\nexport class SelectChangeEvent<TComponent> {\n  constructor(\n    /** The specific SelectComponent that changed. */\n    public readonly source: TComponent,\n    /** The selected value(s) */\n    public readonly value: any\n  ) {}\n}\n\n/**\n * Returns an exception to be thrown when attempting to assign a non-array value to a select\n * in `multiple` mode. Note that `undefined` and `null` are still valid values to allow for\n * resetting the value.\n * @ignore\n */\nexport function getImpdcSelectNonArrayValueError(): Error {\n  return Error('Value must be an array in multiple-selection mode.');\n}\n\n/**\n * Returns an exception to be thrown when assigning a non-function value to the comparator\n * used to determine if a value corresponds to an option. Note that whether the function\n * actually takes two values and returns a boolean is not checked.\n */\nexport function getImpdcSelectNonFunctionValueError(): Error {\n  return Error('`compareWith` must be a function.');\n}\n\n/**\n * Returns an exception to be thrown when attempting to change a select's `multiple` option\n * after initialization.\n * @ignore\n */\nexport function getImpdcSelectDynamicMultipleError(): Error {\n  return Error('Cannot change `multiple` mode of select after initialization.');\n}\n\nconst DEFAULT_ACTIVE_INDEX = -1;\n\ninterface IRenderedSelectOption extends ISelectOption {\n  readonly selected?: boolean;\n  readonly showGroupLabel?: boolean;\n}\n\nconst __SelectComponentBase = mixinTabIndex(\n  mixinDisabled(\n    mixinErrorState(\n      class {\n        public readonly stateChanges = new Subject<void>();\n\n        constructor(\n          public _defaultErrorStateMatcher: ErrorStateMatcher,\n          public _formRoot: ImpdcFormRoot | null,\n          public _parentForm: NgForm | null,\n          public _parentFormGroup: FormGroupDirective | null,\n          public ngControl: NgControl | null\n        ) {}\n      }\n    )\n  )\n);\n\n@Directive()\nexport abstract class _SelectComponentBase\n  extends __SelectComponentBase\n  implements\n    ISelectOptionParentComponent,\n    OnInit,\n    AfterViewInit,\n    OnChanges,\n    DoCheck,\n    OnDestroy,\n    ControlValueAccessor,\n    HasTabIndex,\n    ImpdcFormFieldControl<any>,\n    CanDisable,\n    ICanUpdateErrorState,\n    IHasErrorState\n{\n  @ContentChildren(SelectOptionComponent, { descendants: true })\n  protected staticOptions!: QueryList<SelectOptionComponent>;\n\n  @ViewChildren(SelectOptionDisplayComponent)\n  protected options!: QueryList<SelectOptionDisplayComponent>;\n\n  @ViewChild(NgbDropdown)\n  protected ngbDropdown!: NgbDropdown;\n\n  @ViewChild('toggleButton', { read: ElementRef })\n  protected toggleButtonRef?: ElementRef<HTMLElement>;\n\n  @ViewChild('searchInput', { read: ElementRef<HTMLInputElement> })\n  protected searchInputRef?: ElementRef<HTMLInputElement>;\n\n  private readonly _ngDestroy = new Subject<void>();\n  private readonly _searchSubject = new BehaviorSubject<'none' | 'static'>(\n    'none'\n  );\n  private _previousControl?: AbstractControl | null;\n  private _compareWith = (o1: any, o2: any) => o1 === o2;\n  private _cvaOnChange: (value: any) => void = () => {};\n  private _cvaOnTouched = () => {};\n\n  protected readonly uid: string;\n  protected readonly changeDetector = inject(ChangeDetectorRef);\n  protected readonly ngZone = inject(NgZone);\n  protected readonly searchControl = new FormControl<string | null>(null);\n  protected readonly BadgeTheme = ComponentTheme;\n  protected readonly filteredOptions$: Observable<IRenderedSelectOption[]> =\n    this._searchSubject.pipe(\n      switchMap(searchMode => {\n        switch (searchMode) {\n          case 'none':\n            return (\n              this.staticOptions.changes as Observable<ISelectOption[]>\n            ).pipe(\n              startWith(this.staticOptions.toArray() as ISelectOption[]),\n              map(options =>\n                options.map(opt => ({\n                  groupLabel: opt.groupLabel,\n                  get label() {\n                    return opt.label;\n                  },\n                  value: opt.value,\n                  get disabled() {\n                    return opt.disabled;\n                  },\n                  selected: this.selectionModel.isSelected(opt)\n                }))\n              )\n            );\n          case 'static':\n            return combineLatest([\n              (this.staticOptions.changes as Observable<ISelectOption[]>).pipe(\n                startWith(this.staticOptions.toArray() as ISelectOption[])\n              ),\n              this.searchTextChanges.pipe(startWith(''))\n            ]).pipe(\n              tap(([, searchText]) => {\n                this.activeIndex = !!searchText ? 0 : DEFAULT_ACTIVE_INDEX;\n              }),\n              map(([options, searchText]) => {\n                const renderedOptions = options.map(opt => ({\n                  groupLabel: opt.groupLabel,\n                  get label() {\n                    return opt.label;\n                  },\n                  value: opt.value,\n                  get disabled() {\n                    return opt.disabled;\n                  },\n                  selected: this.selectionModel.isSelected(opt)\n                }));\n\n                return !!searchText\n                  ? renderedOptions.filter(\n                      opt => lc(opt.label).indexOf(lc(searchText)) !== -1\n                    )\n                  : renderedOptions;\n              })\n            );\n        }\n      }),\n      map(options =>\n        Object.entries(\n          options.reduce((result, opt) => {\n            const resolvedGroupLabel = opt.groupLabel?.trim() || '';\n            let showGroupLabel = false;\n\n            if (!(resolvedGroupLabel in result)) {\n              result[resolvedGroupLabel] = [];\n              showGroupLabel = true;\n            }\n\n            result[resolvedGroupLabel].push({\n              ...opt,\n              showGroupLabel\n            });\n            return result;\n          }, {} as { [key: string]: IRenderedSelectOption[] })\n        ).flatMap(([, groupOptions]) => groupOptions)\n      )\n    );\n  protected selectionModel!: SelectModel<ISelectOption>;\n  protected activeIndex = DEFAULT_ACTIVE_INDEX;\n\n  /** @ignore */\n  public readonly optionSelectionChanges: Observable<SelectOptionSelectionChangeEvent> =\n    defer(() => {\n      const options = this.options;\n\n      if (options) {\n        return options.changes.pipe(\n          startWith(options),\n          switchMap(() =>\n            merge(...options.map(option => option.onSelectionChange))\n          )\n        );\n      }\n\n      return this.ngZone.onStable.pipe(\n        take(1),\n        switchMap(() => this.optionSelectionChanges)\n      );\n    });\n\n  /**\n   * Set whether or not an input field will appear for searching and\n   * filtering visible options.\n   *\n   * - `'none'`: No search control will be displayed, and all select options are provided via projected `<impdc-select-option>` elements.\n   * - `'static'`: A search control will be displayed, select options are provided via projected `<impdc-select-option>` elements, and\n   * filtering is performed against the `[label]` attribute value.\n   * @default 'none'\n   */\n  public get search(): 'none' | 'static' {\n    return this._searchSubject.value;\n  }\n  public set search(value: 'none' | 'static') {\n    this._searchSubject.next(value);\n  }\n\n  /**\n   * The placeholder text that will be displayed when no selection has been made.\n   *\n   * @default \\- Select -\n   */\n  public get placeholder(): string {\n    return this._placeholder;\n  }\n  public set placeholder(value: string) {\n    this._placeholder = value;\n    this.stateChanges.next();\n  }\n  protected _placeholder = '- Select -';\n\n  /**\n   * Used to set requiredness of control in a template-based manner;\n   * not necessary when using the Angular reactive forms API and `required` validator.\n   */\n  public get required(): boolean {\n    return (\n      this._required ??\n      this.ngControl?.control?.hasValidator(Validators.required) ??\n      false\n    );\n  }\n  public set required(value: boolean) {\n    this._required = value;\n    this.stateChanges.next();\n  }\n  private _required: boolean | undefined;\n\n  /**\n   * Whether the control is a single-select or multiple-select. Cannot be changed after component initialization.\n   */\n  public get multiple(): boolean {\n    return this._multiple;\n  }\n  protected _multiple = false;\n\n  /**\n   * Function used to compare option values with selected values. The first arg is a\n   * `value` from an option, and the second arg is a `value` from the selection or another option.\n   *\n   * @returns Boolean indicating if the values are equivalent.\n   */\n  public get compareWith() {\n    return this._compareWith;\n  }\n  public set compareWith(fn: (a: any, b: any) => boolean) {\n    if (typeof fn !== 'function') {\n      throw getImpdcSelectNonFunctionValueError();\n    }\n\n    this._compareWith = fn;\n\n    if (this.selectionModel) {\n      // Changing the comparator function means the visual selection may have changed.\n      this._initializeSelection();\n    }\n  }\n\n  /**\n   * Document element that the select dropdown will be attached to in the DOM - either the\n   * document's `<body>` tag, or as a child of the component tag.\n   *\n   * The default value (`'body'`) is generally the correct choice, and should only be\n   * overridden when absolutely certain that the result behavior is what's desired.\n   */\n  public dropdownContainer: 'body' | null = 'body';\n\n  public override errorStateMatcher!: ErrorStateMatcher;\n\n  /** Events fire when selection has been changed by the user. */\n  public readonly selectionChange: EventEmitter<SelectChangeEvent<this>> =\n    new EventEmitter<SelectChangeEvent<this>>();\n\n  /**\n   * Events fire when raw value of select changes. Mainly exists to handle\n   * two-way binding of `value` input property.\n   * @ignore\n   */\n  public readonly valueChange: EventEmitter<any> = new EventEmitter<any>();\n\n  /**\n   * Events fire when the text value of the option search input control has changed.\n   */\n  @Output()\n  public readonly searchTextChanges: Observable<string | null> =\n    this.searchControl.valueChanges.pipe(\n      takeUntilDestroyed(),\n      startWith(''),\n      debounceTime(200),\n      distinctUntilChanged()\n    );\n\n  constructor(uid: string, tabIndex?: string) {\n    super(\n      inject(ErrorStateMatcher),\n      inject(IMPDC_FORM_ROOT, { optional: true }),\n      inject(NgForm, { optional: true }),\n      inject(FormGroupDirective, { optional: true }),\n      inject(NgControl, { optional: true, self: true })\n    );\n\n    this.uid = uid;\n\n    if (this.ngControl) {\n      this.ngControl.valueAccessor = this;\n    }\n\n    this.id = this.id;\n\n    this.tabIndex = parseInt(tabIndex ?? '') || 0;\n  }\n\n  public get dropdownOpen(): boolean {\n    return this.ngbDropdown?.isOpen() ?? false;\n  }\n\n  public get empty(): boolean {\n    return !this.selectionModel || this.selectionModel.isEmpty();\n  }\n\n  public get selected(): ISelectOption | ISelectOption[] {\n    return this._multiple\n      ? this.selectionModel?.selected || []\n      : this.selectionModel?.selected[0];\n  }\n\n  /** @ignore */\n  public focus(options?: FocusOptions): void {\n    this.toggleButtonRef?.nativeElement.focus(options);\n  }\n\n  protected handleOpenChange(isOpen: boolean): void {\n    if (isOpen) {\n      this.onFocus();\n\n      if (this.search !== 'none' && !!this.searchInputRef) {\n        setTimeout(() => {\n          this.searchInputRef?.nativeElement.focus();\n        }, ON_OPEN_AUTO_SCROLL_TIMEOUT_MS);\n      }\n\n      if (!this._multiple && !!this.value) {\n        this._scrollToSelectedOption();\n      }\n    } else {\n      this.onBlur();\n    }\n\n    this.activeIndex = DEFAULT_ACTIVE_INDEX;\n    this.searchControl.reset();\n    this.stateChanges.next();\n  }\n\n  /* Angular lifecycle hooks */\n\n  /** @ignore */\n  public ngOnInit(): void {\n    this.selectionModel = new SelectModel<ISelectOption>(\n      this._multiple,\n      undefined,\n      undefined,\n      (a, b) => {\n        return this.compareWith(a.value, b.value);\n      }\n    );\n    this.stateChanges.next();\n  }\n\n  /** @ignore */\n  public ngAfterViewInit(): void {\n    this.selectionModel.changed$\n      .pipe(takeUntil(this._ngDestroy))\n      .subscribe(changeEvent => {\n        changeEvent.added.forEach(option =>\n          this.options\n            .find(o => this.compareWith(o.value, option.value))\n            ?.select()\n        );\n        changeEvent.removed.forEach(option =>\n          this.options\n            .find(o => this.compareWith(o.value, option.value))\n            ?.deselect()\n        );\n      });\n\n    this.options.changes\n      .pipe(startWith(null), takeUntil(this._ngDestroy))\n      .subscribe(() => {\n        this._resetOptions();\n        this._initializeSelection();\n      });\n  }\n\n  /** @ignore */\n  public ngDoCheck(): void {\n    const ngControl = this.ngControl;\n\n    if (!ngControl) {\n      return;\n    }\n\n    if (this._previousControl !== ngControl.control) {\n      if (\n        this._previousControl !== undefined &&\n        ngControl.disabled !== null &&\n        ngControl.disabled !== this.disabled\n      ) {\n        this.disabled = ngControl?.disabled;\n      }\n\n      this._previousControl = ngControl.control;\n    }\n\n    this.updateErrorState();\n  }\n\n  /** @ignore */\n  public ngOnChanges(changes: SimpleChanges): void {\n    // Managing disabled state is handled via the `mixinDisabled` mixin/generator, but we still need to signal\n    // to the parent form field so it can run change detection when disabled state is changed.\n    if (changes['disabled']) {\n      this.stateChanges.next();\n    }\n  }\n\n  /** @ignore */\n  public ngOnDestroy(): void {\n    this._ngDestroy.next();\n    this._ngDestroy.complete();\n    this.stateChanges.complete();\n  }\n\n  /* ImpdcFormFieldControl */\n  public abstract readonly controlType: string;\n\n  public abstract readonly supportsAffixes: boolean;\n\n  @Input()\n  public get value(): any {\n    return this._value;\n  }\n  public set value(value: any) {\n    const hasAssigned = this._assignValue(value);\n\n    if (hasAssigned) {\n      this._cvaOnChange(value);\n    }\n  }\n  protected _value: any;\n\n  @Input()\n  public get id(): string {\n    return this._id;\n  }\n  public set id(value: string) {\n    this._id = value || this.uid;\n    this.stateChanges.next();\n  }\n  protected _id!: string;\n\n  public get focused(): boolean {\n    return this._focused || this.dropdownOpen;\n  }\n  protected _focused = false;\n\n  /* ControlValueAccessor */\n  /** @ignore */\n  public writeValue(value: any): void {\n    this._assignValue(value);\n  }\n\n  /** @ignore */\n  public registerOnChange(fn: (value: any) => void): void {\n    this._cvaOnChange = fn;\n  }\n\n  /** @ignore */\n  public registerOnTouched(fn: () => {}): void {\n    this._cvaOnTouched = fn;\n  }\n\n  /** @ignore */\n  public setDisabledState(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n    this.changeDetector.markForCheck();\n    this.stateChanges.next();\n  }\n\n  /* Internals */\n\n  protected onFocus(): void {\n    if (!this.disabled) {\n      this._focused = true;\n      this.stateChanges.next();\n    }\n  }\n\n  /**\n   * Calls the CVA touched callback only if the dropdown is closed.\n   */\n  protected onBlur(): void {\n    this._focused = false;\n\n    if (!this.disabled && !this.dropdownOpen) {\n      this._cvaOnTouched();\n      this.changeDetector.markForCheck();\n      this.stateChanges.next();\n    }\n  }\n\n  protected clearSelection(): void {\n    this.value = null;\n    this.focus();\n  }\n\n  protected handleSearchSubmit(evt: Event): void {\n    evt.preventDefault();\n    evt.stopPropagation();\n\n    if (this.activeIndex < 0 || this.activeIndex >= this.options.length) return;\n\n    this.options.get(this.activeIndex)?.nativeElement.click();\n  }\n\n  protected handleSearchUpDown(evt: Event, direction: 'up' | 'down'): void {\n    evt.preventDefault();\n\n    if (direction === 'up') {\n      if (this.activeIndex === this.options.length - 1) {\n        this.activeIndex = (this.activeIndex + 1) % this.options.length;\n      } else {\n        this.activeIndex++;\n      }\n    } else {\n      if (this.activeIndex <= 0) {\n        this.activeIndex = this.options.length - 1;\n      } else {\n        this.activeIndex--;\n      }\n    }\n\n    this.changeDetector.markForCheck();\n  }\n\n  protected markActive(index: number): void {\n    this.activeIndex = index;\n    this.changeDetector.markForCheck();\n  }\n\n  protected selectedIsSingle(\n    selected: ISelectOption | ISelectOption[]\n  ): selected is ISelectOption {\n    return !Array.isArray(selected);\n  }\n\n  private _initializeSelection(): void {\n    // We defer this work into a promise in order to avoid tripping Angular's\n    // \"Expression has changed after it was checked\" error.\n    Promise.resolve().then(() => {\n      if (this.ngControl) {\n        this._value = this.ngControl.value;\n      }\n\n      this._setSelectionByValue(this._value);\n      this.stateChanges.next();\n    });\n  }\n\n  private _setSelectionByValue(value: any | any[]): void {\n    if (this.search === 'none') {\n      this.selectionModel.clear();\n    }\n\n    if (this._multiple && value) {\n      if (!Array.isArray(value)) {\n        throw getImpdcSelectNonArrayValueError();\n      }\n\n      value.forEach(currentValue => this._selectOptionByValue(currentValue));\n      this._sortValues();\n    } else {\n      this._selectOptionByValue(value);\n    }\n\n    this.changeDetector.detectChanges();\n  }\n\n  private _selectOptionByValue(\n    value: any\n  ): SelectOptionDisplayComponent | undefined {\n    const correspondingOption = this.options.find(\n      (option: SelectOptionDisplayComponent) => {\n        if (this.selectionModel.isSelected(option)) {\n          return false;\n        }\n\n        try {\n          return option.value != null && this._compareWith(option.value, value);\n        } catch (error) {\n          console.warn(error);\n          return false;\n        }\n      }\n    );\n\n    if (correspondingOption) {\n      this.selectionModel.select(correspondingOption);\n    }\n\n    return correspondingOption;\n  }\n\n  /** Assigns a value to the select control. Returns a boolean indicating whether or not\n   * the value has changed.\n   */\n  private _assignValue(newValue: any | any[]): boolean {\n    if (\n      newValue !== this._value ||\n      (this._multiple && Array.isArray(newValue))\n    ) {\n      if (this.options) {\n        this.selectionModel.clear();\n        this._setSelectionByValue(newValue);\n      }\n\n      this._value = newValue;\n      return true;\n    }\n\n    return false;\n  }\n\n  private _resetOptions(): void {\n    const changedOrDestroyed = merge(this.options.changes, this._ngDestroy);\n\n    this.optionSelectionChanges\n      .pipe(takeUntil(changedOrDestroyed))\n      .subscribe(event => {\n        this._onSelect(event.source, event.isUserInput);\n\n        if (event.isUserInput && !this._multiple && this.dropdownOpen) {\n          this.ngbDropdown.close();\n          this.focus();\n        }\n      });\n\n    merge(...this.options.map(option => option.stateChanges))\n      .pipe(takeUntil(changedOrDestroyed))\n      .subscribe(() => {\n        this.changeDetector.detectChanges();\n        this.stateChanges.next();\n      });\n  }\n\n  private _onSelect(\n    option: SelectOptionDisplayComponent,\n    isUserInput: boolean\n  ): void {\n    const wasSelected = this.selectionModel.isSelected(option);\n\n    if (option.value == null && !this._multiple) {\n      option.deselect();\n      this.selectionModel.clear();\n\n      if (this.value != null) {\n        this._propagateChanges(option.value);\n      }\n    } else {\n      if (wasSelected !== option.selected) {\n        option.selected\n          ? this.selectionModel.select(option)\n          : this.selectionModel.deselect(option);\n      }\n\n      if (this._multiple) {\n        this._sortValues();\n      }\n    }\n\n    if (wasSelected !== this.selectionModel.isSelected(option)) {\n      this._propagateChanges();\n    }\n\n    this.changeDetector.markForCheck();\n    this.stateChanges.next();\n  }\n\n  private _sortValues(): void {\n    if (\n      this._multiple &&\n      (this.search === 'none' || this.search === 'static')\n    ) {\n      const options = this.staticOptions.toArray();\n\n      this.selectionModel.sort((a, b) => {\n        return (\n          options.findIndex(o => this.compareWith(o.value, a.value)) -\n          options.findIndex(o => this.compareWith(o.value, b.value))\n        );\n      });\n\n      this.stateChanges.next();\n    }\n  }\n\n  protected _propagateChanges(fallbackValue?: any): void {\n    let valToEmit: any = null;\n\n    if (this._multiple) {\n      valToEmit = (this.selected as ISelectOption[]).map(\n        option => option.value\n      );\n    } else {\n      valToEmit = this.selected\n        ? (this.selected as ISelectOption).value\n        : fallbackValue;\n    }\n\n    this._value = valToEmit;\n    this.valueChange.emit(valToEmit);\n    this._cvaOnChange(valToEmit);\n    this.selectionChange.emit(this._buildChangeEvent(valToEmit));\n  }\n\n  protected _buildChangeEvent(value: any): SelectChangeEvent<this> {\n    return new SelectChangeEvent(this, value);\n  }\n\n  /** @ignore */\n  protected _deselectOption(\n    option: ISelectOption,\n    markTouched: boolean = true\n  ): void {\n    if (this._multiple && this.selectionModel.isSelected(option)) {\n      this.selectionModel.deselect(option);\n      this._propagateChanges();\n\n      if (markTouched) {\n        this._cvaOnTouched();\n      }\n\n      this.changeDetector.markForCheck();\n      this.stateChanges.next();\n    }\n  }\n\n  private _scrollToSelectedOption(): void {\n    setTimeout(() => {\n      if (this.dropdownOpen && this.selected && !Array.isArray(this.selected)) {\n        const selectedOptionElement = this.options.find(\n          o =>\n            !Array.isArray(this.selected) &&\n            this.compareWith(o.value, this.selected.value)\n        );\n        selectedOptionElement?.nativeElement.scrollIntoView({\n          block: 'nearest',\n          inline: 'nearest',\n          behavior: 'instant'\n        });\n      }\n    }, ON_OPEN_AUTO_SCROLL_TIMEOUT_MS);\n  }\n}\n\n/**\n * The `SelectComponent` (`<impdc-select`) is a select-style dropdown input where an item (or multiple items) can be picked\n * from a list of *unique* available options. This component can be used within a `FormFieldComponent` (`<impdc-form-field`).\n * To use, add `SelectModule` to the `imports` array of the relevant `NgModule` or standalone component.\n */\n@Component({\n  selector: 'impdc-select',\n  exportAs: 'impdcSelect',\n  standalone: true,\n  imports: [\n    CommonModule,\n    AsyncPipe,\n    ReactiveFormsModule,\n    NgbDropdownModule,\n    IconModule,\n    SelectOptionDisplayComponent,\n    SelectValueTagsDisplayComponent,\n    FormFieldModule,\n    InputDirective,\n    BadgeModule\n  ],\n  templateUrl: './select.component.html',\n  styleUrls: ['./select.component.scss'],\n  // eslint-disable-next-line @angular-eslint/no-inputs-metadata-property\n  inputs: [\n    'disabled',\n    { name: 'tabIndex', transform: numberAttribute },\n    'search',\n    'placeholder',\n    { name: 'required', transform: booleanAttribute },\n    'compareWith',\n    'dropdownContainer',\n    'errorStateMatcher'\n  ],\n  // eslint-disable-next-line @angular-eslint/no-outputs-metadata-property\n  outputs: ['selectionChange', 'valueChange', 'searchTextChanges'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  // eslint-disable-next-line @angular-eslint/no-host-metadata-property\n  host: {\n    '[attr.id]': 'id',\n    '[attr.tabindex]': 'tabIndex',\n    '[attr.aria-required]': 'required.toString()',\n    '[attr.aria-disabled]': 'disabled.toString()',\n    '[attr.aria-invalid]': 'errorState',\n    '[class.form-select]': 'true',\n    '[class.is-invalid]': 'errorState',\n    '[class.impdc-form-field-control]': 'true',\n    '[class.impdc-select--required]': 'required',\n    '[class.impdc-select--disabled]': 'disabled',\n    '[class.impdc-select--invalid]': 'errorState',\n    '[class.impdc-select--empty]': 'empty',\n    '[class.impdc-select--multiple]': 'multiple',\n    '(focus)': 'onFocus(); focus()'\n  },\n  providers: [\n    {\n      provide: ImpdcFormFieldControl,\n      useExisting: SelectComponent\n    },\n    {\n      provide: IMPDC_SELECT_OPTION_PARENT_COMPONENT,\n      useExisting: SelectComponent\n    },\n    {\n      provide: IMPDC_SELECT_VALUE_BADGES_PARENT_COMPONENT,\n      useExisting: SelectComponent\n    }\n  ]\n})\nexport class SelectComponent\n  extends _SelectComponentBase\n  implements ISelectValueBadgesParentComponent\n{\n  public readonly controlType: string = 'impdc-select';\n  public readonly supportsAffixes: boolean = true;\n\n  constructor(@Attribute('tabindex') tabIndex?: string) {\n    super(`impdc-select-${nanoid()}`, tabIndex);\n  }\n\n  /**\n   * Allow the user to click a button inside of the select control and clear their selection(s);\n   *\n   * @default true\n   */\n  @Input({ transform: booleanAttribute })\n  public allowClear: boolean = true;\n\n  @Input({ transform: booleanAttribute })\n  public override get multiple(): boolean {\n    return this._multiple;\n  }\n  public override set multiple(value: boolean) {\n    if (this.selectionModel) {\n      throw getImpdcSelectDynamicMultipleError();\n    }\n\n    this._multiple = value;\n  }\n\n  @Input()\n  public multipleDisplay: 'inside' | 'outside' = 'inside';\n\n  /** @ignore */\n  public deselectOption(option: ISelectOption): void {\n    this._deselectOption(option);\n  }\n}\n","<div\n  ngbDropdown\n  #dropdown=\"ngbDropdown\"\n  [autoClose]=\"multiple ? 'outside' : true\"\n  [container]=\"dropdownContainer\"\n  [dropdownClass]=\"dropdownContainer === 'body' ? 'impartner-hex' : ''\"\n  (openChange)=\"handleOpenChange($event)\"\n  class=\"h-100 w-100\">\n  <button\n    #toggleButton\n    class=\"impdc-select--toggle btn border-0 h-100 text-start\"\n    type=\"button\"\n    role=\"combobox\"\n    [disabled]=\"disabled\"\n    (focus)=\"onFocus()\"\n    (blur)=\"onBlur()\"\n    ngbDropdownToggle>\n    @if (empty) {\n    <span class=\"impdc-select--text impdc-select--placeholder\">{{\n      placeholder\n    }}</span>\n    } @else { @if (selectedIsSingle(selected)) {\n    <span class=\"impdc-select--text impdc-select--value-text\">\n      {{ selected.label }}\n    </span>\n    } @else if (multipleDisplay === 'inside') {\n    <impdc-select-value-tags-display />\n    } @else {\n    <span class=\"impdc-select--text impdc-select--placeholder\">{{\n      placeholder\n    }}</span>\n    } @if (!disabled && allowClear) {\n    <button\n      type=\"button\"\n      class=\"impdc-select--clear-btn btn btn-xs btn-link text-gray-400 ms-auto\"\n      (click)=\"$event.stopPropagation(); dropdown.close(); clearSelection()\">\n      <impdc-icon name=\"times\" [size]=\"16\"></impdc-icon>\n    </button>\n    } }\n  </button>\n  <div\n    ngbDropdownMenu\n    class=\"impdc-select--dropdown-menu bg-white text-gray-600\"\n    role=\"listbox\"\n    tabindex=\"-1\">\n    <div *ngIf=\"search !== 'none'\" class=\"impdc-select--search\">\n      <impdc-form-field>\n        <span impdcTextPrefix (click)=\"searchInput.focus()\">\n          <impdc-icon name=\"search\"></impdc-icon>\n        </span>\n        <input\n          #searchInput\n          impdcInput\n          [formControl]=\"searchControl\"\n          class=\"impdc-select--search-input\"\n          type=\"search\"\n          (keydown.enter)=\"handleSearchSubmit($event)\"\n          (keydown.arrowdown)=\"handleSearchUpDown($event, 'up')\"\n          (keydown.arrowup)=\"handleSearchUpDown($event, 'down')\" />\n        <span impdcTextSuffix>\n          <button\n            *ngIf=\"searchControl.value\"\n            type=\"button\"\n            class=\"impdc-select--clear-btn btn btn-xs btn-link text-gray-400 ms-auto\"\n            (click)=\"searchControl.reset(); searchInput.focus()\">\n            <impdc-icon name=\"times\" [size]=\"16\"></impdc-icon>\n          </button>\n        </span>\n      </impdc-form-field>\n    </div>\n    <div class=\"impdc-select--options\">\n      @for (option of filteredOptions$ | async; track option.value; let idx =\n      $index; let first = $first) { @if (option.groupLabel &&\n      option.showGroupLabel) {\n      <div class=\"impdc-select--option-group-label\">\n        {{ option.groupLabel }}\n      </div>\n      }\n      <impdc-select-option-display\n        [class.impdc-select-option--active]=\"idx === activeIndex\"\n        [class.impdc-select-option--grouped]=\"!!option.groupLabel\"\n        [groupLabel]=\"option.groupLabel\"\n        [label]=\"option.label\"\n        [value]=\"option.value\"\n        [disabled]=\"!!option.disabled\"\n        [selected]=\"option.selected\"\n        [highlightText]=\"searchControl.value\"\n        (mouseenter)=\"markActive(idx)\"\n        (focus)=\"markActive(idx)\" />\n      }\n    </div>\n  </div>\n</div>\n"]}
|