@impartner/design-components 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE.txt +11 -0
- package/README.md +22 -0
- package/constants/fontawesome-icons.d.ts +6 -0
- package/constants/index.d.ts +1 -0
- package/esm2020/constants/fontawesome-icons.mjs +3012 -0
- package/esm2020/constants/index.mjs +2 -0
- package/esm2020/impartner-design-components.mjs +5 -0
- package/esm2020/lib/alert/alert.component.mjs +57 -0
- package/esm2020/lib/alert/alert.module.mjs +18 -0
- package/esm2020/lib/alert/index.mjs +4 -0
- package/esm2020/lib/alert/theme/alert-theme.mjs +2 -0
- package/esm2020/lib/alert/theme/index.mjs +2 -0
- package/esm2020/lib/avatar/avatar.component.mjs +47 -0
- package/esm2020/lib/avatar/avatar.module.mjs +18 -0
- package/esm2020/lib/avatar/index.mjs +3 -0
- package/esm2020/lib/avatar-group/avatar-group.component.mjs +16 -0
- package/esm2020/lib/avatar-group/avatar-group.module.mjs +19 -0
- package/esm2020/lib/avatar-group/index.mjs +3 -0
- package/esm2020/lib/backdrop/backdrop.component.mjs +34 -0
- package/esm2020/lib/backdrop/backdrop.module.mjs +19 -0
- package/esm2020/lib/backdrop/index.mjs +3 -0
- package/esm2020/lib/badge/badge.component.mjs +98 -0
- package/esm2020/lib/badge/badge.module.mjs +19 -0
- package/esm2020/lib/badge/index.mjs +4 -0
- package/esm2020/lib/badge/types/badge-icon.mjs +2 -0
- package/esm2020/lib/badge/types/badge-size.mjs +7 -0
- package/esm2020/lib/badge/types/index.mjs +2 -0
- package/esm2020/lib/branding/branded.directive.mjs +19 -0
- package/esm2020/lib/branding/branding.module.mjs +19 -0
- package/esm2020/lib/branding/index.mjs +3 -0
- package/esm2020/lib/breadcrumb/breadcrumb-item.component.mjs +25 -0
- package/esm2020/lib/breadcrumb/breadcrumb.component.mjs +33 -0
- package/esm2020/lib/breadcrumb/breadcrumb.module.mjs +19 -0
- package/esm2020/lib/breadcrumb/index.mjs +4 -0
- package/esm2020/lib/button/button.component.mjs +116 -0
- package/esm2020/lib/button/button.module.mjs +21 -0
- package/esm2020/lib/button/index.mjs +4 -0
- package/esm2020/lib/button/themes/button-theme.mjs +2 -0
- package/esm2020/lib/button/themes/index.mjs +2 -0
- package/esm2020/lib/button-group/button-group.component.mjs +52 -0
- package/esm2020/lib/button-group/button-group.module.mjs +20 -0
- package/esm2020/lib/button-group/index.mjs +3 -0
- package/esm2020/lib/card-heading/card-heading.component.mjs +30 -0
- package/esm2020/lib/card-heading/card-heading.module.mjs +19 -0
- package/esm2020/lib/card-heading/index.mjs +3 -0
- package/esm2020/lib/design-components.module.mjs +119 -0
- package/esm2020/lib/dropdown/components/dropdown-item/dropdown-item.component.mjs +22 -0
- package/esm2020/lib/dropdown/components/index.mjs +2 -0
- package/esm2020/lib/dropdown/dropdown.component.mjs +140 -0
- package/esm2020/lib/dropdown/dropdown.module.mjs +21 -0
- package/esm2020/lib/dropdown/index.mjs +5 -0
- package/esm2020/lib/dropdown/types/dropdown-position.mjs +2 -0
- package/esm2020/lib/dropdown/types/index.mjs +2 -0
- package/esm2020/lib/file-upload/directives/file-drop.directive.mjs +50 -0
- package/esm2020/lib/file-upload/directives/index.mjs +2 -0
- package/esm2020/lib/file-upload/file-upload.component.mjs +334 -0
- package/esm2020/lib/file-upload/file-upload.module.mjs +29 -0
- package/esm2020/lib/file-upload/index.mjs +5 -0
- package/esm2020/lib/file-upload/pipes/human-readable-byte-size.pipe.mjs +23 -0
- package/esm2020/lib/file-upload/pipes/index.mjs +2 -0
- package/esm2020/lib/form-field/controls/checkbox/checkbox.component.mjs +337 -0
- package/esm2020/lib/form-field/controls/checkbox/checkbox.module.mjs +19 -0
- package/esm2020/lib/form-field/controls/checkbox/index.mjs +3 -0
- package/esm2020/lib/form-field/controls/index.mjs +5 -0
- package/esm2020/lib/form-field/controls/input/index.mjs +2 -0
- package/esm2020/lib/form-field/controls/input/input.directive.mjs +233 -0
- package/esm2020/lib/form-field/controls/radio/index.mjs +6 -0
- package/esm2020/lib/form-field/controls/radio/injection-tokens.mjs +4 -0
- package/esm2020/lib/form-field/controls/radio/interfaces/index.mjs +4 -0
- package/esm2020/lib/form-field/controls/radio/interfaces/radio-button.interface.mjs +2 -0
- package/esm2020/lib/form-field/controls/radio/interfaces/radio-change-event.interface.mjs +11 -0
- package/esm2020/lib/form-field/controls/radio/interfaces/radio-group.interface.mjs +2 -0
- package/esm2020/lib/form-field/controls/radio/radio-button/radio-button.component.mjs +260 -0
- package/esm2020/lib/form-field/controls/radio/radio-group/radio-group.directive.mjs +288 -0
- package/esm2020/lib/form-field/controls/radio/radio.module.mjs +20 -0
- package/esm2020/lib/form-field/controls/select/index.mjs +6 -0
- package/esm2020/lib/form-field/controls/select/option/index.mjs +2 -0
- package/esm2020/lib/form-field/controls/select/option/select-option.component.mjs +138 -0
- package/esm2020/lib/form-field/controls/select/option-parent.mjs +3 -0
- package/esm2020/lib/form-field/controls/select/select-model.mjs +149 -0
- package/esm2020/lib/form-field/controls/select/select.component.mjs +522 -0
- package/esm2020/lib/form-field/controls/select/select.module.mjs +20 -0
- package/esm2020/lib/form-field/controls/shared/index.mjs +2 -0
- package/esm2020/lib/form-field/controls/shared/toggle/components/index.mjs +2 -0
- package/esm2020/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.mjs +17 -0
- package/esm2020/lib/form-field/controls/shared/toggle/index.mjs +4 -0
- package/esm2020/lib/form-field/controls/shared/toggle/toggle.component.mjs +96 -0
- package/esm2020/lib/form-field/controls/shared/toggle/toggle.module.mjs +20 -0
- package/esm2020/lib/form-field/directives/corner-hint.directive.mjs +14 -0
- package/esm2020/lib/form-field/directives/error.directive.mjs +26 -0
- package/esm2020/lib/form-field/directives/form-root.directive.mjs +91 -0
- package/esm2020/lib/form-field/directives/hint.directive.mjs +24 -0
- package/esm2020/lib/form-field/directives/index.mjs +8 -0
- package/esm2020/lib/form-field/directives/label.directive.mjs +14 -0
- package/esm2020/lib/form-field/directives/prefix.directive.mjs +24 -0
- package/esm2020/lib/form-field/directives/suffix.directive.mjs +24 -0
- package/esm2020/lib/form-field/form-field-errors.mjs +5 -0
- package/esm2020/lib/form-field/form-field.component.mjs +132 -0
- package/esm2020/lib/form-field/impdc-forms.mjs +8 -0
- package/esm2020/lib/form-field/impdc-forms.module.mjs +68 -0
- package/esm2020/lib/form-field/index.mjs +2 -0
- package/esm2020/lib/form-field/services/error-state-matcher.service.mjs +28 -0
- package/esm2020/lib/form-field/services/index.mjs +3 -0
- package/esm2020/lib/form-field/services/unique-selection-dispatcher.service.mjs +48 -0
- package/esm2020/lib/form-field/shared/constructors.type.mjs +2 -0
- package/esm2020/lib/form-field/shared/disabled.mixin.mjs +15 -0
- package/esm2020/lib/form-field/shared/error-state.mixin.mjs +24 -0
- package/esm2020/lib/form-field/shared/form-field-control.mjs +10 -0
- package/esm2020/lib/form-field/shared/index.mjs +5 -0
- package/esm2020/lib/form-field/shared/tab-index.mixin.mjs +19 -0
- package/esm2020/lib/icon/icon.component.mjs +70 -0
- package/esm2020/lib/icon/icon.module.mjs +19 -0
- package/esm2020/lib/icon/index.mjs +3 -0
- package/esm2020/lib/index.mjs +26 -0
- package/esm2020/lib/modal/index.mjs +4 -0
- package/esm2020/lib/modal/modal.component.mjs +141 -0
- package/esm2020/lib/modal/modal.module.mjs +37 -0
- package/esm2020/lib/modal/types/index.mjs +3 -0
- package/esm2020/lib/modal/types/modal-component-sizes.mjs +9 -0
- package/esm2020/lib/modal/types/modal-theme.mjs +12 -0
- package/esm2020/lib/pagination/index.mjs +3 -0
- package/esm2020/lib/pagination/pagination.component.mjs +134 -0
- package/esm2020/lib/pagination/pagination.module.mjs +21 -0
- package/esm2020/lib/progress-bar/index.mjs +3 -0
- package/esm2020/lib/progress-bar/progress-bar.component.mjs +35 -0
- package/esm2020/lib/progress-bar/progress-bar.module.mjs +18 -0
- package/esm2020/lib/scrollable/index.mjs +3 -0
- package/esm2020/lib/scrollable/scrollable.component.mjs +193 -0
- package/esm2020/lib/scrollable/scrollable.module.mjs +21 -0
- package/esm2020/lib/select-icon/index.mjs +3 -0
- package/esm2020/lib/select-icon/select-icon.component.mjs +307 -0
- package/esm2020/lib/select-icon/select-icon.module.mjs +35 -0
- package/esm2020/lib/size-detection/directive/element-size.interface.mjs +2 -0
- package/esm2020/lib/size-detection/directive/index.mjs +3 -0
- package/esm2020/lib/size-detection/directive/size-detector.directive.mjs +43 -0
- package/esm2020/lib/size-detection/index.mjs +3 -0
- package/esm2020/lib/size-detection/size-detection.module.mjs +18 -0
- package/esm2020/lib/spinner/index.mjs +3 -0
- package/esm2020/lib/spinner/spinner.component.mjs +24 -0
- package/esm2020/lib/spinner/spinner.module.mjs +18 -0
- package/esm2020/lib/table/index.mjs +3 -0
- package/esm2020/lib/table/table.component.mjs +33 -0
- package/esm2020/lib/table/table.module.mjs +19 -0
- package/esm2020/lib/text-highlight/index.mjs +3 -0
- package/esm2020/lib/text-highlight/text-highlight.component.mjs +81 -0
- package/esm2020/lib/text-highlight/text-highlight.module.mjs +19 -0
- package/esm2020/public-api.mjs +9 -0
- package/esm2020/services/index.mjs +2 -0
- package/esm2020/services/interaction.service.mjs +54 -0
- package/esm2020/types/component-size.mjs +12 -0
- package/esm2020/types/component-theme.mjs +22 -0
- package/esm2020/types/index.mjs +3 -0
- package/esm2020/utilities/boolean-props.mjs +7 -0
- package/esm2020/utilities/dc.mjs +9 -0
- package/esm2020/utilities/index.mjs +6 -0
- package/esm2020/utilities/lc.mjs +9 -0
- package/esm2020/utilities/number-props.mjs +18 -0
- package/esm2020/utilities/sanitize.mjs +7 -0
- package/fesm2015/impartner-design-components.mjs +8295 -0
- package/fesm2015/impartner-design-components.mjs.map +1 -0
- package/fesm2020/impartner-design-components.mjs +8264 -0
- package/fesm2020/impartner-design-components.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/alert/alert.component.d.ts +29 -0
- package/lib/alert/alert.module.d.ts +8 -0
- package/lib/alert/index.d.ts +3 -0
- package/lib/alert/theme/alert-theme.d.ts +1 -0
- package/lib/alert/theme/index.d.ts +1 -0
- package/lib/avatar/avatar.component.d.ts +28 -0
- package/lib/avatar/avatar.module.d.ts +8 -0
- package/lib/avatar/index.d.ts +2 -0
- package/lib/avatar-group/avatar-group.component.d.ts +10 -0
- package/lib/avatar-group/avatar-group.module.d.ts +9 -0
- package/lib/avatar-group/index.d.ts +2 -0
- package/lib/backdrop/backdrop.component.d.ts +19 -0
- package/lib/backdrop/backdrop.module.d.ts +9 -0
- package/lib/backdrop/index.d.ts +2 -0
- package/lib/badge/badge.component.d.ts +48 -0
- package/lib/badge/badge.module.d.ts +9 -0
- package/lib/badge/index.d.ts +3 -0
- package/lib/badge/types/badge-icon.d.ts +1 -0
- package/lib/badge/types/badge-size.d.ts +6 -0
- package/lib/badge/types/index.d.ts +2 -0
- package/lib/branding/branded.directive.d.ts +6 -0
- package/lib/branding/branding.module.d.ts +9 -0
- package/lib/branding/index.d.ts +2 -0
- package/lib/breadcrumb/breadcrumb-item.component.d.ts +7 -0
- package/lib/breadcrumb/breadcrumb.component.d.ts +18 -0
- package/lib/breadcrumb/breadcrumb.module.d.ts +9 -0
- package/lib/breadcrumb/index.d.ts +3 -0
- package/lib/button/button.component.d.ts +47 -0
- package/lib/button/button.module.d.ts +11 -0
- package/lib/button/index.d.ts +3 -0
- package/lib/button/themes/button-theme.d.ts +1 -0
- package/lib/button/themes/index.d.ts +1 -0
- package/lib/button-group/button-group.component.d.ts +22 -0
- package/lib/button-group/button-group.module.d.ts +10 -0
- package/lib/button-group/index.d.ts +2 -0
- package/lib/card-heading/card-heading.component.d.ts +18 -0
- package/lib/card-heading/card-heading.module.d.ts +9 -0
- package/lib/card-heading/index.d.ts +2 -0
- package/lib/design-components.module.d.ts +22 -0
- package/lib/dropdown/components/dropdown-item/dropdown-item.component.d.ts +11 -0
- package/lib/dropdown/components/index.d.ts +1 -0
- package/lib/dropdown/dropdown.component.d.ts +65 -0
- package/lib/dropdown/dropdown.module.d.ts +11 -0
- package/lib/dropdown/index.d.ts +4 -0
- package/lib/dropdown/types/dropdown-position.d.ts +1 -0
- package/lib/dropdown/types/index.d.ts +1 -0
- package/lib/file-upload/directives/file-drop.directive.d.ts +11 -0
- package/lib/file-upload/directives/index.d.ts +1 -0
- package/lib/file-upload/file-upload.component.d.ts +105 -0
- package/lib/file-upload/file-upload.module.d.ts +13 -0
- package/lib/file-upload/index.d.ts +4 -0
- package/lib/file-upload/pipes/human-readable-byte-size.pipe.d.ts +7 -0
- package/lib/file-upload/pipes/index.d.ts +1 -0
- package/lib/form-field/controls/checkbox/checkbox.component.d.ts +133 -0
- package/lib/form-field/controls/checkbox/checkbox.module.d.ts +9 -0
- package/lib/form-field/controls/checkbox/index.d.ts +2 -0
- package/lib/form-field/controls/index.d.ts +4 -0
- package/lib/form-field/controls/input/index.d.ts +1 -0
- package/lib/form-field/controls/input/input.directive.d.ts +84 -0
- package/lib/form-field/controls/radio/index.d.ts +5 -0
- package/lib/form-field/controls/radio/injection-tokens.d.ts +4 -0
- package/lib/form-field/controls/radio/interfaces/index.d.ts +3 -0
- package/lib/form-field/controls/radio/interfaces/radio-button.interface.d.ts +6 -0
- package/lib/form-field/controls/radio/interfaces/radio-change-event.interface.d.ts +12 -0
- package/lib/form-field/controls/radio/interfaces/radio-group.interface.d.ts +13 -0
- package/lib/form-field/controls/radio/radio-button/radio-button.component.d.ts +98 -0
- package/lib/form-field/controls/radio/radio-group/radio-group.directive.d.ts +104 -0
- package/lib/form-field/controls/radio/radio.module.d.ts +10 -0
- package/lib/form-field/controls/select/index.d.ts +5 -0
- package/lib/form-field/controls/select/option/index.d.ts +1 -0
- package/lib/form-field/controls/select/option/select-option.component.d.ts +60 -0
- package/lib/form-field/controls/select/option-parent.d.ts +5 -0
- package/lib/form-field/controls/select/select-model.d.ts +36 -0
- package/lib/form-field/controls/select/select.component.d.ts +170 -0
- package/lib/form-field/controls/select/select.module.d.ts +10 -0
- package/lib/form-field/controls/shared/index.d.ts +1 -0
- package/lib/form-field/controls/shared/toggle/components/index.d.ts +1 -0
- package/lib/form-field/controls/shared/toggle/components/toggle-input/toggle-input.component.d.ts +6 -0
- package/lib/form-field/controls/shared/toggle/index.d.ts +3 -0
- package/lib/form-field/controls/shared/toggle/toggle.component.d.ts +26 -0
- package/lib/form-field/controls/shared/toggle/toggle.module.d.ts +10 -0
- package/lib/form-field/directives/corner-hint.directive.d.ts +5 -0
- package/lib/form-field/directives/error.directive.d.ts +8 -0
- package/lib/form-field/directives/form-root.directive.d.ts +26 -0
- package/lib/form-field/directives/hint.directive.d.ts +6 -0
- package/lib/form-field/directives/index.d.ts +7 -0
- package/lib/form-field/directives/label.directive.d.ts +5 -0
- package/lib/form-field/directives/prefix.directive.d.ts +9 -0
- package/lib/form-field/directives/suffix.directive.d.ts +9 -0
- package/lib/form-field/form-field-errors.d.ts +2 -0
- package/lib/form-field/form-field.component.d.ts +39 -0
- package/lib/form-field/impdc-forms.d.ts +7 -0
- package/lib/form-field/impdc-forms.module.d.ts +19 -0
- package/lib/form-field/index.d.ts +1 -0
- package/lib/form-field/services/error-state-matcher.service.d.ts +12 -0
- package/lib/form-field/services/index.d.ts +2 -0
- package/lib/form-field/services/unique-selection-dispatcher.service.d.ts +29 -0
- package/lib/form-field/shared/constructors.type.d.ts +7 -0
- package/lib/form-field/shared/disabled.mixin.d.ts +10 -0
- package/lib/form-field/shared/error-state.mixin.d.ts +31 -0
- package/lib/form-field/shared/form-field-control.d.ts +24 -0
- package/lib/form-field/shared/index.d.ts +5 -0
- package/lib/form-field/shared/tab-index.mixin.d.ts +13 -0
- package/lib/icon/icon.component.d.ts +30 -0
- package/lib/icon/icon.module.d.ts +9 -0
- package/lib/icon/index.d.ts +2 -0
- package/lib/index.d.ts +25 -0
- package/lib/modal/index.d.ts +3 -0
- package/lib/modal/modal.component.d.ts +80 -0
- package/lib/modal/modal.module.d.ts +13 -0
- package/lib/modal/types/index.d.ts +2 -0
- package/lib/modal/types/modal-component-sizes.d.ts +3 -0
- package/lib/modal/types/modal-theme.d.ts +7 -0
- package/lib/pagination/index.d.ts +2 -0
- package/lib/pagination/pagination.component.d.ts +41 -0
- package/lib/pagination/pagination.module.d.ts +11 -0
- package/lib/progress-bar/index.d.ts +2 -0
- package/lib/progress-bar/progress-bar.component.d.ts +22 -0
- package/lib/progress-bar/progress-bar.module.d.ts +8 -0
- package/lib/scrollable/index.d.ts +2 -0
- package/lib/scrollable/scrollable.component.d.ts +39 -0
- package/lib/scrollable/scrollable.module.d.ts +11 -0
- package/lib/select-icon/index.d.ts +2 -0
- package/lib/select-icon/select-icon.component.d.ts +123 -0
- package/lib/select-icon/select-icon.module.d.ts +11 -0
- package/lib/size-detection/directive/element-size.interface.d.ts +4 -0
- package/lib/size-detection/directive/index.d.ts +2 -0
- package/lib/size-detection/directive/size-detector.directive.d.ts +14 -0
- package/lib/size-detection/index.d.ts +3 -0
- package/lib/size-detection/size-detection.module.d.ts +8 -0
- package/lib/spinner/index.d.ts +2 -0
- package/lib/spinner/spinner.component.d.ts +13 -0
- package/lib/spinner/spinner.module.d.ts +8 -0
- package/lib/table/index.d.ts +2 -0
- package/lib/table/table.component.d.ts +15 -0
- package/lib/table/table.module.d.ts +9 -0
- package/lib/text-highlight/index.d.ts +2 -0
- package/lib/text-highlight/text-highlight.component.d.ts +31 -0
- package/lib/text-highlight/text-highlight.module.d.ts +9 -0
- package/package.json +51 -0
- package/public-api.d.ts +4 -0
- package/services/index.d.ts +1 -0
- package/services/interaction.service.d.ts +14 -0
- package/types/component-size.d.ts +12 -0
- package/types/component-theme.d.ts +12 -0
- package/types/index.d.ts +2 -0
- package/utilities/boolean-props.d.ts +8 -0
- package/utilities/dc.d.ts +6 -0
- package/utilities/index.d.ts +5 -0
- package/utilities/lc.d.ts +6 -0
- package/utilities/number-props.d.ts +15 -0
- package/utilities/sanitize.d.ts +1 -0
|
@@ -0,0 +1,522 @@
|
|
|
1
|
+
/* eslint-disable @angular-eslint/no-conflicting-lifecycle */
|
|
2
|
+
import { Attribute, ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Inject, Input, Optional, Output, Self, ViewChild } from '@angular/core';
|
|
3
|
+
import { Validators } from '@angular/forms';
|
|
4
|
+
import { NgbDropdown, NgbDropdownMenu } from '@ng-bootstrap/ng-bootstrap';
|
|
5
|
+
import { nanoid } from 'nanoid';
|
|
6
|
+
import { coerceBooleanPropertyValue } from '../../../../utilities';
|
|
7
|
+
import { defer, merge, startWith, Subject, switchMap, take, takeUntil } from 'rxjs';
|
|
8
|
+
import { IMPDC_FORM_ROOT } from '../../directives';
|
|
9
|
+
import { ImpdcFormFieldControl, mixinDisabled, mixinErrorState, mixinTabIndex } from '../../shared';
|
|
10
|
+
import { IMPDC_SELECT_OPTION_PARENT_COMPONENT } from './option-parent';
|
|
11
|
+
import { SelectOptionComponent } from './option/select-option.component';
|
|
12
|
+
import { SelectModel } from './select-model';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
import * as i1 from "../../services";
|
|
15
|
+
import * as i2 from "@angular/forms";
|
|
16
|
+
import * as i3 from "@angular/common";
|
|
17
|
+
import * as i4 from "@ng-bootstrap/ng-bootstrap";
|
|
18
|
+
export class SelectChangeEvent {
|
|
19
|
+
constructor(
|
|
20
|
+
/** The specific SelectComponent that changed. */
|
|
21
|
+
source,
|
|
22
|
+
/** The selected value(s) */
|
|
23
|
+
value) {
|
|
24
|
+
this.source = source;
|
|
25
|
+
this.value = value;
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Returns an exception to be thrown when attempting to assign a non-array value to a select
|
|
30
|
+
* in `multiple` mode. Note that `undefined` and `null` are still valid values to allow for
|
|
31
|
+
* resetting the value.
|
|
32
|
+
* @ignore
|
|
33
|
+
*/
|
|
34
|
+
export function getImpdcSelectNonArrayValueError() {
|
|
35
|
+
return Error('Value must be an array in multiple-selection mode.');
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Returns an exception to be thrown when assigning a non-function value to the comparator
|
|
39
|
+
* used to determine if a value corresponds to an option. Note that whether the function
|
|
40
|
+
* actually takes two values and returns a boolean is not checked.
|
|
41
|
+
*/
|
|
42
|
+
export function getImpdcSelectNonFunctionValueError() {
|
|
43
|
+
return Error('`compareWith` must be a function.');
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Returns an exception to be thrown when attempting to change a select's `multiple` option
|
|
47
|
+
* after initialization.
|
|
48
|
+
* @ignore
|
|
49
|
+
*/
|
|
50
|
+
export function getImpdcSelectDynamicMultipleError() {
|
|
51
|
+
return Error('Cannot change `multiple` mode of select after initialization.');
|
|
52
|
+
}
|
|
53
|
+
const _SelectComponentBase = mixinTabIndex(mixinDisabled(mixinErrorState(class {
|
|
54
|
+
constructor(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl) {
|
|
55
|
+
this._defaultErrorStateMatcher = _defaultErrorStateMatcher;
|
|
56
|
+
this._formRoot = _formRoot;
|
|
57
|
+
this._parentForm = _parentForm;
|
|
58
|
+
this._parentFormGroup = _parentFormGroup;
|
|
59
|
+
this.ngControl = ngControl;
|
|
60
|
+
this.stateChanges = new Subject();
|
|
61
|
+
}
|
|
62
|
+
})));
|
|
63
|
+
/**
|
|
64
|
+
* The `SelectComponent` (`<impdc-select`) is a select-style dropdown input where an item (or multiple items) can be picked
|
|
65
|
+
* from a list of available options. This component can be used within a `FormFieldComponent` (`<impdc-form-field`).
|
|
66
|
+
* To use, import `SelectModule` or another module that imports and exports that module from `@impartner/design-components`.
|
|
67
|
+
*/
|
|
68
|
+
export class SelectComponent extends _SelectComponentBase {
|
|
69
|
+
constructor(_changeDetector, _ngZone, tabIndex, _defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl) {
|
|
70
|
+
super(_defaultErrorStateMatcher, _formRoot, _parentForm, _parentFormGroup, ngControl);
|
|
71
|
+
this._changeDetector = _changeDetector;
|
|
72
|
+
this._ngZone = _ngZone;
|
|
73
|
+
/** @ignore */
|
|
74
|
+
this.optionSelectionChanges = defer(() => {
|
|
75
|
+
const options = this.options;
|
|
76
|
+
if (options) {
|
|
77
|
+
return options.changes.pipe(startWith(options), switchMap(() => merge(...options.map(option => option.onSelectionChange))));
|
|
78
|
+
}
|
|
79
|
+
return this._ngZone.onStable.pipe(take(1), switchMap(() => this.optionSelectionChanges));
|
|
80
|
+
});
|
|
81
|
+
this._uid = `impdc-select-${nanoid()}`;
|
|
82
|
+
this._ngDestroy = new Subject();
|
|
83
|
+
this._compareWith = (o1, o2) => o1 === o2;
|
|
84
|
+
this._cvaOnChange = () => { };
|
|
85
|
+
this._cvaOnTouched = () => { };
|
|
86
|
+
this._placeholder = '- Select -';
|
|
87
|
+
this._multiple = false;
|
|
88
|
+
/** Events fire when selection has been changed by the user. */
|
|
89
|
+
this.selectionChange = new EventEmitter();
|
|
90
|
+
/**
|
|
91
|
+
* Events fire when raw value of select changes. Mainly exists to handle
|
|
92
|
+
* two-way binding of `value` input property.
|
|
93
|
+
* @ignore
|
|
94
|
+
*/
|
|
95
|
+
this.valueChange = new EventEmitter();
|
|
96
|
+
/* ImpdcFormFieldControl */
|
|
97
|
+
this.controlType = 'impdc-select';
|
|
98
|
+
this.supportsAffixes = true;
|
|
99
|
+
this._focused = false;
|
|
100
|
+
if (this.ngControl) {
|
|
101
|
+
this.ngControl.valueAccessor = this;
|
|
102
|
+
}
|
|
103
|
+
this.id = this.id;
|
|
104
|
+
this.tabIndex = parseInt(tabIndex) || 0;
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* The placeholder text that will be displayed when no selection has been made.
|
|
108
|
+
*
|
|
109
|
+
* @default \- Select -
|
|
110
|
+
*/
|
|
111
|
+
get placeholder() {
|
|
112
|
+
return this._placeholder;
|
|
113
|
+
}
|
|
114
|
+
set placeholder(value) {
|
|
115
|
+
this._placeholder = value;
|
|
116
|
+
this.stateChanges.next();
|
|
117
|
+
}
|
|
118
|
+
/**
|
|
119
|
+
* Used to set requiredness of control in a template-based manner;
|
|
120
|
+
* not necessary when using the Angular reactive forms API and `required` validator.
|
|
121
|
+
*/
|
|
122
|
+
get required() {
|
|
123
|
+
return (this._required ??
|
|
124
|
+
this.ngControl?.control?.hasValidator(Validators.required) ??
|
|
125
|
+
false);
|
|
126
|
+
}
|
|
127
|
+
set required(value) {
|
|
128
|
+
this._required = coerceBooleanPropertyValue(value);
|
|
129
|
+
this.stateChanges.next();
|
|
130
|
+
}
|
|
131
|
+
/**
|
|
132
|
+
* Sets whether the control is a single-select or multiple-select. Cannot be changed after component initialization.
|
|
133
|
+
*/
|
|
134
|
+
get multiple() {
|
|
135
|
+
return this._multiple;
|
|
136
|
+
}
|
|
137
|
+
set multiple(value) {
|
|
138
|
+
if (this._selectionModel) {
|
|
139
|
+
throw getImpdcSelectDynamicMultipleError();
|
|
140
|
+
}
|
|
141
|
+
this._multiple = coerceBooleanPropertyValue(value);
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Function used to compare option values with selected values. The first arg is a
|
|
145
|
+
* value from an option, and the second arg is a value from the selection.
|
|
146
|
+
*
|
|
147
|
+
* @returns Boolean indicating if the values are equivalent.
|
|
148
|
+
*/
|
|
149
|
+
get compareWith() {
|
|
150
|
+
return this._compareWith;
|
|
151
|
+
}
|
|
152
|
+
set compareWith(fn) {
|
|
153
|
+
if (typeof fn !== 'function') {
|
|
154
|
+
throw getImpdcSelectNonFunctionValueError();
|
|
155
|
+
}
|
|
156
|
+
this._compareWith = fn;
|
|
157
|
+
if (this._selectionModel) {
|
|
158
|
+
// Changing the comparator function means the visual selection may have changed.
|
|
159
|
+
this._initializeSelection();
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
get dropdownOpen() {
|
|
163
|
+
return this._ngbDropdown?.isOpen() ?? false;
|
|
164
|
+
}
|
|
165
|
+
get empty() {
|
|
166
|
+
return !this._selectionModel || this._selectionModel.isEmpty();
|
|
167
|
+
}
|
|
168
|
+
get displayedValue() {
|
|
169
|
+
if (this.empty) {
|
|
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(', ');
|
|
176
|
+
}
|
|
177
|
+
get selected() {
|
|
178
|
+
return this.multiple
|
|
179
|
+
? this._selectionModel?.selected || []
|
|
180
|
+
: this._selectionModel?.selected[0];
|
|
181
|
+
}
|
|
182
|
+
/** @ignore */
|
|
183
|
+
focus(options) {
|
|
184
|
+
this._toggleButtonRef.nativeElement.focus(options);
|
|
185
|
+
}
|
|
186
|
+
_handleOpenChange(isOpen) {
|
|
187
|
+
if (isOpen) {
|
|
188
|
+
this._onFocus();
|
|
189
|
+
}
|
|
190
|
+
else {
|
|
191
|
+
this._onBlur();
|
|
192
|
+
}
|
|
193
|
+
this.stateChanges.next();
|
|
194
|
+
}
|
|
195
|
+
/* Angular lifecycle hooks */
|
|
196
|
+
/** @ignore */
|
|
197
|
+
ngOnInit() {
|
|
198
|
+
this._selectionModel = new SelectModel(this.multiple);
|
|
199
|
+
this.stateChanges.next();
|
|
200
|
+
}
|
|
201
|
+
/** @ignore */
|
|
202
|
+
ngAfterContentInit() {
|
|
203
|
+
this._selectionModel.changed$
|
|
204
|
+
.pipe(takeUntil(this._ngDestroy))
|
|
205
|
+
.subscribe(changeEvent => {
|
|
206
|
+
changeEvent.added.forEach(option => option.select());
|
|
207
|
+
changeEvent.removed.forEach(option => option.deselect());
|
|
208
|
+
});
|
|
209
|
+
this.options.changes
|
|
210
|
+
.pipe(startWith(null), takeUntil(this._ngDestroy))
|
|
211
|
+
.subscribe(() => {
|
|
212
|
+
this._resetOptions();
|
|
213
|
+
this._initializeSelection();
|
|
214
|
+
});
|
|
215
|
+
}
|
|
216
|
+
/** @ignore */
|
|
217
|
+
ngAfterViewInit() {
|
|
218
|
+
this._ngbDropdownMenu.menuItems = this.options;
|
|
219
|
+
}
|
|
220
|
+
/** @ignore */
|
|
221
|
+
ngDoCheck() {
|
|
222
|
+
const ngControl = this.ngControl;
|
|
223
|
+
if (!ngControl) {
|
|
224
|
+
return;
|
|
225
|
+
}
|
|
226
|
+
if (this._previousControl !== ngControl.control) {
|
|
227
|
+
if (this._previousControl !== undefined &&
|
|
228
|
+
ngControl.disabled !== null &&
|
|
229
|
+
ngControl.disabled !== this.disabled) {
|
|
230
|
+
this.disabled = ngControl?.disabled;
|
|
231
|
+
}
|
|
232
|
+
this._previousControl = ngControl.control;
|
|
233
|
+
}
|
|
234
|
+
this.updateErrorState();
|
|
235
|
+
}
|
|
236
|
+
/** @ignore */
|
|
237
|
+
ngOnChanges(changes) {
|
|
238
|
+
// Managing disabled state is handled via the `mixinDisabled` mixin/generator, but we still need to signal
|
|
239
|
+
// to the parent form field so it can run change detection when disabled state is changed.
|
|
240
|
+
if (changes['disabled']) {
|
|
241
|
+
this.stateChanges.next();
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
/** @ignore */
|
|
245
|
+
ngOnDestroy() {
|
|
246
|
+
this._ngDestroy.next();
|
|
247
|
+
this._ngDestroy.complete();
|
|
248
|
+
this.stateChanges.complete();
|
|
249
|
+
}
|
|
250
|
+
get value() {
|
|
251
|
+
return this._value;
|
|
252
|
+
}
|
|
253
|
+
set value(value) {
|
|
254
|
+
const hasAssigned = this._assignValue(value);
|
|
255
|
+
if (hasAssigned) {
|
|
256
|
+
this._cvaOnChange(value);
|
|
257
|
+
}
|
|
258
|
+
}
|
|
259
|
+
get id() {
|
|
260
|
+
return this._id;
|
|
261
|
+
}
|
|
262
|
+
set id(value) {
|
|
263
|
+
this._id = value || this._uid;
|
|
264
|
+
this.stateChanges.next();
|
|
265
|
+
}
|
|
266
|
+
get focused() {
|
|
267
|
+
return this._focused || this.dropdownOpen;
|
|
268
|
+
}
|
|
269
|
+
/* ControlValueAccessor */
|
|
270
|
+
/** @ignore */
|
|
271
|
+
writeValue(value) {
|
|
272
|
+
this._assignValue(value);
|
|
273
|
+
}
|
|
274
|
+
/** @ignore */
|
|
275
|
+
registerOnChange(fn) {
|
|
276
|
+
this._cvaOnChange = fn;
|
|
277
|
+
}
|
|
278
|
+
/** @ignore */
|
|
279
|
+
registerOnTouched(fn) {
|
|
280
|
+
this._cvaOnTouched = fn;
|
|
281
|
+
}
|
|
282
|
+
/** @ignore */
|
|
283
|
+
setDisabledState(isDisabled) {
|
|
284
|
+
this.disabled = isDisabled;
|
|
285
|
+
this._changeDetector.markForCheck();
|
|
286
|
+
this.stateChanges.next();
|
|
287
|
+
}
|
|
288
|
+
/* Internals */
|
|
289
|
+
_onFocus() {
|
|
290
|
+
if (!this.disabled) {
|
|
291
|
+
this._focused = true;
|
|
292
|
+
this.stateChanges.next();
|
|
293
|
+
}
|
|
294
|
+
}
|
|
295
|
+
/**
|
|
296
|
+
* Calls the CVA touched callback only if the dropdown is closed.
|
|
297
|
+
*/
|
|
298
|
+
_onBlur() {
|
|
299
|
+
this._focused = false;
|
|
300
|
+
if (!this.disabled && !this.dropdownOpen) {
|
|
301
|
+
this._cvaOnTouched();
|
|
302
|
+
this._changeDetector.markForCheck();
|
|
303
|
+
this.stateChanges.next();
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
_initializeSelection() {
|
|
307
|
+
// We defer this work into a promise in order to avoid tripping Angular's
|
|
308
|
+
// "Expression has changed after it was checked" error.
|
|
309
|
+
Promise.resolve().then(() => {
|
|
310
|
+
if (this.ngControl) {
|
|
311
|
+
this._value = this.ngControl.value;
|
|
312
|
+
}
|
|
313
|
+
this._setSelectionByValue(this._value);
|
|
314
|
+
this.stateChanges.next();
|
|
315
|
+
});
|
|
316
|
+
}
|
|
317
|
+
_setSelectionByValue(value) {
|
|
318
|
+
this._selectionModel.clear();
|
|
319
|
+
if (this.multiple && value) {
|
|
320
|
+
if (!Array.isArray(value)) {
|
|
321
|
+
throw getImpdcSelectNonArrayValueError();
|
|
322
|
+
}
|
|
323
|
+
value.forEach(currentValue => this._selectOptionByValue(currentValue));
|
|
324
|
+
this._sortValues();
|
|
325
|
+
}
|
|
326
|
+
else {
|
|
327
|
+
this._selectOptionByValue(value);
|
|
328
|
+
}
|
|
329
|
+
this._changeDetector.detectChanges();
|
|
330
|
+
}
|
|
331
|
+
_selectOptionByValue(value) {
|
|
332
|
+
const correspondingOption = this.options.find((option) => {
|
|
333
|
+
if (this._selectionModel.isSelected(option)) {
|
|
334
|
+
return false;
|
|
335
|
+
}
|
|
336
|
+
try {
|
|
337
|
+
return option.value != null && this._compareWith(option.value, value);
|
|
338
|
+
}
|
|
339
|
+
catch (error) {
|
|
340
|
+
console.warn(error);
|
|
341
|
+
return false;
|
|
342
|
+
}
|
|
343
|
+
});
|
|
344
|
+
if (correspondingOption) {
|
|
345
|
+
this._selectionModel.select(correspondingOption);
|
|
346
|
+
}
|
|
347
|
+
return correspondingOption;
|
|
348
|
+
}
|
|
349
|
+
/** Assigns a value to the select control. Returns a boolean indicating whether or not
|
|
350
|
+
* the value has changed.
|
|
351
|
+
*/
|
|
352
|
+
_assignValue(newValue) {
|
|
353
|
+
if (newValue !== this._value ||
|
|
354
|
+
(this._multiple && Array.isArray(newValue))) {
|
|
355
|
+
if (this.options) {
|
|
356
|
+
this._setSelectionByValue(newValue);
|
|
357
|
+
}
|
|
358
|
+
this._value = newValue;
|
|
359
|
+
return true;
|
|
360
|
+
}
|
|
361
|
+
return false;
|
|
362
|
+
}
|
|
363
|
+
_resetOptions() {
|
|
364
|
+
const changedOrDestroyed = merge(this.options.changes, this._ngDestroy);
|
|
365
|
+
this.optionSelectionChanges
|
|
366
|
+
.pipe(takeUntil(changedOrDestroyed))
|
|
367
|
+
.subscribe(event => {
|
|
368
|
+
this._onSelect(event.source, event.isUserInput);
|
|
369
|
+
if (event.isUserInput && !this.multiple && this.dropdownOpen) {
|
|
370
|
+
this._ngbDropdown.close();
|
|
371
|
+
this.focus();
|
|
372
|
+
}
|
|
373
|
+
});
|
|
374
|
+
merge(...this.options.map(option => option.stateChanges))
|
|
375
|
+
.pipe(takeUntil(changedOrDestroyed))
|
|
376
|
+
.subscribe(() => {
|
|
377
|
+
this._changeDetector.detectChanges();
|
|
378
|
+
this.stateChanges.next();
|
|
379
|
+
});
|
|
380
|
+
}
|
|
381
|
+
_onSelect(option, isUserInput) {
|
|
382
|
+
const wasSelected = this._selectionModel.isSelected(option);
|
|
383
|
+
if (option.value == null && !this._multiple) {
|
|
384
|
+
option.deselect();
|
|
385
|
+
this._selectionModel.clear();
|
|
386
|
+
if (this.value != null) {
|
|
387
|
+
this._propagateChanges(option.value);
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
else {
|
|
391
|
+
if (wasSelected !== option.selected) {
|
|
392
|
+
option.selected
|
|
393
|
+
? this._selectionModel.select(option)
|
|
394
|
+
: this._selectionModel.deselect(option);
|
|
395
|
+
}
|
|
396
|
+
if (this.multiple) {
|
|
397
|
+
this._sortValues();
|
|
398
|
+
if (isUserInput) {
|
|
399
|
+
this.focus();
|
|
400
|
+
}
|
|
401
|
+
}
|
|
402
|
+
}
|
|
403
|
+
if (wasSelected !== this._selectionModel.isSelected(option)) {
|
|
404
|
+
this._propagateChanges();
|
|
405
|
+
}
|
|
406
|
+
this._changeDetector.markForCheck();
|
|
407
|
+
this.stateChanges.next();
|
|
408
|
+
}
|
|
409
|
+
_sortValues() {
|
|
410
|
+
if (this.multiple) {
|
|
411
|
+
const options = this.options.toArray();
|
|
412
|
+
this._selectionModel.sort((a, b) => {
|
|
413
|
+
return options.indexOf(a) - options.indexOf(b);
|
|
414
|
+
});
|
|
415
|
+
this.stateChanges.next();
|
|
416
|
+
}
|
|
417
|
+
}
|
|
418
|
+
_propagateChanges(fallbackValue) {
|
|
419
|
+
let valToEmit = null;
|
|
420
|
+
if (this.multiple) {
|
|
421
|
+
valToEmit = this.selected.map(option => option.value);
|
|
422
|
+
}
|
|
423
|
+
else {
|
|
424
|
+
valToEmit = this.selected
|
|
425
|
+
? this.selected.value
|
|
426
|
+
: fallbackValue;
|
|
427
|
+
}
|
|
428
|
+
this._value = valToEmit;
|
|
429
|
+
this.valueChange.emit(valToEmit);
|
|
430
|
+
this._cvaOnChange(valToEmit);
|
|
431
|
+
this.selectionChange.emit(this._buildChangeEvent(valToEmit));
|
|
432
|
+
}
|
|
433
|
+
_buildChangeEvent(value) {
|
|
434
|
+
return new SelectChangeEvent(this, value);
|
|
435
|
+
}
|
|
436
|
+
}
|
|
437
|
+
SelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SelectComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: 'tabindex', attribute: true }, { token: i1.ErrorStateMatcher }, { token: IMPDC_FORM_ROOT, optional: true }, { token: i2.NgForm, optional: true }, { token: i2.FormGroupDirective, optional: true }, { token: i2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
|
|
438
|
+
SelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.12", type: SelectComponent, selector: "impdc-select", inputs: { disabled: "disabled", tabIndex: "tabIndex", placeholder: "placeholder", required: "required", multiple: "multiple", compareWith: "compareWith", errorStateMatcher: "errorStateMatcher", value: "value", id: "id" }, outputs: { selectionChange: "selectionChange", valueChange: "valueChange" }, 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: [
|
|
439
|
+
{
|
|
440
|
+
provide: ImpdcFormFieldControl,
|
|
441
|
+
useExisting: SelectComponent
|
|
442
|
+
},
|
|
443
|
+
{
|
|
444
|
+
provide: IMPDC_SELECT_OPTION_PARENT_COMPONENT,
|
|
445
|
+
useExisting: SelectComponent
|
|
446
|
+
}
|
|
447
|
+
], queries: [{ propertyName: "options", predicate: SelectOptionComponent, descendants: true }], viewQueries: [{ propertyName: "_ngbDropdown", first: true, predicate: NgbDropdown, descendants: true }, { propertyName: "_ngbDropdownMenu", first: true, predicate: NgbDropdownMenu, descendants: true }, { propertyName: "_toggleButtonRef", first: true, predicate: ["toggleButton"], descendants: true, read: ElementRef, static: true }], exportAs: ["impdcSelect"], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<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", styles: [":host{padding:0!important;position:relative}:host.impdc-select--disabled{background-color:var(--impd-color-gray-100)}.impdc-select--toggle{font-weight:inherit;padding-right:3.6rem;cursor:pointer;-webkit-user-select:none;user-select:none;width:100%}:host-context(.is-invalid) .impdc-select--toggle{padding-right:6.6rem}.impdc-select--toggle:disabled{cursor:default}.impdc-select--text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}button[ngbDropdownToggle].dropdown-toggle:after{display:none}\n"], dependencies: [{ kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.NgbDropdown, selector: "[ngbDropdown]", inputs: ["autoClose", "dropdownClass", "open", "placement", "popperOptions", "container", "display"], outputs: ["openChange"], exportAs: ["ngbDropdown"] }, { kind: "directive", type: i4.NgbDropdownToggle, selector: "[ngbDropdownToggle]" }, { kind: "directive", type: i4.NgbDropdownMenu, selector: "[ngbDropdownMenu]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
448
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SelectComponent, decorators: [{
|
|
449
|
+
type: Component,
|
|
450
|
+
args: [{ selector: 'impdc-select', exportAs: 'impdcSelect', inputs: ['disabled', 'tabIndex'], changeDetection: ChangeDetectionStrategy.OnPush, host: {
|
|
451
|
+
'[attr.id]': 'id',
|
|
452
|
+
'[attr.tabindex]': 'tabIndex',
|
|
453
|
+
'[attr.aria-required]': 'required.toString()',
|
|
454
|
+
'[attr.aria-disabled]': 'disabled.toString()',
|
|
455
|
+
'[attr.aria-invalid]': 'errorState',
|
|
456
|
+
'[class.form-select]': 'true',
|
|
457
|
+
'[class.is-invalid]': 'errorState',
|
|
458
|
+
'[class.impdc-form-field-control]': 'true',
|
|
459
|
+
'[class.impdc-select--required]': 'required',
|
|
460
|
+
'[class.impdc-select--disabled]': 'disabled',
|
|
461
|
+
'[class.impdc-select--invalid]': 'errorState',
|
|
462
|
+
'[class.impdc-select--empty]': 'empty',
|
|
463
|
+
'[class.impdc-select--multiple]': 'multiple',
|
|
464
|
+
'(focus)': '_onFocus(); focus()'
|
|
465
|
+
}, providers: [
|
|
466
|
+
{
|
|
467
|
+
provide: ImpdcFormFieldControl,
|
|
468
|
+
useExisting: SelectComponent
|
|
469
|
+
},
|
|
470
|
+
{
|
|
471
|
+
provide: IMPDC_SELECT_OPTION_PARENT_COMPONENT,
|
|
472
|
+
useExisting: SelectComponent
|
|
473
|
+
}
|
|
474
|
+
], template: "<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", styles: [":host{padding:0!important;position:relative}:host.impdc-select--disabled{background-color:var(--impd-color-gray-100)}.impdc-select--toggle{font-weight:inherit;padding-right:3.6rem;cursor:pointer;-webkit-user-select:none;user-select:none;width:100%}:host-context(.is-invalid) .impdc-select--toggle{padding-right:6.6rem}.impdc-select--toggle:disabled{cursor:default}.impdc-select--text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}button[ngbDropdownToggle].dropdown-toggle:after{display:none}\n"] }]
|
|
475
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: undefined, decorators: [{
|
|
476
|
+
type: Attribute,
|
|
477
|
+
args: ['tabindex']
|
|
478
|
+
}] }, { type: i1.ErrorStateMatcher }, { type: undefined, decorators: [{
|
|
479
|
+
type: Optional
|
|
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
|
|
507
|
+
}], multiple: [{
|
|
508
|
+
type: Input
|
|
509
|
+
}], compareWith: [{
|
|
510
|
+
type: Input
|
|
511
|
+
}], errorStateMatcher: [{
|
|
512
|
+
type: Input
|
|
513
|
+
}], selectionChange: [{
|
|
514
|
+
type: Output
|
|
515
|
+
}], valueChange: [{
|
|
516
|
+
type: Output
|
|
517
|
+
}], value: [{
|
|
518
|
+
type: Input
|
|
519
|
+
}], id: [{
|
|
520
|
+
type: Input
|
|
521
|
+
}] } });
|
|
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: string = '- 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: boolean = 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> = 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"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { CommonModule } from '@angular/common';
|
|
2
|
+
import { NgModule } from '@angular/core';
|
|
3
|
+
import { NgbDropdownModule } from '@ng-bootstrap/ng-bootstrap';
|
|
4
|
+
import { SelectOptionComponent } from './option/select-option.component';
|
|
5
|
+
import { SelectComponent } from './select.component';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
export class SelectModule {
|
|
8
|
+
}
|
|
9
|
+
SelectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SelectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
10
|
+
SelectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.2.12", ngImport: i0, type: SelectModule, declarations: [SelectOptionComponent, SelectComponent], imports: [CommonModule, NgbDropdownModule], exports: [SelectOptionComponent, SelectComponent, NgbDropdownModule] });
|
|
11
|
+
SelectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SelectModule, imports: [CommonModule, NgbDropdownModule, NgbDropdownModule] });
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.12", ngImport: i0, type: SelectModule, decorators: [{
|
|
13
|
+
type: NgModule,
|
|
14
|
+
args: [{
|
|
15
|
+
declarations: [SelectOptionComponent, SelectComponent],
|
|
16
|
+
imports: [CommonModule, NgbDropdownModule],
|
|
17
|
+
exports: [SelectOptionComponent, SelectComponent, NgbDropdownModule]
|
|
18
|
+
}]
|
|
19
|
+
}] });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VsZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Rlc2lnbi1jb21wb25lbnRzL3NyYy9saWIvZm9ybS1maWVsZC9jb250cm9scy9zZWxlY3Qvc2VsZWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw0QkFBNEIsQ0FBQztBQUMvRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUN6RSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sb0JBQW9CLENBQUM7O0FBT3JELE1BQU0sT0FBTyxZQUFZOzswR0FBWixZQUFZOzJHQUFaLFlBQVksaUJBSlIscUJBQXFCLEVBQUUsZUFBZSxhQUMzQyxZQUFZLEVBQUUsaUJBQWlCLGFBQy9CLHFCQUFxQixFQUFFLGVBQWUsRUFBRSxpQkFBaUI7MkdBRXhELFlBQVksWUFIYixZQUFZLEVBQUUsaUJBQWlCLEVBQ1MsaUJBQWlCOzRGQUV4RCxZQUFZO2tCQUx4QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHFCQUFxQixFQUFFLGVBQWUsQ0FBQztvQkFDdEQsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLGlCQUFpQixDQUFDO29CQUMxQyxPQUFPLEVBQUUsQ0FBQyxxQkFBcUIsRUFBRSxlQUFlLEVBQUUsaUJBQWlCLENBQUM7aUJBQ3JFIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOZ2JEcm9wZG93bk1vZHVsZSB9IGZyb20gJ0BuZy1ib290c3RyYXAvbmctYm9vdHN0cmFwJztcbmltcG9ydCB7IFNlbGVjdE9wdGlvbkNvbXBvbmVudCB9IGZyb20gJy4vb3B0aW9uL3NlbGVjdC1vcHRpb24uY29tcG9uZW50JztcbmltcG9ydCB7IFNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vc2VsZWN0LmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1NlbGVjdE9wdGlvbkNvbXBvbmVudCwgU2VsZWN0Q29tcG9uZW50XSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZSwgTmdiRHJvcGRvd25Nb2R1bGVdLFxuICBleHBvcnRzOiBbU2VsZWN0T3B0aW9uQ29tcG9uZW50LCBTZWxlY3RDb21wb25lbnQsIE5nYkRyb3Bkb3duTW9kdWxlXVxufSlcbmV4cG9ydCBjbGFzcyBTZWxlY3RNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './toggle';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL2Zvcm0tZmllbGQvY29udHJvbHMvc2hhcmVkL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi90b2dnbGUnO1xuIl19
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './toggle-input/toggle-input.component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9kZXNpZ24tY29tcG9uZW50cy9zcmMvbGliL2Zvcm0tZmllbGQvY29udHJvbHMvc2hhcmVkL3RvZ2dsZS9jb21wb25lbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsdUNBQXVDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3RvZ2dsZS1pbnB1dC90b2dnbGUtaW5wdXQuY29tcG9uZW50JztcbiJdfQ==
|