@eui/ecl 18.0.0-next.75 → 18.0.0-next.77
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/assets/i18n-ecl/bg.json +1 -0
- package/assets/i18n-ecl/cs.json +1 -0
- package/assets/i18n-ecl/da.json +1 -0
- package/assets/i18n-ecl/de.json +1 -0
- package/assets/i18n-ecl/el.json +1 -0
- package/assets/i18n-ecl/en.json +1 -0
- package/assets/i18n-ecl/es.json +1 -0
- package/assets/i18n-ecl/et.json +1 -0
- package/assets/i18n-ecl/fi.json +1 -0
- package/assets/i18n-ecl/fr.json +1 -0
- package/assets/i18n-ecl/ga.json +1 -0
- package/assets/i18n-ecl/hr.json +1 -0
- package/assets/i18n-ecl/hu.json +1 -0
- package/assets/i18n-ecl/it.json +1 -0
- package/assets/i18n-ecl/lt.json +1 -0
- package/assets/i18n-ecl/lv.json +1 -0
- package/assets/i18n-ecl/mt.json +1 -0
- package/assets/i18n-ecl/nl.json +1 -0
- package/assets/i18n-ecl/pl.json +1 -0
- package/assets/i18n-ecl/pt.json +1 -0
- package/assets/i18n-ecl/ro.json +1 -0
- package/assets/i18n-ecl/sk.json +1 -0
- package/assets/i18n-ecl/sl.json +1 -0
- package/assets/i18n-ecl/sv.json +1 -0
- package/docs/components/EclMultiselectDropdownComponent.html +1 -1
- package/docs/components/EclSelectContainerComponent.html +25 -1
- package/docs/components/EclTabsComponent.html +3 -3
- package/docs/dependencies.html +19 -19
- package/docs/directives/EclSelectDirective.html +24 -0
- package/docs/directives/EclTableCellGroupDirective.html +49 -0
- package/docs/js/search/search_index.js +2 -2
- package/esm2022/lib/components/ecl-accordion/ecl-accordion-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-accordion/ecl-accordion.component.mjs +3 -3
- package/esm2022/lib/components/ecl-accordion/ecl-accordion.module.mjs +4 -4
- package/esm2022/lib/components/ecl-app/ecl-app.component.mjs +3 -3
- package/esm2022/lib/components/ecl-app/ecl-app.module.mjs +4 -4
- package/esm2022/lib/components/ecl-banner/ecl-banner-description.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-banner/ecl-banner-picture.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-banner/ecl-banner-title.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-banner/ecl-banner.component.mjs +3 -3
- package/esm2022/lib/components/ecl-banner/ecl-banner.module.mjs +4 -4
- package/esm2022/lib/components/ecl-base.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-blockquote/ecl-blockquote-picture.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-blockquote/ecl-blockquote.component.mjs +3 -3
- package/esm2022/lib/components/ecl-blockquote/ecl-blockquote.module.mjs +4 -4
- package/esm2022/lib/components/ecl-breadcrumb/ecl-breadcrumb-segment.component.mjs +3 -3
- package/esm2022/lib/components/ecl-breadcrumb/ecl-breadcrumb.component.mjs +3 -3
- package/esm2022/lib/components/ecl-breadcrumb/ecl-breadcrumb.module.mjs +4 -4
- package/esm2022/lib/components/ecl-button/ecl-button-label.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-button/ecl-button.component.mjs +5 -5
- package/esm2022/lib/components/ecl-button/ecl-button.module.mjs +4 -4
- package/esm2022/lib/components/ecl-card/ecl-card-body.component.mjs +3 -3
- package/esm2022/lib/components/ecl-card/ecl-card-picture.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-card/ecl-card.component.mjs +3 -3
- package/esm2022/lib/components/ecl-card/ecl-card.module.mjs +4 -4
- package/esm2022/lib/components/ecl-carousel/ecl-carousel-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-carousel/ecl-carousel.component.mjs +3 -3
- package/esm2022/lib/components/ecl-carousel/ecl-carousel.module.mjs +4 -4
- package/esm2022/lib/components/ecl-category-filter/ecl-category-filter/ecl-category-filter.component.mjs +3 -3
- package/esm2022/lib/components/ecl-category-filter/ecl-category-filter-list/ecl-category-filter-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-category-filter/ecl-category-filter-list/ecl-category-filter-list.component.mjs +3 -3
- package/esm2022/lib/components/ecl-category-filter/ecl-category-filter.module.mjs +4 -4
- package/esm2022/lib/components/ecl-checkbox/ecl-checkbox-help.component.mjs +3 -3
- package/esm2022/lib/components/ecl-checkbox/ecl-checkbox-input.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-checkbox/ecl-checkbox-label.component.mjs +3 -3
- package/esm2022/lib/components/ecl-checkbox/ecl-checkbox.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-checkbox/ecl-checkbox.module.mjs +4 -4
- package/esm2022/lib/components/ecl-content-block/ecl-content-block-elements.directive.mjs +51 -51
- package/esm2022/lib/components/ecl-content-block/ecl-content-block.component.mjs +3 -3
- package/esm2022/lib/components/ecl-content-block/ecl-content-block.module.mjs +4 -4
- package/esm2022/lib/components/ecl-content-item/ecl-content-item-image.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-content-item/ecl-content-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-content-item/ecl-content-item.module.mjs +4 -4
- package/esm2022/lib/components/ecl-date-block/ecl-date-block.component.mjs +3 -3
- package/esm2022/lib/components/ecl-date-block/ecl-date-block.module.mjs +4 -4
- package/esm2022/lib/components/ecl-date-picker/ecl-date-picker.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-date-picker/ecl-date-picker.module.mjs +4 -4
- package/esm2022/lib/components/ecl-expandable/ecl-expandable.component.mjs +3 -3
- package/esm2022/lib/components/ecl-expandable/ecl-expandable.module.mjs +4 -4
- package/esm2022/lib/components/ecl-fact-figures/ecl-fact-figures-description.component.mjs +3 -3
- package/esm2022/lib/components/ecl-fact-figures/ecl-fact-figures-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-fact-figures/ecl-fact-figures-title.component.mjs +3 -3
- package/esm2022/lib/components/ecl-fact-figures/ecl-fact-figures-value.component.mjs +3 -3
- package/esm2022/lib/components/ecl-fact-figures/ecl-fact-figures-view-all.component.mjs +3 -3
- package/esm2022/lib/components/ecl-fact-figures/ecl-fact-figures.component.mjs +3 -3
- package/esm2022/lib/components/ecl-fact-figures/ecl-fact-figures.module.mjs +4 -4
- package/esm2022/lib/components/ecl-featured/ecl-featured-item-description.component.mjs +3 -3
- package/esm2022/lib/components/ecl-featured/ecl-featured-item-footer.component.mjs +3 -3
- package/esm2022/lib/components/ecl-featured/ecl-featured-item-link.directive.mjs +9 -9
- package/esm2022/lib/components/ecl-featured/ecl-featured-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-featured/ecl-featured.component.mjs +3 -3
- package/esm2022/lib/components/ecl-featured/ecl-featured.module.mjs +4 -4
- package/esm2022/lib/components/ecl-feedback-message/ecl-feedback-message.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-feedback-message/ecl-feedback-message.module.mjs +4 -4
- package/esm2022/lib/components/ecl-file/ecl-file-download.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-file/ecl-file-item/ecl-file-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-file/ecl-file-items/ecl-file-items.component.mjs +3 -3
- package/esm2022/lib/components/ecl-file/ecl-file-picture.directive.mjs +9 -9
- package/esm2022/lib/components/ecl-file/ecl-file-taxonomy/ecl-file-taxonomy.component.mjs +3 -3
- package/esm2022/lib/components/ecl-file/ecl-file.component.mjs +3 -3
- package/esm2022/lib/components/ecl-file/ecl-file.module.mjs +4 -4
- package/esm2022/lib/components/ecl-file-upload/ecl-file-upload.directive.mjs +5 -5
- package/esm2022/lib/components/ecl-file-upload/ecl-file-upload.module.mjs +4 -4
- package/esm2022/lib/components/ecl-form-group/ecl-form-group.component.mjs +3 -3
- package/esm2022/lib/components/ecl-form-group/ecl-form-group.module.mjs +4 -4
- package/esm2022/lib/components/ecl-form-label/ecl-form-label.component.mjs +3 -3
- package/esm2022/lib/components/ecl-form-label/ecl-form-label.module.mjs +4 -4
- package/esm2022/lib/components/ecl-gallery/ecl-gallery-footer.component.mjs +3 -3
- package/esm2022/lib/components/ecl-gallery/ecl-gallery-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-gallery/ecl-gallery-media.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-gallery/ecl-gallery.component.mjs +3 -3
- package/esm2022/lib/components/ecl-gallery/ecl-gallery.module.mjs +4 -4
- package/esm2022/lib/components/ecl-help-block/ecl-help-block.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-help-block/ecl-help-block.module.mjs +4 -4
- package/esm2022/lib/components/ecl-icon/ecl-icon.component.mjs +3 -3
- package/esm2022/lib/components/ecl-icon/ecl-icon.module.mjs +4 -4
- package/esm2022/lib/components/ecl-inpage-navigation/ecl-inpage-navigation-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.component.mjs +3 -3
- package/esm2022/lib/components/ecl-inpage-navigation/ecl-inpage-navigation.module.mjs +4 -4
- package/esm2022/lib/components/ecl-label/ecl-label.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-label/ecl-label.module.mjs +4 -4
- package/esm2022/lib/components/ecl-link/ecl-link-label.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-link/ecl-link.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-link/ecl-link.module.mjs +4 -4
- package/esm2022/lib/components/ecl-list/ecl-description-list-definition/ecl-description-list-definition.component.mjs +3 -3
- package/esm2022/lib/components/ecl-list/ecl-description-list-definition-item.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-list/ecl-list.directive.mjs +18 -18
- package/esm2022/lib/components/ecl-list/ecl-list.module.mjs +4 -4
- package/esm2022/lib/components/ecl-list-illustration/ecl-list-illustration-icon.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-list-illustration/ecl-list-illustration-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-list-illustration/ecl-list-illustration-picture.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-list-illustration/ecl-list-illustration.component.mjs +3 -3
- package/esm2022/lib/components/ecl-list-illustration/ecl-list-illustration.module.mjs +4 -4
- package/esm2022/lib/components/ecl-loading-indicator/ecl-loading-indicator-label.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-loading-indicator/ecl-loading-indicator-overlay.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-loading-indicator/ecl-loading-indicator.component.mjs +3 -3
- package/esm2022/lib/components/ecl-loading-indicator/ecl-loading-indicator.module.mjs +4 -4
- package/esm2022/lib/components/ecl-media-container/ecl-media-container-iframe.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-media-container/ecl-media-container-item.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-media-container/ecl-media-container-picture.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-media-container/ecl-media-container.component.mjs +3 -3
- package/esm2022/lib/components/ecl-media-container/ecl-media-container.module.mjs +4 -4
- package/esm2022/lib/components/ecl-menu/ecl-menu/ecl-menu-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-menu/ecl-menu/ecl-menu.component.mjs +3 -3
- package/esm2022/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-menu/ecl-menu-mega/ecl-menu-mega.component.mjs +3 -3
- package/esm2022/lib/components/ecl-menu/ecl-menu.module.mjs +4 -4
- package/esm2022/lib/components/ecl-modal/ecl-modal-body-fixed.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-modal/ecl-modal-body.component.mjs +3 -3
- package/esm2022/lib/components/ecl-modal/ecl-modal-close.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-modal/ecl-modal-footer.component.mjs +3 -3
- package/esm2022/lib/components/ecl-modal/ecl-modal-header.component.mjs +3 -3
- package/esm2022/lib/components/ecl-modal/ecl-modal-trigger.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-modal/ecl-modal.component.mjs +3 -3
- package/esm2022/lib/components/ecl-modal/ecl-modal.module.mjs +4 -4
- package/esm2022/lib/components/ecl-multiselect/boldText.pipe.mjs +3 -3
- package/esm2022/lib/components/ecl-multiselect/ecl-multiselect-dropdown/ecl-multiselect-dropdown.component.mjs +6 -6
- package/esm2022/lib/components/ecl-multiselect/ecl-multiselect-input/ecl-multiselect-input.component.mjs +3 -3
- package/esm2022/lib/components/ecl-multiselect/ecl-multiselect-optgroup/ecl-multiselect-optgroup.component.mjs +3 -3
- package/esm2022/lib/components/ecl-multiselect/ecl-multiselect-option/ecl-multiselect-option.component.mjs +3 -3
- package/esm2022/lib/components/ecl-multiselect/ecl-multiselect-option.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-multiselect/ecl-multiselect.component.mjs +3 -3
- package/esm2022/lib/components/ecl-multiselect/ecl-multiselect.module.mjs +4 -4
- package/esm2022/lib/components/ecl-navigation-list/ecl-navigation-list-image/ecl-navigation-list-image.component.mjs +3 -3
- package/esm2022/lib/components/ecl-navigation-list/ecl-navigation-list-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-navigation-list/ecl-navigation-list-picture.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-navigation-list/ecl-navigation-list.component.mjs +3 -3
- package/esm2022/lib/components/ecl-navigation-list/ecl-navigation-list.module.mjs +4 -4
- package/esm2022/lib/components/ecl-news-ticker/ecl-news-ticker-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-news-ticker/ecl-news-ticker.component.mjs +3 -3
- package/esm2022/lib/components/ecl-news-ticker/ecl-news-ticker.module.mjs +4 -4
- package/esm2022/lib/components/ecl-notification/ecl-notification-title.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-notification/ecl-notification.component.mjs +3 -3
- package/esm2022/lib/components/ecl-notification/ecl-notification.module.mjs +4 -4
- package/esm2022/lib/components/ecl-page-header/ecl-page-header-background.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-page-header/ecl-page-header-description.directive.mjs +12 -12
- package/esm2022/lib/components/ecl-page-header/ecl-page-header-info.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-page-header/ecl-page-header-meta.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-page-header/ecl-page-header-title.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-page-header/ecl-page-header.component.mjs +3 -3
- package/esm2022/lib/components/ecl-page-header/ecl-page-header.module.mjs +4 -4
- package/esm2022/lib/components/ecl-pagination/ecl-pagination-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-pagination/ecl-pagination.component.mjs +3 -3
- package/esm2022/lib/components/ecl-pagination/ecl-pagination.module.mjs +4 -4
- package/esm2022/lib/components/ecl-popover/ecl-popover-content.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-popover/ecl-popover-toggle.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-popover/ecl-popover.component.mjs +3 -3
- package/esm2022/lib/components/ecl-popover/ecl-popover.module.mjs +4 -4
- package/esm2022/lib/components/ecl-radio/ecl-radio-help.component.mjs +3 -3
- package/esm2022/lib/components/ecl-radio/ecl-radio-input.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-radio/ecl-radio-label.component.mjs +3 -3
- package/esm2022/lib/components/ecl-radio/ecl-radio.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-radio/ecl-radio.module.mjs +4 -4
- package/esm2022/lib/components/ecl-range/ecl-range-value.component.mjs +3 -3
- package/esm2022/lib/components/ecl-range/ecl-range.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-range/ecl-range.module.mjs +4 -4
- package/esm2022/lib/components/ecl-rating-field/ecl-rating-field.component.mjs +3 -3
- package/esm2022/lib/components/ecl-rating-field/ecl-rating-field.module.mjs +4 -4
- package/esm2022/lib/components/ecl-search-form/ecl-search-form.component.mjs +3 -3
- package/esm2022/lib/components/ecl-search-form/ecl-search-form.module.mjs +4 -4
- package/esm2022/lib/components/ecl-select/ecl-select-container.component.mjs +8 -5
- package/esm2022/lib/components/ecl-select/ecl-select.directive.mjs +8 -4
- package/esm2022/lib/components/ecl-select/ecl-select.module.mjs +4 -4
- package/esm2022/lib/components/ecl-site-footer/ecl-footer-elements/ec/ecl-site-footer-fixed-content.mjs +3 -3
- package/esm2022/lib/components/ecl-site-footer/ecl-footer-elements/ecl-site-footer-column.directive.mjs +9 -9
- package/esm2022/lib/components/ecl-site-footer/ecl-footer-elements/ecl-site-footer-description.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-site-footer/ecl-footer-elements/ecl-site-footer-link.directive.mjs +12 -12
- package/esm2022/lib/components/ecl-site-footer/ecl-footer-elements/ecl-site-footer-list.directive.mjs +15 -15
- package/esm2022/lib/components/ecl-site-footer/ecl-footer-elements/ecl-site-footer-section.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-site-footer/ecl-footer-elements/ecl-site-footer-title.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-site-footer/ecl-footer-elements/eu/ecl-site-footer-fixed-content.mjs +3 -3
- package/esm2022/lib/components/ecl-site-footer/ecl-site-footer.component.mjs +3 -3
- package/esm2022/lib/components/ecl-site-footer/ecl-site-footer.module.mjs +4 -4
- package/esm2022/lib/components/ecl-site-header/action/ecl-site-header-action.component.mjs +3 -3
- package/esm2022/lib/components/ecl-site-header/banner-top/ecl-site-header-banner-top.component.mjs +3 -3
- package/esm2022/lib/components/ecl-site-header/cta/ecl-site-header-cta.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-site-header/ecl-site-header-environment/ecl-site-header-environment.component.mjs +3 -3
- package/esm2022/lib/components/ecl-site-header/ecl-site-header.component.mjs +3 -3
- package/esm2022/lib/components/ecl-site-header/ecl-site-header.module.mjs +4 -4
- package/esm2022/lib/components/ecl-site-header/language/ecl-site-header-language-popover.component.mjs +3 -3
- package/esm2022/lib/components/ecl-site-header/language/ecl-site-header-language.component.mjs +3 -3
- package/esm2022/lib/components/ecl-site-header/login/ecl-site-header-login-details.directive.mjs +6 -6
- package/esm2022/lib/components/ecl-site-header/login/ecl-site-header-login.component.mjs +3 -3
- package/esm2022/lib/components/ecl-site-header/notification/ecl-site-header-notification.component.mjs +3 -3
- package/esm2022/lib/components/ecl-site-header/picture/ecl-site-header-picture.directive.mjs +9 -9
- package/esm2022/lib/components/ecl-site-header/search/ecl-site-header-search.component.mjs +3 -3
- package/esm2022/lib/components/ecl-social-media-follow/ecl-social-media-follow-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-social-media-follow/ecl-social-media-follow-link.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-social-media-follow/ecl-social-media-follow.component.mjs +3 -3
- package/esm2022/lib/components/ecl-social-media-follow/ecl-social-media-follow.module.mjs +4 -4
- package/esm2022/lib/components/ecl-social-media-share/ecl-social-media-share-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-social-media-share/ecl-social-media-share-link.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-social-media-share/ecl-social-media-share.component.mjs +3 -3
- package/esm2022/lib/components/ecl-social-media-share/ecl-social-media-share.module.mjs +4 -4
- package/esm2022/lib/components/ecl-sticky-container/ecl-sticky-container.component.mjs +3 -3
- package/esm2022/lib/components/ecl-sticky-container/ecl-sticky-container.module.mjs +4 -4
- package/esm2022/lib/components/ecl-table/ecl-table-sort-button.component.mjs +3 -3
- package/esm2022/lib/components/ecl-table/ecl-table.directive.mjs +35 -27
- package/esm2022/lib/components/ecl-table/ecl-table.module.mjs +4 -4
- package/esm2022/lib/components/ecl-tabs/ecl-tab-label.component.mjs +3 -3
- package/esm2022/lib/components/ecl-tabs/ecl-tab-more.component.mjs +3 -3
- package/esm2022/lib/components/ecl-tabs/ecl-tab.component.mjs +3 -3
- package/esm2022/lib/components/ecl-tabs/ecl-tabs.component.mjs +26 -12
- package/esm2022/lib/components/ecl-tabs/ecl-tabs.module.mjs +4 -4
- package/esm2022/lib/components/ecl-tag/ecl-tag-set.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-tag/ecl-tag.component.mjs +3 -3
- package/esm2022/lib/components/ecl-tag/ecl-tag.module.mjs +4 -4
- package/esm2022/lib/components/ecl-text-area/ecl-text-area.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-text-area/ecl-text-area.module.mjs +4 -4
- package/esm2022/lib/components/ecl-text-input/ecl-text-input.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-text-input/ecl-text-input.module.mjs +4 -4
- package/esm2022/lib/components/ecl-timeline/ecl-timeline-item-label.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-timeline/ecl-timeline-item-title.directive.mjs +3 -3
- package/esm2022/lib/components/ecl-timeline/ecl-timeline-item-toggler.component.mjs +3 -3
- package/esm2022/lib/components/ecl-timeline/ecl-timeline-item.component.mjs +3 -3
- package/esm2022/lib/components/ecl-timeline/ecl-timeline.component.mjs +3 -3
- package/esm2022/lib/components/ecl-timeline/ecl-timeline.module.mjs +4 -4
- package/esm2022/lib/services/ecl-default-language.service.mjs +3 -3
- package/esm2022/lib/services/ecl-rtl.service.mjs +3 -3
- package/esm2022/lib/services/ecl-theme.service.mjs +3 -3
- package/esm2022/lib/shared/ecl-all.module.mjs +4 -4
- package/esm2022/lib/utils/directives/ecl-click-outside/ecl-click-outside.directive.mjs +3 -3
- package/esm2022/lib/utils/directives/ecl-hidden/ecl-hidden.directive.mjs +3 -3
- package/esm2022/lib/utils/directives/ecl-hidden/ecl-hidden.module.mjs +4 -4
- package/fesm2022/eui-ecl.mjs +13879 -20542
- package/fesm2022/eui-ecl.mjs.map +1 -7
- package/lib/components/ecl-base.directive.d.ts.map +1 -1
- package/lib/components/ecl-button/ecl-button.component.d.ts +1 -1
- package/lib/components/ecl-button/ecl-button.component.d.ts.map +1 -1
- package/lib/components/ecl-carousel/ecl-carousel.component.d.ts.map +1 -1
- package/lib/components/ecl-file-upload/ecl-file-upload.directive.d.ts.map +1 -1
- package/lib/components/ecl-gallery/ecl-gallery.component.d.ts.map +1 -1
- package/lib/components/ecl-list/ecl-list.directive.d.ts.map +1 -1
- package/lib/components/ecl-list-illustration/ecl-list-illustration.component.d.ts.map +1 -1
- package/lib/components/ecl-menu/ecl-menu/ecl-menu.component.d.ts.map +1 -1
- package/lib/components/ecl-navigation-list/ecl-navigation-list.component.d.ts.map +1 -1
- package/lib/components/ecl-pagination/ecl-pagination.component.d.ts.map +1 -1
- package/lib/components/ecl-select/ecl-select-container.component.d.ts +2 -1
- package/lib/components/ecl-select/ecl-select-container.component.d.ts.map +1 -1
- package/lib/components/ecl-select/ecl-select.directive.d.ts +2 -1
- package/lib/components/ecl-select/ecl-select.directive.d.ts.map +1 -1
- package/lib/components/ecl-table/ecl-table.directive.d.ts +5 -2
- package/lib/components/ecl-table/ecl-table.directive.d.ts.map +1 -1
- package/lib/components/ecl-tabs/ecl-tabs.component.d.ts +3 -2
- package/lib/components/ecl-tabs/ecl-tabs.component.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -98,7 +98,7 @@ export class EclTabsComponent extends ECLBaseDirective {
|
|
|
98
98
|
if (this.isMobileBreakpoint) {
|
|
99
99
|
return '0.4s';
|
|
100
100
|
}
|
|
101
|
-
return '
|
|
101
|
+
return '0';
|
|
102
102
|
}
|
|
103
103
|
onTabBlur() {
|
|
104
104
|
this.closeDropdown();
|
|
@@ -113,8 +113,11 @@ export class EclTabsComponent extends ECLBaseDirective {
|
|
|
113
113
|
onTabKeydownArrowRight(index) {
|
|
114
114
|
if (this.isMobileBreakpoint) {
|
|
115
115
|
this.shiftTabs(ShiftDirection.NEXT);
|
|
116
|
+
if (index === this.getTabsCount() - 1) {
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
116
119
|
}
|
|
117
|
-
if (index === this.getTabsCount() - 1) {
|
|
120
|
+
if (index === this.getTabsCount() - 1 && !this.isMobileBreakpoint) {
|
|
118
121
|
this.focusOnFirstTab();
|
|
119
122
|
}
|
|
120
123
|
else {
|
|
@@ -124,8 +127,11 @@ export class EclTabsComponent extends ECLBaseDirective {
|
|
|
124
127
|
onTabKeydownArrowLeft(index) {
|
|
125
128
|
if (this.isMobileBreakpoint) {
|
|
126
129
|
this.shiftTabs(ShiftDirection.PREVIOUS);
|
|
130
|
+
if (index === 0) {
|
|
131
|
+
return;
|
|
132
|
+
}
|
|
127
133
|
}
|
|
128
|
-
if (index === 0) {
|
|
134
|
+
if (index === 0 && !this.isMobileBreakpoint) {
|
|
129
135
|
this.focusOnLastTab();
|
|
130
136
|
}
|
|
131
137
|
else {
|
|
@@ -142,7 +148,7 @@ export class EclTabsComponent extends ECLBaseDirective {
|
|
|
142
148
|
this.index = this.getShifIndex(dir, this.index);
|
|
143
149
|
this.isScrollPrevBtnShow = this.index >= 1;
|
|
144
150
|
this.isScrollNextBtnShow = this.index <= this.getTabsCount() - 1;
|
|
145
|
-
const leftMargin = this.index === 0 ? 0 : this.btnPrev.nativeElement.getBoundingClientRect().width + 13;
|
|
151
|
+
const leftMargin = this.index === 0 ? 0 : this.btnPrev.el.nativeElement.getBoundingClientRect().width + 13;
|
|
146
152
|
let newOffset = 0;
|
|
147
153
|
if (this.isRtl) {
|
|
148
154
|
newOffset = Math.ceil(this.tabsList.nativeElement.offsetWidth -
|
|
@@ -151,7 +157,7 @@ export class EclTabsComponent extends ECLBaseDirective {
|
|
|
151
157
|
leftMargin);
|
|
152
158
|
}
|
|
153
159
|
else {
|
|
154
|
-
newOffset = Math.ceil(this.getTabsAsArray()[this.index]
|
|
160
|
+
newOffset = Math.ceil(this.getTabsAsArray()[this.index]?.hostElement.offsetLeft - leftMargin);
|
|
155
161
|
}
|
|
156
162
|
const maxScroll = Math.ceil(this.getTabsListWidth() - this.el.nativeElement.getBoundingClientRect().width);
|
|
157
163
|
if (newOffset > maxScroll) {
|
|
@@ -167,7 +173,7 @@ export class EclTabsComponent extends ECLBaseDirective {
|
|
|
167
173
|
}
|
|
168
174
|
getShifIndex(dir, index) {
|
|
169
175
|
if (dir === ShiftDirection.NEXT) {
|
|
170
|
-
if (index === this.getTabsCount() - 1) {
|
|
176
|
+
if (index === this.getTabsCount() - 1 && !this.isMobileBreakpoint) {
|
|
171
177
|
return 0;
|
|
172
178
|
}
|
|
173
179
|
else {
|
|
@@ -175,7 +181,7 @@ export class EclTabsComponent extends ECLBaseDirective {
|
|
|
175
181
|
}
|
|
176
182
|
}
|
|
177
183
|
else {
|
|
178
|
-
if (index === 0) {
|
|
184
|
+
if (index === 0 && !this.isMobileBreakpoint) {
|
|
179
185
|
return this.getTabsCount() - 1;
|
|
180
186
|
}
|
|
181
187
|
else {
|
|
@@ -357,6 +363,8 @@ export class EclTabsComponent extends ECLBaseDirective {
|
|
|
357
363
|
this.handleMobile();
|
|
358
364
|
return;
|
|
359
365
|
}
|
|
366
|
+
this.styleTransform = 'translate3d(0px, 0px, 0px)';
|
|
367
|
+
this.index = 0;
|
|
360
368
|
this.initMoreBtnWidth();
|
|
361
369
|
let stopWidth = this.moreBtnWidth + 25;
|
|
362
370
|
const hiddenItems = [];
|
|
@@ -420,6 +428,12 @@ export class EclTabsComponent extends ECLBaseDirective {
|
|
|
420
428
|
this.isMoreButtonShow = false;
|
|
421
429
|
this.isScrollPrevBtnShow = false;
|
|
422
430
|
this.isScrollNextBtnShow = true;
|
|
431
|
+
this.setAllTabsVisible();
|
|
432
|
+
}
|
|
433
|
+
setAllTabsVisible() {
|
|
434
|
+
this.tabs.forEach((item, i) => {
|
|
435
|
+
item.isHidden = false;
|
|
436
|
+
});
|
|
423
437
|
}
|
|
424
438
|
handleRtlChangeState() {
|
|
425
439
|
const isRtlOld = this.isRtl;
|
|
@@ -440,12 +454,12 @@ export class EclTabsComponent extends ECLBaseDirective {
|
|
|
440
454
|
this.styleTransform = 'translate3d(0px, 0px, 0px)';
|
|
441
455
|
this.index = 0;
|
|
442
456
|
}
|
|
443
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
444
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-rc.
|
|
457
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTabsComponent, deps: [{ token: i0.IterableDiffers }, { token: i1.BreakpointObserver }, { token: i0.ChangeDetectorRef }, { token: i0.ElementRef }, { token: i2.EclRtlService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
458
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-rc.3", type: EclTabsComponent, selector: "nav[eclTabs], ecl-tabs", inputs: { bodyClass: "bodyClass" }, outputs: { tabSelect: "tabSelect" }, host: { listeners: { "document:click": "onClick($event.target)", "window:resize": "onWindowResize($event)" } }, queries: [{ propertyName: "tabs", predicate: i0.forwardRef(() => EclTabComponent) }], viewQueries: [{ propertyName: "tabsList", first: true, predicate: ["tabsList"], descendants: true }, { propertyName: "moreButton", first: true, predicate: ["moreButton"], descendants: true }, { propertyName: "btnPrev", first: true, predicate: ["btnPrev"], descendants: true }, { propertyName: "btnNext", first: true, predicate: ["btnNext"], descendants: true }, { propertyName: "dropdownList", first: true, predicate: ["dropdownList"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"ecl-tabs\">\n <div class=\"ecl-tabs__container\"\n [class.ecl-tabs__container--right]=\"isScrollNextBtnShow\"\n [class.ecl-tabs__container--left]=\"isScrollPrevBtnShow\">\n <div\n class=\"ecl-tabs__list\"\n role=\"tablist\"\n #tabsList\n [style.width]=\"getTabsWidthStyle()\"\n [style.transform]=\"styleTransform\"\n [style.transition-duration]=\"getTransitionDuration()\">\n <ng-content select=\"ecl-tab, [eclTab]\"></ng-content>\n <ecl-tab-more [isHidden]=\"!isMoreButtonShow\">\n @if (listTabs.length > 0) {\n <div class=\"ecl-tabs__dropdown\" [class.ecl-tabs__dropdown--show]=\"isDropdownExpanded\">\n <div class=\"ecl-tabs__dropdown-list\" #dropdownList>\n @for (tab of listTabs; track tab.id; let i = $index) {\n <ecl-tab [isActive]=\"tab.isActive\" [isHidden]=\"tab.isHidden\" (click)=\"onTabSelect(tab)\"\n (keydown.arrowRight)=\"onTabKeydownArrowRight(i)\" (keydown.arrowLeft)=\"onTabKeydownArrowLeft(i)\"\n (keydown.home)=\"onTabKeydownHome()\" (keydown.end)=\"onTabKeydownEnd()\"\n (keydown.enter)=\"onTabSelect(tab)\" (keydown.tab)=\"onTabBlur()\">\n <ecl-tab-label>{{ getTabLabel(i) }}</ecl-tab-label>\n </ecl-tab>\n }\n </div>\n </div>\n }\n </ecl-tab-more>\n </div>\n <button #moreButton eclButton class=\"ecl-tabs__toggle\" tabindex=\"-1\" variant=\"ghost\"\n [attr.aria-expanded]=\"isDropdownExpanded\" [class.ecl-tabs__toggle--active]=\"isMoreButtonActive\"\n (click)=\"onDropdownToggle()\" [class.ecl-tabs__toggle--hidden]=\"!isMoreButtonShow\">\n <span eclButtonLabel>\n {{ 'ecl.common.MORE' | translate }}\n ({{ getHiddenTabsCount() }})\n </span>\n <ecl-icon icon=\"corner-arrow\" transform=\"rotate-180\" size=\"fluid\"></ecl-icon>\n </button>\n </div>\n\n <div class=\"ecl-tabs__controls\">\n <button\n #btnPrev\n eclButton\n variant=\"ghost\"\n isIconOnly\n [attr.aria-hidden]=\"true\"\n class=\"ecl-tabs__prev\"\n [class.ecl-u-d-none]=\"!isScrollPrevBtnShow\"\n [class.ecl-u-d-block]=\"isScrollPrevBtnShow\"\n (click)=\"onScrollPrev()\">\n <ecl-icon icon=\"corner-arrow\" transform=\"rotate-270\" size=\"s\" class=\"\"> </ecl-icon>\n <span eclButtonLabel>{{ 'ecl.common.PREVIOUS | translate }}</span>\n </button>\n <button\n #btnNext\n eclButton\n variant=\"ghost\"\n isIconOnly\n [attr.aria-hidden]=\"true\"\n class=\"ecl-tabs__next\"\n [class.ecl-u-d-none]=\"!isScrollNextBtnShow\"\n [class.ecl-u-d-block]=\"isScrollNextBtnShow\"\n (click)=\"onScrollNext()\">\n <ecl-icon icon=\"corner-arrow\" transform=\"rotate-90\" size=\"s\" class=\"\"> </ecl-icon>\n <span eclButtonLabel>{{ 'ecl.common.NEXT | translate }}</span>\n </button>\n </div>\n</div>\n\n@for (tab of tabs.toArray(); track tab.tabLabel) {\n @if (tab.isActive) {\n <div class=\"{{ bodyClass }}\">\n <ng-container *ngTemplateOutlet=\"tab.contentTemplate\"></ng-container>\n </div>\n }\n}\n@for (tab of listTabs; track tab.tabLabel) {\n @if (tab.isActive) {\n <div class=\"{{ bodyClass }}\">\n <ng-container *ngTemplateOutlet=\"tab.contentTemplate\"></ng-container>\n </div>\n }\n}\n", dependencies: [{ kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.EclButtonComponent, selector: "button[eclButton], button[ecl-button], a[eclButton]", inputs: ["isIconOnly", "variant", "containerStyleClass"] }, { kind: "directive", type: i5.EclButtonLabelDirective, selector: "[eclButtonLabel]" }, { kind: "component", type: i6.EclIconComponent, selector: "ecl-icon", inputs: ["iconSet", "icon", "size", "color", "transform", "ariaLabelledby", "role", "ariaHidden", "focusable"] }, { kind: "component", type: i7.EclTabComponent, selector: "ecl-tab, [eclTab]", inputs: ["id", "isHidden", "isActive"], outputs: ["selectTab", "keydownTab"] }, { kind: "component", type: i8.EclTabLabelComponent, selector: "ecl-tab-label" }, { kind: "component", type: i9.EclTabMoreComponent, selector: "ecl-tab-more", inputs: ["isHidden"] }, { kind: "pipe", type: i10.TranslatePipe, name: "translate" }], encapsulation: i0.ViewEncapsulation.None }); }
|
|
445
459
|
}
|
|
446
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
460
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTabsComponent, decorators: [{
|
|
447
461
|
type: Component,
|
|
448
|
-
args: [{ selector: 'nav[eclTabs], ecl-tabs', encapsulation: ViewEncapsulation.None, template: "<div class=\"ecl-tabs\">\n <div class=\"ecl-tabs__container\">\n <div\n class=\"ecl-tabs__list\"\n role=\"tablist\"\n #tabsList\n [style.width]=\"getTabsWidthStyle()\"\n [style.transform]=\"styleTransform\"\n [style.transition-duration]=\"
|
|
462
|
+
args: [{ selector: 'nav[eclTabs], ecl-tabs', encapsulation: ViewEncapsulation.None, template: "<div class=\"ecl-tabs\">\n <div class=\"ecl-tabs__container\"\n [class.ecl-tabs__container--right]=\"isScrollNextBtnShow\"\n [class.ecl-tabs__container--left]=\"isScrollPrevBtnShow\">\n <div\n class=\"ecl-tabs__list\"\n role=\"tablist\"\n #tabsList\n [style.width]=\"getTabsWidthStyle()\"\n [style.transform]=\"styleTransform\"\n [style.transition-duration]=\"getTransitionDuration()\">\n <ng-content select=\"ecl-tab, [eclTab]\"></ng-content>\n <ecl-tab-more [isHidden]=\"!isMoreButtonShow\">\n @if (listTabs.length > 0) {\n <div class=\"ecl-tabs__dropdown\" [class.ecl-tabs__dropdown--show]=\"isDropdownExpanded\">\n <div class=\"ecl-tabs__dropdown-list\" #dropdownList>\n @for (tab of listTabs; track tab.id; let i = $index) {\n <ecl-tab [isActive]=\"tab.isActive\" [isHidden]=\"tab.isHidden\" (click)=\"onTabSelect(tab)\"\n (keydown.arrowRight)=\"onTabKeydownArrowRight(i)\" (keydown.arrowLeft)=\"onTabKeydownArrowLeft(i)\"\n (keydown.home)=\"onTabKeydownHome()\" (keydown.end)=\"onTabKeydownEnd()\"\n (keydown.enter)=\"onTabSelect(tab)\" (keydown.tab)=\"onTabBlur()\">\n <ecl-tab-label>{{ getTabLabel(i) }}</ecl-tab-label>\n </ecl-tab>\n }\n </div>\n </div>\n }\n </ecl-tab-more>\n </div>\n <button #moreButton eclButton class=\"ecl-tabs__toggle\" tabindex=\"-1\" variant=\"ghost\"\n [attr.aria-expanded]=\"isDropdownExpanded\" [class.ecl-tabs__toggle--active]=\"isMoreButtonActive\"\n (click)=\"onDropdownToggle()\" [class.ecl-tabs__toggle--hidden]=\"!isMoreButtonShow\">\n <span eclButtonLabel>\n {{ 'ecl.common.MORE' | translate }}\n ({{ getHiddenTabsCount() }})\n </span>\n <ecl-icon icon=\"corner-arrow\" transform=\"rotate-180\" size=\"fluid\"></ecl-icon>\n </button>\n </div>\n\n <div class=\"ecl-tabs__controls\">\n <button\n #btnPrev\n eclButton\n variant=\"ghost\"\n isIconOnly\n [attr.aria-hidden]=\"true\"\n class=\"ecl-tabs__prev\"\n [class.ecl-u-d-none]=\"!isScrollPrevBtnShow\"\n [class.ecl-u-d-block]=\"isScrollPrevBtnShow\"\n (click)=\"onScrollPrev()\">\n <ecl-icon icon=\"corner-arrow\" transform=\"rotate-270\" size=\"s\" class=\"\"> </ecl-icon>\n <span eclButtonLabel>{{ 'ecl.common.PREVIOUS | translate }}</span>\n </button>\n <button\n #btnNext\n eclButton\n variant=\"ghost\"\n isIconOnly\n [attr.aria-hidden]=\"true\"\n class=\"ecl-tabs__next\"\n [class.ecl-u-d-none]=\"!isScrollNextBtnShow\"\n [class.ecl-u-d-block]=\"isScrollNextBtnShow\"\n (click)=\"onScrollNext()\">\n <ecl-icon icon=\"corner-arrow\" transform=\"rotate-90\" size=\"s\" class=\"\"> </ecl-icon>\n <span eclButtonLabel>{{ 'ecl.common.NEXT | translate }}</span>\n </button>\n </div>\n</div>\n\n@for (tab of tabs.toArray(); track tab.tabLabel) {\n @if (tab.isActive) {\n <div class=\"{{ bodyClass }}\">\n <ng-container *ngTemplateOutlet=\"tab.contentTemplate\"></ng-container>\n </div>\n }\n}\n@for (tab of listTabs; track tab.tabLabel) {\n @if (tab.isActive) {\n <div class=\"{{ bodyClass }}\">\n <ng-container *ngTemplateOutlet=\"tab.contentTemplate\"></ng-container>\n </div>\n }\n}\n" }]
|
|
449
463
|
}], ctorParameters: () => [{ type: i0.IterableDiffers }, { type: i1.BreakpointObserver }, { type: i0.ChangeDetectorRef }, { type: i0.ElementRef }, { type: i2.EclRtlService }], propDecorators: { bodyClass: [{
|
|
450
464
|
type: Input
|
|
451
465
|
}], tabSelect: [{
|
|
@@ -475,4 +489,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.1", ng
|
|
|
475
489
|
type: HostListener,
|
|
476
490
|
args: ['window:resize', ['$event']]
|
|
477
491
|
}] } });
|
|
478
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-tabs.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-tabs/ecl-tabs.component.ts","../../../../../src/lib/components/ecl-tabs/ecl-tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BreakpointObserver } from '@angular/cdk/layout';\nimport {\n    AfterContentInit,\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostListener,\n    Input,\n    IterableChanges,\n    IterableDiffer,\n    IterableDiffers,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\n\nimport { Observable, of, Subject } from 'rxjs';\nimport { mergeWith, takeUntil } from 'rxjs/operators';\nimport { ECLBaseDirective } from '../ecl-base.directive';\nimport { EclButtonComponent } from '../ecl-button';\nimport { EclTabComponent, EclTabSelectEvent } from './ecl-tab.component';\nimport { KeyCode } from '../../utils';\nimport { EclRtlService } from '../../services';\n\nexport enum ShiftDirection {\n    NEXT = 'next',\n    PREVIOUS = 'prev',\n}\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'nav[eclTabs], ecl-tabs',\n    templateUrl: './ecl-tabs.component.html',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EclTabsComponent extends ECLBaseDirective implements OnInit, AfterViewInit, AfterContentInit, OnDestroy {\n    @Input() bodyClass = 'ecl-u-mt-s';\n    @Output() tabSelect = new EventEmitter<EclTabSelectEvent>();\n\n    @ContentChildren(forwardRef(() => EclTabComponent)) tabs: QueryList<EclTabComponent>;\n\n    @ViewChild('tabsList') tabsList: ElementRef;\n    @ViewChild('moreButton') moreButton: EclButtonComponent;\n    @ViewChild('btnPrev') btnPrev: ElementRef;\n    @ViewChild('btnNext') btnNext: ElementRef;\n    @ViewChild('dropdownList') dropdownList: ElementRef;\n    dropdownTabs: Array<EclTabComponent> = [];\n    listTabs: Array<EclTabComponent> = [];\n\n    index = 0;\n    isDropdownExpanded = false;\n    isMobileBreakpoint = false;\n    isMoreButtonShow = true;\n    isScrollPrevBtnShow = false;\n    isScrollNextBtnShow = false;\n    styleTransform = 'translate3d(0px, 0px, 0px)';\n\n    private differ: IterableDiffer<EclTabComponent>;\n    private diff: IterableChanges<EclTabComponent>;\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n    private isFirstCall = true;\n    private isRtl = false;\n    private moreBtnWidth: number;\n    private TIMEOUT_INTERVAL = 300;\n\n    constructor(\n        private differs: IterableDiffers,\n        private cdkBreakpointObserver: BreakpointObserver,\n        private cd: ChangeDetectorRef,\n        private el: ElementRef,\n        private eclRtlService: EclRtlService,\n    ) {\n        super();\n        this.differ = this.differs.find([]).create();\n    }\n\n    ngOnInit(): void {\n        this.observeBreakpointChanges();\n        this.handleRtlChangeState();\n    }\n\n    ngAfterContentInit(): void {\n        this.diff = this.differ.diff(this.tabs);\n    }\n\n    ngAfterViewInit(): void {\n        this.createSecondListForDropdown();\n        this.observeTabsChanges();\n        setTimeout(() => this.handleResize(), this.TIMEOUT_INTERVAL);\n        this.cd.detectChanges();\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    @HostListener('document:click', ['$event.target'])\n    onClick(target): void {\n        if (!this.moreButton.el.nativeElement.contains(target) && !this.dropdownList.nativeElement.contains(target)) {\n            this.closeDropdown();\n        }\n    }\n\n    @HostListener('window:resize', ['$event'])\n    onWindowResize(): void {\n        setTimeout(() => this.handleResize(), this.TIMEOUT_INTERVAL);\n    }\n\n    get isMoreButtonActive(): boolean {\n        return this.listTabs.find((el) => el.isActive) !== undefined;\n    }\n\n    onScrollPrev(): void {\n        this.shiftTabs(ShiftDirection.PREVIOUS);\n    }\n\n    onScrollNext(): void {\n        this.shiftTabs(ShiftDirection.NEXT);\n    }\n\n    onDropdownToggle(): void {\n        this.isDropdownExpanded = !this.isDropdownExpanded;\n    }\n\n    getTabsWidthStyle(): string {\n        return this.isMobileBreakpoint ? `${this.getTabsWidth()}px` : 'auto';\n    }\n\n    getTabsWidth(): number {\n        return this.tabs.reduce((total, item) => (total += Math.ceil(item.getWidth())), 0);\n    }\n\n    getHiddenTabsCount(): number {\n        return this.tabs.filter((item) => item.isHidden).length;\n    }\n\n    getTabLabel(index: number): string {\n        return this.getTabsAsArray()[index].getTabLabel();\n    }\n\n    getTransitionDuration(): string {\n        if (this.isMobileBreakpoint) {\n            return '0.4s';\n        }\n        return '0s';\n    }\n\n    onTabBlur(): void {\n        this.closeDropdown();\n\n        this.getLastVisibleTab().onFocus();\n        this.getLastVisibleTab().onBlur();\n    }\n\n    onTabSelect(tab: EclTabComponent): void {\n        this.deactivateAllTabs(this.tabs.toArray(), this.listTabs);\n        this.activateTab(tab);\n        this.sendTabSelectEvent(tab);\n    }\n\n    onTabKeydownArrowRight(index: number): void {\n        if (this.isMobileBreakpoint) {\n            this.shiftTabs(ShiftDirection.NEXT);\n        }\n        if (index === this.getTabsCount() - 1) {\n            this.focusOnFirstTab();\n        } else {\n            this.focusOnNextTab(index);\n        }\n    }\n\n    onTabKeydownArrowLeft(index: number): void {\n        if (this.isMobileBreakpoint) {\n            this.shiftTabs(ShiftDirection.PREVIOUS);\n        }\n        if (index === 0) {\n            this.focusOnLastTab();\n        } else {\n            this.focusOnPrevTab(index);\n        }\n    }\n\n    onTabKeydownHome(): void {\n        this.focusOnFirstTab();\n    }\n\n    onTabKeydownEnd(): void {\n        this.focusOnLastTab();\n    }\n\n    private shiftTabs(dir: string): void {\n        this.index = this.getShifIndex(dir, this.index);\n\n        this.isScrollPrevBtnShow = this.index >= 1;\n        this.isScrollNextBtnShow = this.index <= this.getTabsCount() - 1;\n\n        const leftMargin = this.index === 0 ? 0 : this.btnPrev.nativeElement.getBoundingClientRect().width + 13;\n\n        let newOffset = 0;\n        if (this.isRtl) {\n            newOffset = Math.ceil(\n                this.tabsList.nativeElement.offsetWidth -\n                    this.getTabsAsArray()[this.index].hostElement.offsetLeft -\n                    this.getTabsAsArray()[this.index].hostElement.offsetWidth -\n                    leftMargin,\n            );\n        } else {\n            newOffset = Math.ceil(this.getTabsAsArray()[this.index].hostElement.offsetLeft - leftMargin);\n        }\n\n        const maxScroll = Math.ceil(this.getTabsListWidth() - this.el.nativeElement.getBoundingClientRect().width);\n\n        if (newOffset > maxScroll) {\n            this.isScrollNextBtnShow = false;\n            newOffset = maxScroll;\n        }\n\n        if (this.isRtl) {\n            this.styleTransform = `translate3d(${newOffset}px, 0px, 0px)`;\n        } else {\n            this.styleTransform = `translate3d(-${newOffset}px, 0px, 0px)`;\n        }\n    }\n\n    private getShifIndex(dir: string, index: number): number {\n        if (dir === ShiftDirection.NEXT) {\n            if (index === this.getTabsCount() - 1) {\n                return 0;\n            } else {\n                return index + 1;\n            }\n        } else {\n            if (index === 0) {\n                return this.getTabsCount() - 1;\n            } else {\n                return index - 1;\n            }\n        }\n    }\n\n    private createSecondListForDropdown(): void {\n        this.tabs.forEach((tab) => {\n            const newTab = Object.assign({}, tab) as EclTabComponent;\n            newTab.isHidden = true;\n            newTab.isActive = false;\n            this.listTabs.push(newTab as EclTabComponent);\n        });\n    }\n\n    private getTabsAsArray(): EclTabComponent[] {\n        return this.tabs.toArray();\n    }\n\n    private getTabsCount(): number {\n        return this.tabs.toArray().length;\n    }\n\n    private closeDropdown(): void {\n        this.isDropdownExpanded = false;\n    }\n\n    private openDropdown(): void {\n        this.isDropdownExpanded = true;\n    }\n\n    private observeTabsChanges(): void {\n        this.createTabsChangesObservable(this.tabs).pipe(takeUntil(this.destroy$)).subscribe(this.onTabsChanges.bind(this));\n    }\n\n    private createTabsChangesObservable(tabs: QueryList<EclTabComponent>): Observable<QueryList<EclTabComponent>> {\n        return of(tabs).pipe(mergeWith(tabs.changes), takeUntil(this.destroy$));\n    }\n\n    private onTabsChanges(): void {\n        this.diff = this.differ.diff(this.tabs);\n\n        if (!this.diff) {\n            this.tabs.forEach((tab) => {\n                this.connectTabEvents(tab);\n            });\n        } else {\n            this.diff.forEachAddedItem((change) => {\n                this.connectTabEvents(change.item);\n            });\n\n            this.diff.forEachRemovedItem((change) => {\n                this.disconnectTabEvents(change.item);\n            });\n        }\n    }\n\n    private connectTabEvents(tab: EclTabComponent): void {\n        tab.selectTab.pipe(takeUntil(this.destroy$)).subscribe(() => {\n            this.onTabSelect(tab);\n        });\n        tab.keydownTab.pipe(takeUntil(this.destroy$)).subscribe((event) => {\n            this.onTabKeydown(event, tab);\n        });\n    }\n\n    private onTabKeydown(event: Event, tab: EclTabComponent): void {\n        event.preventDefault();\n        if (event instanceof KeyboardEvent) {\n            const index = this.getTabsAsArray().indexOf(tab);\n            switch (event.key) {\n                case KeyCode.ARROW_LEFT: {\n                    this.onTabKeydownArrowLeft(index);\n                    break;\n                }\n                case KeyCode.ARROW_RIGHT: {\n                    this.onTabKeydownArrowRight(index);\n                    break;\n                }\n                case KeyCode.END: {\n                    this.onTabKeydownEnd();\n                    break;\n                }\n                case KeyCode.HOME: {\n                    this.onTabKeydownHome();\n                    break;\n                }\n                case KeyCode.ENTER: {\n                    this.onTabSelect(tab);\n                    break;\n                }\n                case KeyCode.TAB: {\n                    this.onTabBlur();\n                    break;\n                }\n                default: {\n                    break;\n                }\n            }\n        }\n    }\n\n    private getLastVisibleTab(): EclTabComponent {\n        let result = null;\n        this.getTabsAsArray().forEach((el) => {\n            if (!el.isHidden) {\n                result = el;\n            } else {\n                return;\n            }\n        });\n        return result;\n    }\n\n    private focusOnNextTab(index: number): void {\n        if (this.getTabsAsArray()[index + 1].isHidden) {\n            this.openDropdown();\n            this.focusOnDropdownTab(index + 1);\n        } else {\n            this.closeDropdown();\n            this.getTabsAsArray()[index + 1].onFocus();\n        }\n    }\n\n    private focusOnFirstTab(): void {\n        this.closeDropdown();\n        this.getFirstTabFromArray().onFocus();\n    }\n\n    private focusOnLastTab(): void {\n        if (!this.getLastTabFromArray().isHidden) {\n            this.getLastTabFromArray().onFocus();\n        } else {\n            this.openDropdown();\n            this.focusOnDropdownTab(this.getTabsCount() - 1);\n        }\n    }\n\n    private focusOnPrevTab(index: number): void {\n        if (!this.listTabs[index - 1].isHidden) {\n            this.focusOnDropdownTab(index - 1);\n        } else {\n            this.closeDropdown();\n            this.getTabsAsArray()[index - 1].onFocus();\n        }\n    }\n\n    private focusOnDropdownTab(index: number): void {\n        this.dropdownList.nativeElement.children[index].firstChild.focus();\n    }\n\n    private blurDropdownTab(index: number): void {\n        this.dropdownList.nativeElement.children[index].firstChild.blur();\n    }\n\n    private getLastTabFromArray(): EclTabComponent {\n        return this.getTabsAsArray()[this.getTabsAsArray().length - 1];\n    }\n\n    private getFirstTabFromArray(): EclTabComponent {\n        return this.getTabsAsArray()[0];\n    }\n\n    private disconnectTabEvents(tab: EclTabComponent): void {\n        if (tab && tab.selectTab) {\n            tab.selectTab.unsubscribe();\n        }\n    }\n\n    private deactivateAllTabs(tabs: Array<EclTabComponent>, listTabs: Array<EclTabComponent>): void {\n        tabs.forEach((it) => {\n            it.isActive = false;\n        });\n\n        listTabs.forEach((it) => {\n            it.isActive = false;\n        });\n    }\n\n    private activateTab(tab: EclTabComponent): void {\n        tab.isActive = true;\n    }\n\n    private sendTabSelectEvent(tab: EclTabComponent): void {\n        this.tabSelect.next(new EclTabSelectEvent(tab));\n    }\n\n    private observeBreakpointChanges(): void {\n        this.cdkBreakpointObserver\n            .observe(['(max-width: 480px)'])\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((result) => {\n                this.isMobileBreakpoint = result.matches;\n            });\n    }\n\n    private handleResize(): void {\n        this.closeDropdown();\n        if (this.isMobileBreakpoint) {\n            this.handleMobile();\n            return;\n        }\n        this.initMoreBtnWidth();\n        let stopWidth = this.moreBtnWidth + 25;\n        const hiddenItems = [];\n        const listWidth = this.getTabsListWidth();\n        this.isScrollNextBtnShow = false;\n        this.isScrollPrevBtnShow = false;\n        this.isMoreButtonShow = false;\n        this.tabs.forEach((item, i) => {\n            item.isHidden = false;\n            if (listWidth >= stopWidth + item.getWidth() && !hiddenItems.includes(i - 1)) {\n                stopWidth += item.getWidth();\n            } else {\n                item.isHidden = true;\n                if (item.isActive) {\n                    this.listTabs[i].isActive = true;\n                }\n                hiddenItems.push(i);\n            }\n        });\n\n        if (!hiddenItems.length) {\n            this.isMoreButtonShow = false;\n            this.setActiveItemForMainTabs();\n            this.hideAllDropdownTabs();\n        } else {\n            this.isMoreButtonShow = true;\n            this.setHiddenItemsForDropdownTabs(hiddenItems);\n        }\n    }\n\n    private initMoreBtnWidth(): void {\n        if (this.isFirstCall) {\n            this.moreBtnWidth = this.moreButton.el.nativeElement.getBoundingClientRect().width;\n            this.isFirstCall = false;\n        }\n    }\n\n    private hideAllDropdownTabs(): void {\n        this.listTabs.forEach(item => item.isHidden = true);\n    }\n\n    private setActiveItemForMainTabs(): void {\n        this.listTabs.forEach((item, index) => {\n            if (item.isActive) {\n                this.tabs.toArray()[index].isActive = true;\n            }\n        });\n    }\n\n    private getTabsListWidth(): number {\n        return this.tabsList.nativeElement.getBoundingClientRect().width;\n    }\n\n    private setHiddenItemsForDropdownTabs(hiddenItems: number[]): void {\n        this.listTabs.forEach((item, index) => {\n            if (hiddenItems.includes(index)) {\n                item.isHidden = false;\n            } else {\n                item.isHidden = true;\n            }\n        });\n    }\n\n    private handleMobile(): void {\n        this.isMoreButtonShow = false;\n        this.isScrollPrevBtnShow = false;\n        this.isScrollNextBtnShow = true;\n    }\n\n    private handleRtlChangeState(): void {\n        const isRtlOld = this.isRtl;\n        this.eclRtlService.currentRtlState$.pipe(takeUntil(this.destroy$)).subscribe((rtlState) => {\n            setTimeout(() => {\n                this.isRtl = rtlState;\n                if (this.isMobileBreakpoint && this.hasRtlChanged(isRtlOld)) {\n                    this.handleRtlChange();\n                } \n            });\n        });\n    }\n\n    private hasRtlChanged(isRtlOld: boolean): boolean {\n        return isRtlOld !== this.isRtl;\n    }\n\n    private handleRtlChange(): void {\n        this.handleMobile();\n        this.styleTransform = 'translate3d(0px, 0px, 0px)';\n        this.index = 0;\n    }\n}\n","<div class=\"ecl-tabs\">\n    <div class=\"ecl-tabs__container\">\n        <div\n            class=\"ecl-tabs__list\"\n            role=\"tablist\"\n            #tabsList\n            [style.width]=\"getTabsWidthStyle()\"\n            [style.transform]=\"styleTransform\"\n            [style.transition-duration]=\"'0' || getTransitionDuration()\">\n            <ng-content select=\"ecl-tab, [eclTab]\"></ng-content>\n            <ecl-tab-more [isHidden]=\"!isMoreButtonShow\">\n                @if (listTabs.length > 0) {\n                <div class=\"ecl-tabs__dropdown\" [class.ecl-tabs__dropdown--show]=\"isDropdownExpanded\">\n                    <div class=\"ecl-tabs__dropdown-list\" #dropdownList>\n                        @for (tab of listTabs; track tab.id; let i = $index) {\n                            <ecl-tab [isActive]=\"tab.isActive\" [isHidden]=\"tab.isHidden\" (click)=\"onTabSelect(tab)\"\n                                     (keydown.arrowRight)=\"onTabKeydownArrowRight(i)\" (keydown.arrowLeft)=\"onTabKeydownArrowLeft(i)\"\n                                     (keydown.home)=\"onTabKeydownHome()\" (keydown.end)=\"onTabKeydownEnd()\"\n                                     (keydown.enter)=\"onTabSelect(tab)\" (keydown.tab)=\"onTabBlur()\">\n                                <ecl-tab-label>{{ getTabLabel(i) }}</ecl-tab-label>\n                            </ecl-tab>\n                        }\n                    </div>\n                </div>\n            }\n            </ecl-tab-more>\n        </div>\n        <button #moreButton eclButton class=\"ecl-tabs__toggle\" tabindex=\"-1\" variant=\"ghost\"\n            [attr.aria-expanded]=\"isDropdownExpanded\" [class.ecl-tabs__toggle--active]=\"isMoreButtonActive\"\n            (click)=\"onDropdownToggle()\" [class.ecl-tabs__toggle--hidden]=\"!isMoreButtonShow\">\n            <span eclButtonLabel>\n                {{ 'ecl.common.MORE' | translate }}\n                ({{ getHiddenTabsCount() }})\n            </span>\n            <ecl-icon icon=\"corner-arrow\" transform=\"rotate-180\" size=\"fluid\"></ecl-icon>\n        </button>\n    </div>\n\n    <div class=\"ecl-tabs__controls\">\n        <button\n            #btnPrev\n            [attr.aria-hidden]=\"true\"\n            class=\"ecl-tabs__prev\"\n            [class.ecl-u-d-none]=\"!isScrollPrevBtnShow\"\n            [class.ecl-u-d-block]=\"isScrollPrevBtnShow\"\n            (click)=\"onScrollPrev()\">\n            <ecl-icon isInverted icon=\"corner-arrow\" transform=\"rotate-270\" size=\"m\" class=\"ecl-u-d-block\"> </ecl-icon>\n            <span class=\"ecl-u-sr-only\"></span>\n        </button>\n        <button\n            #btnNext\n            [attr.aria-hidden]=\"true\"\n            class=\"ecl-tabs__next\"\n            [class.ecl-u-d-none]=\"!isScrollNextBtnShow\"\n            [class.ecl-u-d-block]=\"isScrollNextBtnShow\"\n            (click)=\"onScrollNext()\">\n            <ecl-icon isInverted icon=\"corner-arrow\" color=\"inverted\" transform=\"rotate-90\" size=\"m\" class=\"ecl-u-d-block\"> </ecl-icon>\n            <span class=\"ecl-u-sr-only\"></span>\n        </button>\n    </div>\n</div>\n\n@for (tab of tabs.toArray(); track tab.tabLabel) {\n    @if (tab.isActive) {\n        <div class=\"{{ bodyClass }}\">\n            <ng-container *ngTemplateOutlet=\"tab.contentTemplate\"></ng-container>\n        </div>\n    }\n}\n@for (tab of listTabs; track tab.tabLabel) {\n    @if (tab.isActive) {\n        <div class=\"{{ bodyClass }}\">\n            <ng-container *ngTemplateOutlet=\"tab.contentTemplate\"></ng-container>\n        </div>\n    }\n}\n"]}
|
|
492
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecl-tabs.component.js","sourceRoot":"","sources":["../../../../../src/lib/components/ecl-tabs/ecl-tabs.component.ts","../../../../../src/lib/components/ecl-tabs/ecl-tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { BreakpointObserver } from '@angular/cdk/layout';\nimport {\n    AfterContentInit,\n    AfterViewInit,\n    ChangeDetectorRef,\n    Component,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostListener,\n    Input,\n    IterableChanges,\n    IterableDiffer,\n    IterableDiffers,\n    OnDestroy,\n    OnInit,\n    Output,\n    QueryList,\n    ViewChild,\n    ViewEncapsulation,\n} from '@angular/core';\n\nimport { Observable, of, Subject } from 'rxjs';\nimport { mergeWith, takeUntil } from 'rxjs/operators';\nimport { ECLBaseDirective } from '../ecl-base.directive';\nimport { EclButtonComponent } from '../ecl-button';\nimport { EclTabComponent, EclTabSelectEvent } from './ecl-tab.component';\nimport { KeyCode } from '../../utils';\nimport { EclRtlService } from '../../services';\n\nexport enum ShiftDirection {\n    NEXT = 'next',\n    PREVIOUS = 'prev',\n}\n\n@Component({\n    // eslint-disable-next-line @angular-eslint/component-selector\n    selector: 'nav[eclTabs], ecl-tabs',\n    templateUrl: './ecl-tabs.component.html',\n    encapsulation: ViewEncapsulation.None,\n})\nexport class EclTabsComponent extends ECLBaseDirective implements OnInit, AfterViewInit, AfterContentInit, OnDestroy {\n    @Input() bodyClass = 'ecl-u-mt-s';\n    @Output() tabSelect = new EventEmitter<EclTabSelectEvent>();\n\n    @ContentChildren(forwardRef(() => EclTabComponent)) tabs: QueryList<EclTabComponent>;\n\n    @ViewChild('tabsList') tabsList: ElementRef;\n    @ViewChild('moreButton') moreButton: EclButtonComponent;\n    @ViewChild('btnPrev') btnPrev: EclButtonComponent;\n    @ViewChild('btnNext') btnNext: EclButtonComponent;\n    @ViewChild('dropdownList') dropdownList: ElementRef;\n    dropdownTabs: Array<EclTabComponent> = [];\n    listTabs: Array<EclTabComponent> = [];\n\n    index = 0;\n    isDropdownExpanded = false;\n    isMobileBreakpoint = false;\n    isMoreButtonShow = true;\n    isScrollPrevBtnShow = false;\n    isScrollNextBtnShow = false;\n    styleTransform = 'translate3d(0px, 0px, 0px)';\n\n    private differ: IterableDiffer<EclTabComponent>;\n    private diff: IterableChanges<EclTabComponent>;\n    private destroy$: Subject<boolean> = new Subject<boolean>();\n    private isFirstCall = true;\n    private isRtl = false;\n    private moreBtnWidth: number;\n    private TIMEOUT_INTERVAL = 300;\n\n    constructor(\n        private differs: IterableDiffers,\n        private cdkBreakpointObserver: BreakpointObserver,\n        private cd: ChangeDetectorRef,\n        private el: ElementRef,\n        private eclRtlService: EclRtlService,\n    ) {\n        super();\n        this.differ = this.differs.find([]).create();\n    }\n\n    ngOnInit(): void {\n        this.observeBreakpointChanges();\n        this.handleRtlChangeState();\n    }\n\n    ngAfterContentInit(): void {\n        this.diff = this.differ.diff(this.tabs);\n    }\n\n    ngAfterViewInit(): void {\n        this.createSecondListForDropdown();\n        this.observeTabsChanges();\n        setTimeout(() => this.handleResize(), this.TIMEOUT_INTERVAL);\n        this.cd.detectChanges();\n    }\n\n    ngOnDestroy(): void {\n        this.destroy$.next(true);\n        this.destroy$.unsubscribe();\n    }\n\n    @HostListener('document:click', ['$event.target'])\n    onClick(target): void {\n        if (!this.moreButton.el.nativeElement.contains(target) && !this.dropdownList.nativeElement.contains(target)) {\n            this.closeDropdown();\n        }\n    }\n\n    @HostListener('window:resize', ['$event'])\n    onWindowResize(): void {\n        setTimeout(() => this.handleResize(), this.TIMEOUT_INTERVAL);\n    }\n\n    get isMoreButtonActive(): boolean {\n        return this.listTabs.find((el) => el.isActive) !== undefined;\n    }\n\n    onScrollPrev(): void {\n        this.shiftTabs(ShiftDirection.PREVIOUS);\n    }\n\n    onScrollNext(): void {\n        this.shiftTabs(ShiftDirection.NEXT);\n    }\n\n    onDropdownToggle(): void {\n        this.isDropdownExpanded = !this.isDropdownExpanded;\n    }\n\n    getTabsWidthStyle(): string {\n        return this.isMobileBreakpoint ? `${this.getTabsWidth()}px` : 'auto';\n    }\n\n    getTabsWidth(): number {\n        return this.tabs.reduce((total, item) => (total += Math.ceil(item.getWidth())), 0);\n    }\n\n    getHiddenTabsCount(): number {\n        return this.tabs.filter((item) => item.isHidden).length;\n    }\n\n    getTabLabel(index: number): string {\n        return this.getTabsAsArray()[index].getTabLabel();\n    }\n\n    getTransitionDuration(): string {\n        if (this.isMobileBreakpoint) {\n            return '0.4s';\n        }\n        return '0';\n    }\n\n    onTabBlur(): void {\n        this.closeDropdown();\n\n        this.getLastVisibleTab().onFocus();\n        this.getLastVisibleTab().onBlur();\n    }\n\n    onTabSelect(tab: EclTabComponent): void {\n        this.deactivateAllTabs(this.tabs.toArray(), this.listTabs);\n        this.activateTab(tab);\n        this.sendTabSelectEvent(tab);\n    }\n\n    onTabKeydownArrowRight(index: number): void {\n        if (this.isMobileBreakpoint) {\n            this.shiftTabs(ShiftDirection.NEXT);\n            if (index === this.getTabsCount() - 1) {\n                return;\n            }\n        }\n\n            if (index === this.getTabsCount() - 1 && !this.isMobileBreakpoint ) {\n                this.focusOnFirstTab();\n        } else {\n            this.focusOnNextTab(index);\n        }\n    }\n\n    onTabKeydownArrowLeft(index: number): void {\n        if (this.isMobileBreakpoint) {\n            this.shiftTabs(ShiftDirection.PREVIOUS);\n            if (index === 0) {\n                return;\n            }\n        }\n\n            if (index === 0 && !this.isMobileBreakpoint) {\n                this.focusOnLastTab();\n        } else {\n            this.focusOnPrevTab(index);\n        }\n    }\n\n    onTabKeydownHome(): void {\n        this.focusOnFirstTab();\n    }\n\n    onTabKeydownEnd(): void {\n        this.focusOnLastTab();\n    }\n\n    private shiftTabs(dir: string): void {\n        this.index = this.getShifIndex(dir, this.index);\n\n        this.isScrollPrevBtnShow = this.index >= 1;\n        this.isScrollNextBtnShow = this.index <= this.getTabsCount() - 1;\n\n        const leftMargin = this.index === 0 ? 0 : this.btnPrev.el.nativeElement.getBoundingClientRect().width + 13;\n\n        let newOffset = 0;\n        if (this.isRtl) {\n            newOffset = Math.ceil(\n                this.tabsList.nativeElement.offsetWidth -\n                    this.getTabsAsArray()[this.index].hostElement.offsetLeft -\n                    this.getTabsAsArray()[this.index].hostElement.offsetWidth -\n                    leftMargin,\n            );\n        } else {\n            newOffset = Math.ceil(this.getTabsAsArray()[this.index]?.hostElement.offsetLeft - leftMargin);\n        }\n\n        const maxScroll = Math.ceil(this.getTabsListWidth() - this.el.nativeElement.getBoundingClientRect().width);\n\n        if (newOffset > maxScroll) {\n            this.isScrollNextBtnShow = false;\n            newOffset = maxScroll;\n        }\n\n        if (this.isRtl) {\n            this.styleTransform = `translate3d(${newOffset}px, 0px, 0px)`;\n        } else {\n            this.styleTransform = `translate3d(-${newOffset}px, 0px, 0px)`;\n        }\n    }\n\n    private getShifIndex(dir: string, index: number): number {\n        if (dir === ShiftDirection.NEXT) {\n            if (index === this.getTabsCount() - 1 && !this.isMobileBreakpoint ) {\n                return 0;\n            } else {\n                return index + 1;\n            }\n        } else {\n            if (index === 0  && !this.isMobileBreakpoint) {\n                return this.getTabsCount() - 1;\n            } else {\n                return index - 1;\n            }\n        }\n    }\n\n    private createSecondListForDropdown(): void {\n        this.tabs.forEach((tab) => {\n            const newTab = Object.assign({}, tab) as EclTabComponent;\n            newTab.isHidden = true;\n            newTab.isActive = false;\n            this.listTabs.push(newTab as EclTabComponent);\n        });\n    }\n\n    private getTabsAsArray(): EclTabComponent[] {\n        return this.tabs.toArray();\n    }\n\n    private getTabsCount(): number {\n        return this.tabs.toArray().length;\n    }\n\n    private closeDropdown(): void {\n        this.isDropdownExpanded = false;\n    }\n\n    private openDropdown(): void {\n        this.isDropdownExpanded = true;\n    }\n\n    private observeTabsChanges(): void {\n        this.createTabsChangesObservable(this.tabs).pipe(takeUntil(this.destroy$)).subscribe(this.onTabsChanges.bind(this));\n    }\n\n    private createTabsChangesObservable(tabs: QueryList<EclTabComponent>): Observable<QueryList<EclTabComponent>> {\n        return of(tabs).pipe(mergeWith(tabs.changes), takeUntil(this.destroy$));\n    }\n\n    private onTabsChanges(): void {\n        this.diff = this.differ.diff(this.tabs);\n\n        if (!this.diff) {\n            this.tabs.forEach((tab) => {\n                this.connectTabEvents(tab);\n            });\n        } else {\n            this.diff.forEachAddedItem((change) => {\n                this.connectTabEvents(change.item);\n            });\n\n            this.diff.forEachRemovedItem((change) => {\n                this.disconnectTabEvents(change.item);\n            });\n        }\n    }\n\n    private connectTabEvents(tab: EclTabComponent): void {\n        tab.selectTab.pipe(takeUntil(this.destroy$)).subscribe(() => {\n            this.onTabSelect(tab);\n        });\n        tab.keydownTab.pipe(takeUntil(this.destroy$)).subscribe((event) => {\n            this.onTabKeydown(event, tab);\n        });\n    }\n\n    private onTabKeydown(event: Event, tab: EclTabComponent): void {\n        event.preventDefault();\n        if (event instanceof KeyboardEvent) {\n            const index = this.getTabsAsArray().indexOf(tab);\n            switch (event.key) {\n                case KeyCode.ARROW_LEFT: {\n                    this.onTabKeydownArrowLeft(index);\n                    break;\n                }\n                case KeyCode.ARROW_RIGHT: {\n                    this.onTabKeydownArrowRight(index);\n                    break;\n                }\n                case KeyCode.END: {\n                    this.onTabKeydownEnd();\n                    break;\n                }\n                case KeyCode.HOME: {\n                    this.onTabKeydownHome();\n                    break;\n                }\n                case KeyCode.ENTER: {\n                    this.onTabSelect(tab);\n                    break;\n                }\n                case KeyCode.TAB: {\n                    this.onTabBlur();\n                    break;\n                }\n                default: {\n                    break;\n                }\n            }\n        }\n    }\n\n    private getLastVisibleTab(): EclTabComponent {\n        let result = null;\n        this.getTabsAsArray().forEach((el) => {\n            if (!el.isHidden) {\n                result = el;\n            } else {\n                return;\n            }\n        });\n        return result;\n    }\n\n    private focusOnNextTab(index: number): void {\n        if (this.getTabsAsArray()[index + 1].isHidden) {\n            this.openDropdown();\n            this.focusOnDropdownTab(index + 1);\n        } else {\n            this.closeDropdown();\n            this.getTabsAsArray()[index + 1].onFocus();\n        }\n    }\n\n    private focusOnFirstTab(): void {\n        this.closeDropdown();\n        this.getFirstTabFromArray().onFocus();\n    }\n\n    private focusOnLastTab(): void {\n        if (!this.getLastTabFromArray().isHidden) {\n            this.getLastTabFromArray().onFocus();\n        } else {\n            this.openDropdown();\n            this.focusOnDropdownTab(this.getTabsCount() - 1);\n        }\n    }\n\n    private focusOnPrevTab(index: number): void {\n        if (!this.listTabs[index - 1].isHidden) {\n            this.focusOnDropdownTab(index - 1);\n        } else {\n            this.closeDropdown();\n            this.getTabsAsArray()[index - 1].onFocus();\n        }\n    }\n\n    private focusOnDropdownTab(index: number): void {\n        this.dropdownList.nativeElement.children[index].firstChild.focus();\n    }\n\n    private blurDropdownTab(index: number): void {\n        this.dropdownList.nativeElement.children[index].firstChild.blur();\n    }\n\n    private getLastTabFromArray(): EclTabComponent {\n        return this.getTabsAsArray()[this.getTabsAsArray().length - 1];\n    }\n\n    private getFirstTabFromArray(): EclTabComponent {\n        return this.getTabsAsArray()[0];\n    }\n\n    private disconnectTabEvents(tab: EclTabComponent): void {\n        if (tab && tab.selectTab) {\n            tab.selectTab.unsubscribe();\n        }\n    }\n\n    private deactivateAllTabs(tabs: Array<EclTabComponent>, listTabs: Array<EclTabComponent>): void {\n        tabs.forEach((it) => {\n            it.isActive = false;\n        });\n\n        listTabs.forEach((it) => {\n            it.isActive = false;\n        });\n    }\n\n    private activateTab(tab: EclTabComponent): void {\n        tab.isActive = true;\n    }\n\n    private sendTabSelectEvent(tab: EclTabComponent): void {\n        this.tabSelect.next(new EclTabSelectEvent(tab));\n    }\n\n    private observeBreakpointChanges(): void {\n        this.cdkBreakpointObserver\n            .observe(['(max-width: 480px)'])\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((result) => {\n                this.isMobileBreakpoint = result.matches;\n            });\n    }\n\n    private handleResize(): void {\n        this.closeDropdown();\n        if (this.isMobileBreakpoint) {\n            this.handleMobile();\n            return;\n        }\n        this.styleTransform = 'translate3d(0px, 0px, 0px)';\n        this.index = 0;\n        this.initMoreBtnWidth();\n        let stopWidth = this.moreBtnWidth + 25;\n        const hiddenItems = [];\n        const listWidth = this.getTabsListWidth();\n        this.isScrollNextBtnShow = false;\n        this.isScrollPrevBtnShow = false;\n        this.isMoreButtonShow = false;\n        this.tabs.forEach((item, i) => {\n            item.isHidden = false;\n            if (listWidth >= stopWidth + item.getWidth() && !hiddenItems.includes(i - 1)) {\n                stopWidth += item.getWidth();\n            } else {\n                item.isHidden = true;\n                if (item.isActive) {\n                    this.listTabs[i].isActive = true;\n                }\n                hiddenItems.push(i);\n            }\n        });\n\n        if (!hiddenItems.length) {\n            this.isMoreButtonShow = false;\n            this.setActiveItemForMainTabs();\n            this.hideAllDropdownTabs();\n        } else {\n            this.isMoreButtonShow = true;\n            this.setHiddenItemsForDropdownTabs(hiddenItems);\n        }\n    }\n\n    private initMoreBtnWidth(): void {\n        if (this.isFirstCall) {\n            this.moreBtnWidth = this.moreButton.el.nativeElement.getBoundingClientRect().width;\n            this.isFirstCall = false;\n        }\n    }\n\n    private hideAllDropdownTabs(): void {\n        this.listTabs.forEach(item => item.isHidden = true);\n    }\n\n    private setActiveItemForMainTabs(): void {\n        this.listTabs.forEach((item, index) => {\n            if (item.isActive) {\n                this.tabs.toArray()[index].isActive = true;\n            }\n        });\n    }\n\n    private getTabsListWidth(): number {\n        return this.tabsList.nativeElement.getBoundingClientRect().width;\n    }\n\n    private setHiddenItemsForDropdownTabs(hiddenItems: number[]): void {\n        this.listTabs.forEach((item, index) => {\n            if (hiddenItems.includes(index)) {\n                item.isHidden = false;\n            } else {\n                item.isHidden = true;\n            }\n        });\n    }\n\n    private handleMobile(): void {\n        this.isMoreButtonShow = false;\n        this.isScrollPrevBtnShow = false;\n        this.isScrollNextBtnShow = true;\n        this.setAllTabsVisible();\n    }\n\n    private setAllTabsVisible(): void {\n        this.tabs.forEach((item , i) => {\n            item.isHidden = false;\n        })\n    }\n\n    private handleRtlChangeState(): void {\n        const isRtlOld = this.isRtl;\n        this.eclRtlService.currentRtlState$.pipe(takeUntil(this.destroy$)).subscribe((rtlState) => {\n            setTimeout(() => {\n                this.isRtl = rtlState;\n                if (this.isMobileBreakpoint && this.hasRtlChanged(isRtlOld)) {\n                    this.handleRtlChange();\n                }\n            });\n        });\n    }\n\n    private hasRtlChanged(isRtlOld: boolean): boolean {\n        return isRtlOld !== this.isRtl;\n    }\n\n    private handleRtlChange(): void {\n        this.handleMobile();\n        this.styleTransform = 'translate3d(0px, 0px, 0px)';\n        this.index = 0;\n    }\n}\n","<div class=\"ecl-tabs\">\n    <div class=\"ecl-tabs__container\"\n         [class.ecl-tabs__container--right]=\"isScrollNextBtnShow\"\n         [class.ecl-tabs__container--left]=\"isScrollPrevBtnShow\">\n        <div\n            class=\"ecl-tabs__list\"\n            role=\"tablist\"\n            #tabsList\n            [style.width]=\"getTabsWidthStyle()\"\n            [style.transform]=\"styleTransform\"\n            [style.transition-duration]=\"getTransitionDuration()\">\n            <ng-content select=\"ecl-tab, [eclTab]\"></ng-content>\n            <ecl-tab-more [isHidden]=\"!isMoreButtonShow\">\n                @if (listTabs.length > 0) {\n                <div class=\"ecl-tabs__dropdown\" [class.ecl-tabs__dropdown--show]=\"isDropdownExpanded\">\n                    <div class=\"ecl-tabs__dropdown-list\" #dropdownList>\n                        @for (tab of listTabs; track tab.id; let i = $index) {\n                            <ecl-tab [isActive]=\"tab.isActive\" [isHidden]=\"tab.isHidden\" (click)=\"onTabSelect(tab)\"\n                                     (keydown.arrowRight)=\"onTabKeydownArrowRight(i)\" (keydown.arrowLeft)=\"onTabKeydownArrowLeft(i)\"\n                                     (keydown.home)=\"onTabKeydownHome()\" (keydown.end)=\"onTabKeydownEnd()\"\n                                     (keydown.enter)=\"onTabSelect(tab)\" (keydown.tab)=\"onTabBlur()\">\n                                <ecl-tab-label>{{ getTabLabel(i) }}</ecl-tab-label>\n                            </ecl-tab>\n                        }\n                    </div>\n                </div>\n            }\n            </ecl-tab-more>\n        </div>\n        <button #moreButton eclButton class=\"ecl-tabs__toggle\" tabindex=\"-1\" variant=\"ghost\"\n            [attr.aria-expanded]=\"isDropdownExpanded\" [class.ecl-tabs__toggle--active]=\"isMoreButtonActive\"\n            (click)=\"onDropdownToggle()\" [class.ecl-tabs__toggle--hidden]=\"!isMoreButtonShow\">\n            <span eclButtonLabel>\n                {{ 'ecl.common.MORE' | translate }}\n                ({{ getHiddenTabsCount() }})\n            </span>\n            <ecl-icon icon=\"corner-arrow\" transform=\"rotate-180\" size=\"fluid\"></ecl-icon>\n        </button>\n    </div>\n\n    <div class=\"ecl-tabs__controls\">\n        <button\n            #btnPrev\n            eclButton\n            variant=\"ghost\"\n            isIconOnly\n            [attr.aria-hidden]=\"true\"\n            class=\"ecl-tabs__prev\"\n            [class.ecl-u-d-none]=\"!isScrollPrevBtnShow\"\n            [class.ecl-u-d-block]=\"isScrollPrevBtnShow\"\n            (click)=\"onScrollPrev()\">\n            <ecl-icon icon=\"corner-arrow\" transform=\"rotate-270\" size=\"s\" class=\"\"> </ecl-icon>\n            <span eclButtonLabel>{{ 'ecl.common.PREVIOUS | translate }}</span>\n        </button>\n        <button\n            #btnNext\n            eclButton\n            variant=\"ghost\"\n            isIconOnly\n            [attr.aria-hidden]=\"true\"\n            class=\"ecl-tabs__next\"\n            [class.ecl-u-d-none]=\"!isScrollNextBtnShow\"\n            [class.ecl-u-d-block]=\"isScrollNextBtnShow\"\n            (click)=\"onScrollNext()\">\n            <ecl-icon icon=\"corner-arrow\" transform=\"rotate-90\" size=\"s\" class=\"\"> </ecl-icon>\n            <span eclButtonLabel>{{ 'ecl.common.NEXT | translate }}</span>\n        </button>\n    </div>\n</div>\n\n@for (tab of tabs.toArray(); track tab.tabLabel) {\n    @if (tab.isActive) {\n        <div class=\"{{ bodyClass }}\">\n            <ng-container *ngTemplateOutlet=\"tab.contentTemplate\"></ng-container>\n        </div>\n    }\n}\n@for (tab of listTabs; track tab.tabLabel) {\n    @if (tab.isActive) {\n        <div class=\"{{ bodyClass }}\">\n            <ng-container *ngTemplateOutlet=\"tab.contentTemplate\"></ng-container>\n        </div>\n    }\n}\n"]}
|
|
@@ -12,20 +12,20 @@ import { ECLClickOutsideDirective } from '../../utils';
|
|
|
12
12
|
import * as i0 from "@angular/core";
|
|
13
13
|
const COMPONENTS = [EclTabsComponent, EclTabComponent, EclTabLabelComponent, EclTabMoreComponent];
|
|
14
14
|
export class EclTabsComponentModule {
|
|
15
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
16
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0-rc.
|
|
15
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTabsComponentModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
16
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTabsComponentModule, declarations: [EclTabsComponent, EclTabComponent, EclTabLabelComponent, EclTabMoreComponent], imports: [CommonModule,
|
|
17
17
|
EclLinkDirectiveModule,
|
|
18
18
|
EclButtonComponentModule,
|
|
19
19
|
EclIconComponentModule,
|
|
20
20
|
TranslateModule,
|
|
21
21
|
ECLClickOutsideDirective], exports: [EclTabsComponent, EclTabComponent, EclTabLabelComponent, EclTabMoreComponent] }); }
|
|
22
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
22
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTabsComponentModule, imports: [CommonModule,
|
|
23
23
|
EclLinkDirectiveModule,
|
|
24
24
|
EclButtonComponentModule,
|
|
25
25
|
EclIconComponentModule,
|
|
26
26
|
TranslateModule] }); }
|
|
27
27
|
}
|
|
28
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTabsComponentModule, decorators: [{
|
|
29
29
|
type: NgModule,
|
|
30
30
|
args: [{
|
|
31
31
|
imports: [
|
|
@@ -5,10 +5,10 @@ export class EclTagSetDirective extends ECLBaseDirective {
|
|
|
5
5
|
get cssClasses() {
|
|
6
6
|
return [super.getCssClasses('ecl-tag-set')].join(' ').trim();
|
|
7
7
|
}
|
|
8
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
9
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0-rc.
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTagSetDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
9
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0-rc.3", type: EclTagSetDirective, selector: "[eclTagSet]", host: { properties: { "class": "this.cssClasses" } }, usesInheritance: true, ngImport: i0 }); }
|
|
10
10
|
}
|
|
11
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTagSetDirective, decorators: [{
|
|
12
12
|
type: Directive,
|
|
13
13
|
args: [{
|
|
14
14
|
selector: '[eclTagSet]',
|
|
@@ -33,10 +33,10 @@ export class EclTagComponent extends ECLBaseDirective {
|
|
|
33
33
|
this.isVisible = false;
|
|
34
34
|
}
|
|
35
35
|
}
|
|
36
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
37
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-rc.
|
|
36
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTagComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
37
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.0-rc.3", type: EclTagComponent, selector: "ecl-tag, [eclTag]", inputs: { variant: "variant", isWrapped: ["isWrapped", "isWrapped", booleanAttribute] }, outputs: { remove: "remove" }, host: { properties: { "attr.hidden": "this.isHidden", "class": "this.cssClasses" } }, usesInheritance: true, ngImport: i0, template: "<ng-content></ng-content>\n@if(isRemovable) {\n <span class=\"ecl-tag__icon\" (click)=\"onRemoveClick($event)\">\n <ecl-icon icon=\"close-outline\" class=\"ecl-tag__icon-close\" role=\"img\">\n <title>{{title | titlecase}}</title>\n </ecl-icon>\n</span>\n}\n", dependencies: [{ kind: "component", type: i1.EclIconComponent, selector: "ecl-icon", inputs: ["iconSet", "icon", "size", "color", "transform", "ariaLabelledby", "role", "ariaHidden", "focusable"] }, { kind: "pipe", type: i2.TitleCasePipe, name: "titlecase" }] }); }
|
|
38
38
|
}
|
|
39
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
39
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTagComponent, decorators: [{
|
|
40
40
|
type: Component,
|
|
41
41
|
args: [{ selector: 'ecl-tag, [eclTag]', template: "<ng-content></ng-content>\n@if(isRemovable) {\n <span class=\"ecl-tag__icon\" (click)=\"onRemoveClick($event)\">\n <ecl-icon icon=\"close-outline\" class=\"ecl-tag__icon-close\" role=\"img\">\n <title>{{title | titlecase}}</title>\n </ecl-icon>\n</span>\n}\n" }]
|
|
42
42
|
}], propDecorators: { variant: [{
|
|
@@ -5,11 +5,11 @@ import { EclTagComponent } from './ecl-tag.component';
|
|
|
5
5
|
import { EclTagSetDirective } from './ecl-tag-set.directive';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
export class EclTagComponentModule {
|
|
8
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
9
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0-rc.
|
|
10
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTagComponentModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
9
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTagComponentModule, declarations: [EclTagComponent, EclTagSetDirective], imports: [CommonModule, EclIconComponentModule], exports: [EclTagComponent, EclTagSetDirective] }); }
|
|
10
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTagComponentModule, imports: [CommonModule, EclIconComponentModule] }); }
|
|
11
11
|
}
|
|
12
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
12
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTagComponentModule, decorators: [{
|
|
13
13
|
type: NgModule,
|
|
14
14
|
args: [{
|
|
15
15
|
imports: [CommonModule, EclIconComponentModule],
|
|
@@ -20,10 +20,10 @@ export class EclTextAreaDirective extends ECLBaseDirective {
|
|
|
20
20
|
this.eclSize = 'm';
|
|
21
21
|
this.isInvalid = false;
|
|
22
22
|
}
|
|
23
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
24
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-rc.
|
|
23
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTextAreaDirective, deps: [{ token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
24
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-rc.3", type: EclTextAreaDirective, selector: "textarea[eclTextArea]", inputs: { eclSize: "eclSize", isInvalid: ["isInvalid", "isInvalid", booleanAttribute] }, host: { properties: { "class": "this.cssClasses", "class.ecl-text-area--invalid": "this.invalidState" } }, usesInheritance: true, ngImport: i0 }); }
|
|
25
25
|
}
|
|
26
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTextAreaDirective, decorators: [{
|
|
27
27
|
type: Directive,
|
|
28
28
|
args: [{
|
|
29
29
|
selector: 'textarea[eclTextArea]',
|
|
@@ -3,11 +3,11 @@ import { CommonModule } from '@angular/common';
|
|
|
3
3
|
import { EclTextAreaDirective } from './ecl-text-area.directive';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export class EclTextAreaDirectiveModule {
|
|
6
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
7
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0-rc.
|
|
8
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
6
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTextAreaDirectiveModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
7
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTextAreaDirectiveModule, declarations: [EclTextAreaDirective], imports: [CommonModule], exports: [EclTextAreaDirective] }); }
|
|
8
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTextAreaDirectiveModule, imports: [CommonModule] }); }
|
|
9
9
|
}
|
|
10
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTextAreaDirectiveModule, decorators: [{
|
|
11
11
|
type: NgModule,
|
|
12
12
|
args: [{
|
|
13
13
|
imports: [CommonModule],
|
|
@@ -21,10 +21,10 @@ export class EclTextInputDirective extends ECLBaseDirective {
|
|
|
21
21
|
return this.isInvalid;
|
|
22
22
|
}
|
|
23
23
|
}
|
|
24
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
25
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-rc.
|
|
24
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTextInputDirective, deps: [{ token: i1.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
25
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "18.0.0-rc.3", type: EclTextInputDirective, isStandalone: true, selector: "input[eclTextInput]", inputs: { eclSize: "eclSize", isInvalid: ["isInvalid", "isInvalid", booleanAttribute] }, host: { properties: { "attr.type": "this.type", "class": "this.cssClasses", "class.ecl-text-input--invalid": "this.invalidState" } }, usesInheritance: true, ngImport: i0 }); }
|
|
26
26
|
}
|
|
27
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
27
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTextInputDirective, decorators: [{
|
|
28
28
|
type: Directive,
|
|
29
29
|
args: [{
|
|
30
30
|
selector: 'input[eclTextInput]',
|
|
@@ -3,11 +3,11 @@ import { CommonModule } from '@angular/common';
|
|
|
3
3
|
import { EclTextInputDirective } from './ecl-text-input.directive';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
export class EclTextInputDirectiveModule {
|
|
6
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
7
|
-
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0-rc.
|
|
8
|
-
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
6
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTextInputDirectiveModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
7
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTextInputDirectiveModule, imports: [CommonModule, EclTextInputDirective], exports: [EclTextInputDirective] }); }
|
|
8
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTextInputDirectiveModule, imports: [CommonModule] }); }
|
|
9
9
|
}
|
|
10
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
10
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTextInputDirectiveModule, decorators: [{
|
|
11
11
|
type: NgModule,
|
|
12
12
|
args: [{
|
|
13
13
|
imports: [CommonModule, EclTextInputDirective],
|
|
@@ -5,10 +5,10 @@ export class EclTimelineItemLabelDirective extends ECLBaseDirective {
|
|
|
5
5
|
get cssClasses() {
|
|
6
6
|
return [super.getCssClasses('ecl-timeline__label')].join(' ').trim();
|
|
7
7
|
}
|
|
8
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
9
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0-rc.
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTimelineItemLabelDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
9
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0-rc.3", type: EclTimelineItemLabelDirective, selector: "[eclTimelineItemLabel]", host: { properties: { "class": "this.cssClasses" } }, usesInheritance: true, ngImport: i0 }); }
|
|
10
10
|
}
|
|
11
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTimelineItemLabelDirective, decorators: [{
|
|
12
12
|
type: Directive,
|
|
13
13
|
args: [{
|
|
14
14
|
selector: '[eclTimelineItemLabel]',
|
|
@@ -5,10 +5,10 @@ export class EclTimelineItemTitleDirective extends ECLBaseDirective {
|
|
|
5
5
|
get cssClasses() {
|
|
6
6
|
return [super.getCssClasses('ecl-timeline__title')].join(' ').trim();
|
|
7
7
|
}
|
|
8
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
9
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0-rc.
|
|
8
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTimelineItemTitleDirective, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
9
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.0.0-rc.3", type: EclTimelineItemTitleDirective, selector: "[eclTimelineItemTitle]", host: { properties: { "class": "this.cssClasses" } }, usesInheritance: true, ngImport: i0 }); }
|
|
10
10
|
}
|
|
11
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTimelineItemTitleDirective, decorators: [{
|
|
12
12
|
type: Directive,
|
|
13
13
|
args: [{
|
|
14
14
|
selector: '[eclTimelineItemTitle]',
|
|
@@ -9,10 +9,10 @@ export class EclTimelineItemTogglerComponent extends ECLBaseDirective {
|
|
|
9
9
|
onTogglerClick() {
|
|
10
10
|
this.toggle.emit();
|
|
11
11
|
}
|
|
12
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
13
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-rc.
|
|
12
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTimelineItemTogglerComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
13
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.0-rc.3", type: EclTimelineItemTogglerComponent, selector: "ecl-timeline-item-toggler", outputs: { toggle: "toggle" }, host: { listeners: { "click": "onTogglerClick()" } }, usesInheritance: true, ngImport: i0, template: "<ng-content></ng-content>\n" }); }
|
|
14
14
|
}
|
|
15
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.0-rc.3", ngImport: i0, type: EclTimelineItemTogglerComponent, decorators: [{
|
|
16
16
|
type: Component,
|
|
17
17
|
args: [{ selector: 'ecl-timeline-item-toggler', template: "<ng-content></ng-content>\n" }]
|
|
18
18
|
}], propDecorators: { toggle: [{
|