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