@ethlete/cdk 3.10.0 → 3.12.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 +16 -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/filter-overlay/components/filter-overlay-page-outlet/filter-overlay-page-outlet.component.mjs +30 -16
- package/esm2022/lib/components/filter-overlay/constants/filter-overlay.constants.mjs +3 -0
- package/esm2022/lib/components/filter-overlay/constants/index.mjs +2 -0
- package/esm2022/lib/components/filter-overlay/constants/public-api.mjs +2 -0
- package/esm2022/lib/components/filter-overlay/directives/filter-overlay-link/filter-overlay-link.directive.mjs +26 -6
- package/esm2022/lib/components/filter-overlay/directives/filter-overlay-reset/filter-overlay-reset.directive.mjs +25 -6
- package/esm2022/lib/components/filter-overlay/directives/filter-overlay-submit/filter-overlay-submit.directive.mjs +25 -6
- package/esm2022/lib/components/filter-overlay/public-api.mjs +2 -1
- package/esm2022/lib/components/filter-overlay/services/filter-overlay.service.mjs +37 -0
- package/esm2022/lib/components/filter-overlay/services/public-api.mjs +2 -0
- package/esm2022/lib/components/filter-overlay/types/filter-overlay-config.types.mjs +2 -0
- package/esm2022/lib/components/filter-overlay/types/index.mjs +2 -0
- package/esm2022/lib/components/filter-overlay/types/public-api.mjs +2 -0
- package/esm2022/lib/components/filter-overlay/utils/filter-overlay-ref.mjs +50 -0
- package/esm2022/lib/components/filter-overlay/utils/index.mjs +2 -0
- package/esm2022/lib/components/filter-overlay/utils/public-api.mjs +2 -0
- 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 +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/components/combobox/combobox.component.mjs +6 -4
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox/combobox.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-empty-template/combobox-body-empty-template.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-error-template/combobox-body-error-template.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-loading-template/combobox-body-loading-template.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/directives/combobox-body-more-items-hint-template/combobox-body-more-items-hint-template.directive.mjs +3 -3
- 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-selected-option-template/combobox-selected-option-template.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-body/combobox-body.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-option/combobox-option.component.mjs +3 -3
- 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 +3 -3
- package/esm2022/lib/components/forms/components/selection-list/directives/selection-list-option/selection-list-option.directive.mjs +3 -3
- 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/expose-input-vars/expose-input-vars.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 +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/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/overlay/components/overlay-container/overlay-container.component.mjs +15 -11
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-close/overlay-close.directive.mjs +5 -5
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-title/overlay-title.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/components/overlay/services/overlay.service.mjs +143 -48
- package/esm2022/lib/components/overlay/components/overlay/types/overlay.types.mjs +1 -1
- package/esm2022/lib/components/overlay/components/overlay/utils/overlay-position-builder.mjs +26 -7
- package/esm2022/lib/components/overlay/components/overlay/utils/overlay-ref.mjs +5 -5
- 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 +3 -3
- package/esm2022/lib/components/overlay/index.mjs +2 -0
- 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 +6 -6
- package/fesm2022/ethlete-cdk.mjs +8717 -8449
- package/fesm2022/ethlete-cdk.mjs.map +1 -1
- package/lib/components/filter-overlay/components/filter-overlay-page-outlet/filter-overlay-page-outlet.component.d.ts +4 -0
- package/lib/components/filter-overlay/constants/filter-overlay.constants.d.ts +3 -0
- package/lib/components/filter-overlay/constants/index.d.ts +1 -0
- package/lib/components/filter-overlay/constants/public-api.d.ts +1 -0
- package/lib/components/filter-overlay/directives/filter-overlay-link/filter-overlay-link.directive.d.ts +5 -1
- package/lib/components/filter-overlay/directives/filter-overlay-reset/filter-overlay-reset.directive.d.ts +5 -1
- package/lib/components/filter-overlay/directives/filter-overlay-submit/filter-overlay-submit.directive.d.ts +5 -1
- package/lib/components/filter-overlay/public-api.d.ts +1 -0
- package/lib/components/filter-overlay/services/filter-overlay.service.d.ts +13 -0
- package/lib/components/filter-overlay/services/public-api.d.ts +1 -0
- package/lib/components/filter-overlay/types/filter-overlay-config.types.d.ts +26 -0
- package/lib/components/filter-overlay/types/index.d.ts +1 -0
- package/lib/components/filter-overlay/types/public-api.d.ts +1 -0
- package/lib/components/filter-overlay/utils/filter-overlay-ref.d.ts +16 -0
- package/lib/components/filter-overlay/utils/index.d.ts +1 -0
- package/lib/components/filter-overlay/utils/public-api.d.ts +1 -0
- package/lib/components/forms/components/select/components/combobox/components/combobox/combobox.component.d.ts +1 -1
- package/lib/components/overlay/components/overlay/types/overlay.types.d.ts +13 -1
- package/lib/components/overlay/components/overlay/utils/overlay-position-builder.d.ts +11 -0
- package/lib/components/overlay/components/overlay/utils/overlay-ref.d.ts +1 -1
- package/lib/components/overlay/index.d.ts +1 -0
- package/package.json +3 -3
- package/src/lib/styles/cdk.css +3 -1
|
@@ -5,7 +5,7 @@ import { ViewportService, createDestroy, equal } from '@ethlete/core';
|
|
|
5
5
|
import { Subject, combineLatest, defer, map, of, pairwise, startWith, takeUntil, tap } from 'rxjs';
|
|
6
6
|
import { OverlayContainerComponent } from '../components';
|
|
7
7
|
import { OVERLAY_CONFIG, OVERLAY_DATA, OVERLAY_DEFAULT_OPTIONS, OVERLAY_SCROLL_STRATEGY } from '../constants';
|
|
8
|
-
import { OverlayPositionBuilder, OverlayRef, createOverlayConfig } from '../utils';
|
|
8
|
+
import { ET_OVERLAY_BOTTOM_SHEET_CLASS, ET_OVERLAY_LEFT_SHEET_CLASS, ET_OVERLAY_RIGHT_SHEET_CLASS, ET_OVERLAY_TOP_SHEET_CLASS, OverlayPositionBuilder, OverlayRef, createOverlayConfig, } from '../utils';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
let uniqueId = 0;
|
|
11
11
|
const ID_PREFIX = 'et-overlay-';
|
|
@@ -37,6 +37,15 @@ const setClass = (el, prevClass, currClass) => {
|
|
|
37
37
|
}
|
|
38
38
|
}
|
|
39
39
|
};
|
|
40
|
+
const isHtmlElement = (element) => {
|
|
41
|
+
return element instanceof HTMLElement;
|
|
42
|
+
};
|
|
43
|
+
const isTouchEvent = (event) => {
|
|
44
|
+
return event.type[0] === 't';
|
|
45
|
+
};
|
|
46
|
+
const isPointerEvent = (event) => {
|
|
47
|
+
return event.type[0] === 'c';
|
|
48
|
+
};
|
|
40
49
|
export class OverlayService {
|
|
41
50
|
constructor() {
|
|
42
51
|
this._destroy$ = createDestroy();
|
|
@@ -71,6 +80,7 @@ export class OverlayService {
|
|
|
71
80
|
...composedConfig,
|
|
72
81
|
disableClose: true,
|
|
73
82
|
closeOnDestroy: false,
|
|
83
|
+
panelClass: 'et-overlay-pane',
|
|
74
84
|
container: {
|
|
75
85
|
type: OverlayContainerComponent,
|
|
76
86
|
providers: () => [
|
|
@@ -85,6 +95,7 @@ export class OverlayService {
|
|
|
85
95
|
{ provide: OverlayContainerComponent, useValue: overlayContainer },
|
|
86
96
|
{ provide: OVERLAY_DATA, useValue: cdkConfig.data },
|
|
87
97
|
{ provide: OverlayRef, useValue: overlayRef },
|
|
98
|
+
...(composedConfig.providers ?? []),
|
|
88
99
|
];
|
|
89
100
|
},
|
|
90
101
|
});
|
|
@@ -92,59 +103,143 @@ export class OverlayService {
|
|
|
92
103
|
overlayRef.componentRef = cdkRef.componentRef;
|
|
93
104
|
overlayRef.componentInstance = cdkRef.componentInstance;
|
|
94
105
|
cdkRef.containerInstance.overlayRef = overlayRef;
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
106
|
+
const containerEl = overlayRef._containerInstance.elementRef.nativeElement;
|
|
107
|
+
const overlayPaneEl = cdkRef.overlayRef.overlayElement;
|
|
108
|
+
const backdropEl = cdkRef.overlayRef.backdropElement;
|
|
109
|
+
const overlayWrapper = cdkRef.overlayRef.hostElement;
|
|
110
|
+
const defaultAnimationBuffer = 50; // 50px since the default animation uses spring physics and thus will overshoot.
|
|
111
|
+
const useDefaultAnimation = composedConfig.customAnimated !== true;
|
|
112
|
+
const origin = composedConfig.origin;
|
|
113
|
+
if (origin) {
|
|
114
|
+
const originX = isHtmlElement(origin)
|
|
115
|
+
? origin.getBoundingClientRect().left
|
|
116
|
+
: isTouchEvent(origin)
|
|
117
|
+
? origin.changedTouches[0].clientX
|
|
118
|
+
: isPointerEvent(origin)
|
|
119
|
+
? origin.clientX !== 0
|
|
120
|
+
? origin.clientX
|
|
121
|
+
: origin.target.getBoundingClientRect().left
|
|
122
|
+
: -1;
|
|
123
|
+
const originY = isHtmlElement(origin)
|
|
124
|
+
? origin.getBoundingClientRect().top
|
|
125
|
+
: isTouchEvent(origin)
|
|
126
|
+
? origin.changedTouches[0].clientY
|
|
127
|
+
: isPointerEvent(origin)
|
|
128
|
+
? origin.clientY !== 0
|
|
129
|
+
? origin.clientY
|
|
130
|
+
: origin.target.getBoundingClientRect().top
|
|
131
|
+
: -1;
|
|
132
|
+
if (originX !== -1 && originY !== -1) {
|
|
133
|
+
setStyle(containerEl, 'transform-origin', `${originX}px ${originY}px`);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
combineLatest(composedConfig.positions.map((breakpoint) => (breakpoint.breakpoint ? this._viewportService.observe({ min: breakpoint.breakpoint }) : of(true)).pipe(map((isActive) => ({
|
|
137
|
+
isActive,
|
|
138
|
+
config: breakpoint.config,
|
|
139
|
+
size: typeof breakpoint.breakpoint === 'number'
|
|
140
|
+
? breakpoint.breakpoint
|
|
141
|
+
: breakpoint.breakpoint === undefined
|
|
142
|
+
? 0
|
|
143
|
+
: this._viewportService.getBreakpointSize(breakpoint.breakpoint, 'min'),
|
|
144
|
+
})))))
|
|
145
|
+
.pipe(takeUntil(overlayRef.afterClosed()), takeUntil(this._destroy$), map((entries) => {
|
|
146
|
+
const activeBreakpoints = entries.filter((entry) => entry.isActive);
|
|
147
|
+
const highestBreakpoint = activeBreakpoints.reduce((prev, curr) => (prev.size > curr.size ? prev : curr));
|
|
148
|
+
return highestBreakpoint.config;
|
|
149
|
+
}), startWith(null), pairwise(), tap(([prevConfig, currConfig]) => {
|
|
150
|
+
if (!currConfig)
|
|
151
|
+
return;
|
|
152
|
+
const containerClass = currConfig.containerClass;
|
|
153
|
+
const applyDefaultMaxWidths = () => {
|
|
118
154
|
setStyle(overlayPaneEl, 'max-width', currConfig.maxWidth);
|
|
119
155
|
setStyle(overlayPaneEl, 'max-height', currConfig.maxHeight);
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
setClass(backdropEl, prevConfig?.backdropClass, currConfig?.backdropClass);
|
|
156
|
+
};
|
|
157
|
+
const combineOrMakeCalc = (value, append) => {
|
|
158
|
+
if (!value)
|
|
159
|
+
return append;
|
|
160
|
+
if (typeof value === 'number') {
|
|
161
|
+
return `calc(${value}px + ${append})`;
|
|
127
162
|
}
|
|
128
|
-
if (
|
|
129
|
-
|
|
163
|
+
else if (value.startsWith('calc(')) {
|
|
164
|
+
return `${value.slice(0, value.length - 1)} + ${append})`;
|
|
130
165
|
}
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
166
|
+
return `calc(${value} + ${append})`;
|
|
167
|
+
};
|
|
168
|
+
if (useDefaultAnimation && containerClass?.length) {
|
|
169
|
+
if (containerClass?.includes(ET_OVERLAY_LEFT_SHEET_CLASS) ||
|
|
170
|
+
containerClass?.includes(ET_OVERLAY_RIGHT_SHEET_CLASS)) {
|
|
171
|
+
setStyle(overlayPaneEl, 'max-width', combineOrMakeCalc(currConfig.maxWidth, `${defaultAnimationBuffer}px`));
|
|
172
|
+
setStyle(overlayPaneEl, 'max-height', currConfig.maxHeight);
|
|
136
173
|
}
|
|
137
|
-
if (
|
|
138
|
-
|
|
174
|
+
else if (containerClass?.includes(ET_OVERLAY_TOP_SHEET_CLASS) ||
|
|
175
|
+
containerClass?.includes(ET_OVERLAY_BOTTOM_SHEET_CLASS)) {
|
|
176
|
+
setStyle(overlayPaneEl, 'max-height', combineOrMakeCalc(currConfig.maxHeight, `${defaultAnimationBuffer}px`));
|
|
177
|
+
setStyle(overlayPaneEl, 'max-width', currConfig.maxWidth);
|
|
139
178
|
}
|
|
140
179
|
else {
|
|
141
|
-
|
|
180
|
+
applyDefaultMaxWidths();
|
|
142
181
|
}
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
|
|
182
|
+
}
|
|
183
|
+
else {
|
|
184
|
+
applyDefaultMaxWidths();
|
|
185
|
+
}
|
|
186
|
+
setStyle(overlayPaneEl, 'min-width', currConfig.minWidth);
|
|
187
|
+
setStyle(overlayPaneEl, 'min-height', currConfig.minHeight);
|
|
188
|
+
setStyle(overlayPaneEl, 'width', currConfig.width);
|
|
189
|
+
setStyle(overlayPaneEl, 'height', currConfig.height);
|
|
190
|
+
setClass(containerEl, prevConfig?.containerClass, currConfig?.containerClass);
|
|
191
|
+
setClass(overlayPaneEl, prevConfig?.paneClass, currConfig?.paneClass);
|
|
192
|
+
setClass(overlayWrapper, prevConfig?.overlayClass, currConfig?.overlayClass);
|
|
193
|
+
// FIXME: These classes should only be removed if no open overlays require them inside their config.
|
|
194
|
+
setClass(document.documentElement, prevConfig?.documentClass, currConfig?.documentClass);
|
|
195
|
+
setClass(document.body, prevConfig?.bodyClass, currConfig?.bodyClass);
|
|
196
|
+
if (backdropEl) {
|
|
197
|
+
setClass(backdropEl, prevConfig?.backdropClass, currConfig?.backdropClass);
|
|
198
|
+
}
|
|
199
|
+
if (!equal(prevConfig?.position, currConfig?.position)) {
|
|
200
|
+
overlayRef.updatePosition(currConfig.position);
|
|
201
|
+
}
|
|
202
|
+
if (currConfig.positionStrategy) {
|
|
203
|
+
cdkRef.overlayRef.updatePositionStrategy(currConfig.positionStrategy);
|
|
204
|
+
}
|
|
205
|
+
else {
|
|
206
|
+
cdkRef.overlayRef.updatePosition();
|
|
207
|
+
}
|
|
208
|
+
if (currConfig.dragToDismiss) {
|
|
209
|
+
overlayRef._containerInstance._enableDragToDismiss(currConfig.dragToDismiss);
|
|
210
|
+
}
|
|
211
|
+
else {
|
|
212
|
+
overlayRef._containerInstance._disableDragToDismiss();
|
|
213
|
+
}
|
|
214
|
+
}))
|
|
215
|
+
.subscribe();
|
|
146
216
|
this.openOverlays.push(overlayRef);
|
|
147
217
|
this.afterOpened.next(overlayRef);
|
|
218
|
+
overlayRef.beforeClosed().subscribe(() => {
|
|
219
|
+
// FIXME: These classes should only be removed if no open overlays require them inside their config.
|
|
220
|
+
const documentClasses = composedConfig.positions.map((position) => position.config.documentClass);
|
|
221
|
+
for (const klass of documentClasses) {
|
|
222
|
+
if (!klass)
|
|
223
|
+
continue;
|
|
224
|
+
if (Array.isArray(klass)) {
|
|
225
|
+
document.documentElement.classList.remove(...klass);
|
|
226
|
+
}
|
|
227
|
+
else {
|
|
228
|
+
document.documentElement.classList.remove(klass);
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
const bodyClasses = composedConfig.positions.map((position) => position.config.bodyClass);
|
|
232
|
+
for (const klass of bodyClasses) {
|
|
233
|
+
if (!klass)
|
|
234
|
+
continue;
|
|
235
|
+
if (Array.isArray(klass)) {
|
|
236
|
+
document.body.classList.remove(...klass);
|
|
237
|
+
}
|
|
238
|
+
else {
|
|
239
|
+
document.body.classList.remove(klass);
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
});
|
|
148
243
|
overlayRef.afterClosed().subscribe(() => {
|
|
149
244
|
const index = this.openOverlays.indexOf(overlayRef);
|
|
150
245
|
if (index === -1)
|
|
@@ -173,10 +268,10 @@ export class OverlayService {
|
|
|
173
268
|
const parent = this._parentOverlayService;
|
|
174
269
|
return parent ? parent._getAfterAllClosed() : this._afterAllClosedAtThisLevel;
|
|
175
270
|
}
|
|
176
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.
|
|
177
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.
|
|
271
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: OverlayService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
272
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: OverlayService }); }
|
|
178
273
|
}
|
|
179
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.
|
|
274
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.5", ngImport: i0, type: OverlayService, decorators: [{
|
|
180
275
|
type: Injectable
|
|
181
276
|
}] });
|
|
182
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.service.js","sourceRoot":"","sources":["../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/overlay/services/overlay.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceCssPixelValue } from '@angular/cdk/coercion';\nimport { Dialog as CdkDialog, DialogConfig as CdkDialogConfig } from '@angular/cdk/dialog';\nimport { ComponentType } from '@angular/cdk/overlay';\nimport { ComponentRef, Injectable, OnDestroy, TemplateRef, inject } from '@angular/core';\nimport { ViewportService, createDestroy, equal } from '@ethlete/core';\nimport { Observable, Subject, combineLatest, defer, map, of, pairwise, startWith, takeUntil, tap } from 'rxjs';\nimport { OverlayContainerComponent } from '../components';\nimport { OVERLAY_CONFIG, OVERLAY_DATA, OVERLAY_DEFAULT_OPTIONS, OVERLAY_SCROLL_STRATEGY } from '../constants';\nimport { OverlayConfig } from '../types';\nimport { OverlayPositionBuilder, OverlayRef, createOverlayConfig } from '../utils';\n\nlet uniqueId = 0;\nconst ID_PREFIX = 'et-overlay-';\n\nconst setStyle = (el: HTMLElement, style: string, value: string | number | null | undefined) => {\n  if (value === null || value === undefined) {\n    el.style.removeProperty(style);\n  } else {\n    el.style.setProperty(style, coerceCssPixelValue(value));\n  }\n};\n\nconst setClass = (el: HTMLElement, prevClass?: string | string[], currClass?: string | string[]) => {\n  if (!equal(prevClass, currClass)) {\n    if (prevClass) {\n      if (Array.isArray(prevClass)) {\n        el.classList.remove(...prevClass);\n      } else {\n        el.classList.remove(prevClass);\n      }\n    }\n\n    if (currClass) {\n      if (Array.isArray(currClass)) {\n        el.classList.add(...currClass);\n      } else {\n        el.classList.add(currClass);\n      }\n    }\n  }\n};\n\n@Injectable()\nexport class OverlayService implements OnDestroy {\n  private readonly _destroy$ = createDestroy();\n  private readonly _defaultOptions = inject(OVERLAY_DEFAULT_OPTIONS, { optional: true });\n  private readonly _scrollStrategy = inject(OVERLAY_SCROLL_STRATEGY);\n  private readonly _parentOverlayService = inject(OverlayService, { optional: true, skipSelf: true });\n  private readonly _dialog = inject(CdkDialog);\n  private readonly _viewportService = inject(ViewportService);\n\n  private readonly _openOverlaysAtThisLevel: OverlayRef[] = [];\n  private readonly _afterAllClosedAtThisLevel = new Subject<void>();\n  private readonly _afterOpenedAtThisLevel = new Subject<OverlayRef>();\n\n  readonly positions = new OverlayPositionBuilder();\n\n  readonly afterAllClosed = defer(() =>\n    this.openOverlays.length ? this._getAfterAllClosed() : this._getAfterAllClosed().pipe(startWith(undefined)),\n  ) as Observable<void>;\n\n  get openOverlays(): OverlayRef[] {\n    return this._parentOverlayService ? this._parentOverlayService.openOverlays : this._openOverlaysAtThisLevel;\n  }\n\n  get afterOpened(): Subject<OverlayRef> {\n    return this._parentOverlayService ? this._parentOverlayService.afterOpened : this._afterOpenedAtThisLevel;\n  }\n\n  ngOnDestroy() {\n    this._closeOverlays(this._openOverlaysAtThisLevel);\n    this._afterAllClosedAtThisLevel.complete();\n    this._afterOpenedAtThisLevel.complete();\n  }\n\n  open<T, D = unknown, R = unknown>(component: ComponentType<T>, config: OverlayConfig<D>): OverlayRef<T, R>;\n  open<T, D = unknown, R = unknown>(template: TemplateRef<T>, config: OverlayConfig<D>): OverlayRef<T, R>;\n  open<T, D = unknown, R = unknown>(\n    template: ComponentType<T> | TemplateRef<T>,\n    config: OverlayConfig<D>,\n  ): OverlayRef<T, R>;\n  open<T, D = unknown, R = unknown>(\n    componentOrTemplateRef: ComponentType<T> | TemplateRef<T>,\n    config: OverlayConfig<D>,\n  ): OverlayRef<T, R> {\n    let overlayRef: OverlayRef<T, R>;\n\n    const composedConfig = createOverlayConfig<D>(this._defaultOptions as OverlayConfig<D>, config);\n    composedConfig.id = composedConfig.id || `${ID_PREFIX}${uniqueId++}`;\n    composedConfig.scrollStrategy = composedConfig.scrollStrategy || this._scrollStrategy();\n\n    const cdkRef = this._dialog.open<R, D, T>(componentOrTemplateRef, {\n      ...composedConfig,\n      disableClose: true,\n      closeOnDestroy: false,\n      container: {\n        type: OverlayContainerComponent,\n        providers: () => [\n          { provide: OVERLAY_CONFIG, useValue: composedConfig },\n          { provide: CdkDialogConfig, useValue: composedConfig },\n        ],\n      },\n      templateContext: () => ({ dialogRef: overlayRef }),\n      providers: (ref, cdkConfig, overlayContainer) => {\n        overlayRef = new OverlayRef(ref, composedConfig, overlayContainer as OverlayContainerComponent);\n\n        return [\n          { provide: OverlayContainerComponent, useValue: overlayContainer },\n          { provide: OVERLAY_DATA, useValue: cdkConfig.data },\n          { provide: OverlayRef, useValue: overlayRef },\n        ];\n      },\n    });\n\n    /* eslint-disable @typescript-eslint/no-non-null-assertion*/\n    (overlayRef! as { componentRef: ComponentRef<T> }).componentRef = cdkRef.componentRef!;\n    overlayRef!.componentInstance = cdkRef.componentInstance!;\n\n    (cdkRef.containerInstance as OverlayContainerComponent).overlayRef = overlayRef!;\n\n    if (composedConfig.positions?.length) {\n      combineLatest(\n        composedConfig.positions.map((breakpoint) =>\n          (breakpoint.breakpoint ? this._viewportService.observe({ min: breakpoint.breakpoint }) : of(true)).pipe(\n            map((isActive) => ({\n              isActive,\n              config: breakpoint.config,\n              size:\n                typeof breakpoint.breakpoint === 'number'\n                  ? breakpoint.breakpoint\n                  : breakpoint.breakpoint === undefined\n                  ? 0\n                  : this._viewportService.getBreakpointSize(breakpoint.breakpoint, 'min'),\n            })),\n          ),\n        ),\n      )\n        .pipe(\n          takeUntil(overlayRef!.afterClosed()),\n          takeUntil(this._destroy$),\n          map((entries) => {\n            const activeBreakpoints = entries.filter((entry) => entry.isActive);\n            const highestBreakpoint = activeBreakpoints.reduce((prev, curr) => (prev.size > curr.size ? prev : curr));\n\n            return highestBreakpoint.config;\n          }),\n          startWith(null),\n          pairwise(),\n          tap(([prevConfig, currConfig]) => {\n            if (!currConfig) return;\n\n            const overlayPaneEl = cdkRef.overlayRef.overlayElement;\n            const containerEl = overlayRef._containerInstance.elementRef.nativeElement;\n            const backdropEl = cdkRef.overlayRef.backdropElement;\n            const overlayWrapper = cdkRef.overlayRef.hostElement;\n\n            setStyle(overlayPaneEl, 'min-width', currConfig.minWidth);\n            setStyle(overlayPaneEl, 'min-height', currConfig.minHeight);\n            setStyle(overlayPaneEl, 'max-width', currConfig.maxWidth);\n            setStyle(overlayPaneEl, 'max-height', currConfig.maxHeight);\n            setStyle(overlayPaneEl, 'width', currConfig.width);\n            setStyle(overlayPaneEl, 'height', currConfig.height);\n\n            setClass(containerEl, prevConfig?.containerClass, currConfig?.containerClass);\n            setClass(overlayPaneEl, prevConfig?.paneClass, currConfig?.paneClass);\n            setClass(overlayWrapper, prevConfig?.overlayClass, currConfig?.overlayClass);\n\n            if (backdropEl) {\n              setClass(backdropEl, prevConfig?.backdropClass, currConfig?.backdropClass);\n            }\n\n            if (!equal(prevConfig?.position, currConfig?.position)) {\n              overlayRef.updatePosition(currConfig.position);\n            }\n\n            if (currConfig.positionStrategy) {\n              cdkRef.overlayRef.updatePositionStrategy(currConfig.positionStrategy);\n            } else {\n              cdkRef.overlayRef.updatePosition();\n            }\n\n            if (currConfig.dragToDismiss) {\n              overlayRef._containerInstance._enableDragToDismiss(currConfig.dragToDismiss);\n            } else {\n              overlayRef._containerInstance._disableDragToDismiss();\n            }\n          }),\n        )\n        .subscribe();\n    }\n\n    this.openOverlays.push(overlayRef!);\n    this.afterOpened.next(overlayRef!);\n\n    overlayRef!.afterClosed().subscribe(() => {\n      const index = this.openOverlays.indexOf(overlayRef);\n\n      if (index === -1) return;\n\n      this.openOverlays.splice(index, 1);\n\n      if (!this.openOverlays.length) {\n        this._getAfterAllClosed().next();\n      }\n    });\n\n    return overlayRef!;\n\n    /* eslint-enable @typescript-eslint/no-non-null-assertion*/\n  }\n\n  closeAll(): void {\n    this._closeOverlays(this.openOverlays);\n  }\n\n  getOverlayById(id: string): OverlayRef | undefined {\n    return this.openOverlays.find((overlay) => overlay.id === id);\n  }\n\n  private _closeOverlays(overlays: OverlayRef[]) {\n    let i = overlays.length;\n\n    while (i--) {\n      overlays[i].close();\n    }\n  }\n\n  private _getAfterAllClosed(): Subject<void> {\n    const parent = this._parentOverlayService;\n    return parent ? parent._getAfterAllClosed() : this._afterAllClosedAtThisLevel;\n  }\n}\n"]}
|
|
277
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.service.js","sourceRoot":"","sources":["../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/overlay/services/overlay.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,MAAM,IAAI,SAAS,EAAE,YAAY,IAAI,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAE3F,OAAO,EAAgB,UAAU,EAA0B,MAAM,EAAE,MAAM,eAAe,CAAC;AACzF,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACtE,OAAO,EAAc,OAAO,EAAE,aAAa,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,EAAE,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AAC/G,OAAO,EAAE,yBAAyB,EAAE,MAAM,eAAe,CAAC;AAC1D,OAAO,EAAE,cAAc,EAAE,YAAY,EAAE,uBAAuB,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AAE9G,OAAO,EACL,6BAA6B,EAC7B,2BAA2B,EAC3B,4BAA4B,EAC5B,0BAA0B,EAC1B,sBAAsB,EACtB,UAAU,EACV,mBAAmB,GACpB,MAAM,UAAU,CAAC;;AAElB,IAAI,QAAQ,GAAG,CAAC,CAAC;AACjB,MAAM,SAAS,GAAG,aAAa,CAAC;AAEhC,MAAM,QAAQ,GAAG,CAAC,EAAe,EAAE,KAAa,EAAE,KAAyC,EAAE,EAAE;IAC7F,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,SAAS,EAAE;QACzC,EAAE,CAAC,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;KAChC;SAAM;QACL,EAAE,CAAC,KAAK,CAAC,WAAW,CAAC,KAAK,EAAE,mBAAmB,CAAC,KAAK,CAAC,CAAC,CAAC;KACzD;AACH,CAAC,CAAC;AAEF,MAAM,QAAQ,GAAG,CAAC,EAAe,EAAE,SAA6B,EAAE,SAA6B,EAAE,EAAE;IACjG,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,SAAS,CAAC,EAAE;QAChC,IAAI,SAAS,EAAE;YACb,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;gBAC5B,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,SAAS,CAAC,CAAC;aACnC;iBAAM;gBACL,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;aAChC;SACF;QAED,IAAI,SAAS,EAAE;YACb,IAAI,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE;gBAC5B,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC,CAAC;aAChC;iBAAM;gBACL,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;aAC7B;SACF;KACF;AACH,CAAC,CAAC;AAEF,MAAM,aAAa,GAAG,CAAC,OAA8B,EAA0B,EAAE;IAC/E,OAAO,OAAO,YAAY,WAAW,CAAC;AACxC,CAAC,CAAC;AAEF,MAAM,YAAY,GAAG,CAAC,KAAY,EAAuB,EAAE;IACzD,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC;AAC/B,CAAC,CAAC;AAEF,MAAM,cAAc,GAAG,CAAC,KAAY,EAAyB,EAAE;IAC7D,OAAO,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC;AAC/B,CAAC,CAAC;AAGF,MAAM,OAAO,cAAc;IAD3B;QAEmB,cAAS,GAAG,aAAa,EAAE,CAAC;QAC5B,oBAAe,GAAG,MAAM,CAAC,uBAAuB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QACtE,oBAAe,GAAG,MAAM,CAAC,uBAAuB,CAAC,CAAC;QAClD,0BAAqB,GAAG,MAAM,CAAC,cAAc,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QACnF,YAAO,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAC5B,qBAAgB,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;QAE3C,6BAAwB,GAAiB,EAAE,CAAC;QAC5C,+BAA0B,GAAG,IAAI,OAAO,EAAQ,CAAC;QACjD,4BAAuB,GAAG,IAAI,OAAO,EAAc,CAAC;QAE5D,cAAS,GAAG,IAAI,sBAAsB,EAAE,CAAC;QAEzC,mBAAc,GAAG,KAAK,CAAC,GAAG,EAAE,CACnC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CACxF,CAAC;KAsRvB;IApRC,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,wBAAwB,CAAC;IAC9G,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC,qBAAqB,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,uBAAuB,CAAC;IAC5G,CAAC;IAED,WAAW;QACT,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,wBAAwB,CAAC,CAAC;QACnD,IAAI,CAAC,0BAA0B,CAAC,QAAQ,EAAE,CAAC;QAC3C,IAAI,CAAC,uBAAuB,CAAC,QAAQ,EAAE,CAAC;IAC1C,CAAC;IAQD,IAAI,CACF,sBAAyD,EACzD,MAAwB;QAExB,IAAI,UAA4B,CAAC;QAEjC,MAAM,cAAc,GAAG,mBAAmB,CAAI,IAAI,CAAC,eAAmC,EAAE,MAAM,CAAC,CAAC;QAChG,cAAc,CAAC,EAAE,GAAG,cAAc,CAAC,EAAE,IAAI,GAAG,SAAS,GAAG,QAAQ,EAAE,EAAE,CAAC;QACrE,cAAc,CAAC,cAAc,GAAG,cAAc,CAAC,cAAc,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;QAExF,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAU,sBAAsB,EAAE;YAChE,GAAG,cAAc;YACjB,YAAY,EAAE,IAAI;YAClB,cAAc,EAAE,KAAK;YACrB,UAAU,EAAE,iBAAiB;YAC7B,SAAS,EAAE;gBACT,IAAI,EAAE,yBAAyB;gBAC/B,SAAS,EAAE,GAAG,EAAE,CAAC;oBACf,EAAE,OAAO,EAAE,cAAc,EAAE,QAAQ,EAAE,cAAc,EAAE;oBACrD,EAAE,OAAO,EAAE,eAAe,EAAE,QAAQ,EAAE,cAAc,EAAE;iBACvD;aACF;YACD,eAAe,EAAE,GAAG,EAAE,CAAC,CAAC,EAAE,SAAS,EAAE,UAAU,EAAE,CAAC;YAClD,SAAS,EAAE,CAAC,GAAG,EAAE,SAAS,EAAE,gBAAgB,EAAE,EAAE;gBAC9C,UAAU,GAAG,IAAI,UAAU,CAAC,GAAG,EAAE,cAAc,EAAE,gBAA6C,CAAC,CAAC;gBAEhG,OAAO;oBACL,EAAE,OAAO,EAAE,yBAAyB,EAAE,QAAQ,EAAE,gBAAgB,EAAE;oBAClE,EAAE,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,SAAS,CAAC,IAAI,EAAE;oBACnD,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE;oBAC7C,GAAG,CAAC,cAAc,CAAC,SAAS,IAAI,EAAE,CAAC;iBACpC,CAAC;YACJ,CAAC;SACF,CAAC,CAAC;QAEH,4DAA4D;QAC3D,UAAiD,CAAC,YAAY,GAAG,MAAM,CAAC,YAAa,CAAC;QACvF,UAAW,CAAC,iBAAiB,GAAG,MAAM,CAAC,iBAAkB,CAAC;QAEzD,MAAM,CAAC,iBAA+C,CAAC,UAAU,GAAG,UAAW,CAAC;QAEjF,MAAM,WAAW,GAAG,UAAW,CAAC,kBAAkB,CAAC,UAAU,CAAC,aAA4B,CAAC;QAC3F,MAAM,aAAa,GAAG,MAAM,CAAC,UAAU,CAAC,cAAc,CAAC;QACvD,MAAM,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,eAAe,CAAC;QACrD,MAAM,cAAc,GAAG,MAAM,CAAC,UAAU,CAAC,WAAW,CAAC;QACrD,MAAM,sBAAsB,GAAG,EAAE,CAAC,CAAC,gFAAgF;QACnH,MAAM,mBAAmB,GAAG,cAAc,CAAC,cAAc,KAAK,IAAI,CAAC;QACnE,MAAM,MAAM,GAAG,cAAc,CAAC,MAAM,CAAC;QAErC,IAAI,MAAM,EAAE;YACV,MAAM,OAAO,GAAG,aAAa,CAAC,MAAM,CAAC;gBACnC,CAAC,CAAC,MAAM,CAAC,qBAAqB,EAAE,CAAC,IAAI;gBACrC,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC;oBACtB,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,OAAO;oBAClC,CAAC,CAAC,cAAc,CAAC,MAAM,CAAC;wBACxB,CAAC,CAAC,MAAM,CAAC,OAAO,KAAK,CAAC;4BACpB,CAAC,CAAC,MAAM,CAAC,OAAO;4BAChB,CAAC,CAAE,MAAM,CAAC,MAAsB,CAAC,qBAAqB,EAAE,CAAC,IAAI;wBAC/D,CAAC,CAAC,CAAC,CAAC,CAAC;YACP,MAAM,OAAO,GAAG,aAAa,CAAC,MAAM,CAAC;gBACnC,CAAC,CAAC,MAAM,CAAC,qBAAqB,EAAE,CAAC,GAAG;gBACpC,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC;oBACtB,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,OAAO;oBAClC,CAAC,CAAC,cAAc,CAAC,MAAM,CAAC;wBACxB,CAAC,CAAC,MAAM,CAAC,OAAO,KAAK,CAAC;4BACpB,CAAC,CAAC,MAAM,CAAC,OAAO;4BAChB,CAAC,CAAE,MAAM,CAAC,MAAsB,CAAC,qBAAqB,EAAE,CAAC,GAAG;wBAC9D,CAAC,CAAC,CAAC,CAAC,CAAC;YAEP,IAAI,OAAO,KAAK,CAAC,CAAC,IAAI,OAAO,KAAK,CAAC,CAAC,EAAE;gBACpC,QAAQ,CAAC,WAAW,EAAE,kBAAkB,EAAE,GAAG,OAAO,MAAM,OAAO,IAAI,CAAC,CAAC;aACxE;SACF;QAED,aAAa,CACX,cAAc,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAC1C,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,EAAE,GAAG,EAAE,UAAU,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CACrG,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;YACjB,QAAQ;YACR,MAAM,EAAE,UAAU,CAAC,MAAM;YACzB,IAAI,EACF,OAAO,UAAU,CAAC,UAAU,KAAK,QAAQ;gBACvC,CAAC,CAAC,UAAU,CAAC,UAAU;gBACvB,CAAC,CAAC,UAAU,CAAC,UAAU,KAAK,SAAS;oBACrC,CAAC,CAAC,CAAC;oBACH,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,UAAU,CAAC,UAAU,EAAE,KAAK,CAAC;SAC5E,CAAC,CAAC,CACJ,CACF,CACF;aACE,IAAI,CACH,SAAS,CAAC,UAAW,CAAC,WAAW,EAAE,CAAC,EACpC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE;YACd,MAAM,iBAAiB,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YACpE,MAAM,iBAAiB,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;YAE1G,OAAO,iBAAiB,CAAC,MAAM,CAAC;QAClC,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,EACf,QAAQ,EAAE,EACV,GAAG,CAAC,CAAC,CAAC,UAAU,EAAE,UAAU,CAAC,EAAE,EAAE;YAC/B,IAAI,CAAC,UAAU;gBAAE,OAAO;YAExB,MAAM,cAAc,GAAG,UAAU,CAAC,cAAc,CAAC;YAEjD,MAAM,qBAAqB,GAAG,GAAG,EAAE;gBACjC,QAAQ,CAAC,aAAa,EAAE,WAAW,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;gBAC1D,QAAQ,CAAC,aAAa,EAAE,YAAY,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;YAC9D,CAAC,CAAC;YAEF,MAAM,iBAAiB,GAAG,CAAC,KAAyC,EAAE,MAAc,EAAE,EAAE;gBACtF,IAAI,CAAC,KAAK;oBAAE,OAAO,MAAM,CAAC;gBAE1B,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;oBAC7B,OAAO,QAAQ,KAAK,QAAQ,MAAM,GAAG,CAAC;iBACvC;qBAAM,IAAI,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE;oBACpC,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,MAAM,MAAM,GAAG,CAAC;iBAC3D;gBAED,OAAO,QAAQ,KAAK,MAAM,MAAM,GAAG,CAAC;YACtC,CAAC,CAAC;YAEF,IAAI,mBAAmB,IAAI,cAAc,EAAE,MAAM,EAAE;gBACjD,IACE,cAAc,EAAE,QAAQ,CAAC,2BAA2B,CAAC;oBACrD,cAAc,EAAE,QAAQ,CAAC,4BAA4B,CAAC,EACtD;oBACA,QAAQ,CACN,aAAa,EACb,WAAW,EACX,iBAAiB,CAAC,UAAU,CAAC,QAAQ,EAAE,GAAG,sBAAsB,IAAI,CAAC,CACtE,CAAC;oBACF,QAAQ,CAAC,aAAa,EAAE,YAAY,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;iBAC7D;qBAAM,IACL,cAAc,EAAE,QAAQ,CAAC,0BAA0B,CAAC;oBACpD,cAAc,EAAE,QAAQ,CAAC,6BAA6B,CAAC,EACvD;oBACA,QAAQ,CACN,aAAa,EACb,YAAY,EACZ,iBAAiB,CAAC,UAAU,CAAC,SAAS,EAAE,GAAG,sBAAsB,IAAI,CAAC,CACvE,CAAC;oBAEF,QAAQ,CAAC,aAAa,EAAE,WAAW,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;iBAC3D;qBAAM;oBACL,qBAAqB,EAAE,CAAC;iBACzB;aACF;iBAAM;gBACL,qBAAqB,EAAE,CAAC;aACzB;YAED,QAAQ,CAAC,aAAa,EAAE,WAAW,EAAE,UAAU,CAAC,QAAQ,CAAC,CAAC;YAC1D,QAAQ,CAAC,aAAa,EAAE,YAAY,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC;YAE5D,QAAQ,CAAC,aAAa,EAAE,OAAO,EAAE,UAAU,CAAC,KAAK,CAAC,CAAC;YACnD,QAAQ,CAAC,aAAa,EAAE,QAAQ,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;YAErD,QAAQ,CAAC,WAAW,EAAE,UAAU,EAAE,cAAc,EAAE,UAAU,EAAE,cAAc,CAAC,CAAC;YAC9E,QAAQ,CAAC,aAAa,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC;YACtE,QAAQ,CAAC,cAAc,EAAE,UAAU,EAAE,YAAY,EAAE,UAAU,EAAE,YAAY,CAAC,CAAC;YAE7E,oGAAoG;YACpG,QAAQ,CAAC,QAAQ,CAAC,eAAe,EAAE,UAAU,EAAE,aAAa,EAAE,UAAU,EAAE,aAAa,CAAC,CAAC;YACzF,QAAQ,CAAC,QAAQ,CAAC,IAAI,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,SAAS,CAAC,CAAC;YAEtE,IAAI,UAAU,EAAE;gBACd,QAAQ,CAAC,UAAU,EAAE,UAAU,EAAE,aAAa,EAAE,UAAU,EAAE,aAAa,CAAC,CAAC;aAC5E;YAED,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,CAAC,EAAE;gBACtD,UAAU,CAAC,cAAc,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;aAChD;YAED,IAAI,UAAU,CAAC,gBAAgB,EAAE;gBAC/B,MAAM,CAAC,UAAU,CAAC,sBAAsB,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC;aACvE;iBAAM;gBACL,MAAM,CAAC,UAAU,CAAC,cAAc,EAAE,CAAC;aACpC;YAED,IAAI,UAAU,CAAC,aAAa,EAAE;gBAC5B,UAAU,CAAC,kBAAkB,CAAC,oBAAoB,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;aAC9E;iBAAM;gBACL,UAAU,CAAC,kBAAkB,CAAC,qBAAqB,EAAE,CAAC;aACvD;QACH,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;QAEf,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,UAAW,CAAC,CAAC;QACpC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAW,CAAC,CAAC;QAEnC,UAAW,CAAC,YAAY,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YACxC,oGAAoG;YACpG,MAAM,eAAe,GAAG,cAAc,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC;YAElG,KAAK,MAAM,KAAK,IAAI,eAAe,EAAE;gBACnC,IAAI,CAAC,KAAK;oBAAE,SAAS;gBAErB,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oBACxB,QAAQ,CAAC,eAAe,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,CAAC;iBACrD;qBAAM;oBACL,QAAQ,CAAC,eAAe,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;iBAClD;aACF;YAED,MAAM,WAAW,GAAG,cAAc,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YAE1F,KAAK,MAAM,KAAK,IAAI,WAAW,EAAE;gBAC/B,IAAI,CAAC,KAAK;oBAAE,SAAS;gBAErB,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;oBACxB,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,KAAK,CAAC,CAAC;iBAC1C;qBAAM;oBACL,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;iBACvC;aACF;QACH,CAAC,CAAC,CAAC;QAEH,UAAW,CAAC,WAAW,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YACvC,MAAM,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;YAEpD,IAAI,KAAK,KAAK,CAAC,CAAC;gBAAE,OAAO;YAEzB,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YAEnC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE;gBAC7B,IAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI,EAAE,CAAC;aAClC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,UAAW,CAAC;QAEnB,2DAA2D;IAC7D,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACzC,CAAC;IAED,cAAc,CAAC,EAAU;QACvB,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;IAChE,CAAC;IAEO,cAAc,CAAC,QAAsB;QAC3C,IAAI,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC;QAExB,OAAO,CAAC,EAAE,EAAE;YACV,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;SACrB;IACH,CAAC;IAEO,kBAAkB;QACxB,MAAM,MAAM,GAAG,IAAI,CAAC,qBAAqB,CAAC;QAC1C,OAAO,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,kBAAkB,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,0BAA0B,CAAC;IAChF,CAAC;8GArSU,cAAc;kHAAd,cAAc;;2FAAd,cAAc;kBAD1B,UAAU","sourcesContent":["import { coerceCssPixelValue } from '@angular/cdk/coercion';\nimport { Dialog as CdkDialog, DialogConfig as CdkDialogConfig } from '@angular/cdk/dialog';\nimport { ComponentType } from '@angular/cdk/overlay';\nimport { ComponentRef, Injectable, OnDestroy, TemplateRef, inject } from '@angular/core';\nimport { ViewportService, createDestroy, equal } from '@ethlete/core';\nimport { Observable, Subject, combineLatest, defer, map, of, pairwise, startWith, takeUntil, tap } from 'rxjs';\nimport { OverlayContainerComponent } from '../components';\nimport { OVERLAY_CONFIG, OVERLAY_DATA, OVERLAY_DEFAULT_OPTIONS, OVERLAY_SCROLL_STRATEGY } from '../constants';\nimport { OverlayConfig } from '../types';\nimport {\n  ET_OVERLAY_BOTTOM_SHEET_CLASS,\n  ET_OVERLAY_LEFT_SHEET_CLASS,\n  ET_OVERLAY_RIGHT_SHEET_CLASS,\n  ET_OVERLAY_TOP_SHEET_CLASS,\n  OverlayPositionBuilder,\n  OverlayRef,\n  createOverlayConfig,\n} from '../utils';\n\nlet uniqueId = 0;\nconst ID_PREFIX = 'et-overlay-';\n\nconst setStyle = (el: HTMLElement, style: string, value: string | number | null | undefined) => {\n  if (value === null || value === undefined) {\n    el.style.removeProperty(style);\n  } else {\n    el.style.setProperty(style, coerceCssPixelValue(value));\n  }\n};\n\nconst setClass = (el: HTMLElement, prevClass?: string | string[], currClass?: string | string[]) => {\n  if (!equal(prevClass, currClass)) {\n    if (prevClass) {\n      if (Array.isArray(prevClass)) {\n        el.classList.remove(...prevClass);\n      } else {\n        el.classList.remove(prevClass);\n      }\n    }\n\n    if (currClass) {\n      if (Array.isArray(currClass)) {\n        el.classList.add(...currClass);\n      } else {\n        el.classList.add(currClass);\n      }\n    }\n  }\n};\n\nconst isHtmlElement = (element: HTMLElement | unknown): element is HTMLElement => {\n  return element instanceof HTMLElement;\n};\n\nconst isTouchEvent = (event: Event): event is TouchEvent => {\n  return event.type[0] === 't';\n};\n\nconst isPointerEvent = (event: Event): event is PointerEvent => {\n  return event.type[0] === 'c';\n};\n\n@Injectable()\nexport class OverlayService implements OnDestroy {\n  private readonly _destroy$ = createDestroy();\n  private readonly _defaultOptions = inject(OVERLAY_DEFAULT_OPTIONS, { optional: true });\n  private readonly _scrollStrategy = inject(OVERLAY_SCROLL_STRATEGY);\n  private readonly _parentOverlayService = inject(OverlayService, { optional: true, skipSelf: true });\n  private readonly _dialog = inject(CdkDialog);\n  private readonly _viewportService = inject(ViewportService);\n\n  private readonly _openOverlaysAtThisLevel: OverlayRef[] = [];\n  private readonly _afterAllClosedAtThisLevel = new Subject<void>();\n  private readonly _afterOpenedAtThisLevel = new Subject<OverlayRef>();\n\n  readonly positions = new OverlayPositionBuilder();\n\n  readonly afterAllClosed = defer(() =>\n    this.openOverlays.length ? this._getAfterAllClosed() : this._getAfterAllClosed().pipe(startWith(undefined)),\n  ) as Observable<void>;\n\n  get openOverlays(): OverlayRef[] {\n    return this._parentOverlayService ? this._parentOverlayService.openOverlays : this._openOverlaysAtThisLevel;\n  }\n\n  get afterOpened(): Subject<OverlayRef> {\n    return this._parentOverlayService ? this._parentOverlayService.afterOpened : this._afterOpenedAtThisLevel;\n  }\n\n  ngOnDestroy() {\n    this._closeOverlays(this._openOverlaysAtThisLevel);\n    this._afterAllClosedAtThisLevel.complete();\n    this._afterOpenedAtThisLevel.complete();\n  }\n\n  open<T, D = unknown, R = unknown>(component: ComponentType<T>, config: OverlayConfig<D>): OverlayRef<T, R>;\n  open<T, D = unknown, R = unknown>(template: TemplateRef<T>, config: OverlayConfig<D>): OverlayRef<T, R>;\n  open<T, D = unknown, R = unknown>(\n    template: ComponentType<T> | TemplateRef<T>,\n    config: OverlayConfig<D>,\n  ): OverlayRef<T, R>;\n  open<T, D = unknown, R = unknown>(\n    componentOrTemplateRef: ComponentType<T> | TemplateRef<T>,\n    config: OverlayConfig<D>,\n  ): OverlayRef<T, R> {\n    let overlayRef: OverlayRef<T, R>;\n\n    const composedConfig = createOverlayConfig<D>(this._defaultOptions as OverlayConfig<D>, config);\n    composedConfig.id = composedConfig.id || `${ID_PREFIX}${uniqueId++}`;\n    composedConfig.scrollStrategy = composedConfig.scrollStrategy || this._scrollStrategy();\n\n    const cdkRef = this._dialog.open<R, D, T>(componentOrTemplateRef, {\n      ...composedConfig,\n      disableClose: true,\n      closeOnDestroy: false,\n      panelClass: 'et-overlay-pane',\n      container: {\n        type: OverlayContainerComponent,\n        providers: () => [\n          { provide: OVERLAY_CONFIG, useValue: composedConfig },\n          { provide: CdkDialogConfig, useValue: composedConfig },\n        ],\n      },\n      templateContext: () => ({ dialogRef: overlayRef }),\n      providers: (ref, cdkConfig, overlayContainer) => {\n        overlayRef = new OverlayRef(ref, composedConfig, overlayContainer as OverlayContainerComponent);\n\n        return [\n          { provide: OverlayContainerComponent, useValue: overlayContainer },\n          { provide: OVERLAY_DATA, useValue: cdkConfig.data },\n          { provide: OverlayRef, useValue: overlayRef },\n          ...(composedConfig.providers ?? []),\n        ];\n      },\n    });\n\n    /* eslint-disable @typescript-eslint/no-non-null-assertion*/\n    (overlayRef! as { componentRef: ComponentRef<T> }).componentRef = cdkRef.componentRef!;\n    overlayRef!.componentInstance = cdkRef.componentInstance!;\n\n    (cdkRef.containerInstance as OverlayContainerComponent).overlayRef = overlayRef!;\n\n    const containerEl = overlayRef!._containerInstance.elementRef.nativeElement as HTMLElement;\n    const overlayPaneEl = cdkRef.overlayRef.overlayElement;\n    const backdropEl = cdkRef.overlayRef.backdropElement;\n    const overlayWrapper = cdkRef.overlayRef.hostElement;\n    const defaultAnimationBuffer = 50; // 50px since the default animation uses spring physics and thus will overshoot.\n    const useDefaultAnimation = composedConfig.customAnimated !== true;\n    const origin = composedConfig.origin;\n\n    if (origin) {\n      const originX = isHtmlElement(origin)\n        ? origin.getBoundingClientRect().left\n        : isTouchEvent(origin)\n        ? origin.changedTouches[0].clientX\n        : isPointerEvent(origin)\n        ? origin.clientX !== 0\n          ? origin.clientX\n          : (origin.target as HTMLElement).getBoundingClientRect().left\n        : -1;\n      const originY = isHtmlElement(origin)\n        ? origin.getBoundingClientRect().top\n        : isTouchEvent(origin)\n        ? origin.changedTouches[0].clientY\n        : isPointerEvent(origin)\n        ? origin.clientY !== 0\n          ? origin.clientY\n          : (origin.target as HTMLElement).getBoundingClientRect().top\n        : -1;\n\n      if (originX !== -1 && originY !== -1) {\n        setStyle(containerEl, 'transform-origin', `${originX}px ${originY}px`);\n      }\n    }\n\n    combineLatest(\n      composedConfig.positions.map((breakpoint) =>\n        (breakpoint.breakpoint ? this._viewportService.observe({ min: breakpoint.breakpoint }) : of(true)).pipe(\n          map((isActive) => ({\n            isActive,\n            config: breakpoint.config,\n            size:\n              typeof breakpoint.breakpoint === 'number'\n                ? breakpoint.breakpoint\n                : breakpoint.breakpoint === undefined\n                ? 0\n                : this._viewportService.getBreakpointSize(breakpoint.breakpoint, 'min'),\n          })),\n        ),\n      ),\n    )\n      .pipe(\n        takeUntil(overlayRef!.afterClosed()),\n        takeUntil(this._destroy$),\n        map((entries) => {\n          const activeBreakpoints = entries.filter((entry) => entry.isActive);\n          const highestBreakpoint = activeBreakpoints.reduce((prev, curr) => (prev.size > curr.size ? prev : curr));\n\n          return highestBreakpoint.config;\n        }),\n        startWith(null),\n        pairwise(),\n        tap(([prevConfig, currConfig]) => {\n          if (!currConfig) return;\n\n          const containerClass = currConfig.containerClass;\n\n          const applyDefaultMaxWidths = () => {\n            setStyle(overlayPaneEl, 'max-width', currConfig.maxWidth);\n            setStyle(overlayPaneEl, 'max-height', currConfig.maxHeight);\n          };\n\n          const combineOrMakeCalc = (value: string | number | null | undefined, append: string) => {\n            if (!value) return append;\n\n            if (typeof value === 'number') {\n              return `calc(${value}px + ${append})`;\n            } else if (value.startsWith('calc(')) {\n              return `${value.slice(0, value.length - 1)} + ${append})`;\n            }\n\n            return `calc(${value} + ${append})`;\n          };\n\n          if (useDefaultAnimation && containerClass?.length) {\n            if (\n              containerClass?.includes(ET_OVERLAY_LEFT_SHEET_CLASS) ||\n              containerClass?.includes(ET_OVERLAY_RIGHT_SHEET_CLASS)\n            ) {\n              setStyle(\n                overlayPaneEl,\n                'max-width',\n                combineOrMakeCalc(currConfig.maxWidth, `${defaultAnimationBuffer}px`),\n              );\n              setStyle(overlayPaneEl, 'max-height', currConfig.maxHeight);\n            } else if (\n              containerClass?.includes(ET_OVERLAY_TOP_SHEET_CLASS) ||\n              containerClass?.includes(ET_OVERLAY_BOTTOM_SHEET_CLASS)\n            ) {\n              setStyle(\n                overlayPaneEl,\n                'max-height',\n                combineOrMakeCalc(currConfig.maxHeight, `${defaultAnimationBuffer}px`),\n              );\n\n              setStyle(overlayPaneEl, 'max-width', currConfig.maxWidth);\n            } else {\n              applyDefaultMaxWidths();\n            }\n          } else {\n            applyDefaultMaxWidths();\n          }\n\n          setStyle(overlayPaneEl, 'min-width', currConfig.minWidth);\n          setStyle(overlayPaneEl, 'min-height', currConfig.minHeight);\n\n          setStyle(overlayPaneEl, 'width', currConfig.width);\n          setStyle(overlayPaneEl, 'height', currConfig.height);\n\n          setClass(containerEl, prevConfig?.containerClass, currConfig?.containerClass);\n          setClass(overlayPaneEl, prevConfig?.paneClass, currConfig?.paneClass);\n          setClass(overlayWrapper, prevConfig?.overlayClass, currConfig?.overlayClass);\n\n          // FIXME: These classes should only be removed if no open overlays require them inside their config.\n          setClass(document.documentElement, prevConfig?.documentClass, currConfig?.documentClass);\n          setClass(document.body, prevConfig?.bodyClass, currConfig?.bodyClass);\n\n          if (backdropEl) {\n            setClass(backdropEl, prevConfig?.backdropClass, currConfig?.backdropClass);\n          }\n\n          if (!equal(prevConfig?.position, currConfig?.position)) {\n            overlayRef.updatePosition(currConfig.position);\n          }\n\n          if (currConfig.positionStrategy) {\n            cdkRef.overlayRef.updatePositionStrategy(currConfig.positionStrategy);\n          } else {\n            cdkRef.overlayRef.updatePosition();\n          }\n\n          if (currConfig.dragToDismiss) {\n            overlayRef._containerInstance._enableDragToDismiss(currConfig.dragToDismiss);\n          } else {\n            overlayRef._containerInstance._disableDragToDismiss();\n          }\n        }),\n      )\n      .subscribe();\n\n    this.openOverlays.push(overlayRef!);\n    this.afterOpened.next(overlayRef!);\n\n    overlayRef!.beforeClosed().subscribe(() => {\n      // FIXME: These classes should only be removed if no open overlays require them inside their config.\n      const documentClasses = composedConfig.positions.map((position) => position.config.documentClass);\n\n      for (const klass of documentClasses) {\n        if (!klass) continue;\n\n        if (Array.isArray(klass)) {\n          document.documentElement.classList.remove(...klass);\n        } else {\n          document.documentElement.classList.remove(klass);\n        }\n      }\n\n      const bodyClasses = composedConfig.positions.map((position) => position.config.bodyClass);\n\n      for (const klass of bodyClasses) {\n        if (!klass) continue;\n\n        if (Array.isArray(klass)) {\n          document.body.classList.remove(...klass);\n        } else {\n          document.body.classList.remove(klass);\n        }\n      }\n    });\n\n    overlayRef!.afterClosed().subscribe(() => {\n      const index = this.openOverlays.indexOf(overlayRef);\n\n      if (index === -1) return;\n\n      this.openOverlays.splice(index, 1);\n\n      if (!this.openOverlays.length) {\n        this._getAfterAllClosed().next();\n      }\n    });\n\n    return overlayRef!;\n\n    /* eslint-enable @typescript-eslint/no-non-null-assertion*/\n  }\n\n  closeAll(): void {\n    this._closeOverlays(this.openOverlays);\n  }\n\n  getOverlayById(id: string): OverlayRef | undefined {\n    return this.openOverlays.find((overlay) => overlay.id === id);\n  }\n\n  private _closeOverlays(overlays: OverlayRef[]) {\n    let i = overlays.length;\n\n    while (i--) {\n      overlays[i].close();\n    }\n  }\n\n  private _getAfterAllClosed(): Subject<void> {\n    const parent = this._parentOverlayService;\n    return parent ? parent._getAfterAllClosed() : this._afterAllClosedAtThisLevel;\n  }\n}\n"]}
|
|
@@ -3,4 +3,4 @@ export const OVERLAY_STATE = {
|
|
|
3
3
|
CLOSING: 'closing',
|
|
4
4
|
CLOSED: 'closed',
|
|
5
5
|
};
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay.types.js","sourceRoot":"","sources":["../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/overlay/types/overlay.types.ts"],"names":[],"mappings":"AA0BA,MAAM,CAAC,MAAM,aAAa,GAAG;IAC3B,IAAI,EAAE,MAAM;IACZ,OAAO,EAAE,SAAS;IAClB,MAAM,EAAE,QAAQ;CACR,CAAC","sourcesContent":["import { Direction } from '@angular/cdk/bidi';\nimport { PositionStrategy, ScrollStrategy } from '@angular/cdk/overlay';\nimport { Injector, StaticProvider, ViewContainerRef } from '@angular/core';\nimport { Breakpoint } from '@ethlete/core';\n\n/** Options for where to set focus to automatically on overlay open */\nexport type OverlayAutoFocusTarget = 'dialog' | 'first-tabbable' | 'first-heading';\n\n/** Valid ARIA roles for a overlay element. */\nexport type OverlayRole = 'dialog' | 'alertdialog';\n\n/** Possible overrides for a overlay's position. */\nexport interface OverlayPosition {\n  /** Override for the overlay's top position. */\n  top?: string;\n\n  /** Override for the overlay's bottom position. */\n  bottom?: string;\n\n  /** Override for the overlay's left position. */\n  left?: string;\n\n  /** Override for the overlay's right position. */\n  right?: string;\n}\n\nexport const OVERLAY_STATE = {\n  OPEN: 'open',\n  CLOSING: 'closing',\n  CLOSED: 'closed',\n} as const;\n\nexport type OverlayState = (typeof OVERLAY_STATE)[keyof typeof OVERLAY_STATE];\n\nexport interface OverlayDragToDismissConfig {\n  /** Direction in which the overlay can be dragged. */\n  direction: 'to-top' | 'to-bottom' | 'to-left' | 'to-right';\n\n  /**\n   * The minimum distance in pixels that the user must swipe to dismiss the overlay.\n   *\n   * @default 150 // 150px\n   */\n  minDistanceToDismiss?: number;\n\n  /**\n   * The minimum velocity in pixels per second that the user must swipe to dismiss the overlay.\n   *\n   * @default 150 // 150px/s\n   */\n  minVelocityToDismiss?: number;\n}\n\nexport interface OverlayBreakpointConfig {\n  /** Min-width of the overlay. If a number is provided, assumes pixel units. */\n  minWidth?: number | string;\n\n  /** Max-width of the overlay. If a number is provided, assumes pixel units. */\n  maxWidth?: number | string;\n\n  /** Min-height of the overlay. If a number is provided, assumes pixel units. */\n  minHeight?: number | string;\n\n  /** Max-height of the overlay. If a number is provided, assumes pixel units. */\n  maxHeight?: number | string;\n\n  /** Width of the overlay. */\n  width?: number | string;\n\n  /** Height of the overlay. */\n  height?: number | string;\n\n  /** Position strategy to be used for the overlay. */\n  positionStrategy?: PositionStrategy;\n\n  /** Custom class for the overlay container. */\n  containerClass?: string | string[];\n\n  /** Custom class for the overlay pane. */\n  paneClass?: string | string[];\n\n  /** Extra CSS classes to be added to the overlay overlay container. */\n  overlayClass?: string | string[];\n\n  /** Custom class for the backdrop. */\n  backdropClass?: string | string[];\n\n  /** Custom class for the document (`<html>` element). */\n  documentClass?: string | string[];\n\n  /** Custom class for the `<body>` element */\n  bodyClass?: string | string[];\n\n  /** Position overrides. */\n  position?: OverlayPosition;\n\n  /** Determine if and in what direction the overlay should be able to be dragged to dismiss it. */\n  dragToDismiss?: OverlayDragToDismissConfig;\n}\n\nexport interface OverlayBreakpointConfigEntry {\n  /**\n   * Breakpoint to apply the config for. If a number is provided, it will be used as a pixel value.\n   * Always uses the min-width media query.\n   *\n   * @default 'xs' // 0px\n   */\n  breakpoint?: Breakpoint | number;\n\n  /**\n   * Overlay configuration to be applied when the breakpoint is active.\n   */\n  config: OverlayBreakpointConfig;\n}\n\nexport interface OverlayConfig<D = unknown> {\n  /**\n   * Conditionally applied overlay configurations based on breakpoints.\n   */\n  positions: OverlayBreakpointConfigEntry[];\n\n  /**\n   * Where the attached component should live in Angular's *logical* component tree.\n   * This affects what is available for injection and the change detection order for the\n   * component instantiated inside of the overlay. This does not affect where the overlay\n   * content will be rendered.\n   */\n  viewContainerRef?: ViewContainerRef;\n\n  /**\n   * Injector used for the instantiation of the component to be attached. If provided,\n   * takes precedence over the injector indirectly provided by `ViewContainerRef`.\n   */\n  injector?: Injector;\n\n  /** ID for the overlay. If omitted, a unique one will be generated. */\n  id?: string;\n\n  /**\n   * The ARIA role of the overlay element.\n   * @default 'dialog'\n   */\n  role?: OverlayRole;\n\n  /**\n   * Whether the overlay has a backdrop.\n   * @default true\n   */\n  hasBackdrop?: boolean;\n\n  /**\n   * Whether the user can use escape or clicking on the backdrop to close the modal.\n   * @default false\n   */\n  disableClose?: boolean;\n\n  /**\n   * Data being injected into the child component.\n   * @default null\n   */\n  data?: D | null;\n\n  /** Layout direction for the overlay's content. */\n  direction?: Direction;\n\n  /**\n   * ID of the element that describes the overlay.\n   * @default null\n   */\n  ariaDescribedBy?: string | null;\n\n  /**\n   * ID of the element that labels the overlay.\n   * @default null\n   */\n  ariaLabelledBy?: string | null;\n\n  /**\n   * Aria label to assign to the overlay element.\n   * @default null\n   */\n  ariaLabel?: string | null;\n\n  /**\n   * Whether this is a modal overlay. Used to set the `aria-modal` attribute.\n   * @default true\n   */\n  ariaModal?: boolean;\n\n  /**\n   * Whether the overlay uses a custom animation.\n   * @default false\n   */\n  customAnimated?: boolean;\n\n  /**\n   * Where the overlay should focus on open.\n   * Can be one of AutoFocusTarget, or a css selector string.\n   * @default 'first-tabbable'\n   */\n  autoFocus?: OverlayAutoFocusTarget | string;\n\n  /**\n   * Whether the overlay should restore focus to the\n   * previously-focused element, after it's closed.\n   * @default true\n   */\n  restoreFocus?: boolean;\n\n  /**\n   * Whether to wait for the opening animation to finish before trapping focus.\n   * @default true\n   */\n  delayFocusTrap?: boolean;\n\n  /** Scroll strategy to be used for the overlay. */\n  scrollStrategy?: ScrollStrategy;\n\n  /**\n   * Whether the overlay should close when the user goes backwards/forwards in history.\n   * Note that this usually doesn't include clicking on links (unless the user is using\n   * the `HashLocationStrategy`).\n   * @default true\n   */\n  closeOnNavigation?: boolean;\n\n  /**\n   * Extra providers to be made available to the overlay.\n   */\n  providers?: StaticProvider[];\n\n  /**\n   * The origin element that triggered the overlay's opening.\n   */\n  origin?: HTMLElement | MouseEvent | TouchEvent | KeyboardEvent | PointerEvent;\n}\n"]}
|
package/esm2022/lib/components/overlay/components/overlay/utils/overlay-position-builder.mjs
CHANGED
|
@@ -1,5 +1,11 @@
|
|
|
1
1
|
import { Overlay } from '@angular/cdk/overlay';
|
|
2
2
|
import { inject } from '@angular/core';
|
|
3
|
+
export const ET_OVERLAY_LEFT_SHEET_CLASS = 'et-overlay--left-sheet';
|
|
4
|
+
export const ET_OVERLAY_RIGHT_SHEET_CLASS = 'et-overlay--right-sheet';
|
|
5
|
+
export const ET_OVERLAY_TOP_SHEET_CLASS = 'et-overlay--top-sheet';
|
|
6
|
+
export const ET_OVERLAY_BOTTOM_SHEET_CLASS = 'et-overlay--bottom-sheet';
|
|
7
|
+
export const ET_OVERLAY_DIALOG_CLASS = 'et-overlay--dialog';
|
|
8
|
+
export const ET_OVERLAY_FULL_SCREEN_DIALOG_CLASS = 'et-overlay--full-screen-dialog';
|
|
3
9
|
export class OverlayPositionBuilder {
|
|
4
10
|
constructor() {
|
|
5
11
|
this._overlay = inject(Overlay);
|
|
@@ -11,7 +17,7 @@ export class OverlayPositionBuilder {
|
|
|
11
17
|
maxWidth: '80vw',
|
|
12
18
|
minHeight: undefined,
|
|
13
19
|
minWidth: undefined,
|
|
14
|
-
containerClass:
|
|
20
|
+
containerClass: ET_OVERLAY_DIALOG_CLASS,
|
|
15
21
|
positionStrategy: this._overlay.position().global().centerHorizontally().centerVertically(),
|
|
16
22
|
},
|
|
17
23
|
fullScreenDialog: {
|
|
@@ -21,8 +27,9 @@ export class OverlayPositionBuilder {
|
|
|
21
27
|
maxWidth: undefined,
|
|
22
28
|
minHeight: undefined,
|
|
23
29
|
minWidth: undefined,
|
|
24
|
-
containerClass:
|
|
30
|
+
containerClass: ET_OVERLAY_FULL_SCREEN_DIALOG_CLASS,
|
|
25
31
|
positionStrategy: this._overlay.position().global().left('0').top('0').bottom('0').right('0'),
|
|
32
|
+
documentClass: 'et-overlay--full-screen-dialog-document',
|
|
26
33
|
},
|
|
27
34
|
bottomSheet: {
|
|
28
35
|
width: '100%',
|
|
@@ -31,7 +38,7 @@ export class OverlayPositionBuilder {
|
|
|
31
38
|
maxWidth: '640px',
|
|
32
39
|
minHeight: undefined,
|
|
33
40
|
minWidth: undefined,
|
|
34
|
-
containerClass:
|
|
41
|
+
containerClass: ET_OVERLAY_BOTTOM_SHEET_CLASS,
|
|
35
42
|
positionStrategy: this._overlay.position().global().centerHorizontally().bottom('0'),
|
|
36
43
|
dragToDismiss: {
|
|
37
44
|
direction: 'to-bottom',
|
|
@@ -44,7 +51,7 @@ export class OverlayPositionBuilder {
|
|
|
44
51
|
maxWidth: '640px',
|
|
45
52
|
minHeight: undefined,
|
|
46
53
|
minWidth: undefined,
|
|
47
|
-
containerClass:
|
|
54
|
+
containerClass: ET_OVERLAY_TOP_SHEET_CLASS,
|
|
48
55
|
positionStrategy: this._overlay.position().global().centerHorizontally().top('0'),
|
|
49
56
|
dragToDismiss: {
|
|
50
57
|
direction: 'to-top',
|
|
@@ -57,7 +64,7 @@ export class OverlayPositionBuilder {
|
|
|
57
64
|
maxWidth: '640px',
|
|
58
65
|
minHeight: undefined,
|
|
59
66
|
minWidth: undefined,
|
|
60
|
-
containerClass:
|
|
67
|
+
containerClass: ET_OVERLAY_LEFT_SHEET_CLASS,
|
|
61
68
|
positionStrategy: this._overlay.position().global().left('0').centerVertically(),
|
|
62
69
|
dragToDismiss: {
|
|
63
70
|
direction: 'to-left',
|
|
@@ -70,7 +77,7 @@ export class OverlayPositionBuilder {
|
|
|
70
77
|
maxWidth: '640px',
|
|
71
78
|
minHeight: undefined,
|
|
72
79
|
minWidth: undefined,
|
|
73
|
-
containerClass:
|
|
80
|
+
containerClass: ET_OVERLAY_RIGHT_SHEET_CLASS,
|
|
74
81
|
positionStrategy: this._overlay.position().global().right('0').centerVertically(),
|
|
75
82
|
dragToDismiss: {
|
|
76
83
|
direction: 'to-right',
|
|
@@ -90,6 +97,18 @@ export class OverlayPositionBuilder {
|
|
|
90
97
|
];
|
|
91
98
|
return data;
|
|
92
99
|
}
|
|
100
|
+
transformingFullScreenDialogToRightSheet(customConfig) {
|
|
101
|
+
const data = [
|
|
102
|
+
{
|
|
103
|
+
config: this.mergeConfigs(this.DEFAULTS.fullScreenDialog, customConfig?.fullScreenDialog ?? {}),
|
|
104
|
+
},
|
|
105
|
+
{
|
|
106
|
+
breakpoint: 'md',
|
|
107
|
+
config: this.mergeConfigs(this.DEFAULTS.rightSheet, customConfig?.rightSheet ?? {}),
|
|
108
|
+
},
|
|
109
|
+
];
|
|
110
|
+
return data;
|
|
111
|
+
}
|
|
93
112
|
dialog(customConfig) {
|
|
94
113
|
const data = [
|
|
95
114
|
{
|
|
@@ -148,4 +167,4 @@ export class OverlayPositionBuilder {
|
|
|
148
167
|
return config;
|
|
149
168
|
}
|
|
150
169
|
}
|
|
151
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay-position-builder.js","sourceRoot":"","sources":["../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/overlay/utils/overlay-position-builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay } from '@angular/cdk/overlay';\nimport { inject } from '@angular/core';\nimport { OverlayBreakpointConfig, OverlayBreakpointConfigEntry } from '../types';\n\nexport class OverlayPositionBuilder {\n  private readonly _overlay = inject(Overlay);\n\n  readonly DEFAULTS = {\n    dialog: {\n      width: undefined,\n      height: undefined,\n      maxHeight: '80vh',\n      maxWidth: '80vw',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: 'et-overlay--dialog',\n      positionStrategy: this._overlay.position().global().centerHorizontally().centerVertically(),\n    },\n    fullScreenDialog: {\n      width: '100%',\n      height: '100%',\n      maxHeight: undefined,\n      maxWidth: undefined,\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: 'et-overlay--full-screen-dialog',\n      positionStrategy: this._overlay.position().global().left('0').top('0').bottom('0').right('0'),\n    },\n    bottomSheet: {\n      width: '100%',\n      height: undefined,\n      maxHeight: 'calc(100% - 72px)',\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: 'et-overlay--bottom-sheet',\n      positionStrategy: this._overlay.position().global().centerHorizontally().bottom('0'),\n      dragToDismiss: {\n        direction: 'to-bottom',\n      },\n    },\n    topSheet: {\n      width: '100%',\n      height: undefined,\n      maxHeight: 'calc(100% - 72px)',\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: 'et-overlay--top-sheet',\n      positionStrategy: this._overlay.position().global().centerHorizontally().top('0'),\n      dragToDismiss: {\n        direction: 'to-top',\n      },\n    },\n    leftSheet: {\n      width: '100%',\n      height: '100%',\n      maxHeight: undefined,\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: 'et-overlay--left-sheet',\n      positionStrategy: this._overlay.position().global().left('0').centerVertically(),\n      dragToDismiss: {\n        direction: 'to-left',\n      },\n    },\n    rightSheet: {\n      width: '100%',\n      height: '100%',\n      maxHeight: undefined,\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: 'et-overlay--right-sheet',\n      positionStrategy: this._overlay.position().global().right('0').centerVertically(),\n      dragToDismiss: {\n        direction: 'to-right',\n      },\n    },\n  } satisfies Record<string, OverlayBreakpointConfig>;\n\n  transformingBottomSheetToDialog(customConfig?: {\n    bottomSheet?: OverlayBreakpointConfig;\n    dialog?: OverlayBreakpointConfig;\n  }) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.bottomSheet, customConfig?.bottomSheet ?? {}),\n      },\n      {\n        breakpoint: 'md',\n        config: this.mergeConfigs(this.DEFAULTS.dialog, customConfig?.dialog ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  dialog(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.dialog, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  fullScreenDialog(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.fullScreenDialog, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  bottomSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.bottomSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  topSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.topSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  leftSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.leftSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  rightSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.rightSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  mergeConfigs(...configs: OverlayBreakpointConfig[]) {\n    const config = configs.reduce((acc, curr) => {\n      return {\n        ...acc,\n        ...curr,\n      };\n    }, {} as OverlayBreakpointConfig);\n\n    return config;\n  }\n}\n"]}
|
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay-position-builder.js","sourceRoot":"","sources":["../../../../../../../../../../libs/cdk/src/lib/components/overlay/components/overlay/utils/overlay-position-builder.ts"],"names":[],"mappings":"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","sourcesContent":["import { Overlay } from '@angular/cdk/overlay';\nimport { inject } from '@angular/core';\nimport { OverlayBreakpointConfig, OverlayBreakpointConfigEntry } from '../types';\n\nexport const ET_OVERLAY_LEFT_SHEET_CLASS = 'et-overlay--left-sheet';\nexport const ET_OVERLAY_RIGHT_SHEET_CLASS = 'et-overlay--right-sheet';\nexport const ET_OVERLAY_TOP_SHEET_CLASS = 'et-overlay--top-sheet';\nexport const ET_OVERLAY_BOTTOM_SHEET_CLASS = 'et-overlay--bottom-sheet';\nexport const ET_OVERLAY_DIALOG_CLASS = 'et-overlay--dialog';\nexport const ET_OVERLAY_FULL_SCREEN_DIALOG_CLASS = 'et-overlay--full-screen-dialog';\n\nexport class OverlayPositionBuilder {\n  private readonly _overlay = inject(Overlay);\n\n  readonly DEFAULTS = {\n    dialog: {\n      width: undefined,\n      height: undefined,\n      maxHeight: '80vh',\n      maxWidth: '80vw',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: ET_OVERLAY_DIALOG_CLASS,\n      positionStrategy: this._overlay.position().global().centerHorizontally().centerVertically(),\n    },\n    fullScreenDialog: {\n      width: '100%',\n      height: '100%',\n      maxHeight: undefined,\n      maxWidth: undefined,\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: ET_OVERLAY_FULL_SCREEN_DIALOG_CLASS,\n      positionStrategy: this._overlay.position().global().left('0').top('0').bottom('0').right('0'),\n      documentClass: 'et-overlay--full-screen-dialog-document',\n    },\n    bottomSheet: {\n      width: '100%',\n      height: undefined,\n      maxHeight: 'calc(100% - 72px)',\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: ET_OVERLAY_BOTTOM_SHEET_CLASS,\n      positionStrategy: this._overlay.position().global().centerHorizontally().bottom('0'),\n      dragToDismiss: {\n        direction: 'to-bottom',\n      },\n    },\n    topSheet: {\n      width: '100%',\n      height: undefined,\n      maxHeight: 'calc(100% - 72px)',\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: ET_OVERLAY_TOP_SHEET_CLASS,\n      positionStrategy: this._overlay.position().global().centerHorizontally().top('0'),\n      dragToDismiss: {\n        direction: 'to-top',\n      },\n    },\n    leftSheet: {\n      width: '100%',\n      height: '100%',\n      maxHeight: undefined,\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: ET_OVERLAY_LEFT_SHEET_CLASS,\n      positionStrategy: this._overlay.position().global().left('0').centerVertically(),\n      dragToDismiss: {\n        direction: 'to-left',\n      },\n    },\n    rightSheet: {\n      width: '100%',\n      height: '100%',\n      maxHeight: undefined,\n      maxWidth: '640px',\n      minHeight: undefined,\n      minWidth: undefined,\n      containerClass: ET_OVERLAY_RIGHT_SHEET_CLASS,\n      positionStrategy: this._overlay.position().global().right('0').centerVertically(),\n      dragToDismiss: {\n        direction: 'to-right',\n      },\n    },\n  } satisfies Record<string, OverlayBreakpointConfig>;\n\n  transformingBottomSheetToDialog(customConfig?: {\n    bottomSheet?: OverlayBreakpointConfig;\n    dialog?: OverlayBreakpointConfig;\n  }) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.bottomSheet, customConfig?.bottomSheet ?? {}),\n      },\n      {\n        breakpoint: 'md',\n        config: this.mergeConfigs(this.DEFAULTS.dialog, customConfig?.dialog ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  transformingFullScreenDialogToRightSheet(customConfig?: {\n    fullScreenDialog?: OverlayBreakpointConfig;\n    rightSheet?: OverlayBreakpointConfig;\n  }) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.fullScreenDialog, customConfig?.fullScreenDialog ?? {}),\n      },\n      {\n        breakpoint: 'md',\n        config: this.mergeConfigs(this.DEFAULTS.rightSheet, customConfig?.rightSheet ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  dialog(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.dialog, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  fullScreenDialog(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.fullScreenDialog, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  bottomSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.bottomSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  topSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.topSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  leftSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.leftSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  rightSheet(customConfig?: OverlayBreakpointConfig) {\n    const data: OverlayBreakpointConfigEntry[] = [\n      {\n        config: this.mergeConfigs(this.DEFAULTS.rightSheet, customConfig ?? {}),\n      },\n    ];\n\n    return data;\n  }\n\n  mergeConfigs(...configs: OverlayBreakpointConfig[]) {\n    const config = configs.reduce((acc, curr) => {\n      return {\n        ...acc,\n        ...curr,\n      };\n    }, {} as OverlayBreakpointConfig);\n\n    return config;\n  }\n}\n"]}
|