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