@ethlete/cdk 4.2.0 → 4.2.2
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 +6 -7
- 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 +9 -18
- 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 +7 -7
- package/esm2022/lib/components/bracket/partials/bracket-round-header/bracket-round-header.component.mjs +7 -7
- package/esm2022/lib/components/button/components/button/button.component.mjs +3 -3
- package/esm2022/lib/components/button/components/query-button/query-button.component.mjs +7 -7
- 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/filter-overlay/components/filter-overlay-page-outlet/filter-overlay-page-outlet.component.mjs +11 -11
- package/esm2022/lib/components/filter/filter-overlay/directives/filter-overlay-back-or-close/filter-overlay-back-or-close.directive.mjs +3 -3
- package/esm2022/lib/components/filter/filter-overlay/directives/filter-overlay-link/filter-overlay-link.directive.mjs +3 -3
- package/esm2022/lib/components/filter/filter-overlay/directives/filter-overlay-reset/filter-overlay-reset.directive.mjs +3 -3
- package/esm2022/lib/components/filter/filter-overlay/directives/filter-overlay-submit/filter-overlay-submit.directive.mjs +3 -3
- package/esm2022/lib/components/filter/filter-overlay/services/filter-overlay.service.mjs +3 -3
- package/esm2022/lib/components/filter/rich-filter/components/rich-filter-host/rich-filter-host.component.mjs +3 -3
- package/esm2022/lib/components/filter/rich-filter/directives/rich-filter-button/rich-filter-button.directive.mjs +3 -3
- package/esm2022/lib/components/filter/rich-filter/directives/rich-filter-button-slot/rich-filter-button-slot.directive.mjs +3 -3
- package/esm2022/lib/components/filter/rich-filter/directives/rich-filter-content/rich-filter-content.directive.mjs +3 -3
- package/esm2022/lib/components/filter/rich-filter/directives/rich-filter-top/rich-filter-top.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/components/checkbox/checkbox.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/components/checkbox-field/checkbox-field.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/components/checkbox-group/checkbox-group.component.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/directives/checkbox/checkbox.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-field/checkbox-field.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-group/checkbox-group.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/checkbox/directives/checkbox-group-control/checkbox-group-control.directive.mjs +3 -3
- package/esm2022/lib/components/forms/components/error/components/error/error.component.mjs +6 -6
- 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 +6 -6
- 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 +5 -5
- 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 -8
- 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 +7 -9
- package/esm2022/lib/components/forms/components/select/components/combobox/partials/combobox-option/combobox-option.component.mjs +8 -8
- package/esm2022/lib/components/forms/components/select/components/native-select/components/native-select/native-select.component.mjs +6 -6
- 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 +6 -6
- 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 +6 -6
- 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 +4 -5
- package/esm2022/lib/components/forms/components/selection-list/components/selection-list-option/selection-list-option.component.mjs +5 -5
- 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 +6 -6
- package/esm2022/lib/components/forms/components/slider/components/slider-field/slider-field.component.mjs +6 -6
- 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 +3 -3
- package/esm2022/lib/components/overlay/components/overlay/partials/overlay-close/overlay-close.directive.mjs +3 -3
- 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 +4 -4
- package/esm2022/lib/components/overlay/components/toggletip/components/toggletip/toggletip.component.mjs +8 -8
- 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 +8 -8
- package/esm2022/lib/components/overlay/components/tooltip/directives/tooltip/tooltip.directive.mjs +4 -4
- package/esm2022/lib/components/overlay/directives/dynamic-overlay-title/dynamic-overlay-title.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/directives/overlay-close-auto-blocker/overlay-close-auto-blocker.directive.mjs +3 -3
- package/esm2022/lib/components/overlay/services/dynamic-overlay.service.mjs +3 -3
- package/esm2022/lib/components/pagination/components/pagination/pagination.component.mjs +7 -7
- package/esm2022/lib/components/pagination/partials/pagination-link/pagination-link.directive.mjs +3 -3
- package/esm2022/lib/components/pagination/services/pagination-head.service.mjs +4 -4
- package/esm2022/lib/components/pagination/utils/pagination.util.mjs +1 -1
- package/esm2022/lib/components/picture/picture-data.directive.mjs +3 -3
- package/esm2022/lib/components/picture/picture.component.mjs +8 -8
- package/esm2022/lib/components/picture/pipes/normalize-source/normalize-source.pipe.mjs +3 -3
- package/esm2022/lib/components/progress-spinner/progress-spinner.component.mjs +6 -6
- package/esm2022/lib/components/query-error/components/query-error/query-error.component.mjs +5 -6
- 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 +219 -146
- 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 +5 -6
- 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 +7 -9
- 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 +21 -13
- package/esm2022/lib/services/swipe-handler.service.mjs +3 -3
- package/fesm2022/ethlete-cdk.mjs +898 -834
- package/fesm2022/ethlete-cdk.mjs.map +1 -1
- package/lib/components/picture/picture.component.d.ts +1 -1
- package/lib/components/scrollable/components/scrollable/scrollable.component.d.ts +55 -35
- package/lib/components/tabs/utils/paginated-tab-header.directive.d.ts +1 -1
- package/package.json +7 -7
|
@@ -1,18 +1,63 @@
|
|
|
1
|
-
import { NgClass
|
|
2
|
-
import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter,
|
|
3
|
-
import { CursorDragScrollDirective, IS_ACTIVE_ELEMENT, IS_ELEMENT, LetDirective, ObserveScrollStateDirective, TypedQueryList, createDestroy, getElementVisibleStates, scrollToElement, signalElementIntersection, signalElementScrollState, signalHostAttributes, } from '@ethlete/core';
|
|
1
|
+
import { NgClass } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, ContentChildren, ElementRef, EventEmitter, Input, Output, ViewChild, ViewEncapsulation, booleanAttribute, computed, effect, inject, isDevMode, numberAttribute, signal, } from '@angular/core';
|
|
3
|
+
import { CursorDragScrollDirective, IS_ACTIVE_ELEMENT, IS_ELEMENT, LetDirective, ObserveScrollStateDirective, TypedQueryList, createDestroy, getElementVisibleStates, isElementVisible, nextFrame, scrollToElement, signalElementIntersection, signalElementScrollState, signalHostAttributes, signalHostClasses, } from '@ethlete/core';
|
|
4
4
|
import { BehaviorSubject, debounceTime, fromEvent, merge, of, startWith, takeUntil, tap } from 'rxjs';
|
|
5
5
|
import { ChevronIconComponent } from '../../../icons';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
export class ScrollableComponent {
|
|
8
|
-
set
|
|
9
|
-
this.
|
|
8
|
+
set _itemSize(v) {
|
|
9
|
+
this.itemSize.set(v);
|
|
10
10
|
}
|
|
11
|
-
set
|
|
12
|
-
this.
|
|
11
|
+
set _direction(v) {
|
|
12
|
+
this.direction.set(v);
|
|
13
13
|
}
|
|
14
|
-
set
|
|
15
|
-
this.
|
|
14
|
+
set _scrollableRole(v) {
|
|
15
|
+
this.scrollableRole.set(v);
|
|
16
|
+
}
|
|
17
|
+
set _scrollableClass(v) {
|
|
18
|
+
this.scrollableClass.set(v);
|
|
19
|
+
}
|
|
20
|
+
set _renderMasks(v) {
|
|
21
|
+
this.renderMasks.set(v);
|
|
22
|
+
}
|
|
23
|
+
set _renderButtons(v) {
|
|
24
|
+
this.renderButtons.set(v);
|
|
25
|
+
}
|
|
26
|
+
set _renderScrollbars(v) {
|
|
27
|
+
this.renderScrollbars.set(v);
|
|
28
|
+
}
|
|
29
|
+
set _stickyButtons(v) {
|
|
30
|
+
this.stickyButtons.set(v);
|
|
31
|
+
}
|
|
32
|
+
set _cursorDragScroll(v) {
|
|
33
|
+
this.cursorDragScroll.set(v);
|
|
34
|
+
}
|
|
35
|
+
set _disableActiveElementScrolling(v) {
|
|
36
|
+
this.disableActiveElementScrolling.set(v);
|
|
37
|
+
}
|
|
38
|
+
set _scrollMode(v) {
|
|
39
|
+
this.scrollMode.set(v);
|
|
40
|
+
}
|
|
41
|
+
set _snap(v) {
|
|
42
|
+
this.snap.set(v);
|
|
43
|
+
}
|
|
44
|
+
set _scrollMargin(v) {
|
|
45
|
+
this.scrollMargin.set(v);
|
|
46
|
+
}
|
|
47
|
+
set _scrollable(e) {
|
|
48
|
+
this.scrollable.set(e);
|
|
49
|
+
}
|
|
50
|
+
set _firstElement(e) {
|
|
51
|
+
this.firstElement.set(e);
|
|
52
|
+
}
|
|
53
|
+
set _lastElement(e) {
|
|
54
|
+
this.lastElement.set(e);
|
|
55
|
+
}
|
|
56
|
+
set _activeElementList(e) {
|
|
57
|
+
this.activeElementList.set(e);
|
|
58
|
+
}
|
|
59
|
+
set _elementList(e) {
|
|
60
|
+
this.elementList.set(e);
|
|
16
61
|
}
|
|
17
62
|
get highestVisibleIntersection() {
|
|
18
63
|
const elements = this._latestVisibilityStates$.value;
|
|
@@ -66,87 +111,121 @@ export class ScrollableComponent {
|
|
|
66
111
|
this._elementRef = inject(ElementRef);
|
|
67
112
|
this._isCursorDragging$ = new BehaviorSubject(false);
|
|
68
113
|
this._latestVisibilityStates$ = new BehaviorSubject([]);
|
|
69
|
-
this.itemSize = 'auto';
|
|
70
|
-
this.direction = 'horizontal';
|
|
71
|
-
this.
|
|
72
|
-
this.
|
|
73
|
-
this.
|
|
74
|
-
this.
|
|
75
|
-
this.
|
|
76
|
-
this.
|
|
77
|
-
this.
|
|
78
|
-
this.
|
|
79
|
-
this.
|
|
114
|
+
this.itemSize = signal('auto');
|
|
115
|
+
this.direction = signal('horizontal');
|
|
116
|
+
this.scrollableRole = signal(null);
|
|
117
|
+
this.scrollableClass = signal(null);
|
|
118
|
+
this.renderMasks = signal(true);
|
|
119
|
+
this.renderButtons = signal(true);
|
|
120
|
+
this.renderScrollbars = signal(false);
|
|
121
|
+
this.stickyButtons = signal(false);
|
|
122
|
+
this.cursorDragScroll = signal(true);
|
|
123
|
+
this.disableActiveElementScrolling = signal(false);
|
|
124
|
+
this.scrollMode = signal('container');
|
|
125
|
+
this.snap = signal(false);
|
|
126
|
+
this.scrollMargin = signal(0);
|
|
80
127
|
this.scrollStateChange = new EventEmitter();
|
|
81
128
|
this.intersectionChange = new EventEmitter();
|
|
82
|
-
this.
|
|
83
|
-
this.
|
|
84
|
-
this.
|
|
85
|
-
this.
|
|
86
|
-
this.
|
|
87
|
-
this.containerScrollState = signalElementScrollState(this.
|
|
88
|
-
this.firstElementIntersection = signalElementIntersection(this.
|
|
89
|
-
this.
|
|
90
|
-
this.
|
|
129
|
+
this.scrollable = signal(null);
|
|
130
|
+
this.firstElement = signal(null);
|
|
131
|
+
this.lastElement = signal(null);
|
|
132
|
+
this.activeElementList = signal(null);
|
|
133
|
+
this.elementList = signal(null);
|
|
134
|
+
this.containerScrollState = signalElementScrollState(this.scrollable);
|
|
135
|
+
this.firstElementIntersection = signalElementIntersection(this.firstElement, { root: this.scrollable });
|
|
136
|
+
this.firstElementVisibility = signal(null);
|
|
137
|
+
this.lastElementIntersection = signalElementIntersection(this.lastElement, { root: this.scrollable });
|
|
138
|
+
this.lastElementVisibility = signal(null);
|
|
91
139
|
this.canScroll = computed(() => {
|
|
92
|
-
const dir = this.direction;
|
|
140
|
+
const dir = this.direction();
|
|
93
141
|
if (dir === 'horizontal') {
|
|
94
142
|
return this.containerScrollState().canScrollHorizontally;
|
|
95
143
|
}
|
|
96
144
|
return this.containerScrollState().canScrollVertically;
|
|
97
145
|
});
|
|
98
|
-
this.isAtStart = computed(() =>
|
|
99
|
-
|
|
146
|
+
this.isAtStart = computed(() => {
|
|
147
|
+
if (!this.canScroll()) {
|
|
148
|
+
return true;
|
|
149
|
+
}
|
|
150
|
+
const intersection = this.firstElementIntersection();
|
|
151
|
+
if (!intersection) {
|
|
152
|
+
return this.firstElementVisibility()?.inline ?? true;
|
|
153
|
+
}
|
|
154
|
+
return intersection.isIntersecting;
|
|
155
|
+
});
|
|
156
|
+
this.isAtEnd = computed(() => {
|
|
157
|
+
if (!this.canScroll()) {
|
|
158
|
+
return true;
|
|
159
|
+
}
|
|
160
|
+
const intersection = this.lastElementIntersection();
|
|
161
|
+
if (!intersection) {
|
|
162
|
+
return this.lastElementVisibility()?.inline ?? true;
|
|
163
|
+
}
|
|
164
|
+
return intersection.isIntersecting;
|
|
165
|
+
});
|
|
166
|
+
this.enableOverlayAnimations = signal(false);
|
|
100
167
|
this.hostAttributes = signalHostAttributes({
|
|
101
|
-
'
|
|
102
|
-
|
|
103
|
-
'
|
|
104
|
-
'
|
|
168
|
+
'item-size': this.itemSize,
|
|
169
|
+
direction: this.direction,
|
|
170
|
+
'render-scrollbars': this.renderScrollbars,
|
|
171
|
+
'sticky-buttons': this.stickyButtons,
|
|
105
172
|
});
|
|
173
|
+
this.hostClasses = signalHostClasses({
|
|
174
|
+
'et-scrollable--can-scroll': this.canScroll,
|
|
175
|
+
'et-scrollable--is-at-start': this.isAtStart,
|
|
176
|
+
'et-scrollable--is-at-end': this.isAtEnd,
|
|
177
|
+
'et-scrollable--enable-overlay-animations': this.enableOverlayAnimations,
|
|
178
|
+
});
|
|
179
|
+
effect(() => {
|
|
180
|
+
const scrollable = this.scrollable()?.nativeElement;
|
|
181
|
+
const firstElement = this.firstElement()?.nativeElement;
|
|
182
|
+
const lastElement = this.lastElement()?.nativeElement;
|
|
183
|
+
const activeElementList = this.activeElementList()?.toArray();
|
|
184
|
+
if (!scrollable || !firstElement || !lastElement || !activeElementList) {
|
|
185
|
+
return;
|
|
186
|
+
}
|
|
187
|
+
const firstActive = activeElementList.find((a) => a.isActiveElement);
|
|
188
|
+
if (firstActive && !this.disableActiveElementScrolling()) {
|
|
189
|
+
const offsetTop = firstActive.elementRef.nativeElement.offsetTop - scrollable.offsetTop;
|
|
190
|
+
const offsetLeft = firstActive.elementRef.nativeElement.offsetLeft - scrollable.offsetLeft;
|
|
191
|
+
scrollable.scrollLeft = offsetLeft;
|
|
192
|
+
scrollable.scrollTop = offsetTop;
|
|
193
|
+
}
|
|
194
|
+
this.firstElementVisibility.set(isElementVisible({
|
|
195
|
+
container: scrollable,
|
|
196
|
+
element: firstElement,
|
|
197
|
+
}));
|
|
198
|
+
this.lastElementVisibility.set(isElementVisible({
|
|
199
|
+
container: scrollable,
|
|
200
|
+
element: lastElement,
|
|
201
|
+
}));
|
|
202
|
+
// We need to wait one frame before enabling animations to prevent a animation from playing during initial render.
|
|
203
|
+
nextFrame(() => this.enableOverlayAnimations.set(true));
|
|
204
|
+
}, { allowSignalWrites: true });
|
|
106
205
|
effect(() => {
|
|
107
206
|
const isAtStart = this.isAtStart();
|
|
108
207
|
const isAtEnd = this.isAtEnd();
|
|
109
208
|
const canScroll = this.canScroll();
|
|
110
209
|
this.scrollStateChange.emit({
|
|
111
210
|
canScroll,
|
|
112
|
-
isAtEnd,
|
|
113
|
-
isAtStart,
|
|
211
|
+
isAtEnd: !!isAtEnd,
|
|
212
|
+
isAtStart: !!isAtStart,
|
|
114
213
|
});
|
|
115
214
|
});
|
|
116
215
|
}
|
|
117
216
|
ngAfterContentInit() {
|
|
118
|
-
if (!this.activeElements || !this.elements) {
|
|
119
|
-
return;
|
|
120
|
-
}
|
|
121
|
-
this.activeElements.changes
|
|
122
|
-
.pipe(startWith(this.activeElements), tap((activeElements) => {
|
|
123
|
-
if (this.disableActiveElementScrolling) {
|
|
124
|
-
return;
|
|
125
|
-
}
|
|
126
|
-
const firstActive = activeElements
|
|
127
|
-
.filter((a) => !!a)
|
|
128
|
-
.find((a) => a.isActiveElement);
|
|
129
|
-
if (!firstActive) {
|
|
130
|
-
return;
|
|
131
|
-
}
|
|
132
|
-
scrollToElement({
|
|
133
|
-
behavior: 'auto',
|
|
134
|
-
container: this.scrollable.nativeElement,
|
|
135
|
-
element: firstActive.elementRef.nativeElement,
|
|
136
|
-
scrollInlineMargin: this.direction === 'horizontal' ? this.scrollMargin : 0,
|
|
137
|
-
scrollBlockMargin: this.direction === 'horizontal' ? 0 : this.scrollMargin,
|
|
138
|
-
});
|
|
139
|
-
}), takeUntil(this._destroy$))
|
|
140
|
-
.subscribe();
|
|
141
217
|
this._setupScrollListening();
|
|
142
218
|
}
|
|
143
219
|
scrollOneContainerSize(direction) {
|
|
144
|
-
const scrollElement = this.scrollable
|
|
220
|
+
const scrollElement = this.scrollable()?.nativeElement;
|
|
221
|
+
if (!scrollElement) {
|
|
222
|
+
return;
|
|
223
|
+
}
|
|
145
224
|
const parent = this._elementRef.nativeElement;
|
|
146
|
-
const scrollableSize = this.direction === 'horizontal' ? parent.clientWidth : parent.clientHeight;
|
|
147
|
-
const currentScroll = this.direction === 'horizontal' ? scrollElement.scrollLeft : scrollElement.scrollTop;
|
|
225
|
+
const scrollableSize = this.direction() === 'horizontal' ? parent.clientWidth : parent.clientHeight;
|
|
226
|
+
const currentScroll = this.direction() === 'horizontal' ? scrollElement.scrollLeft : scrollElement.scrollTop;
|
|
148
227
|
scrollElement.scrollTo({
|
|
149
|
-
[this.direction === 'horizontal' ? 'left' : 'top']: currentScroll + (direction === 'start' ? -scrollableSize : scrollableSize),
|
|
228
|
+
[this.direction() === 'horizontal' ? 'left' : 'top']: currentScroll + (direction === 'start' ? -scrollableSize : scrollableSize),
|
|
150
229
|
behavior: 'smooth',
|
|
151
230
|
});
|
|
152
231
|
}
|
|
@@ -164,39 +243,39 @@ export class ScrollableComponent {
|
|
|
164
243
|
}
|
|
165
244
|
this.scrollToElement({
|
|
166
245
|
element: el?.element,
|
|
167
|
-
direction: this.direction === 'horizontal' ? 'inline' : 'block',
|
|
246
|
+
direction: this.direction() === 'horizontal' ? 'inline' : 'block',
|
|
168
247
|
origin: direction,
|
|
169
|
-
...(this.direction === 'horizontal'
|
|
170
|
-
? { scrollInlineMargin: this.scrollMargin }
|
|
171
|
-
: { scrollBlockMargin: this.scrollMargin }),
|
|
248
|
+
...(this.direction() === 'horizontal'
|
|
249
|
+
? { scrollInlineMargin: this.scrollMargin() }
|
|
250
|
+
: { scrollBlockMargin: this.scrollMargin() }),
|
|
172
251
|
});
|
|
173
252
|
}
|
|
174
253
|
scrollToElement(options) {
|
|
175
|
-
const scrollElement = this.scrollable
|
|
254
|
+
const scrollElement = this.scrollable()?.nativeElement;
|
|
176
255
|
scrollToElement({
|
|
177
256
|
container: scrollElement,
|
|
178
|
-
...(this.direction === 'horizontal'
|
|
179
|
-
? { scrollInlineMargin: this.scrollMargin }
|
|
180
|
-
: { scrollBlockMargin: this.scrollMargin }),
|
|
257
|
+
...(this.direction() === 'horizontal'
|
|
258
|
+
? { scrollInlineMargin: this.scrollMargin() }
|
|
259
|
+
: { scrollBlockMargin: this.scrollMargin() }),
|
|
181
260
|
...options,
|
|
182
261
|
});
|
|
183
262
|
}
|
|
184
263
|
scrollToElementByIndex(options) {
|
|
185
|
-
const elements = this.
|
|
264
|
+
const elements = this.elementList()?.toArray() ?? [];
|
|
186
265
|
if (!elements.length) {
|
|
187
266
|
if (isDevMode()) {
|
|
188
267
|
console.warn('No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.');
|
|
189
268
|
}
|
|
190
269
|
return;
|
|
191
270
|
}
|
|
192
|
-
const scrollElement = this.scrollable
|
|
271
|
+
const scrollElement = this.scrollable()?.nativeElement;
|
|
193
272
|
const element = elements[options.index]?.elementRef.nativeElement;
|
|
194
273
|
scrollToElement({
|
|
195
274
|
container: scrollElement,
|
|
196
275
|
element,
|
|
197
|
-
...(this.direction === 'horizontal'
|
|
198
|
-
? { scrollInlineMargin: this.scrollMargin }
|
|
199
|
-
: { scrollBlockMargin: this.scrollMargin }),
|
|
276
|
+
...(this.direction() === 'horizontal'
|
|
277
|
+
? { scrollInlineMargin: this.scrollMargin() }
|
|
278
|
+
: { scrollBlockMargin: this.scrollMargin() }),
|
|
200
279
|
...options,
|
|
201
280
|
});
|
|
202
281
|
}
|
|
@@ -204,7 +283,7 @@ export class ScrollableComponent {
|
|
|
204
283
|
this._isCursorDragging$.next(isDragging);
|
|
205
284
|
}
|
|
206
285
|
scrollToStartDirection() {
|
|
207
|
-
if (this.scrollMode === 'container') {
|
|
286
|
+
if (this.scrollMode() === 'container') {
|
|
208
287
|
this.scrollOneContainerSize('start');
|
|
209
288
|
}
|
|
210
289
|
else {
|
|
@@ -212,7 +291,7 @@ export class ScrollableComponent {
|
|
|
212
291
|
}
|
|
213
292
|
}
|
|
214
293
|
scrollToStartEnd() {
|
|
215
|
-
if (this.scrollMode === 'container') {
|
|
294
|
+
if (this.scrollMode() === 'container') {
|
|
216
295
|
this.scrollOneContainerSize('end');
|
|
217
296
|
}
|
|
218
297
|
else {
|
|
@@ -220,7 +299,11 @@ export class ScrollableComponent {
|
|
|
220
299
|
}
|
|
221
300
|
}
|
|
222
301
|
_setupScrollListening() {
|
|
223
|
-
const scrollElement = this.scrollable
|
|
302
|
+
const scrollElement = this.scrollable()?.nativeElement;
|
|
303
|
+
const elements = this.elementList();
|
|
304
|
+
if (!scrollElement || !elements) {
|
|
305
|
+
return;
|
|
306
|
+
}
|
|
224
307
|
let isSnapping = false;
|
|
225
308
|
let snapTimeout = 0;
|
|
226
309
|
merge(fromEvent(scrollElement, 'wheel'), fromEvent(scrollElement, 'touchstart'))
|
|
@@ -228,21 +311,21 @@ export class ScrollableComponent {
|
|
|
228
311
|
isSnapping = false;
|
|
229
312
|
}))
|
|
230
313
|
.subscribe();
|
|
231
|
-
merge(fromEvent(scrollElement, 'scroll'), this._isCursorDragging$,
|
|
314
|
+
merge(fromEvent(scrollElement, 'scroll'), this._isCursorDragging$, elements.changes.pipe(startWith(elements)) ?? of(null))
|
|
232
315
|
.pipe(debounceTime(300), takeUntil(this._destroy$), tap(() => {
|
|
233
|
-
const
|
|
316
|
+
const els = elements
|
|
234
317
|
?.toArray()
|
|
235
318
|
.map((e) => e?.elementRef.nativeElement)
|
|
236
319
|
.filter((e) => !!e) ?? [];
|
|
237
|
-
if (!
|
|
320
|
+
if (!els.length) {
|
|
238
321
|
this._latestVisibilityStates$.next([]);
|
|
239
322
|
return;
|
|
240
323
|
}
|
|
241
324
|
const states = getElementVisibleStates({
|
|
242
|
-
elements,
|
|
325
|
+
elements: els,
|
|
243
326
|
container: scrollElement,
|
|
244
327
|
});
|
|
245
|
-
const prop = this.direction === 'horizontal' ? 'inlineIntersection' : 'blockIntersection';
|
|
328
|
+
const prop = this.direction() === 'horizontal' ? 'inlineIntersection' : 'blockIntersection';
|
|
246
329
|
const stateClass = `et-element--is-intersecting`;
|
|
247
330
|
for (const state of states) {
|
|
248
331
|
if (state[prop] === 100) {
|
|
@@ -263,7 +346,7 @@ export class ScrollableComponent {
|
|
|
263
346
|
});
|
|
264
347
|
this.intersectionChange.emit(intersectionChanges);
|
|
265
348
|
this._latestVisibilityStates$.next(intersectionChanges);
|
|
266
|
-
if (isSnapping || this._isCursorDragging$.value || !this.snap)
|
|
349
|
+
if (isSnapping || this._isCursorDragging$.value || !this.snap())
|
|
267
350
|
return;
|
|
268
351
|
const prev = this.previousPartialIntersection;
|
|
269
352
|
const next = this.nextPartialIntersection;
|
|
@@ -283,10 +366,10 @@ export class ScrollableComponent {
|
|
|
283
366
|
scrollToElement({
|
|
284
367
|
container: scrollElement,
|
|
285
368
|
element: highestIntersecting.element,
|
|
286
|
-
direction: this.direction === 'horizontal' ? 'inline' : 'block',
|
|
369
|
+
direction: this.direction() === 'horizontal' ? 'inline' : 'block',
|
|
287
370
|
origin,
|
|
288
|
-
scrollBlockMargin: this.direction === 'horizontal' ? 0 : this.scrollMargin,
|
|
289
|
-
scrollInlineMargin: this.direction === 'horizontal' ? this.scrollMargin : 0,
|
|
371
|
+
scrollBlockMargin: this.direction() === 'horizontal' ? 0 : this.scrollMargin(),
|
|
372
|
+
scrollInlineMargin: this.direction() === 'horizontal' ? this.scrollMargin() : 0,
|
|
290
373
|
});
|
|
291
374
|
isSnapping = true;
|
|
292
375
|
window.clearTimeout(snapTimeout);
|
|
@@ -296,81 +379,71 @@ export class ScrollableComponent {
|
|
|
296
379
|
}))
|
|
297
380
|
.subscribe();
|
|
298
381
|
}
|
|
299
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.
|
|
300
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "
|
|
382
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ScrollableComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
383
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.2", type: ScrollableComponent, isStandalone: true, selector: "et-scrollable", inputs: { _itemSize: ["itemSize", "_itemSize"], _direction: ["direction", "_direction"], _scrollableRole: ["scrollableRole", "_scrollableRole"], _scrollableClass: ["scrollableClass", "_scrollableClass"], _renderMasks: ["renderMasks", "_renderMasks", booleanAttribute], _renderButtons: ["renderButtons", "_renderButtons", booleanAttribute], _renderScrollbars: ["renderScrollbars", "_renderScrollbars", booleanAttribute], _stickyButtons: ["stickyButtons", "_stickyButtons", booleanAttribute], _cursorDragScroll: ["cursorDragScroll", "_cursorDragScroll", booleanAttribute], _disableActiveElementScrolling: ["disableActiveElementScrolling", "_disableActiveElementScrolling", booleanAttribute], _scrollMode: ["scrollMode", "_scrollMode"], _snap: ["snap", "_snap", booleanAttribute], _scrollMargin: ["scrollMargin", "_scrollMargin", numberAttribute] }, outputs: { scrollStateChange: "scrollStateChange", intersectionChange: "intersectionChange" }, host: { classAttribute: "et-scrollable" }, queries: [{ propertyName: "_activeElementList", predicate: IS_ACTIVE_ELEMENT, descendants: true }, { propertyName: "_elementList", predicate: IS_ELEMENT, descendants: true }], viewQueries: [{ propertyName: "_scrollable", first: true, predicate: ["scrollable"], descendants: true, static: true }, { propertyName: "_firstElement", first: true, predicate: ["firstElement"], descendants: true, static: true }, { propertyName: "_lastElement", first: true, predicate: ["lastElement"], descendants: true, static: true }], ngImport: i0, template: "<div\n #scrollable\n [attr.role]=\"scrollableRole() ?? undefined\"\n [etCursorDragScroll]=\"cursorDragScroll()\"\n [allowedDirection]=\"direction()\"\n (cursorDragStart)=\"setIsCursorDragging(true)\"\n (cursorDragEnd)=\"setIsCursorDragging(false)\"\n class=\"et-scrollable-container-outer\"\n>\n <div [ngClass]=\"scrollableClass()\" class=\"et-scrollable-container\">\n <div #firstElement class=\"et-scroll-observer-first-element\"></div>\n <ng-content />\n <div #lastElement class=\"et-scroll-observer-last-element\"></div>\n </div>\n</div>\n\n@if (renderMasks()) {\n <div class=\"et-scrollable-masks\">\n <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n </div>\n}\n\n@if (renderButtons()) {\n <div class=\"et-scrollable-buttons\">\n <button\n (click)=\"scrollToStartDirection()\"\n class=\"et-scrollable-button et-scrollable-button--start\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n <button\n (click)=\"scrollToStartEnd()\"\n class=\"et-scrollable-button et-scrollable-button--end\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n </div>\n}\n", styles: [".et-scrollable{--mask: #121212 0, transparent 100%;--mask-size: 25px;--_auto-size: min-content;--_flow: column;display:grid;position:relative}.et-scrollable[item-size=same]{--_auto-size: 1fr}.et-scrollable[item-size=full]{--_auto-size: 100%}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer{scrollbar-width:none}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer::-webkit-scrollbar{display:none}.et-scrollable[direction=horizontal] .et-scrollable-container-outer{overflow-x:auto;overflow-y:hidden}.et-scrollable[direction=horizontal] .et-scrollable-container{grid-auto-columns:var(--_auto-size)}.et-scrollable[direction=horizontal] .et-scrollable-mask,.et-scrollable[direction=horizontal] .et-scrollable-button{inline-size:var(--mask-size);block-size:100%}.et-scrollable[direction=horizontal] .et-scrollable-mask--start,.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:0;inset-inline:0 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--end,.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:0;inset-inline:calc(100% - 40px) 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--start{background:linear-gradient(to right,var(--mask))}.et-scrollable[direction=horizontal] .et-scrollable-mask--end{background:linear-gradient(to left,var(--mask));inset-inline:calc(100% - var(--mask-size)) 100%}.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:calc(50% - 20px);transform:rotate(-90deg)}.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:calc(50% - 20px);transform:rotate(90deg)}.et-scrollable[direction=vertical]{--_flow: row}.et-scrollable[direction=vertical] .et-scrollable-container-outer{overflow-x:hidden;overflow-y:auto}.et-scrollable[direction=vertical] .et-scrollable-container{grid-auto-rows:var(--_auto-size)}.et-scrollable[direction=vertical] .et-scrollable-mask,.et-scrollable[direction=vertical] .et-scrollable-button{block-size:var(--mask-size);inline-size:100%}.et-scrollable[direction=vertical] .et-scrollable-mask--start,.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-block-start:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--end,.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-block-end:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--start{background:linear-gradient(to bottom,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-mask--end{background:linear-gradient(to top,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-inline-start:calc(50% - 20px);transform:rotate(0)}.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-inline-start:calc(50% - 20px);transform:rotate(180deg)}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-masks .et-scrollable-mask--start,.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{opacity:1}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{pointer-events:all}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-masks .et-scrollable-mask--end,.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{opacity:1}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{pointer-events:all}.et-scrollable .et-scrollable-container-outer{overflow:auto;display:grid;grid-row:1/1;grid-column:1/1}.et-scrollable .et-scroll-observer-first-element,.et-scrollable .et-scroll-observer-last-element{position:absolute;block-size:100%;inline-size:1px;pointer-events:none}.et-scrollable .et-scroll-observer-first-element{inset-inline-start:1px}.et-scrollable .et-scroll-observer-last-element{inset-inline-end:1px}.et-scrollable .et-scrollable-container{display:grid;grid-auto-flow:var(--_flow);position:relative}.et-scrollable .et-scrollable-masks,.et-scrollable .et-scrollable-buttons{grid-row:1/1;grid-column:1/1;pointer-events:none}.et-scrollable .et-scrollable-masks .et-scrollable-mask,.et-scrollable .et-scrollable-masks .et-scrollable-button,.et-scrollable .et-scrollable-buttons .et-scrollable-mask,.et-scrollable .et-scrollable-buttons .et-scrollable-button{position:absolute;opacity:0}.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-mask,.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-button{transition:opacity .3s var(--ease-5)}.et-scrollable .et-scrollable-buttons .et-scrollable-button{background:transparent;border:none;padding:12px;inline-size:40px;block-size:40px;border-radius:4px;cursor:pointer}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-chevron-icon{pointer-events:none}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--start{inset-inline:0 0}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--end{inset-inline:calc(100% - 40px) 0}.et-scrollable[sticky-buttons=true]{--_sticky-margin: 10%}.et-scrollable[sticky-buttons=true] .et-scrollable-button{position:sticky}.et-scrollable[sticky-buttons=true][direction=horizontal] .et-scrollable-buttons{margin-block:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons{margin-inline:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons .et-scrollable-button--end{inset-block-start:100%}\n"], dependencies: [{ kind: "directive", type: CursorDragScrollDirective, selector: "[etCursorDragScroll]", inputs: ["etCursorDragScroll", "allowedDirection"], outputs: ["cursorDragStart", "cursorDragMove", "cursorDragEnd"], exportAs: ["etCursorDragScroll"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: ChevronIconComponent, selector: "et-chevron-icon" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
301
384
|
}
|
|
302
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.
|
|
385
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.2", ngImport: i0, type: ScrollableComponent, decorators: [{
|
|
303
386
|
type: Component,
|
|
304
|
-
args: [{ selector: 'et-scrollable', standalone: true, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, imports: [CursorDragScrollDirective, ObserveScrollStateDirective, NgClass,
|
|
387
|
+
args: [{ selector: 'et-scrollable', standalone: true, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, imports: [CursorDragScrollDirective, ObserveScrollStateDirective, NgClass, LetDirective, ChevronIconComponent], host: {
|
|
305
388
|
class: 'et-scrollable',
|
|
306
|
-
}, template: "<div\n #scrollable\n [attr.role]=\"scrollableRole ?? undefined\"\n [etCursorDragScroll]=\"cursorDragScroll\"\n [allowedDirection]=\"direction\"\n (cursorDragStart)=\"setIsCursorDragging(true)\"\n (cursorDragEnd)=\"setIsCursorDragging(false)\"\n class=\"et-scrollable-container-outer\"\n>\n <div [ngClass]=\"scrollableClass\" class=\"et-scrollable-container\">\n <div #firstElement class=\"et-scroll-observer-first-element\"></div>\n <ng-content />\n <div #lastElement class=\"et-scroll-observer-last-element\"></div>\n </div>\n</div>\n\n
|
|
307
|
-
}], ctorParameters: () => [], propDecorators: {
|
|
308
|
-
type: Input
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
}, {
|
|
315
|
-
type: HostBinding,
|
|
316
|
-
args: ['attr.direction']
|
|
317
|
-
}], scrollableRole: [{
|
|
318
|
-
type: Input
|
|
319
|
-
}], scrollableClass: [{
|
|
320
|
-
type: Input
|
|
321
|
-
}], renderMasks: [{
|
|
389
|
+
}, template: "<div\n #scrollable\n [attr.role]=\"scrollableRole() ?? undefined\"\n [etCursorDragScroll]=\"cursorDragScroll()\"\n [allowedDirection]=\"direction()\"\n (cursorDragStart)=\"setIsCursorDragging(true)\"\n (cursorDragEnd)=\"setIsCursorDragging(false)\"\n class=\"et-scrollable-container-outer\"\n>\n <div [ngClass]=\"scrollableClass()\" class=\"et-scrollable-container\">\n <div #firstElement class=\"et-scroll-observer-first-element\"></div>\n <ng-content />\n <div #lastElement class=\"et-scroll-observer-last-element\"></div>\n </div>\n</div>\n\n@if (renderMasks()) {\n <div class=\"et-scrollable-masks\">\n <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n </div>\n}\n\n@if (renderButtons()) {\n <div class=\"et-scrollable-buttons\">\n <button\n (click)=\"scrollToStartDirection()\"\n class=\"et-scrollable-button et-scrollable-button--start\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n <button\n (click)=\"scrollToStartEnd()\"\n class=\"et-scrollable-button et-scrollable-button--end\"\n aria-hidden=\"true\"\n type=\"button\"\n tabindex=\"-1\"\n >\n <et-chevron-icon />\n </button>\n </div>\n}\n", styles: [".et-scrollable{--mask: #121212 0, transparent 100%;--mask-size: 25px;--_auto-size: min-content;--_flow: column;display:grid;position:relative}.et-scrollable[item-size=same]{--_auto-size: 1fr}.et-scrollable[item-size=full]{--_auto-size: 100%}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer{scrollbar-width:none}.et-scrollable[render-scrollbars=false] .et-scrollable-container-outer::-webkit-scrollbar{display:none}.et-scrollable[direction=horizontal] .et-scrollable-container-outer{overflow-x:auto;overflow-y:hidden}.et-scrollable[direction=horizontal] .et-scrollable-container{grid-auto-columns:var(--_auto-size)}.et-scrollable[direction=horizontal] .et-scrollable-mask,.et-scrollable[direction=horizontal] .et-scrollable-button{inline-size:var(--mask-size);block-size:100%}.et-scrollable[direction=horizontal] .et-scrollable-mask--start,.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:0;inset-inline:0 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--end,.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:0;inset-inline:calc(100% - 40px) 0}.et-scrollable[direction=horizontal] .et-scrollable-mask--start{background:linear-gradient(to right,var(--mask))}.et-scrollable[direction=horizontal] .et-scrollable-mask--end{background:linear-gradient(to left,var(--mask));inset-inline:calc(100% - var(--mask-size)) 100%}.et-scrollable[direction=horizontal] .et-scrollable-button--start{inset-block-start:calc(50% - 20px);transform:rotate(-90deg)}.et-scrollable[direction=horizontal] .et-scrollable-button--end{inset-block-start:calc(50% - 20px);transform:rotate(90deg)}.et-scrollable[direction=vertical]{--_flow: row}.et-scrollable[direction=vertical] .et-scrollable-container-outer{overflow-x:hidden;overflow-y:auto}.et-scrollable[direction=vertical] .et-scrollable-container{grid-auto-rows:var(--_auto-size)}.et-scrollable[direction=vertical] .et-scrollable-mask,.et-scrollable[direction=vertical] .et-scrollable-button{block-size:var(--mask-size);inline-size:100%}.et-scrollable[direction=vertical] .et-scrollable-mask--start,.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-block-start:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--end,.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-block-end:0;inset-inline-start:0}.et-scrollable[direction=vertical] .et-scrollable-mask--start{background:linear-gradient(to bottom,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-mask--end{background:linear-gradient(to top,var(--mask))}.et-scrollable[direction=vertical] .et-scrollable-button--start{inset-inline-start:calc(50% - 20px);transform:rotate(0)}.et-scrollable[direction=vertical] .et-scrollable-button--end{inset-inline-start:calc(50% - 20px);transform:rotate(180deg)}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-masks .et-scrollable-mask--start,.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{opacity:1}.et-scrollable:not(.et-scrollable--is-at-start) .et-scrollable-buttons .et-scrollable-button--start{pointer-events:all}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-masks .et-scrollable-mask--end,.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{opacity:1}.et-scrollable:not(.et-scrollable--is-at-end) .et-scrollable-buttons .et-scrollable-button--end{pointer-events:all}.et-scrollable .et-scrollable-container-outer{overflow:auto;display:grid;grid-row:1/1;grid-column:1/1}.et-scrollable .et-scroll-observer-first-element,.et-scrollable .et-scroll-observer-last-element{position:absolute;block-size:100%;inline-size:1px;pointer-events:none}.et-scrollable .et-scroll-observer-first-element{inset-inline-start:1px}.et-scrollable .et-scroll-observer-last-element{inset-inline-end:1px}.et-scrollable .et-scrollable-container{display:grid;grid-auto-flow:var(--_flow);position:relative}.et-scrollable .et-scrollable-masks,.et-scrollable .et-scrollable-buttons{grid-row:1/1;grid-column:1/1;pointer-events:none}.et-scrollable .et-scrollable-masks .et-scrollable-mask,.et-scrollable .et-scrollable-masks .et-scrollable-button,.et-scrollable .et-scrollable-buttons .et-scrollable-mask,.et-scrollable .et-scrollable-buttons .et-scrollable-button{position:absolute;opacity:0}.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-mask,.et-scrollable.et-scrollable--can-scroll.et-scrollable--enable-overlay-animations .et-scrollable-button{transition:opacity .3s var(--ease-5)}.et-scrollable .et-scrollable-buttons .et-scrollable-button{background:transparent;border:none;padding:12px;inline-size:40px;block-size:40px;border-radius:4px;cursor:pointer}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-chevron-icon{pointer-events:none}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--start{inset-inline:0 0}.et-scrollable .et-scrollable-buttons .et-scrollable-button .et-scrollable-button--end{inset-inline:calc(100% - 40px) 0}.et-scrollable[sticky-buttons=true]{--_sticky-margin: 10%}.et-scrollable[sticky-buttons=true] .et-scrollable-button{position:sticky}.et-scrollable[sticky-buttons=true][direction=horizontal] .et-scrollable-buttons{margin-block:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons{margin-inline:var(--_sticky-margin)}.et-scrollable[sticky-buttons=true][direction=vertical] .et-scrollable-buttons .et-scrollable-button--end{inset-block-start:100%}\n"] }]
|
|
390
|
+
}], ctorParameters: () => [], propDecorators: { _itemSize: [{
|
|
391
|
+
type: Input,
|
|
392
|
+
args: [{ alias: 'itemSize' }]
|
|
393
|
+
}], _direction: [{
|
|
394
|
+
type: Input,
|
|
395
|
+
args: [{ alias: 'direction' }]
|
|
396
|
+
}], _scrollableRole: [{
|
|
322
397
|
type: Input,
|
|
323
|
-
args: [{
|
|
324
|
-
}],
|
|
398
|
+
args: [{ alias: 'scrollableRole' }]
|
|
399
|
+
}], _scrollableClass: [{
|
|
325
400
|
type: Input,
|
|
326
|
-
args: [{
|
|
327
|
-
}],
|
|
401
|
+
args: [{ alias: 'scrollableClass' }]
|
|
402
|
+
}], _renderMasks: [{
|
|
328
403
|
type: Input,
|
|
329
|
-
args: [{ transform: booleanAttribute }]
|
|
330
|
-
}, {
|
|
331
|
-
type: HostBinding,
|
|
332
|
-
args: ['attr.render-scrollbars']
|
|
333
|
-
}], stickyButtons: [{
|
|
404
|
+
args: [{ transform: booleanAttribute, alias: 'renderMasks' }]
|
|
405
|
+
}], _renderButtons: [{
|
|
334
406
|
type: Input,
|
|
335
|
-
args: [{ transform: booleanAttribute }]
|
|
336
|
-
}, {
|
|
337
|
-
type: HostBinding,
|
|
338
|
-
args: ['attr.sticky-buttons']
|
|
339
|
-
}], cursorDragScroll: [{
|
|
407
|
+
args: [{ transform: booleanAttribute, alias: 'renderButtons' }]
|
|
408
|
+
}], _renderScrollbars: [{
|
|
340
409
|
type: Input,
|
|
341
|
-
args: [{ transform: booleanAttribute }]
|
|
342
|
-
}],
|
|
410
|
+
args: [{ transform: booleanAttribute, alias: 'renderScrollbars' }]
|
|
411
|
+
}], _stickyButtons: [{
|
|
343
412
|
type: Input,
|
|
344
|
-
args: [{ transform: booleanAttribute }]
|
|
345
|
-
}],
|
|
346
|
-
type: Input
|
|
347
|
-
}], snap: [{
|
|
413
|
+
args: [{ transform: booleanAttribute, alias: 'stickyButtons' }]
|
|
414
|
+
}], _cursorDragScroll: [{
|
|
348
415
|
type: Input,
|
|
349
|
-
args: [{ transform: booleanAttribute }]
|
|
350
|
-
}],
|
|
416
|
+
args: [{ transform: booleanAttribute, alias: 'cursorDragScroll' }]
|
|
417
|
+
}], _disableActiveElementScrolling: [{
|
|
351
418
|
type: Input,
|
|
352
|
-
args: [{ transform:
|
|
419
|
+
args: [{ transform: booleanAttribute, alias: 'disableActiveElementScrolling' }]
|
|
420
|
+
}], _scrollMode: [{
|
|
421
|
+
type: Input,
|
|
422
|
+
args: [{ alias: 'scrollMode' }]
|
|
423
|
+
}], _snap: [{
|
|
424
|
+
type: Input,
|
|
425
|
+
args: [{ transform: booleanAttribute, alias: 'snap' }]
|
|
426
|
+
}], _scrollMargin: [{
|
|
427
|
+
type: Input,
|
|
428
|
+
args: [{ transform: numberAttribute, alias: 'scrollMargin' }]
|
|
353
429
|
}], scrollStateChange: [{
|
|
354
430
|
type: Output
|
|
355
431
|
}], intersectionChange: [{
|
|
356
432
|
type: Output
|
|
357
|
-
}],
|
|
433
|
+
}], _scrollable: [{
|
|
358
434
|
type: ViewChild,
|
|
359
435
|
args: ['scrollable', { static: true }]
|
|
360
|
-
}],
|
|
361
|
-
type:
|
|
362
|
-
args: ['
|
|
363
|
-
}],
|
|
364
|
-
type:
|
|
365
|
-
args: ['
|
|
366
|
-
}],
|
|
367
|
-
type: ViewChildren,
|
|
368
|
-
args: ['lastElement']
|
|
369
|
-
}], activeElements: [{
|
|
436
|
+
}], _firstElement: [{
|
|
437
|
+
type: ViewChild,
|
|
438
|
+
args: ['firstElement', { static: true }]
|
|
439
|
+
}], _lastElement: [{
|
|
440
|
+
type: ViewChild,
|
|
441
|
+
args: ['lastElement', { static: true }]
|
|
442
|
+
}], _activeElementList: [{
|
|
370
443
|
type: ContentChildren,
|
|
371
444
|
args: [IS_ACTIVE_ELEMENT, { descendants: true }]
|
|
372
|
-
}],
|
|
445
|
+
}], _elementList: [{
|
|
373
446
|
type: ContentChildren,
|
|
374
447
|
args: [IS_ELEMENT, { descendants: true }]
|
|
375
448
|
}] } });
|
|
376
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/scrollable/components/scrollable/scrollable.component.ts","../../../../../../../../../libs/cdk/src/lib/components/scrollable/components/scrollable/scrollable.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,eAAe,EACf,UAAU,EACV,YAAY,EACZ,WAAW,EACX,KAAK,EACL,MAAM,EACN,SAAS,EACT,YAAY,EACZ,iBAAiB,EACjB,gBAAgB,EAChB,QAAQ,EACR,MAAM,EACN,MAAM,EACN,SAAS,EACT,eAAe,EACf,MAAM,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,yBAAyB,EACzB,iBAAiB,EACjB,UAAU,EAGV,YAAY,EAEZ,2BAA2B,EAG3B,cAAc,EACd,aAAa,EACb,uBAAuB,EACvB,eAAe,EACf,yBAAyB,EACzB,wBAAwB,EACxB,oBAAoB,GACrB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,YAAY,EAAE,SAAS,EAAE,KAAK,EAAE,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,EAAE,MAAM,MAAM,CAAC;AACtG,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;;AAetD,MAAM,OAAO,mBAAmB;IA2D9B,IACc,cAAc,CAAC,IAA6C;QACxE,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IAGD,IACc,gBAAgB,CAAC,IAA6C;QAC1E,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACnC,CAAC;IAGD,IACc,eAAe,CAAC,IAA6C;QACzE,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAClC,CAAC;IASD,IAAI,0BAA0B;QAC5B,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE;YACpC,IAAI,CAAC,IAAI,EAAE;gBACT,OAAO,IAAI,CAAC;aACb;YAED,OAAO,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;QACvE,CAAC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,uBAAuB;QACzB,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,0BAA0B,GAAG,IAAI,CAAC,0BAA0B,CAAC;QAEnE,IAAI,CAAC,0BAA0B,EAAE;YAC/B,OAAO,IAAI,CAAC;SACb;QAED,MAAM,SAAS,GAAG,QAAQ,CAAC,KAAK,CAAC,0BAA0B,CAAC,KAAK,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC;QAEvG,IAAI,SAAS,KAAK,CAAC,CAAC,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,WAAW,GAAG,QAAQ,CAAC,0BAA0B,CAAC,KAAK,GAAG,SAAS,CAAC,CAAC;QAE3E,OAAO,WAAW,IAAI,IAAI,CAAC;IAC7B,CAAC;IAED,IAAI,2BAA2B;QAC7B,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,0BAA0B,GAAG,IAAI,CAAC,0BAA0B,CAAC;QAEnE,IAAI,CAAC,0BAA0B,EAAE;YAC/B,OAAO,IAAI,CAAC;SACb;QAED,MAAM,aAAa,GAAG,QAAQ;aAC3B,KAAK,CAAC,CAAC,EAAE,0BAA0B,CAAC,KAAK,CAAC;aAC1C,OAAO,EAAE;aACT,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC;QAEvC,IAAI,aAAa,KAAK,CAAC,CAAC,EAAE;YACxB,OAAO,IAAI,CAAC;SACb;QAED,MAAM,eAAe,GAAG,QAAQ,CAAC,0BAA0B,CAAC,KAAK,GAAG,aAAa,GAAG,CAAC,CAAC,CAAC;QAEvF,OAAO,eAAe,IAAI,IAAI,CAAC;IACjC,CAAC;IAkCD;QArLiB,cAAS,GAAG,aAAa,EAAE,CAAC;QAC5B,gBAAW,GAAG,MAAM,CAA0B,UAAU,CAAC,CAAC;QAE1D,uBAAkB,GAAG,IAAI,eAAe,CAAU,KAAK,CAAC,CAAC;QACzD,6BAAwB,GAAG,IAAI,eAAe,CAAiC,EAAE,CAAC,CAAC;QAIpG,aAAQ,GAA6B,MAAM,CAAC;QAI5C,cAAS,GAA8B,YAAY,CAAC;QASpD,gBAAW,GAAG,IAAI,CAAC;QAGnB,kBAAa,GAAG,IAAI,CAAC;QAIrB,qBAAgB,GAAG,KAAK,CAAC;QAIzB,kBAAa,GAAG,KAAK,CAAC;QAGtB,qBAAgB,GAAG,IAAI,CAAC;QAGxB,kCAA6B,GAAG,KAAK,CAAC;QAGtC,eAAU,GAAyB,WAAW,CAAC;QAG/C,SAAI,GAAG,KAAK,CAAC;QAGb,iBAAY,GAAG,CAAC,CAAC;QAGR,sBAAiB,GAAG,IAAI,YAAY,EAA6B,CAAC;QAGlE,uBAAkB,GAAG,IAAI,YAAY,EAAkC,CAAC;QAShE,oBAAe,GAAG,MAAM,CAAiD,IAAI,CAAC,CAAC;QAM/E,sBAAiB,GAAG,MAAM,CAAiD,IAAI,CAAC,CAAC;QAMjF,qBAAgB,GAAG,MAAM,CAAiD,IAAI,CAAC,CAAC;QAGjG,mBAAc,GAAoD,IAAI,CAAC;QAGvE,aAAQ,GAA8C,IAAI,CAAC;QAqExC,yBAAoB,GAAG,wBAAwB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QACtE,6BAAwB,GAAG,yBAAyB,CAAC,IAAI,CAAC,iBAAiB,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QACnG,4BAAuB,GAAG,yBAAyB,CAAC,IAAI,CAAC,gBAAgB,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QAEjG,0BAAqB,GAAG,QAAQ,CACjD,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,wBAAwB,EAAE,IAAI,CAAC,CAAC,IAAI,CAAC,uBAAuB,EAAE,CAC5E,CAAC;QAEiB,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE;YAC3C,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC;YAE3B,IAAI,GAAG,KAAK,YAAY,EAAE;gBACxB,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAC,qBAAqB,CAAC;aAC1D;YAED,OAAO,IAAI,CAAC,oBAAoB,EAAE,CAAC,mBAAmB,CAAC;QACzD,CAAC,CAAC,CAAC;QAEgB,cAAS,GAAG,QAAQ,CAAC,GAAG,EAAE,CAC3C,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,wBAAwB,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CACzE,CAAC;QACiB,YAAO,GAAG,QAAQ,CAAC,GAAG,EAAE,CACzC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,uBAAuB,EAAE,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CACxE,CAAC;QAEiB,mBAAc,GAAG,oBAAoB,CAAC;YACvD,YAAY,EAAE,IAAI,CAAC,SAAS;YAC5B,UAAU,EAAE,IAAI,CAAC,SAAS;YAC1B,QAAQ,EAAE,IAAI,CAAC,OAAO;YACtB,kBAAkB,EAAE,IAAI,CAAC,qBAAqB;SAC/C,CAAC,CAAC;QAGD,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YACnC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;YAC/B,MAAM,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YAEnC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC;gBAC1B,SAAS;gBACT,OAAO;gBACP,SAAS;aACV,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAC1C,OAAO;SACR;QAED,IAAI,CAAC,cAAc,CAAC,OAAO;aACxB,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,EAC9B,GAAG,CAAC,CAAC,cAAc,EAAE,EAAE;YACrB,IAAI,IAAI,CAAC,6BAA6B,EAAE;gBACtC,OAAO;aACR;YAED,MAAM,WAAW,GAAG,cAAc;iBAC/B,MAAM,CAAC,CAAC,CAAC,EAAiC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;iBACjD,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC;YAElC,IAAI,CAAC,WAAW,EAAE;gBAChB,OAAO;aACR;YAED,eAAe,CAAC;gBACd,QAAQ,EAAE,MAAM;gBAChB,SAAS,EAAE,IAAI,CAAC,UAAU,CAAC,aAAa;gBACxC,OAAO,EAAE,WAAW,CAAC,UAAU,CAAC,aAAa;gBAC7C,kBAAkB,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;gBAC3E,iBAAiB,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY;aAC3E,CAAC,CAAC;QACL,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B;aACA,SAAS,EAAE,CAAC;QAEf,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC/B,CAAC;IAED,sBAAsB,CAAC,SAA0B;QAC/C,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACpD,MAAM,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC;QAE9C,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC;QAClG,MAAM,aAAa,GAAG,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,CAAC,aAAa,CAAC,SAAS,CAAC;QAE3G,aAAa,CAAC,QAAQ,CAAC;YACrB,CAAC,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,EAChD,aAAa,GAAG,CAAC,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,cAAc,CAAC;YAC5E,QAAQ,EAAE,QAAQ;SACnB,CAAC,CAAC;IACL,CAAC;IAED,iBAAiB,CAAC,SAA0B;QAC1C,MAAM,QAAQ,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAC;QAErD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,IAAI,SAAS,EAAE,EAAE;gBACf,OAAO,CAAC,IAAI,CACV,mHAAmH,CACpH,CAAC;aACH;YACD,OAAO;SACR;QAED,MAAM,EAAE,GAAG,SAAS,KAAK,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,2BAA2B,CAAC,CAAC,CAAC,IAAI,CAAC,uBAAuB,CAAC;QAEnG,IAAI,CAAC,EAAE,EAAE;YACP,OAAO;SACR;QAED,IAAI,CAAC,eAAe,CAAC;YACnB,OAAO,EAAE,EAAE,EAAE,OAAO;YACpB,SAAS,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO;YAC/D,MAAM,EAAE,SAAS;YACjB,GAAG,CAAC,IAAI,CAAC,SAAS,KAAK,YAAY;gBACjC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,CAAC,YAAY,EAAE;gBAC3C,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC;SAC9C,CAAC,CAAC;IACL,CAAC;IAED,eAAe,CAAC,OAAkD;QAChE,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QAEpD,eAAe,CAAC;YACd,SAAS,EAAE,aAAa;YACxB,GAAG,CAAC,IAAI,CAAC,SAAS,KAAK,YAAY;gBACjC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,CAAC,YAAY,EAAE;gBAC3C,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC;YAC7C,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAED,sBAAsB,CAAC,OAAsE;QAC3F,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QAEhD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;YACpB,IAAI,SAAS,EAAE,EAAE;gBACf,OAAO,CAAC,IAAI,CACV,mHAAmH,CACpH,CAAC;aACH;YACD,OAAO;SACR;QAED,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACpD,MAAM,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC,aAAa,CAAC;QAElE,eAAe,CAAC;YACd,SAAS,EAAE,aAAa;YACxB,OAAO;YACP,GAAG,CAAC,IAAI,CAAC,SAAS,KAAK,YAAY;gBACjC,CAAC,CAAC,EAAE,kBAAkB,EAAE,IAAI,CAAC,YAAY,EAAE;gBAC3C,CAAC,CAAC,EAAE,iBAAiB,EAAE,IAAI,CAAC,YAAY,EAAE,CAAC;YAC7C,GAAG,OAAO;SACX,CAAC,CAAC;IACL,CAAC;IAES,mBAAmB,CAAC,UAAmB;QAC/C,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC3C,CAAC;IAES,sBAAsB;QAC9B,IAAI,IAAI,CAAC,UAAU,KAAK,WAAW,EAAE;YACnC,IAAI,CAAC,sBAAsB,CAAC,OAAO,CAAC,CAAC;SACtC;aAAM;YACL,IAAI,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;SACjC;IACH,CAAC;IAES,gBAAgB;QACxB,IAAI,IAAI,CAAC,UAAU,KAAK,WAAW,EAAE;YACnC,IAAI,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAC;SACpC;aAAM;YACL,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;SAC/B;IACH,CAAC;IAEO,qBAAqB;QAC3B,MAAM,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;QACpD,IAAI,UAAU,GAAG,KAAK,CAAC;QACvB,IAAI,WAAW,GAAG,CAAC,CAAC;QAEpB,KAAK,CAAC,SAAS,CAAa,aAAa,EAAE,OAAO,CAAC,EAAE,SAAS,CAAa,aAAa,EAAE,YAAY,CAAC,CAAC;aACrG,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,GAAG,CAAC,GAAG,EAAE;YACP,UAAU,GAAG,KAAK,CAAC;QACrB,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;QAEf,KAAK,CACH,SAAS,CAAC,aAAa,EAAE,QAAQ,CAAC,EAClC,IAAI,CAAC,kBAAkB,EACvB,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,CAClE;aACE,IAAI,CACH,YAAY,CAAC,GAAG,CAAC,EACjB,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,EACzB,GAAG,CAAC,GAAG,EAAE;YACP,MAAM,QAAQ,GACZ,IAAI,CAAC,QAAQ;gBACX,EAAE,OAAO,EAAE;iBACV,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,UAAU,CAAC,aAAa,CAAC;iBACvC,MAAM,CAAC,CAAC,CAAC,EAAoB,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YAEhD,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE;gBACpB,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAEvC,OAAO;aACR;YAED,MAAM,MAAM,GAAG,uBAAuB,CAAC;gBACrC,QAAQ;gBACR,SAAS,EAAE,aAAa;aACzB,CAAC,CAAC;YAEH,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,mBAAmB,CAAC;YAC1F,MAAM,UAAU,GAAG,6BAA6B,CAAC;YAEjD,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE;gBAC1B,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,GAAG,EAAE;oBACvB,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;iBACzC;qBAAM;oBACL,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;iBAC5C;aACF;YAED,MAAM,mBAAmB,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;gBAC9C,MAAM,KAAK,GAAiC;oBAC1C,OAAO,EAAE,CAAC,CAAC,OAAO;oBAClB,iBAAiB,EAAE,CAAC,CAAC,IAAI,CAAC,GAAG,GAAG;oBAChC,cAAc,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG;oBAC/B,KAAK,EAAE,CAAC;iBACT,CAAC;gBAEF,OAAO,KAAK,CAAC;YACf,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YAElD,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YAExD,IAAI,UAAU,IAAI,IAAI,CAAC,kBAAkB,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,IAAI;gBAAE,OAAO;YAEtE,MAAM,IAAI,GAAG,IAAI,CAAC,2BAA2B,CAAC;YAC9C,MAAM,IAAI,GAAG,IAAI,CAAC,uBAAuB,CAAC;YAC1C,MAAM,QAAQ,GACZ,CAAC,IAAI;gBACL,CAAC,IAAI;gBACL,IAAI,CAAC,iBAAiB,KAAK,CAAC;gBAC5B,IAAI,CAAC,iBAAiB,KAAK,CAAC;gBAC5B,IAAI,CAAC,iBAAiB,KAAK,IAAI,CAAC,iBAAiB,CAAC;YAEpD,IAAI,QAAQ;gBAAE,OAAO;YAErB,MAAM,mBAAmB,GAAG,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;YAC1F,MAAM,qBAAqB,GAAG,IAAI,CAAC,0BAA0B,EAAE,KAAK,CAAC;YAErE,IAAI,qBAAqB,KAAK,SAAS;gBAAE,OAAO;YAEhD,MAAM,wBAAwB,GAAG,mBAAmB,CAAC,KAAK,CAAC;YAC3D,MAAM,MAAM,GAAG,wBAAwB,GAAG,qBAAqB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC;YAElF,eAAe,CAAC;gBACd,SAAS,EAAE,aAAa;gBACxB,OAAO,EAAE,mBAAmB,CAAC,OAAO;gBACpC,SAAS,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO;gBAC/D,MAAM;gBACN,iBAAiB,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY;gBAC1E,kBAAkB,EAAE,IAAI,CAAC,SAAS,KAAK,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;aAC5E,CAAC,CAAC;YAEH,UAAU,GAAG,IAAI,CAAC;YAElB,MAAM,CAAC,YAAY,CAAC,WAAW,CAAC,CAAC;YAEjC,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;gBACnC,UAAU,GAAG,KAAK,CAAC;YACrB,CAAC,EAAE,IAAI,CAAC,CAAC;QACX,CAAC,CAAC,CACH;aACA,SAAS,EAAE,CAAC;IACjB,CAAC;8GArbU,mBAAmB;kGAAnB,mBAAmB,2NAqBV,gBAAgB,qDAGhB,gBAAgB,8DAGhB,gBAAgB,qDAIhB,gBAAgB,8DAIhB,gBAAgB,qGAGhB,gBAAgB,oDAMhB,gBAAgB,kDAGhB,eAAe,6XA8BlB,iBAAiB,8DAGjB,UAAU,oaCzI7B,mwCAyCA,g7KDWY,yBAAyB,wNAA+B,OAAO,oFAAE,IAAI,6FAAgB,oBAAoB;;2FAKxG,mBAAmB;kBAZ/B,SAAS;+BACE,eAAe,cAGb,IAAI,iBACD,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,WACtC,CAAC,yBAAyB,EAAE,2BAA2B,EAAE,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,oBAAoB,CAAC,QAC9G;wBACJ,KAAK,EAAE,eAAe;qBACvB;wDAWD,QAAQ;sBAFP,KAAK;;sBACL,WAAW;uBAAC,gBAAgB;gBAK7B,SAAS;sBAFR,KAAK;;sBACL,WAAW;uBAAC,gBAAgB;gBAI7B,cAAc;sBADb,KAAK;gBAIN,eAAe;sBADd,KAAK;gBAIN,WAAW;sBADV,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,aAAa;sBADZ,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAKtC,gBAAgB;sBAFf,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;;sBACrC,WAAW;uBAAC,wBAAwB;gBAKrC,aAAa;sBAFZ,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;;sBACrC,WAAW;uBAAC,qBAAqB;gBAIlC,gBAAgB;sBADf,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,6BAA6B;sBAD5B,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,UAAU;sBADT,KAAK;gBAIN,IAAI;sBADH,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAItC,YAAY;sBADX,KAAK;uBAAC,EAAE,SAAS,EAAE,eAAe,EAAE;gBAI5B,iBAAiB;sBADzB,MAAM;gBAIE,kBAAkB;sBAD1B,MAAM;gBAIP,UAAU;sBADT,SAAS;uBAAC,YAAY,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAI3B,cAAc;sBAD3B,YAAY;uBAAC,YAAY;gBAOZ,gBAAgB;sBAD7B,YAAY;uBAAC,cAAc;gBAOd,eAAe;sBAD5B,YAAY;uBAAC,aAAa;gBAO3B,cAAc;sBADb,eAAe;uBAAC,iBAAiB,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE;gBAIzD,QAAQ;sBADP,eAAe;uBAAC,UAAU,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE","sourcesContent":["import { NgClass, NgIf } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  HostBinding,\n  Input,\n  Output,\n  ViewChild,\n  ViewChildren,\n  ViewEncapsulation,\n  booleanAttribute,\n  computed,\n  effect,\n  inject,\n  isDevMode,\n  numberAttribute,\n  signal,\n} from '@angular/core';\nimport {\n  CursorDragScrollDirective,\n  IS_ACTIVE_ELEMENT,\n  IS_ELEMENT,\n  IsActiveElementDirective,\n  IsElementDirective,\n  LetDirective,\n  NgClassType,\n  ObserveScrollStateDirective,\n  ScrollObserverScrollState,\n  ScrollToElementOptions,\n  TypedQueryList,\n  createDestroy,\n  getElementVisibleStates,\n  scrollToElement,\n  signalElementIntersection,\n  signalElementScrollState,\n  signalHostAttributes,\n} from '@ethlete/core';\nimport { BehaviorSubject, debounceTime, fromEvent, merge, of, startWith, takeUntil, tap } from 'rxjs';\nimport { ChevronIconComponent } from '../../../icons';\nimport { ScrollableIntersectionChange, ScrollableScrollMode } from '../../types';\n\n@Component({\n  selector: 'et-scrollable',\n  templateUrl: './scrollable.component.html',\n  styleUrls: ['./scrollable.component.scss'],\n  standalone: true,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [CursorDragScrollDirective, ObserveScrollStateDirective, NgClass, NgIf, LetDirective, ChevronIconComponent],\n  host: {\n    class: 'et-scrollable',\n  },\n})\nexport class ScrollableComponent implements AfterContentInit {\n  private readonly _destroy$ = createDestroy();\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  private readonly _isCursorDragging$ = new BehaviorSubject<boolean>(false);\n  private readonly _latestVisibilityStates$ = new BehaviorSubject<ScrollableIntersectionChange[]>([]);\n\n  @Input()\n  @HostBinding('attr.item-size')\n  itemSize: 'auto' | 'same' | 'full' = 'auto';\n\n  @Input()\n  @HostBinding('attr.direction')\n  direction: 'horizontal' | 'vertical' = 'horizontal';\n\n  @Input()\n  scrollableRole?: string;\n\n  @Input()\n  scrollableClass?: NgClassType;\n\n  @Input({ transform: booleanAttribute })\n  renderMasks = true;\n\n  @Input({ transform: booleanAttribute })\n  renderButtons = true;\n\n  @Input({ transform: booleanAttribute })\n  @HostBinding('attr.render-scrollbars')\n  renderScrollbars = false;\n\n  @Input({ transform: booleanAttribute })\n  @HostBinding('attr.sticky-buttons')\n  stickyButtons = false;\n\n  @Input({ transform: booleanAttribute })\n  cursorDragScroll = true;\n\n  @Input({ transform: booleanAttribute })\n  disableActiveElementScrolling = false;\n\n  @Input()\n  scrollMode: ScrollableScrollMode = 'container';\n\n  @Input({ transform: booleanAttribute })\n  snap = false;\n\n  @Input({ transform: numberAttribute })\n  scrollMargin = 0;\n\n  @Output()\n  readonly scrollStateChange = new EventEmitter<ScrollObserverScrollState>();\n\n  @Output()\n  readonly intersectionChange = new EventEmitter<ScrollableIntersectionChange[]>();\n\n  @ViewChild('scrollable', { static: true })\n  scrollable!: ElementRef<HTMLElement>;\n\n  @ViewChildren('scrollable')\n  protected set scrollableList(list: TypedQueryList<ElementRef<HTMLElement>>) {\n    this._scrollableList.set(list);\n  }\n  private readonly _scrollableList = signal<TypedQueryList<ElementRef<HTMLElement>> | null>(null);\n\n  @ViewChildren('firstElement')\n  protected set firstElementList(list: TypedQueryList<ElementRef<HTMLElement>>) {\n    this._firstElementList.set(list);\n  }\n  private readonly _firstElementList = signal<TypedQueryList<ElementRef<HTMLElement>> | null>(null);\n\n  @ViewChildren('lastElement')\n  protected set lastElementList(list: TypedQueryList<ElementRef<HTMLElement>>) {\n    this._lastElementList.set(list);\n  }\n  private readonly _lastElementList = signal<TypedQueryList<ElementRef<HTMLElement>> | null>(null);\n\n  @ContentChildren(IS_ACTIVE_ELEMENT, { descendants: true })\n  activeElements: TypedQueryList<IsActiveElementDirective> | null = null;\n\n  @ContentChildren(IS_ELEMENT, { descendants: true })\n  elements: TypedQueryList<IsElementDirective> | null = null;\n\n  get highestVisibleIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    return elements.reduce((prev, curr) => {\n      if (!prev) {\n        return curr;\n      }\n\n      return curr.intersectionRatio > prev.intersectionRatio ? curr : prev;\n    });\n  }\n\n  get nextPartialIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    const highestVisibleIntersection = this.highestVisibleIntersection;\n\n    if (!highestVisibleIntersection) {\n      return null;\n    }\n\n    const nextIndex = elements.slice(highestVisibleIntersection.index).findIndex((e) => !e.isIntersecting);\n\n    if (nextIndex === -1) {\n      return null;\n    }\n\n    const nextElement = elements[highestVisibleIntersection.index + nextIndex];\n\n    return nextElement || null;\n  }\n\n  get previousPartialIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    const highestVisibleIntersection = this.highestVisibleIntersection;\n\n    if (!highestVisibleIntersection) {\n      return null;\n    }\n\n    const previousIndex = elements\n      .slice(0, highestVisibleIntersection.index)\n      .reverse()\n      .findIndex((e) => !e.isIntersecting);\n\n    if (previousIndex === -1) {\n      return null;\n    }\n\n    const previousElement = elements[highestVisibleIntersection.index - previousIndex - 1];\n\n    return previousElement || null;\n  }\n\n  protected readonly containerScrollState = signalElementScrollState(this._scrollableList);\n  protected readonly firstElementIntersection = signalElementIntersection(this._firstElementList, this._scrollableList);\n  protected readonly lastElementIntersection = signalElementIntersection(this._lastElementList, this._scrollableList);\n\n  protected readonly shouldAnimateOverlays = computed(\n    () => !!this.firstElementIntersection() && !!this.lastElementIntersection(),\n  );\n\n  protected readonly canScroll = computed(() => {\n    const dir = this.direction;\n\n    if (dir === 'horizontal') {\n      return this.containerScrollState().canScrollHorizontally;\n    }\n\n    return this.containerScrollState().canScrollVertically;\n  });\n\n  protected readonly isAtStart = computed(() =>\n    this.canScroll() ? this.firstElementIntersection().isIntersecting : true,\n  );\n  protected readonly isAtEnd = computed(() =>\n    this.canScroll() ? this.lastElementIntersection().isIntersecting : true,\n  );\n\n  protected readonly hostAttributes = signalHostAttributes({\n    'can-scroll': this.canScroll,\n    'at-start': this.isAtStart,\n    'at-end': this.isAtEnd,\n    'animate-overlays': this.shouldAnimateOverlays,\n  });\n\n  constructor() {\n    effect(() => {\n      const isAtStart = this.isAtStart();\n      const isAtEnd = this.isAtEnd();\n      const canScroll = this.canScroll();\n\n      this.scrollStateChange.emit({\n        canScroll,\n        isAtEnd,\n        isAtStart,\n      });\n    });\n  }\n\n  ngAfterContentInit(): void {\n    if (!this.activeElements || !this.elements) {\n      return;\n    }\n\n    this.activeElements.changes\n      .pipe(\n        startWith(this.activeElements),\n        tap((activeElements) => {\n          if (this.disableActiveElementScrolling) {\n            return;\n          }\n\n          const firstActive = activeElements\n            .filter((a): a is IsActiveElementDirective => !!a)\n            .find((a) => a.isActiveElement);\n\n          if (!firstActive) {\n            return;\n          }\n\n          scrollToElement({\n            behavior: 'auto',\n            container: this.scrollable.nativeElement,\n            element: firstActive.elementRef.nativeElement,\n            scrollInlineMargin: this.direction === 'horizontal' ? this.scrollMargin : 0,\n            scrollBlockMargin: this.direction === 'horizontal' ? 0 : this.scrollMargin,\n          });\n        }),\n        takeUntil(this._destroy$),\n      )\n      .subscribe();\n\n    this._setupScrollListening();\n  }\n\n  scrollOneContainerSize(direction: 'start' | 'end') {\n    const scrollElement = this.scrollable.nativeElement;\n    const parent = this._elementRef.nativeElement;\n\n    const scrollableSize = this.direction === 'horizontal' ? parent.clientWidth : parent.clientHeight;\n    const currentScroll = this.direction === 'horizontal' ? scrollElement.scrollLeft : scrollElement.scrollTop;\n\n    scrollElement.scrollTo({\n      [this.direction === 'horizontal' ? 'left' : 'top']:\n        currentScroll + (direction === 'start' ? -scrollableSize : scrollableSize),\n      behavior: 'smooth',\n    });\n  }\n\n  scrollOneItemSize(direction: 'start' | 'end') {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      if (isDevMode()) {\n        console.warn(\n          'No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.',\n        );\n      }\n      return;\n    }\n\n    const el = direction === 'start' ? this.previousPartialIntersection : this.nextPartialIntersection;\n\n    if (!el) {\n      return;\n    }\n\n    this.scrollToElement({\n      element: el?.element,\n      direction: this.direction === 'horizontal' ? 'inline' : 'block',\n      origin: direction,\n      ...(this.direction === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin }\n        : { scrollBlockMargin: this.scrollMargin }),\n    });\n  }\n\n  scrollToElement(options: Omit<ScrollToElementOptions, 'container'>) {\n    const scrollElement = this.scrollable.nativeElement;\n\n    scrollToElement({\n      container: scrollElement,\n      ...(this.direction === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin }\n        : { scrollBlockMargin: this.scrollMargin }),\n      ...options,\n    });\n  }\n\n  scrollToElementByIndex(options: Omit<ScrollToElementOptions, 'container'> & { index: number }) {\n    const elements = this.elements?.toArray() ?? [];\n\n    if (!elements.length) {\n      if (isDevMode()) {\n        console.warn(\n          'No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.',\n        );\n      }\n      return;\n    }\n\n    const scrollElement = this.scrollable.nativeElement;\n    const element = elements[options.index]?.elementRef.nativeElement;\n\n    scrollToElement({\n      container: scrollElement,\n      element,\n      ...(this.direction === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin }\n        : { scrollBlockMargin: this.scrollMargin }),\n      ...options,\n    });\n  }\n\n  protected setIsCursorDragging(isDragging: boolean) {\n    this._isCursorDragging$.next(isDragging);\n  }\n\n  protected scrollToStartDirection() {\n    if (this.scrollMode === 'container') {\n      this.scrollOneContainerSize('start');\n    } else {\n      this.scrollOneItemSize('start');\n    }\n  }\n\n  protected scrollToStartEnd() {\n    if (this.scrollMode === 'container') {\n      this.scrollOneContainerSize('end');\n    } else {\n      this.scrollOneItemSize('end');\n    }\n  }\n\n  private _setupScrollListening() {\n    const scrollElement = this.scrollable.nativeElement;\n    let isSnapping = false;\n    let snapTimeout = 0;\n\n    merge(fromEvent<WheelEvent>(scrollElement, 'wheel'), fromEvent<TouchEvent>(scrollElement, 'touchstart'))\n      .pipe(\n        takeUntil(this._destroy$),\n        tap(() => {\n          isSnapping = false;\n        }),\n      )\n      .subscribe();\n\n    merge(\n      fromEvent(scrollElement, 'scroll'),\n      this._isCursorDragging$,\n      this.elements?.changes.pipe(startWith(this.elements)) ?? of(null),\n    )\n      .pipe(\n        debounceTime(300),\n        takeUntil(this._destroy$),\n        tap(() => {\n          const elements =\n            this.elements\n              ?.toArray()\n              .map((e) => e?.elementRef.nativeElement)\n              .filter((e): e is HTMLElement => !!e) ?? [];\n\n          if (!elements.length) {\n            this._latestVisibilityStates$.next([]);\n\n            return;\n          }\n\n          const states = getElementVisibleStates({\n            elements,\n            container: scrollElement,\n          });\n\n          const prop = this.direction === 'horizontal' ? 'inlineIntersection' : 'blockIntersection';\n          const stateClass = `et-element--is-intersecting`;\n\n          for (const state of states) {\n            if (state[prop] === 100) {\n              state.element.classList.add(stateClass);\n            } else {\n              state.element.classList.remove(stateClass);\n            }\n          }\n\n          const intersectionChanges = states.map((s, i) => {\n            const state: ScrollableIntersectionChange = {\n              element: s.element,\n              intersectionRatio: s[prop] / 100,\n              isIntersecting: s[prop] === 100,\n              index: i,\n            };\n\n            return state;\n          });\n\n          this.intersectionChange.emit(intersectionChanges);\n\n          this._latestVisibilityStates$.next(intersectionChanges);\n\n          if (isSnapping || this._isCursorDragging$.value || !this.snap) return;\n\n          const prev = this.previousPartialIntersection;\n          const next = this.nextPartialIntersection;\n          const skipSnap =\n            !prev ||\n            !next ||\n            prev.intersectionRatio === 0 ||\n            next.intersectionRatio === 0 ||\n            prev.intersectionRatio === next.intersectionRatio;\n\n          if (skipSnap) return;\n\n          const highestIntersecting = prev.intersectionRatio > next.intersectionRatio ? prev : next;\n          const fullIntersectionIndex = this.highestVisibleIntersection?.index;\n\n          if (fullIntersectionIndex === undefined) return;\n\n          const highestIntersectingIndex = highestIntersecting.index;\n          const origin = highestIntersectingIndex > fullIntersectionIndex ? 'end' : 'start';\n\n          scrollToElement({\n            container: scrollElement,\n            element: highestIntersecting.element,\n            direction: this.direction === 'horizontal' ? 'inline' : 'block',\n            origin,\n            scrollBlockMargin: this.direction === 'horizontal' ? 0 : this.scrollMargin,\n            scrollInlineMargin: this.direction === 'horizontal' ? this.scrollMargin : 0,\n          });\n\n          isSnapping = true;\n\n          window.clearTimeout(snapTimeout);\n\n          snapTimeout = window.setTimeout(() => {\n            isSnapping = false;\n          }, 1000);\n        }),\n      )\n      .subscribe();\n  }\n}\n","<div\n  #scrollable\n  [attr.role]=\"scrollableRole ?? undefined\"\n  [etCursorDragScroll]=\"cursorDragScroll\"\n  [allowedDirection]=\"direction\"\n  (cursorDragStart)=\"setIsCursorDragging(true)\"\n  (cursorDragEnd)=\"setIsCursorDragging(false)\"\n  class=\"et-scrollable-container-outer\"\n>\n  <div [ngClass]=\"scrollableClass\" class=\"et-scrollable-container\">\n    <div #firstElement class=\"et-scroll-observer-first-element\"></div>\n    <ng-content />\n    <div #lastElement class=\"et-scroll-observer-last-element\"></div>\n  </div>\n</div>\n\n<div *ngIf=\"renderMasks\" class=\"et-scrollable-masks\">\n  <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n  <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n</div>\n\n<div *ngIf=\"renderButtons\" class=\"et-scrollable-buttons\">\n  <button\n    (click)=\"scrollToStartDirection()\"\n    class=\"et-scrollable-button et-scrollable-button--start\"\n    aria-hidden=\"true\"\n    type=\"button\"\n    tabindex=\"-1\"\n  >\n    <et-chevron-icon />\n  </button>\n  <button\n    (click)=\"scrollToStartEnd()\"\n    class=\"et-scrollable-button et-scrollable-button--end\"\n    aria-hidden=\"true\"\n    type=\"button\"\n    tabindex=\"-1\"\n  >\n    <et-chevron-icon />\n  </button>\n</div>\n"]}
|
|
449
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"scrollable.component.js","sourceRoot":"","sources":["../../../../../../../../../libs/cdk/src/lib/components/scrollable/components/scrollable/scrollable.component.ts","../../../../../../../../../libs/cdk/src/lib/components/scrollable/components/scrollable/scrollable.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  ViewChild,\n  ViewEncapsulation,\n  booleanAttribute,\n  computed,\n  effect,\n  inject,\n  isDevMode,\n  numberAttribute,\n  signal,\n} from '@angular/core';\nimport {\n  CurrentElementVisibility,\n  CursorDragScrollDirective,\n  IS_ACTIVE_ELEMENT,\n  IS_ELEMENT,\n  IsActiveElementDirective,\n  IsElementDirective,\n  LetDirective,\n  NgClassType,\n  ObserveScrollStateDirective,\n  ScrollObserverScrollState,\n  ScrollToElementOptions,\n  TypedQueryList,\n  createDestroy,\n  getElementVisibleStates,\n  isElementVisible,\n  nextFrame,\n  scrollToElement,\n  signalElementIntersection,\n  signalElementScrollState,\n  signalHostAttributes,\n  signalHostClasses,\n} from '@ethlete/core';\nimport { BehaviorSubject, debounceTime, fromEvent, merge, of, startWith, takeUntil, tap } from 'rxjs';\nimport { ChevronIconComponent } from '../../../icons';\nimport { ScrollableIntersectionChange, ScrollableScrollMode } from '../../types';\n\n@Component({\n  selector: 'et-scrollable',\n  templateUrl: './scrollable.component.html',\n  styleUrls: ['./scrollable.component.scss'],\n  standalone: true,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [CursorDragScrollDirective, ObserveScrollStateDirective, NgClass, LetDirective, ChevronIconComponent],\n  host: {\n    class: 'et-scrollable',\n  },\n})\nexport class ScrollableComponent implements AfterContentInit {\n  private readonly _destroy$ = createDestroy();\n  private readonly _elementRef = inject<ElementRef<HTMLElement>>(ElementRef);\n\n  private readonly _isCursorDragging$ = new BehaviorSubject<boolean>(false);\n  private readonly _latestVisibilityStates$ = new BehaviorSubject<ScrollableIntersectionChange[]>([]);\n\n  @Input({ alias: 'itemSize' })\n  set _itemSize(v: 'auto' | 'same' | 'full') {\n    this.itemSize.set(v);\n  }\n  readonly itemSize = signal<'auto' | 'same' | 'full'>('auto');\n\n  @Input({ alias: 'direction' })\n  set _direction(v: 'horizontal' | 'vertical') {\n    this.direction.set(v);\n  }\n  readonly direction = signal<'horizontal' | 'vertical'>('horizontal');\n\n  @Input({ alias: 'scrollableRole' })\n  set _scrollableRole(v: string | null) {\n    this.scrollableRole.set(v);\n  }\n  readonly scrollableRole = signal<string | null>(null);\n\n  @Input({ alias: 'scrollableClass' })\n  set _scrollableClass(v: NgClassType | null) {\n    this.scrollableClass.set(v);\n  }\n  readonly scrollableClass = signal<NgClassType | null>(null);\n\n  @Input({ transform: booleanAttribute, alias: 'renderMasks' })\n  set _renderMasks(v: boolean) {\n    this.renderMasks.set(v);\n  }\n  readonly renderMasks = signal(true);\n\n  @Input({ transform: booleanAttribute, alias: 'renderButtons' })\n  set _renderButtons(v: boolean) {\n    this.renderButtons.set(v);\n  }\n  readonly renderButtons = signal(true);\n\n  @Input({ transform: booleanAttribute, alias: 'renderScrollbars' })\n  set _renderScrollbars(v: boolean) {\n    this.renderScrollbars.set(v);\n  }\n  readonly renderScrollbars = signal(false);\n\n  @Input({ transform: booleanAttribute, alias: 'stickyButtons' })\n  set _stickyButtons(v: boolean) {\n    this.stickyButtons.set(v);\n  }\n  readonly stickyButtons = signal(false);\n\n  @Input({ transform: booleanAttribute, alias: 'cursorDragScroll' })\n  set _cursorDragScroll(v: boolean) {\n    this.cursorDragScroll.set(v);\n  }\n  readonly cursorDragScroll = signal(true);\n\n  @Input({ transform: booleanAttribute, alias: 'disableActiveElementScrolling' })\n  set _disableActiveElementScrolling(v: boolean) {\n    this.disableActiveElementScrolling.set(v);\n  }\n  readonly disableActiveElementScrolling = signal(false);\n\n  @Input({ alias: 'scrollMode' })\n  set _scrollMode(v: ScrollableScrollMode) {\n    this.scrollMode.set(v);\n  }\n  readonly scrollMode = signal<ScrollableScrollMode>('container');\n\n  @Input({ transform: booleanAttribute, alias: 'snap' })\n  set _snap(v: boolean) {\n    this.snap.set(v);\n  }\n  readonly snap = signal(false);\n\n  @Input({ transform: numberAttribute, alias: 'scrollMargin' })\n  set _scrollMargin(v: number) {\n    this.scrollMargin.set(v);\n  }\n  readonly scrollMargin = signal(0);\n\n  @Output()\n  readonly scrollStateChange = new EventEmitter<ScrollObserverScrollState>();\n\n  @Output()\n  readonly intersectionChange = new EventEmitter<ScrollableIntersectionChange[]>();\n\n  @ViewChild('scrollable', { static: true })\n  private set _scrollable(e: ElementRef<HTMLElement>) {\n    this.scrollable.set(e);\n  }\n  readonly scrollable = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ViewChild('firstElement', { static: true })\n  private set _firstElement(e: ElementRef<HTMLElement>) {\n    this.firstElement.set(e);\n  }\n  readonly firstElement = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ViewChild('lastElement', { static: true })\n  private set _lastElement(e: ElementRef<HTMLElement>) {\n    this.lastElement.set(e);\n  }\n  readonly lastElement = signal<ElementRef<HTMLElement> | null>(null);\n\n  @ContentChildren(IS_ACTIVE_ELEMENT, { descendants: true })\n  private set _activeElementList(e: TypedQueryList<IsActiveElementDirective>) {\n    this.activeElementList.set(e);\n  }\n  readonly activeElementList = signal<TypedQueryList<IsActiveElementDirective> | null>(null);\n\n  @ContentChildren(IS_ELEMENT, { descendants: true })\n  private set _elementList(e: TypedQueryList<IsElementDirective>) {\n    this.elementList.set(e);\n  }\n  readonly elementList = signal<TypedQueryList<IsElementDirective> | null>(null);\n\n  get highestVisibleIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    return elements.reduce((prev, curr) => {\n      if (!prev) {\n        return curr;\n      }\n\n      return curr.intersectionRatio > prev.intersectionRatio ? curr : prev;\n    });\n  }\n\n  get nextPartialIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    const highestVisibleIntersection = this.highestVisibleIntersection;\n\n    if (!highestVisibleIntersection) {\n      return null;\n    }\n\n    const nextIndex = elements.slice(highestVisibleIntersection.index).findIndex((e) => !e.isIntersecting);\n\n    if (nextIndex === -1) {\n      return null;\n    }\n\n    const nextElement = elements[highestVisibleIntersection.index + nextIndex];\n\n    return nextElement || null;\n  }\n\n  get previousPartialIntersection() {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      return null;\n    }\n\n    const highestVisibleIntersection = this.highestVisibleIntersection;\n\n    if (!highestVisibleIntersection) {\n      return null;\n    }\n\n    const previousIndex = elements\n      .slice(0, highestVisibleIntersection.index)\n      .reverse()\n      .findIndex((e) => !e.isIntersecting);\n\n    if (previousIndex === -1) {\n      return null;\n    }\n\n    const previousElement = elements[highestVisibleIntersection.index - previousIndex - 1];\n\n    return previousElement || null;\n  }\n\n  protected readonly containerScrollState = signalElementScrollState(this.scrollable);\n  protected readonly firstElementIntersection = signalElementIntersection(this.firstElement, { root: this.scrollable });\n  protected readonly firstElementVisibility = signal<CurrentElementVisibility | null>(null);\n  protected readonly lastElementIntersection = signalElementIntersection(this.lastElement, { root: this.scrollable });\n  protected readonly lastElementVisibility = signal<CurrentElementVisibility | null>(null);\n\n  protected readonly canScroll = computed(() => {\n    const dir = this.direction();\n\n    if (dir === 'horizontal') {\n      return this.containerScrollState().canScrollHorizontally;\n    }\n\n    return this.containerScrollState().canScrollVertically;\n  });\n\n  protected readonly isAtStart = computed(() => {\n    if (!this.canScroll()) {\n      return true;\n    }\n\n    const intersection = this.firstElementIntersection();\n\n    if (!intersection) {\n      return this.firstElementVisibility()?.inline ?? true;\n    }\n\n    return intersection.isIntersecting;\n  });\n  protected readonly isAtEnd = computed(() => {\n    if (!this.canScroll()) {\n      return true;\n    }\n\n    const intersection = this.lastElementIntersection();\n\n    if (!intersection) {\n      return this.lastElementVisibility()?.inline ?? true;\n    }\n\n    return intersection.isIntersecting;\n  });\n\n  protected readonly enableOverlayAnimations = signal(false);\n\n  protected readonly hostAttributes = signalHostAttributes({\n    'item-size': this.itemSize,\n    direction: this.direction,\n    'render-scrollbars': this.renderScrollbars,\n    'sticky-buttons': this.stickyButtons,\n  });\n\n  protected readonly hostClasses = signalHostClasses({\n    'et-scrollable--can-scroll': this.canScroll,\n    'et-scrollable--is-at-start': this.isAtStart,\n    'et-scrollable--is-at-end': this.isAtEnd,\n    'et-scrollable--enable-overlay-animations': this.enableOverlayAnimations,\n  });\n\n  constructor() {\n    effect(\n      () => {\n        const scrollable = this.scrollable()?.nativeElement;\n        const firstElement = this.firstElement()?.nativeElement;\n        const lastElement = this.lastElement()?.nativeElement;\n        const activeElementList = this.activeElementList()?.toArray();\n\n        if (!scrollable || !firstElement || !lastElement || !activeElementList) {\n          return;\n        }\n\n        const firstActive = activeElementList.find((a) => a.isActiveElement);\n\n        if (firstActive && !this.disableActiveElementScrolling()) {\n          const offsetTop = firstActive.elementRef.nativeElement.offsetTop - scrollable.offsetTop;\n          const offsetLeft = firstActive.elementRef.nativeElement.offsetLeft - scrollable.offsetLeft;\n          scrollable.scrollLeft = offsetLeft;\n          scrollable.scrollTop = offsetTop;\n        }\n\n        this.firstElementVisibility.set(\n          isElementVisible({\n            container: scrollable,\n            element: firstElement,\n          }),\n        );\n\n        this.lastElementVisibility.set(\n          isElementVisible({\n            container: scrollable,\n            element: lastElement,\n          }),\n        );\n\n        // We need to wait one frame before enabling animations to prevent a animation from playing during initial render.\n        nextFrame(() => this.enableOverlayAnimations.set(true));\n      },\n      { allowSignalWrites: true },\n    );\n\n    effect(() => {\n      const isAtStart = this.isAtStart();\n      const isAtEnd = this.isAtEnd();\n      const canScroll = this.canScroll();\n\n      this.scrollStateChange.emit({\n        canScroll,\n        isAtEnd: !!isAtEnd,\n        isAtStart: !!isAtStart,\n      });\n    });\n  }\n\n  ngAfterContentInit(): void {\n    this._setupScrollListening();\n  }\n\n  scrollOneContainerSize(direction: 'start' | 'end') {\n    const scrollElement = this.scrollable()?.nativeElement;\n\n    if (!scrollElement) {\n      return;\n    }\n\n    const parent = this._elementRef.nativeElement;\n\n    const scrollableSize = this.direction() === 'horizontal' ? parent.clientWidth : parent.clientHeight;\n    const currentScroll = this.direction() === 'horizontal' ? scrollElement.scrollLeft : scrollElement.scrollTop;\n\n    scrollElement.scrollTo({\n      [this.direction() === 'horizontal' ? 'left' : 'top']:\n        currentScroll + (direction === 'start' ? -scrollableSize : scrollableSize),\n      behavior: 'smooth',\n    });\n  }\n\n  scrollOneItemSize(direction: 'start' | 'end') {\n    const elements = this._latestVisibilityStates$.value;\n\n    if (!elements.length) {\n      if (isDevMode()) {\n        console.warn(\n          'No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.',\n        );\n      }\n      return;\n    }\n\n    const el = direction === 'start' ? this.previousPartialIntersection : this.nextPartialIntersection;\n\n    if (!el) {\n      return;\n    }\n\n    this.scrollToElement({\n      element: el?.element,\n      direction: this.direction() === 'horizontal' ? 'inline' : 'block',\n      origin: direction,\n      ...(this.direction() === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin() }\n        : { scrollBlockMargin: this.scrollMargin() }),\n    });\n  }\n\n  scrollToElement(options: Omit<ScrollToElementOptions, 'container'>) {\n    const scrollElement = this.scrollable()?.nativeElement;\n\n    scrollToElement({\n      container: scrollElement,\n      ...(this.direction() === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin() }\n        : { scrollBlockMargin: this.scrollMargin() }),\n      ...options,\n    });\n  }\n\n  scrollToElementByIndex(options: Omit<ScrollToElementOptions, 'container'> & { index: number }) {\n    const elements = this.elementList()?.toArray() ?? [];\n\n    if (!elements.length) {\n      if (isDevMode()) {\n        console.warn(\n          'No elements found to scroll to. Make sure to apply the isElement directive to the elements you want to scroll to.',\n        );\n      }\n      return;\n    }\n\n    const scrollElement = this.scrollable()?.nativeElement;\n    const element = elements[options.index]?.elementRef.nativeElement;\n\n    scrollToElement({\n      container: scrollElement,\n      element,\n      ...(this.direction() === 'horizontal'\n        ? { scrollInlineMargin: this.scrollMargin() }\n        : { scrollBlockMargin: this.scrollMargin() }),\n      ...options,\n    });\n  }\n\n  protected setIsCursorDragging(isDragging: boolean) {\n    this._isCursorDragging$.next(isDragging);\n  }\n\n  protected scrollToStartDirection() {\n    if (this.scrollMode() === 'container') {\n      this.scrollOneContainerSize('start');\n    } else {\n      this.scrollOneItemSize('start');\n    }\n  }\n\n  protected scrollToStartEnd() {\n    if (this.scrollMode() === 'container') {\n      this.scrollOneContainerSize('end');\n    } else {\n      this.scrollOneItemSize('end');\n    }\n  }\n\n  private _setupScrollListening() {\n    const scrollElement = this.scrollable()?.nativeElement;\n    const elements = this.elementList();\n\n    if (!scrollElement || !elements) {\n      return;\n    }\n\n    let isSnapping = false;\n    let snapTimeout = 0;\n\n    merge(fromEvent<WheelEvent>(scrollElement, 'wheel'), fromEvent<TouchEvent>(scrollElement, 'touchstart'))\n      .pipe(\n        takeUntil(this._destroy$),\n        tap(() => {\n          isSnapping = false;\n        }),\n      )\n      .subscribe();\n\n    merge(\n      fromEvent(scrollElement, 'scroll'),\n      this._isCursorDragging$,\n      elements.changes.pipe(startWith(elements)) ?? of(null),\n    )\n      .pipe(\n        debounceTime(300),\n        takeUntil(this._destroy$),\n        tap(() => {\n          const els =\n            elements\n              ?.toArray()\n              .map((e) => e?.elementRef.nativeElement)\n              .filter((e): e is HTMLElement => !!e) ?? [];\n\n          if (!els.length) {\n            this._latestVisibilityStates$.next([]);\n\n            return;\n          }\n\n          const states = getElementVisibleStates({\n            elements: els,\n            container: scrollElement,\n          });\n\n          const prop = this.direction() === 'horizontal' ? 'inlineIntersection' : 'blockIntersection';\n          const stateClass = `et-element--is-intersecting`;\n\n          for (const state of states) {\n            if (state[prop] === 100) {\n              state.element.classList.add(stateClass);\n            } else {\n              state.element.classList.remove(stateClass);\n            }\n          }\n\n          const intersectionChanges = states.map((s, i) => {\n            const state: ScrollableIntersectionChange = {\n              element: s.element,\n              intersectionRatio: s[prop] / 100,\n              isIntersecting: s[prop] === 100,\n              index: i,\n            };\n\n            return state;\n          });\n\n          this.intersectionChange.emit(intersectionChanges);\n\n          this._latestVisibilityStates$.next(intersectionChanges);\n\n          if (isSnapping || this._isCursorDragging$.value || !this.snap()) return;\n\n          const prev = this.previousPartialIntersection;\n          const next = this.nextPartialIntersection;\n          const skipSnap =\n            !prev ||\n            !next ||\n            prev.intersectionRatio === 0 ||\n            next.intersectionRatio === 0 ||\n            prev.intersectionRatio === next.intersectionRatio;\n\n          if (skipSnap) return;\n\n          const highestIntersecting = prev.intersectionRatio > next.intersectionRatio ? prev : next;\n          const fullIntersectionIndex = this.highestVisibleIntersection?.index;\n\n          if (fullIntersectionIndex === undefined) return;\n\n          const highestIntersectingIndex = highestIntersecting.index;\n          const origin = highestIntersectingIndex > fullIntersectionIndex ? 'end' : 'start';\n\n          scrollToElement({\n            container: scrollElement,\n            element: highestIntersecting.element,\n            direction: this.direction() === 'horizontal' ? 'inline' : 'block',\n            origin,\n            scrollBlockMargin: this.direction() === 'horizontal' ? 0 : this.scrollMargin(),\n            scrollInlineMargin: this.direction() === 'horizontal' ? this.scrollMargin() : 0,\n          });\n\n          isSnapping = true;\n\n          window.clearTimeout(snapTimeout);\n\n          snapTimeout = window.setTimeout(() => {\n            isSnapping = false;\n          }, 1000);\n        }),\n      )\n      .subscribe();\n  }\n}\n","<div\n  #scrollable\n  [attr.role]=\"scrollableRole() ?? undefined\"\n  [etCursorDragScroll]=\"cursorDragScroll()\"\n  [allowedDirection]=\"direction()\"\n  (cursorDragStart)=\"setIsCursorDragging(true)\"\n  (cursorDragEnd)=\"setIsCursorDragging(false)\"\n  class=\"et-scrollable-container-outer\"\n>\n  <div [ngClass]=\"scrollableClass()\" class=\"et-scrollable-container\">\n    <div #firstElement class=\"et-scroll-observer-first-element\"></div>\n    <ng-content />\n    <div #lastElement class=\"et-scroll-observer-last-element\"></div>\n  </div>\n</div>\n\n@if (renderMasks()) {\n  <div class=\"et-scrollable-masks\">\n    <div class=\"et-scrollable-mask et-scrollable-mask--start\"></div>\n    <div class=\"et-scrollable-mask et-scrollable-mask--end\"></div>\n  </div>\n}\n\n@if (renderButtons()) {\n  <div class=\"et-scrollable-buttons\">\n    <button\n      (click)=\"scrollToStartDirection()\"\n      class=\"et-scrollable-button et-scrollable-button--start\"\n      aria-hidden=\"true\"\n      type=\"button\"\n      tabindex=\"-1\"\n    >\n      <et-chevron-icon />\n    </button>\n    <button\n      (click)=\"scrollToStartEnd()\"\n      class=\"et-scrollable-button et-scrollable-button--end\"\n      aria-hidden=\"true\"\n      type=\"button\"\n      tabindex=\"-1\"\n    >\n      <et-chevron-icon />\n    </button>\n  </div>\n}\n"]}
|